Files
wedding-planner/components/app-sidebar.tsx
2025-07-24 09:42:57 -04:00

172 lines
3.4 KiB
TypeScript

"use client"
import * as React from "react"
import {
IconBuildingArch,
IconDashboard,
IconDatabase,
IconFileWord,
IconHelp,
IconInnerShadowTop,
IconListDetails,
IconReport,
IconSearch,
IconSettings,
IconUsers,
} from "@tabler/icons-react"
import { NavMain } from "@/components/nav-main"
import { NavUser } from "@/components/nav-user"
import {
Sidebar,
SidebarContent,
SidebarFooter,
SidebarHeader,
SidebarMenu,
SidebarMenuButton,
SidebarMenuItem,
} from "@/components/ui/sidebar"
import Link from "next/link"
import { UserContext } from "@/context/UserContext"
const data = {
navMain: [
{
title: "Dashboard",
url: "/dashboard",
icon: IconDashboard,
},
{
title: "Events",
url: "/events",
icon: IconListDetails,
},
{
title: "Guest Book",
url: "/guest-book",
icon: IconUsers,
},
{
title: "Locations",
url: "/venues",
icon: IconBuildingArch,
},
],
// navClouds: [
// {
// title: "Capture",
// icon: IconCamera,
// isActive: true,
// url: "#",
// items: [
// {
// title: "Active Proposals",
// url: "#",
// },
// {
// title: "Archived",
// url: "#",
// },
// ],
// },
// {
// title: "Proposal",
// icon: IconFileDescription,
// url: "#",
// items: [
// {
// title: "Active Proposals",
// url: "#",
// },
// {
// title: "Archived",
// url: "#",
// },
// ],
// },
// {
// title: "Prompts",
// icon: IconFileAi,
// url: "#",
// items: [
// {
// title: "Active Proposals",
// url: "#",
// },
// {
// title: "Archived",
// url: "#",
// },
// ],
// },
// ],
navSecondary: [
{
title: "Settings",
url: "/admin",
icon: IconSettings,
},
{
title: "Get Help",
url: "#",
icon: IconHelp,
},
{
title: "Search",
url: "#",
icon: IconSearch,
},
],
documents: [
{
name: "Data Library",
url: "#",
icon: IconDatabase,
},
{
name: "Reports",
url: "#",
icon: IconReport,
},
{
name: "Word Assistant",
url: "#",
icon: IconFileWord,
},
],
}
export function AppSidebar({ ...props }: React.ComponentProps<typeof Sidebar>) {
const { currentUser } = React.useContext(UserContext)
return (
<Sidebar collapsible="offcanvas" {...props}>
<SidebarHeader>
<SidebarMenu>
<SidebarMenuItem>
<SidebarMenuButton
asChild
className="data-[slot=sidebar-menu-button]:!p-1.5"
>
<Link href="/">
<IconInnerShadowTop className="!size-5" />
<span className="text-base font-semibold">Event Planner</span>
</Link>
</SidebarMenuButton>
</SidebarMenuItem>
</SidebarMenu>
</SidebarHeader>
<SidebarContent>
<NavMain items={data.navMain} />
{/* <NavDocuments items={data.documents} />
<NavSecondary items={data.navSecondary} className="mt-auto" /> */}
</SidebarContent>
{currentUser && (
<SidebarFooter>
<NavUser user={currentUser} />
</SidebarFooter>
)}
</Sidebar>
)
}