import { useEffect, useState } from "react"; export function useDebouncedValue(value: T, delay = 180) { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const timer = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(timer); }; }, [delay, value]); return debouncedValue; }