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