Files
lamp/features/im/hooks/use-debounced-value.ts

18 lines
380 B
TypeScript

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