import { useState, useEffect } from "react"; /** * Debounce a value by a given delay. * * Returns the debounced value which only updates * after the specified delay has elapsed without changes. */ export function useDebounce(value: T, delay: number = 300): T { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const timer = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(timer); }; }, [value, delay]); return debouncedValue; }