import { useEffect, useState } from 'react'; function useDebounced(value: T, delay: number): T { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const handler = setTimeout(() => { setDebouncedValue(value); }, delay); return () => clearTimeout(handler); // clear timeout nếu value thay đổi trước khi delay hết }, [value, delay]); return debouncedValue; } export default useDebounced;