import { useEffect, useState } from "react"; /** Returns `value` delayed by `delayMs`; resets the timer on each change. */ export function useDebouncedValue(value: T, delayMs: number): T { const [debounced, setDebounced] = useState(value); useEffect(() => { const id = setTimeout(() => setDebounced(value), delayMs); return () => clearTimeout(id); }, [value, delayMs]); return debounced; }