import { useState, useEffect } from 'react' export default function useDebounce(value: T, delay: number) { const [debouncedValue, setDebouncedValue] = useState(value) useEffect(() => { const handler = window.setTimeout(() => { setDebouncedValue(value) }, delay) return () => { window.clearTimeout(handler) } }, [value, delay]) return debouncedValue }