From 509f4ca53c256fc7989828f5da44f9357d9b20c9 Mon Sep 17 00:00:00 2001 From: melloware Date: Fri, 1 Dec 2023 15:36:20 -0500 Subject: [PATCH] Fix #5490: useDebounce fixed --- components/lib/hooks/useDebounce.js | 29 +++++++++++++++++++++-------- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/components/lib/hooks/useDebounce.js b/components/lib/hooks/useDebounce.js index 29ba443edc..93d11fbeee 100644 --- a/components/lib/hooks/useDebounce.js +++ b/components/lib/hooks/useDebounce.js @@ -1,16 +1,29 @@ import * as React from 'react'; -import { useTimeout } from './useTimeout'; +import { useMountEffect, useUnmountEffect } from './Hooks'; export const useDebounce = (initialValue, delay) => { const [inputValue, setInputValue] = React.useState(initialValue); const [debouncedValue, setDebouncedValue] = React.useState(initialValue); - const timeout = useTimeout( - () => { - setDebouncedValue(inputValue); - }, - delay, - inputValue !== debouncedValue - ); + const mountedRef = React.useRef(false); + const timeoutRef = React.useRef(null); + const cancelTimer = () => window.clearTimeout(timeoutRef.current); + + useMountEffect(() => { + mountedRef.current = true; + }); + + useUnmountEffect(() => { + cancelTimer(); + }); + + React.useEffect(() => { + if (mountedRef.current) { + cancelTimer(); + timeoutRef.current = window.setTimeout(() => { + setDebouncedValue(inputValue); + }, delay); + } + }, [inputValue, delay]); return [inputValue, debouncedValue, setInputValue]; };