From 524f6f9ff596f95b4d393dff8c70a5ae4afdbc35 Mon Sep 17 00:00:00 2001 From: KuangPF <1633397286@qq.com> Date: Sun, 16 Jul 2023 14:43:04 +0800 Subject: [PATCH] =?UTF-8?q?feat(hooks):=20`useMenu`=20=E6=94=AF=E6=8C=81?= =?UTF-8?q?=20group=20=E4=B8=8E=20single=20=E6=A8=A1=E5=BC=8F=E6=B7=B7?= =?UTF-8?q?=E5=90=88=E6=8E=92=E5=BA=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/hooks/useMenu.tsx | 189 ++++++++++++++++++++++-------------------- 1 file changed, 100 insertions(+), 89 deletions(-) diff --git a/src/hooks/useMenu.tsx b/src/hooks/useMenu.tsx index d36ed22..c5b72af 100644 --- a/src/hooks/useMenu.tsx +++ b/src/hooks/useMenu.tsx @@ -103,52 +103,102 @@ const useMenu = (options: UseMenuOptions = {}): [MenuProps['items'], string] => const sidebarItems = [...(sidebarData ?? [])]; return ( - sidebarItems?.reduce>((result, group) => { - if (group?.title) { - // sideBar menu group 模式, 默认以非 group 模式渲染 - const isSideBarGroupMode = - sidebarGroupModePath === true - ? true - : (sidebarGroupModePath ?? []).filter((rule: ISidebarGroupModePathItem) => { - return typeof rule === 'string' ? pathname.startsWith(rule) : rule.test(pathname); - }).length > 0; + sidebarItems?.reduce>( + (result, group) => { + if (group?.title) { + // sideBar menu group 模式, 默认以非 group 模式渲染 + const isSideBarGroupMode = + sidebarGroupModePath === true + ? true + : (sidebarGroupModePath ?? []).filter((rule: ISidebarGroupModePathItem) => { + return typeof rule === 'string' + ? pathname.startsWith(rule) + : rule.test(pathname); + }).length > 0; - if (isSideBarGroupMode) { - result.push({ - type: 'group', - label: group?.title, - key: group?.title, - children: group.children?.map((item) => ({ - label: ( - - {before} - {removeTitleCode(item?.title)} - {item.frontmatter && ( - - {removeTitleCode(item.frontmatter.subtitle)} - - )} - {after} - - ), - key: item.link.replace(/(-cn$)/g, '') - })) - }); + if (isSideBarGroupMode) { + result.push({ + type: 'group', + label: group?.title, + order: group?.order, + key: group?.title, + children: group.children?.map((item) => ({ + label: ( + + {before} + {removeTitleCode(item?.title)} + {item.frontmatter && ( + + {removeTitleCode(item.frontmatter.subtitle)} + + )} + {after} + + ), + key: item.link.replace(/(-cn$)/g, '') + })) + }); + } else { + const childrenGroup = group.children.reduce< + Record[number]['children']> + >((childrenResult, child) => { + const nextChildrenResult = childrenResult; + const type = child?.frontmatter?.type ?? 'default'; + if (!nextChildrenResult[type]) { + nextChildrenResult[type] = []; + } + nextChildrenResult[type].push(child); + return nextChildrenResult; + }, {}); + const childItems: any[] = []; + childItems.push( + ...childrenGroup.default.map((item) => ({ + label: ( + + {before} + {removeTitleCode(item?.title)} + {after} + + ), + key: item.link.replace(/(-cn$)/g, '') + })) + ); + Object.entries(childrenGroup).forEach(([type, children]) => { + if (type !== 'default') { + childItems.push({ + type: 'group', + label: type, + key: type, + children: children?.map((item) => ({ + label: ( + + {before} + {removeTitleCode(item?.title)} + {after} + + ), + key: item.link.replace(/(-cn$)/g, '') + })) + }); + } + }); + result.push({ + label: group?.title, + key: group?.title, + order: group?.order, + children: childItems + }); + } } else { - const childrenGroup = group.children.reduce< - Record[number]['children']> - >((childrenResult, child) => { - const nextChildrenResult = childrenResult; - const type = child?.frontmatter?.type ?? 'default'; - if (!nextChildrenResult[type]) { - nextChildrenResult[type] = []; - } - nextChildrenResult[type].push(child); - return nextChildrenResult; - }, {}); - const childItems: any[] = []; - childItems.push( - ...childrenGroup.default.map((item) => ({ + const list = group.children || []; + // 如果有 date 字段,我们就对其进行排序 + if (list.every((info) => info?.frontmatter?.date)) { + list.sort((a, b) => (a?.frontmatter?.date > b?.frontmatter?.date ? -1 : 1)); + } + + result.push( + ...list.map((item) => ({ + order: item?.order, label: ( {before} @@ -159,53 +209,14 @@ const useMenu = (options: UseMenuOptions = {}): [MenuProps['items'], string] => key: item.link.replace(/(-cn$)/g, '') })) ); - Object.entries(childrenGroup).forEach(([type, children]) => { - if (type !== 'default') { - childItems.push({ - type: 'group', - label: type, - key: type, - children: children?.map((item) => ({ - label: ( - - {before} - {removeTitleCode(item?.title)} - {after} - - ), - key: item.link.replace(/(-cn$)/g, '') - })) - }); - } - }); - result.push({ - label: group?.title, - key: group?.title, - children: childItems - }); - } - } else { - const list = group.children || []; - // 如果有 date 字段,我们就对其进行排序 - if (list.every((info) => info?.frontmatter?.date)) { - list.sort((a, b) => (a?.frontmatter?.date > b?.frontmatter?.date ? -1 : 1)); } - result.push( - ...list.map((item) => ({ - label: ( - - {before} - {removeTitleCode(item?.title)} - {after} - - ), - key: item.link.replace(/(-cn$)/g, '') - })) - ); - } - return result; - }, []) ?? [] + // group 模式与 single 模式混合排序 + result.sort((a, b) => (a?.order < b?.order ? -1 : 1)); + return result; + }, + [] + ) ?? [] ); }, [sidebarData, sidebarGroupModePath, pathname, search, before, after]);