import { useEffect, useState } from 'react' export const useDebounce = (value: T, delay = 300) => { const [debounced, setDebounced] = useState(value) useEffect(() => { const timer = window.setTimeout(() => setDebounced(value), delay) return () => window.clearTimeout(timer) }, [value, delay]) return debounced }