import { useEffect, useState } from "react"; /** * Hook that returns a debounced value that only updates after the specified delay * @param value - The value to debounce * @param delay - The delay in milliseconds (default: 300ms) * @returns The debounced value */ export function useDebouncedValue(value: T, delay: number = 300): T { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const timer = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(timer); }; }, [value, delay]); return debouncedValue; }