import { useCallback, useEffect, useRef, useState } from "react"; export function useDebouncedValue(value: any, delay: number): any { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const handler = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(handler); }; }, [value, delay]); return debouncedValue; } export const useDebouncedFunction = any>(func: T, delay: number): ((...args: Parameters) => void) => { const timeoutRef = useRef(null); const debouncedFunction = useCallback( (...args: Parameters) => { if (timeoutRef.current) { clearTimeout(timeoutRef.current); } timeoutRef.current = setTimeout(() => func(...args), delay); }, [func, delay], ); return debouncedFunction; };