import * as React from "react"; // consider using https://github.com/xnimorz/use-debounce export function useDebounce(value: T, delay?: number): T { const [debouncedValue, setDebouncedValue] = React.useState(value); React.useEffect(() => { const timer = setTimeout(() => setDebouncedValue(value), delay ?? 500); return () => { clearTimeout(timer); }; }, [value, delay]); return debouncedValue; }