2024-12-01 23:19:21 +05:00
|
|
|
import {
|
2024-12-06 14:16:05 +05:00
|
|
|
Calculator,
|
2024-12-01 23:19:21 +05:00
|
|
|
ChevronRight,
|
|
|
|
Coins,
|
|
|
|
CreditCard,
|
|
|
|
Handshake,
|
|
|
|
MonitorSpeaker,
|
|
|
|
Smartphone,
|
|
|
|
UsersRound,
|
|
|
|
} from "lucide-react";
|
2024-11-24 23:30:44 +05:00
|
|
|
|
|
|
|
import {
|
|
|
|
Collapsible,
|
|
|
|
CollapsibleContent,
|
|
|
|
CollapsibleTrigger,
|
|
|
|
} from "@/components/ui/collapsible";
|
|
|
|
import {
|
|
|
|
Sidebar,
|
|
|
|
SidebarContent,
|
|
|
|
SidebarGroup,
|
|
|
|
SidebarGroupContent,
|
|
|
|
SidebarGroupLabel,
|
|
|
|
SidebarHeader,
|
|
|
|
SidebarMenu,
|
|
|
|
SidebarMenuButton,
|
|
|
|
SidebarMenuItem,
|
|
|
|
SidebarRail,
|
|
|
|
} from "@/components/ui/sidebar";
|
|
|
|
import Link from "next/link";
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
navMain: [
|
|
|
|
{
|
|
|
|
title: "MENU",
|
|
|
|
url: "#",
|
2024-11-27 14:18:17 +05:00
|
|
|
requiredRoles: ["ADMIN", "USER"],
|
2024-11-24 23:30:44 +05:00
|
|
|
items: [
|
|
|
|
{
|
|
|
|
title: "Devices",
|
|
|
|
url: "/devices",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <Smartphone size={16} />,
|
2024-11-24 23:30:44 +05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "Payments",
|
|
|
|
url: "/payments",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <CreditCard size={16} />,
|
2024-11-24 23:30:44 +05:00
|
|
|
},
|
2024-12-22 21:34:57 +05:00
|
|
|
{
|
|
|
|
title: "Parental Control",
|
|
|
|
url: "/parental-control",
|
|
|
|
icon: <CreditCard size={16} />,
|
|
|
|
},
|
2024-11-30 23:38:32 +05:00
|
|
|
{
|
|
|
|
title: "Agreements",
|
|
|
|
url: "/agreements",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <Handshake size={16} />,
|
2024-11-30 23:38:32 +05:00
|
|
|
},
|
2024-11-24 23:30:44 +05:00
|
|
|
],
|
|
|
|
},
|
2024-11-27 14:18:17 +05:00
|
|
|
{
|
|
|
|
title: "ADMIN CONTROL",
|
|
|
|
url: "#",
|
|
|
|
requiredRoles: ["ADMIN"],
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
title: "Users",
|
|
|
|
url: "/users",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <UsersRound size={16} />,
|
2024-11-27 14:18:17 +05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "User Devices",
|
|
|
|
url: "/user-devices",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <MonitorSpeaker size={16} />,
|
2024-11-27 14:18:17 +05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "User Payments",
|
|
|
|
url: "/user-payments",
|
2024-12-01 23:19:21 +05:00
|
|
|
icon: <Coins size={16} />,
|
2024-11-27 14:18:17 +05:00
|
|
|
},
|
2024-12-06 14:16:05 +05:00
|
|
|
{
|
|
|
|
title: "Price Calculator",
|
|
|
|
url: "/price-calculator",
|
|
|
|
icon: <Calculator size={16} />,
|
|
|
|
},
|
2024-11-27 14:18:17 +05:00
|
|
|
],
|
|
|
|
},
|
2024-11-24 23:30:44 +05:00
|
|
|
],
|
|
|
|
};
|
|
|
|
|
2024-11-27 14:18:17 +05:00
|
|
|
export function AppSidebar({
|
|
|
|
role,
|
|
|
|
...props
|
|
|
|
}: React.ComponentProps<typeof Sidebar> & { role: string }) {
|
2024-11-24 23:30:44 +05:00
|
|
|
return (
|
2024-11-27 14:18:17 +05:00
|
|
|
<Sidebar {...props} className="z-50">
|
2024-11-24 23:30:44 +05:00
|
|
|
<SidebarHeader>
|
2024-12-06 14:16:05 +05:00
|
|
|
<h4 className="p-2 rounded title-bg border text-center uppercase ">
|
2024-11-24 23:30:44 +05:00
|
|
|
Sar Link Portal
|
|
|
|
</h4>
|
|
|
|
</SidebarHeader>
|
|
|
|
<SidebarContent className="gap-0">
|
2024-11-27 14:18:17 +05:00
|
|
|
{data.navMain
|
|
|
|
.filter(
|
|
|
|
(item) =>
|
|
|
|
!item.requiredRoles || item.requiredRoles.includes(role || ""),
|
|
|
|
)
|
|
|
|
.map((item) => {
|
|
|
|
if (item.requiredRoles?.includes(role)) {
|
|
|
|
return (
|
|
|
|
<Collapsible
|
|
|
|
key={item.title}
|
|
|
|
title={item.title}
|
|
|
|
defaultOpen
|
|
|
|
className="group/collapsible"
|
|
|
|
>
|
|
|
|
<SidebarGroup>
|
|
|
|
<SidebarGroupLabel
|
|
|
|
asChild
|
|
|
|
className="group/label text-sm text-sidebar-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground"
|
|
|
|
>
|
|
|
|
<CollapsibleTrigger>
|
|
|
|
{item.title}{" "}
|
|
|
|
<ChevronRight className="ml-auto transition-transform group-data-[state=open]/collapsible:rotate-90" />
|
|
|
|
</CollapsibleTrigger>
|
|
|
|
</SidebarGroupLabel>
|
|
|
|
<CollapsibleContent>
|
|
|
|
<SidebarGroupContent>
|
|
|
|
<SidebarMenu>
|
|
|
|
{item.items.map((item) => (
|
|
|
|
<SidebarMenuItem key={item.title}>
|
|
|
|
<SidebarMenuButton className="py-6" asChild>
|
|
|
|
<Link className="text-md" href={item.url}>
|
2024-12-01 23:19:21 +05:00
|
|
|
{item.icon}
|
|
|
|
<span className="opacity-70 ml-2">
|
|
|
|
{item.title}
|
|
|
|
</span>
|
2024-11-27 14:18:17 +05:00
|
|
|
</Link>
|
|
|
|
</SidebarMenuButton>
|
|
|
|
</SidebarMenuItem>
|
|
|
|
))}
|
|
|
|
</SidebarMenu>
|
|
|
|
</SidebarGroupContent>
|
|
|
|
</CollapsibleContent>
|
|
|
|
</SidebarGroup>
|
|
|
|
</Collapsible>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
})}
|
2024-11-24 23:30:44 +05:00
|
|
|
</SidebarContent>
|
|
|
|
<SidebarRail />
|
|
|
|
</Sidebar>
|
|
|
|
);
|
|
|
|
}
|