import { useState, useEffect } from 'react'; export const useDebouncedValue = (value: T, delay = 500) => { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const timeout = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(timeout); }; }, [value, delay]); return debouncedValue; };