From 8e2609f66f4f1be7bc92cc91b898338ba5ac410b Mon Sep 17 00:00:00 2001 From: Jony J <1844749591@qq.com> Date: Wed, 25 Dec 2024 11:44:04 +0800 Subject: [PATCH] fix: force update to keep disable state work (#612) * fix: force update to keep disable state work * refactor: replace disabled ref cache with state * perf: remove unnecessary setState and init map --- src/OptionList.tsx | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/OptionList.tsx b/src/OptionList.tsx index d69aec40..5b53047e 100644 --- a/src/OptionList.tsx +++ b/src/OptionList.tsx @@ -160,18 +160,18 @@ const OptionList: React.ForwardRefRenderFunction = (_, }, [searchValue]); // ========================= Disabled ========================= - const disabledCacheRef = React.useRef>(new Map()); + // Cache disabled states in React state to ensure re-render when cache updates + const [disabledCache, setDisabledCache] = React.useState>(() => new Map()); - // Clear cache if `leftMaxCount` changed React.useEffect(() => { if (leftMaxCount) { - disabledCacheRef.current.clear(); + setDisabledCache(new Map()); } }, [leftMaxCount]); function getDisabledWithCache(node: DataNode) { const value = node[fieldNames.value]; - if (!disabledCacheRef.current.has(value)) { + if (!disabledCache.has(value)) { const entity = valueEntities.get(value); const isLeaf = (entity.children || []).length === 0; @@ -184,12 +184,12 @@ const OptionList: React.ForwardRefRenderFunction = (_, ); const checkableChildrenCount = checkableChildren.length; - disabledCacheRef.current.set(value, checkableChildrenCount > leftMaxCount); + disabledCache.set(value, checkableChildrenCount > leftMaxCount); } else { - disabledCacheRef.current.set(value, false); + disabledCache.set(value, false); } } - return disabledCacheRef.current.get(value); + return disabledCache.get(value); } const nodeDisabled = useEvent((node: DataNode) => {