Files
omnivore/packages/web/lib/hooks/useDebounce.tsx
2022-02-11 09:24:33 -08:00

17 lines
387 B
TypeScript

import { useState, useEffect } from 'react';
export default function useDebounce<T>(value: T, delay: number) {
const [debouncedValue, setDebouncedValue] = useState(value);
useEffect(() => {
const handler = setTimeout(() => {
setDebouncedValue(value);
}, delay);
return () => {
clearTimeout(handler);
};
}, [value, delay]);
return debouncedValue;
}