import { A, useLocation } from '@solidjs/router';
type LinkItem = {
href: string;
label: string;
icon: string;
aliasPrefix?: string;
group: string;
};
const links: LinkItem[] = [
{ href: '/admin', label: 'Dashboard', icon: 'dashboard.svg', group: '__top__' },
{ 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', 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.', 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/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/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', 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' },
];
export default function AdminSidebar() {
const location = useLocation();
const isActive = (href: string, aliasPrefix?: string) => {
if (href === '/admin') return location.pathname === '/admin';
if (aliasPrefix && location.pathname.startsWith(aliasPrefix)) return true;
return location.pathname === href || location.pathname.startsWith(`${href}/`);
};
const NavItem = (item: LinkItem) => {
const active = isActive(item.href, item.aliasPrefix);
return (
{item.label}
);
};
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');
return (
);
}