/** * Copyright (c) 2023-present Plane Software, Inc. and contributors * SPDX-License-Identifier: AGPL-3.0-only * See the LICENSE file for details. */ import { useState, useEffect } from "react"; const useDebounce = (value: T, milliSeconds: number): T => { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const handler = setTimeout(() => { setDebouncedValue(value); }, milliSeconds); return () => { clearTimeout(handler); }; }, [value, milliSeconds]); return debouncedValue; }; export default useDebounce;