From 75628f4eddb15cac5b6ccf74ca857565c90af08c Mon Sep 17 00:00:00 2001 From: Felipe Trost Date: Thu, 20 Jun 2024 18:46:41 +0200 Subject: [PATCH] feat(ms2/layoutmenu): show selected item --- .../[environmentId]/layout-client.tsx | 29 +++++++++++++++++-- .../(dashboard)/[environmentId]/layout.tsx | 14 ++++----- 2 files changed, 34 insertions(+), 9 deletions(-) diff --git a/src/management-system-v2/app/(dashboard)/[environmentId]/layout-client.tsx b/src/management-system-v2/app/(dashboard)/[environmentId]/layout-client.tsx index 27d758334..1c97cc063 100644 --- a/src/management-system-v2/app/(dashboard)/[environmentId]/layout-client.tsx +++ b/src/management-system-v2/app/(dashboard)/[environmentId]/layout-client.tsx @@ -9,7 +9,7 @@ import cn from 'classnames'; import Link from 'next/link'; import { signIn, useSession } from 'next-auth/react'; import { create } from 'zustand'; -import { useRouter } from 'next/navigation'; +import { usePathname, useRouter, useSearchParams } from 'next/navigation'; import { Environment } from '@/lib/data/environment-schema'; import { useEnvironment } from '@/components/auth-can'; import UserAvatar from '@/components/user-avatar'; @@ -45,6 +45,7 @@ const Layout: FC< }) => { const session = useSession(); const router = useRouter(); + const pathname = usePathname(); const mobileDrawerOpen = useLayoutMobileDrawer((state) => state.open); const setMobileDrawerOpen = useLayoutMobileDrawer((state) => state.set); @@ -58,7 +59,31 @@ const Layout: FC< (item) => !(breakpoint.xs && item && 'type' in item && item.type === 'divider'), ); - const menu = ; + let activeKey: string | undefined; + for (const layoutItem of layoutMenuItems) { + if ( + layoutItem === null || + !('type' in layoutItem) || + layoutItem.type !== 'group' || + !layoutItem.children + ) + continue; + + activeKey = layoutItem?.children.find((item) => { + return item?.key && pathname.includes(item.key as string); + })?.key as string; + + if (activeKey) break; + } + + const menu = ( + + ); return ( diff --git a/src/management-system-v2/app/(dashboard)/[environmentId]/layout.tsx b/src/management-system-v2/app/(dashboard)/[environmentId]/layout.tsx index 26d10434b..d1916442f 100644 --- a/src/management-system-v2/app/(dashboard)/[environmentId]/layout.tsx +++ b/src/management-system-v2/app/(dashboard)/[environmentId]/layout.tsx @@ -45,14 +45,14 @@ const DashboardLayout = async ({ if (can('view', 'Process')) children.push({ - key: 'processes', + key: '/processes', label: Process List, icon: , }); if (can('view', 'Template')) children.push({ - key: 'templates', + key: '/templates', label: Templates, icon: , }); @@ -73,7 +73,7 @@ const DashboardLayout = async ({ const children: MenuProps['items'] = []; children.push({ - key: 'executions', + key: '/executions', label: Instances, icon: , }); @@ -93,7 +93,7 @@ const DashboardLayout = async ({ if (process.env.ENABLE_MACHINE_CONFIG) { layoutMenuItems.push({ - key: 'machine-config', + key: '/machine-config', label: Machine Config, icon: , }); @@ -113,14 +113,14 @@ const DashboardLayout = async ({ if (can('manage', 'User')) children.push({ - key: 'users', + key: '/users', label: Users, icon: , }); if (ability.can('manage', 'RoleMapping') || ability.can('manage', 'Role')) children.push({ - key: 'roles', + key: '/roles', label: Roles, icon: , }); @@ -145,7 +145,7 @@ const DashboardLayout = async ({ type: 'group', children: [ { - key: 'general-settings', + key: '/general-settings', label: ( General Settings ),