import { A, useLocation } from '@solidjs/router'; import { For, Show } from 'solid-js'; import { Bell, Briefcase, ClipboardList, FileText, FolderCog, HandHelping, LayoutGrid, Percent, Receipt, Sparkles, UserCircle2, Users, WalletCards, } from 'lucide-solid'; type Item = { href: string; label: string; iconPath?: string; icon?: any; aliasPrefix?: string; separatorBefore?: boolean; group?: string; }; const items: Item[] = [ { href: '/admin', label: 'Dashboard', icon: LayoutGrid }, { href: '/admin/roles', label: 'Internal Role Management', icon: FolderCog, group: 'Management' }, { href: '/admin/runtime-roles', label: 'External Role Management', icon: Users }, { href: '/admin/onboarding-management', label: 'External Onboarding', icon: Users, aliasPrefix: '/admin/onboarding-schemas' }, { href: '/admin/internal-dashboard-management', label: 'Internal Dashboards', icon: LayoutGrid }, { href: '/admin/external-dashboard-management', label: 'External Dashboards', icon: LayoutGrid, aliasPrefix: '/admin/role-ui-configs' }, { href: '/admin/approval', label: 'Approval Management', icon: ClipboardList }, { href: '/admin/department', label: 'Department Management', icon: Briefcase, group: 'Organisation' }, { href: '/admin/designation', label: 'Designation Management', icon: Briefcase }, { href: '/admin/employees', label: 'Employee Management', icon: UserCircle2 }, { href: '/admin/users', label: 'Users Management', icon: Users }, { href: '/admin/company', label: 'Company Management', icon: Briefcase }, { href: '/admin/candidate', label: 'Candidate Management', icon: UserCircle2 }, { href: '/admin/customer', label: 'Customer Management', icon: UserCircle2 }, { href: '/admin/photographer', label: 'Photographer Management', icon: Sparkles, group: 'Service Providers' }, { href: '/admin/makeup-artist', label: 'Makeup Artist Management', icon: Sparkles }, { href: '/admin/tutors', label: 'Tutors Management', icon: Sparkles }, { href: '/admin/developers', label: 'Developers Management', icon: Sparkles }, { href: '/admin/jobs', label: 'Jobs Management', icon: Briefcase, group: 'Operations' }, { href: '/admin/leads', label: 'Leads Management', icon: HandHelping }, { href: '/admin/pricing', label: 'Pricing Management', icon: WalletCards, group: 'Finance' }, { href: '/admin/credit', label: 'Credit Management', icon: WalletCards }, { href: '/admin/coupon', label: 'Coupon Management', icon: Percent }, { href: '/admin/discount', label: 'Discount Management', icon: Percent }, { href: '/admin/tax', label: 'Tax Management', icon: Receipt }, { href: '/admin/order', label: 'Order Management', icon: FileText }, { href: '/admin/invoice', label: 'Invoice Management', icon: FileText }, { href: '/admin/review', label: 'Review Management', icon: FileText, group: 'Support' }, { href: '/admin/support', label: 'Support Management', icon: UserCircle2 }, { href: '/admin/report', label: 'Report Management', icon: Bell }, { href: '/admin/ledger', label: 'Ledger Management', icon: Receipt }, { href: '/admin/kb', label: 'Knowledge Base', icon: FileText }, { href: '/admin/notifications', label: 'Notifications', icon: Bell }, ]; export default function AdminSidebar(props: { onNavigate?: () => void; onLogout?: () => void }) { const location = useLocation(); const active = (item: Item) => { if (item.href === '/admin') return location.pathname === '/admin'; if (item.aliasPrefix && location.pathname.startsWith(item.aliasPrefix)) return true; return location.pathname === item.href || location.pathname.startsWith(`${item.href}/`); }; return ( ); }