From 229f4f735636cdf65030b9ca47d1b2e0238a8dc1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=B0=8F=E8=B1=AA?= <1844749591@qq.com> Date: Wed, 6 Nov 2024 16:53:39 +0800 Subject: [PATCH] chore: remove unnecessary logic --- src/OptionList.tsx | 28 ++++++++++++++++------------ 1 file changed, 16 insertions(+), 12 deletions(-) diff --git a/src/OptionList.tsx b/src/OptionList.tsx index 6fb4268e..9cfa34e6 100644 --- a/src/OptionList.tsx +++ b/src/OptionList.tsx @@ -179,23 +179,27 @@ const OptionList: React.ForwardRefRenderFunction = (_, if (!open) { return; } + let nextActiveKey = null; - // // Prioritize activating the searched node - if (searchValue) { + const getFirstNode = () => { const firstNode = getFirstMatchingNode(memoTreeData); - setActiveKey(firstNode ? firstNode[fieldNames.value] : null); - return; - } + return firstNode ? firstNode[fieldNames.value] : null; + }; - // If no search value, activate the first checked node - if (!multiple && checkedKeys.length) { - setActiveKey(checkedKeys[0]); - return; + // search mode active first node + if (searchValue) { + nextActiveKey = getFirstNode(); + } + // single mode active first checked node + else if (!multiple && checkedKeys.length) { + nextActiveKey = checkedKeys[0]; + } + // default active first node + else { + nextActiveKey = getFirstNode(); } - // If no search value and no checked nodes, activate the first node - const firstNode = getFirstMatchingNode(memoTreeData); - setActiveKey(firstNode ? firstNode[fieldNames.value] : null); + setActiveKey(nextActiveKey); }, [open, searchValue]); // ========================= Keyboard =========================