CoastalCommitsPastes/client/lib/hooks/use-debounce.ts

17 lines
362 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
}