+
Checking session…
diff --git a/src/components/AdminSidebar.tsx b/src/components/AdminSidebar.tsx
index 8bae74d..b8e7c19 100644
--- a/src/components/AdminSidebar.tsx
+++ b/src/components/AdminSidebar.tsx
@@ -1,71 +1,59 @@
import { A, useLocation } from '@solidjs/router';
-import { createSignal } from 'solid-js';
type LinkItem = {
href: string;
label: string;
icon: string;
aliasPrefix?: string;
- group?: string;
+ group: string;
};
const links: LinkItem[] = [
- { href: '/admin', label: 'Dashboard', icon: 'dashboard.svg', group: 'Overview' },
+ { href: '/admin', label: 'Dashboard', icon: 'dashboard.svg', group: '__top__' },
- { href: '/admin/department', label: 'Department', icon: 'department.svg', group: 'Organization' },
- { href: '/admin/designation', label: 'Designation', icon: 'designation.svg', group: 'Organization' },
- { href: '/admin/employees', label: 'Employees', icon: 'users.svg', group: 'Organization' },
+ { href: '/admin/roles', label: 'Internal Role Management', icon: 'role.svg', group: 'Management' },
+ { href: '/admin/runtime-roles', label: 'External Role Management', icon: 'role.svg', group: 'Management' },
+ { href: '/admin/onboarding-schemas', label: 'External Onboarding', icon: 'reviews.svg', group: 'Management' },
+ { href: '/admin/internal-dashboard-management',label: 'Internal Dashboard Mgmt.', icon: 'dashboard.svg', group: 'Management' },
+ { href: '/admin/external-dashboard-management',label: 'External Dashboard Mgmt.', icon: 'dashboard.svg', aliasPrefix: '/admin/role-ui-configs', group: 'Management' },
+ { href: '/admin/approval', label: 'Approval Management', icon: 'approval.svg', group: 'Management' },
+ { href: '/admin/department', label: 'Department Management', icon: 'department.svg', group: 'Management' },
+ { href: '/admin/designation', label: 'Designation Management', icon: 'designation.svg',group: 'Management' },
+ { href: '/admin/employees', label: 'Employee Management', icon: 'users.svg', group: 'Management' },
+ { href: '/admin/users', label: 'Users Management', icon: 'users.svg', group: 'Management' },
+ { href: '/admin/company', label: 'Company Management', icon: 'company.svg', group: 'Management' },
+ { href: '/admin/candidate', label: 'Candidate Management', icon: 'candidate.svg', group: 'Management' },
+ { href: '/admin/customer', label: 'Customer Management', icon: 'users.svg', group: 'Management' },
+ { href: '/admin/photographer', label: 'Photographer Management', icon: 'photographer.svg',group: 'Management' },
+ { href: '/admin/makeup-artist', label: 'Makeup Artist Management', icon: 'makeup-artist.svg',group: 'Management'},
+ { href: '/admin/tutors', label: 'Tutors Management', icon: 'tutor.svg', group: 'Management' },
+ { href: '/admin/developers', label: 'Developers Management', icon: 'developers.svg', group: 'Management' },
+ { href: '/admin/video-editors', label: 'Video Editor Management', icon: 'developers.svg', group: 'Management' },
+ { href: '/admin/fitness-trainers', label: 'Fitness Trainer Management', icon: 'tutor.svg', group: 'Management' },
+ { href: '/admin/catering-services', label: 'Catering Services Mgmt.', icon: 'company.svg', group: 'Management' },
+ { href: '/admin/graphic-designers', label: 'Graphics Designer Mgmt.', icon: 'developers.svg', group: 'Management' },
+ { href: '/admin/social-media-managers', label: 'Social Media Mgr. Mgmt.', icon: 'developers.svg', group: 'Management' },
+ { href: '/admin/jobs', label: 'Jobs Management', icon: 'jobs.svg', group: 'Management' },
+ { href: '/admin/leads', label: 'Leads Management', icon: 'leads.svg', group: 'Management' },
- { href: '/admin/roles', label: 'Internal Roles', icon: 'role.svg', group: 'Access & Roles' },
- { href: '/admin/runtime-roles', label: 'External Roles', icon: 'role.svg', group: 'Access & Roles' },
- { href: '/admin/onboarding-schemas', label: 'Onboarding Flows', icon: 'reviews.svg', group: 'Access & Roles' },
+ { href: '/admin/pricing', label: 'Pricing Management', icon: 'pricing.svg', group: 'Finance' },
+ { href: '/admin/credit', label: 'Credit Management', icon: 'credits.svg', group: 'Finance' },
+ { href: '/admin/coupon', label: 'Coupon Management', icon: 'coupon.svg', group: 'Finance' },
+ { href: '/admin/discount', label: 'Discount Management', icon: 'discount.svg', group: 'Finance' },
+ { href: '/admin/tax', label: 'Tax Management', icon: 'tax.svg', group: 'Finance' },
+ { href: '/admin/order', label: 'Order Management', icon: 'order.svg', group: 'Finance' },
+ { href: '/admin/invoice', label: 'Invoice Management', icon: 'invoice.svg', group: 'Finance' },
+ { href: '/admin/ledger', label: 'Ledger Management', icon: 'ledger.svg', group: 'Finance' },
- { href: '/admin/internal-dashboard-management', label: 'Internal Dashboards', icon: 'dashboard.svg', group: 'Dashboards' },
- { href: '/admin/external-dashboard-management', label: 'External Dashboards', icon: 'dashboard.svg', aliasPrefix: '/admin/role-ui-configs', group: 'Dashboards' },
-
- { href: '/admin/users', label: 'Users', icon: 'users.svg', group: 'People' },
- { href: '/admin/company', label: 'Companies', icon: 'company.svg', group: 'People' },
- { href: '/admin/candidate', label: 'Candidates', icon: 'candidate.svg', group: 'People' },
- { href: '/admin/customer', label: 'Customers', icon: 'users.svg', group: 'People' },
- { href: '/admin/photographer', label: 'Photographers', icon: 'photographer.svg', group: 'People' },
- { href: '/admin/makeup-artist', label: 'Makeup Artists', icon: 'makeup-artist.svg', group: 'People' },
- { href: '/admin/tutors', label: 'Tutors', icon: 'tutor.svg', group: 'People' },
- { href: '/admin/developers', label: 'Developers', icon: 'developers.svg', group: 'People' },
- { href: '/admin/video-editors', label: 'Video Editors', icon: 'developers.svg', group: 'People' },
- { href: '/admin/fitness-trainers', label: 'Fitness Trainers', icon: 'tutor.svg', group: 'People' },
- { href: '/admin/catering-services', label: 'Catering Services', icon: 'company.svg', group: 'People' },
- { href: '/admin/graphic-designers', label: 'Graphic Designers', icon: 'developers.svg', group: 'People' },
- { href: '/admin/social-media-managers', label: 'Social Media Mgr.', icon: 'developers.svg', group: 'People' },
-
- { href: '/admin/jobs', label: 'Jobs', icon: 'jobs.svg', group: 'Content' },
- { href: '/admin/leads', label: 'Leads', icon: 'leads.svg', group: 'Content' },
- { href: '/admin/review', label: 'Reviews', icon: 'reviews.svg', group: 'Content' },
- { href: '/admin/kb', label: 'Knowledge Base', icon: 'reviews.svg', group: 'Content' },
- { href: '/admin/notifications', label: 'Notifications', icon: 'reviews.svg', group: 'Content' },
-
- { href: '/admin/pricing', label: 'Pricing', icon: 'pricing.svg', group: 'Finance' },
- { href: '/admin/credit', label: 'Credits', icon: 'credits.svg', group: 'Finance' },
- { href: '/admin/coupon', label: 'Coupons', icon: 'coupon.svg', group: 'Finance' },
- { href: '/admin/discount', label: 'Discounts', icon: 'discount.svg', group: 'Finance' },
- { href: '/admin/tax', label: 'Tax', icon: 'tax.svg', group: 'Finance' },
- { href: '/admin/order', label: 'Orders', icon: 'order.svg', group: 'Finance' },
- { href: '/admin/invoice', label: 'Invoices', icon: 'invoice.svg', group: 'Finance' },
- { href: '/admin/ledger', label: 'Ledger', icon: 'ledger.svg', group: 'Finance' },
-
- { href: '/admin/approval', label: 'Approvals', icon: 'approval.svg', group: 'Operations' },
- { href: '/admin/support', label: 'Support', icon: 'support.svg', group: 'Operations' },
- { href: '/admin/report', label: 'Reports', icon: 'report.svg', group: 'Operations' },
+ { href: '/admin/review', label: 'Review Management', icon: 'reviews.svg', group: 'Platform' },
+ { href: '/admin/support', label: 'Support Management', icon: 'support.svg', group: 'Platform' },
+ { href: '/admin/kb', label: 'Knowledge Base Mgmt.', icon: 'reviews.svg', group: 'Platform' },
+ { href: '/admin/notifications', label: 'Notifications', icon: 'reviews.svg', group: 'Platform' },
+ { href: '/admin/report', label: 'Report Management', icon: 'report.svg', group: 'Platform' },
];
-// Build ordered group list preserving first appearance
-const GROUP_ORDER: string[] = [];
-for (const item of links) {
- if (item.group && !GROUP_ORDER.includes(item.group)) GROUP_ORDER.push(item.group);
-}
-
export default function AdminSidebar() {
const location = useLocation();
- const [collapsed, setCollapsed] = createSignal(false);
const isActive = (href: string, aliasPrefix?: string) => {
if (href === '/admin') return location.pathname === '/admin';
@@ -73,91 +61,73 @@ export default function AdminSidebar() {
return location.pathname === href || location.pathname.startsWith(`${href}/`);
};
+ const topLinks = links.filter(l => l.group === '__top__');
+ const mgmtLinks = links.filter(l => l.group === 'Management');
+ const finLinks = links.filter(l => l.group === 'Finance');
+ const platLinks = links.filter(l => l.group === 'Platform');
+
+ const NavItem = (item: LinkItem) => {
+ const active = isActive(item.href, item.aliasPrefix);
+ return (
+
+
+ {item.label}
+
+ );
+ };
+
+ const GroupLabel = (label: string) => (
+
+ );
+
return (
-