useDebounce
useDebounce.tsx
import { useState, useEffect } from "react";
function useDebounce(value: any, delay: number): any {
const [debouncedValue, setDebouncedValue] = useState(value);
useEffect(() => {
const timeoutId = setTimeout(() => {
setDebouncedValue(value);
}, delay);
return () => {
clearTimeout(timeoutId);
};
}, [value, delay]);
return debouncedValue;
}