mirror of
https://github.com/kjanat/livedash-node.git
synced 2026-01-16 12:12:09 +01:00
Security Enhancements: - Implemented proper rate limiting with automatic cleanup for /register and /forgot-password endpoints - Added memory usage protection with MAX_ENTRIES limit (10000) - Fixed rate limiter memory leaks by adding cleanup intervals - Improved IP extraction with x-real-ip and x-client-ip header support Code Quality Improvements: - Refactored ProcessingStatusManager from individual functions to class-based architecture - Maintained backward compatibility with singleton instance pattern - Fixed TypeScript strict mode violations across the codebase - Resolved all build errors and type mismatches UI Component Fixes: - Removed unused chart components (Charts.tsx, DonutChart.tsx) - Fixed calendar component type issues by removing unused custom implementations - Resolved theme provider type imports - Fixed confetti component default options handling - Corrected pointer component coordinate type definitions Type System Improvements: - Extended NextAuth types to support dual auth systems (regular and platform users) - Fixed nullable type handling throughout the codebase - Resolved Prisma JSON field type compatibility issues - Corrected SessionMessage and ImportRecord interface definitions - Fixed ES2015 iteration compatibility issues Database & Performance: - Updated database pool configuration for Prisma adapter compatibility - Fixed pagination response structure in user management endpoints - Improved error handling with proper error class usage Testing & Build: - All TypeScript compilation errors resolved - ESLint warnings remain but no errors - Build completes successfully with proper static generation
122 lines
3.4 KiB
TypeScript
122 lines
3.4 KiB
TypeScript
"use client";
|
|
|
|
import {
|
|
AnimatePresence,
|
|
type HTMLMotionProps,
|
|
motion,
|
|
useMotionValue,
|
|
} from "motion/react";
|
|
import { useEffect, useRef, useState } from "react";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
interface PointerProps extends Omit<HTMLMotionProps<"div">, "ref"> {
|
|
children?: React.ReactNode;
|
|
}
|
|
|
|
/**
|
|
* A custom pointer component that displays an animated cursor.
|
|
* Add this as a child to any component to enable a custom pointer when hovering.
|
|
* You can pass custom children to render as the pointer.
|
|
*
|
|
* @component
|
|
* @param {PointerProps} props - The component props
|
|
*/
|
|
export function Pointer({
|
|
className,
|
|
style,
|
|
children,
|
|
...props
|
|
}: PointerProps): React.ReactElement {
|
|
const x = useMotionValue(0);
|
|
const y = useMotionValue(0);
|
|
const [isActive, setIsActive] = useState<boolean>(false);
|
|
const containerRef = useRef<HTMLDivElement>(null);
|
|
|
|
useEffect(() => {
|
|
if (typeof window !== "undefined" && containerRef.current) {
|
|
// Get the parent element directly from the ref
|
|
const parentElement = containerRef.current.parentElement;
|
|
|
|
if (parentElement) {
|
|
// Add cursor-none to parent
|
|
parentElement.style.cursor = "none";
|
|
|
|
// Add event listeners to parent
|
|
const handleMouseMove = (e: MouseEvent) => {
|
|
x.set(e.clientX);
|
|
y.set(e.clientY);
|
|
};
|
|
|
|
const handleMouseEnter = () => {
|
|
setIsActive(true);
|
|
};
|
|
|
|
const handleMouseLeave = () => {
|
|
setIsActive(false);
|
|
};
|
|
|
|
parentElement.addEventListener("mousemove", handleMouseMove);
|
|
parentElement.addEventListener("mouseenter", handleMouseEnter);
|
|
parentElement.addEventListener("mouseleave", handleMouseLeave);
|
|
|
|
return () => {
|
|
parentElement.style.cursor = "";
|
|
parentElement.removeEventListener("mousemove", handleMouseMove);
|
|
parentElement.removeEventListener("mouseenter", handleMouseEnter);
|
|
parentElement.removeEventListener("mouseleave", handleMouseLeave);
|
|
};
|
|
}
|
|
}
|
|
}, [x, y]);
|
|
|
|
return (
|
|
<>
|
|
<div ref={containerRef} />
|
|
<AnimatePresence>
|
|
{isActive && (
|
|
<motion.div
|
|
className="transform-[translate(-50%,-50%)] pointer-events-none fixed z-50"
|
|
style={{
|
|
top: y,
|
|
left: x,
|
|
...style,
|
|
}}
|
|
initial={{
|
|
scale: 0,
|
|
opacity: 0,
|
|
}}
|
|
animate={{
|
|
scale: 1,
|
|
opacity: 1,
|
|
}}
|
|
exit={{
|
|
scale: 0,
|
|
opacity: 0,
|
|
}}
|
|
{...props}
|
|
>
|
|
{children || (
|
|
<svg
|
|
stroke="currentColor"
|
|
fill="currentColor"
|
|
strokeWidth="1"
|
|
viewBox="0 0 16 16"
|
|
height="24"
|
|
width="24"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
className={cn(
|
|
"rotate-[-70deg] stroke-white text-black",
|
|
className
|
|
)}
|
|
>
|
|
<title>Mouse pointer</title>
|
|
<path d="M14.082 2.182a.5.5 0 0 1 .103.557L8.528 15.467a.5.5 0 0 1-.917-.007L5.57 10.694.803 8.652a.5.5 0 0 1-.006-.916l12.728-5.657a.5.5 0 0 1 .556.103z" />
|
|
</svg>
|
|
)}
|
|
</motion.div>
|
|
)}
|
|
</AnimatePresence>
|
|
</>
|
|
);
|
|
}
|