Files
dragonsstash/src/hooks/use-debounce.ts
xCyanGrizzly 3a5726e82b Init
2026-02-18 14:26:36 +01:00

20 lines
395 B
TypeScript

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