From 95b6bcce6a3686f397f08451d7fc9ef500379207 Mon Sep 17 00:00:00 2001 From: vince Date: Wed, 10 Jul 2024 22:13:55 +0800 Subject: [PATCH] feat: can also see the menu without permission, but jump to 403 --- apps/web-antd/src/locales/langs/en-US.json | 1 + apps/web-antd/src/locales/langs/zh-CN.json | 1 + apps/web-antd/src/router/routes/modules/demos.ts | 13 +++++++++++++ .../demos/access/frontend/menu-visible-403.vue | 13 +++++++++++++ .../generate-routes-frontend.ts | 14 ++++++++------ 5 files changed, 36 insertions(+), 6 deletions(-) create mode 100644 apps/web-antd/src/views/demos/access/frontend/menu-visible-403.vue diff --git a/apps/web-antd/src/locales/langs/en-US.json b/apps/web-antd/src/locales/langs/en-US.json index 4f7723dc..cfcadf51 100644 --- a/apps/web-antd/src/locales/langs/en-US.json +++ b/apps/web-antd/src/locales/langs/en-US.json @@ -8,6 +8,7 @@ "backendControl": "Backend Control", "pageAccess": "Page Access", "buttonControl": "Button Control", + "menuVisible403": "Menu Visible(403)", "superVisible": "Visible to Super", "adminVisible": "Visible to Admin", "userVisible": "Visible to User" diff --git a/apps/web-antd/src/locales/langs/zh-CN.json b/apps/web-antd/src/locales/langs/zh-CN.json index 44c16184..c488badf 100644 --- a/apps/web-antd/src/locales/langs/zh-CN.json +++ b/apps/web-antd/src/locales/langs/zh-CN.json @@ -8,6 +8,7 @@ "backendControl": "后端控制", "pageAccess": "页面访问", "buttonControl": "按钮控制", + "menuVisible403": "菜单可见(403)", "superVisible": "Super 可见", "adminVisible": "Admin 可见", "userVisible": "User 可见" diff --git a/apps/web-antd/src/router/routes/modules/demos.ts b/apps/web-antd/src/router/routes/modules/demos.ts index fdcc1e78..f2870077 100644 --- a/apps/web-antd/src/router/routes/modules/demos.ts +++ b/apps/web-antd/src/router/routes/modules/demos.ts @@ -54,6 +54,19 @@ const routes: RouteRecordRaw[] = [ title: $t('page.demos.access.buttonControl'), }, }, + { + name: 'AccessFrontendMenuVisible403', + path: 'menu-visible-403', + component: () => + import('#/views/demos/access/frontend/menu-visible-403.vue'), + meta: { + authority: ['no-body'], + icon: 'mdi:button-cursor', + menuVisibleWithForbidden: true, + title: $t('page.demos.access.menuVisible403'), + }, + }, + { name: 'AccessFrontendSuperVisible', path: 'super-visible', diff --git a/apps/web-antd/src/views/demos/access/frontend/menu-visible-403.vue b/apps/web-antd/src/views/demos/access/frontend/menu-visible-403.vue new file mode 100644 index 00000000..2c18601a --- /dev/null +++ b/apps/web-antd/src/views/demos/access/frontend/menu-visible-403.vue @@ -0,0 +1,13 @@ + + + diff --git a/packages/business/access/src/generate-menu-and-routes/generate-routes-frontend.ts b/packages/business/access/src/generate-menu-and-routes/generate-routes-frontend.ts index 22957152..328f0081 100644 --- a/packages/business/access/src/generate-menu-and-routes/generate-routes-frontend.ts +++ b/packages/business/access/src/generate-menu-and-routes/generate-routes-frontend.ts @@ -34,14 +34,12 @@ async function generateRoutesByFrontend( */ function hasAuthority(route: RouteRecordRaw, access: string[]) { const authority = route.meta?.authority; - if (!authority) { return true; } - return ( - access.some((value) => authority.includes(value)) || - menuHasVisibleWithForbidden(route) - ); + const canAccess = access.some((value) => authority.includes(value)); + + return canAccess || (!canAccess && menuHasVisibleWithForbidden(route)); } /** @@ -57,7 +55,11 @@ function hasVisible(route?: RouteRecordRaw) { * @param route */ function menuHasVisibleWithForbidden(route: RouteRecordRaw) { - return !!route.meta?.menuVisibleWithForbidden; + return ( + !!route.meta?.authority && + Reflect.has(route.meta || {}, 'menuVisibleWithForbidden') && + !!route.meta?.menuVisibleWithForbidden + ); } export { generateRoutesByFrontend, hasAuthority, hasVisible };