openrag/frontend/lib/debounce.ts
2025-09-18 13:33:56 -03:00

23 lines
530 B
TypeScript

import { useCallback, useRef } from "react";
export function useDebounce<T extends (...args: never[]) => void>(
callback: T,
delay: number,
): T {
const timeoutRef = useRef<NodeJS.Timeout | null>(null);
const debouncedCallback = useCallback(
(...args: Parameters<T>) => {
if (timeoutRef.current) {
clearTimeout(timeoutRef.current);
}
timeoutRef.current = setTimeout(() => {
callback(...args);
}, delay);
},
[callback, delay],
) as T;
return debouncedCallback;
}