Files
memefast/resources/js/components/app-sidebar.tsx
2025-06-13 17:11:59 +08:00

73 lines
2.2 KiB
TypeScript

import { NavFooter } from '@/components/nav-footer';
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 { SharedData, type NavItem } from '@/types';
import { Link, usePage } from '@inertiajs/react';
import { LayoutGrid, UserCog } from 'lucide-react';
import AppLogo from './app-logo';
const mainNavItems: NavItem[] = [
{
title: 'Dashboard',
href: route('dashboard'),
icon: LayoutGrid,
},
];
const adminMainNavItems: NavItem[] = [
{
title: 'Admin Dashboard',
href: route('admin.dashboard'),
icon: UserCog,
},
{
title: 'Background Generation',
href: route('admin.background-generation'),
icon: UserCog,
},
];
const footerNavItems: NavItem[] = [
// {
// title: 'Repository',
// href: 'https://github.com/laravel/react-starter-kit',
// icon: Folder,
// },
// {
// title: 'Documentation',
// href: 'https://laravel.com/docs/starter-kits',
// icon: BookOpen,
// },
];
export function AppSidebar() {
const { auth } = usePage<SharedData>().props;
return (
<Sidebar collapsible="icon" variant="inset">
<SidebarHeader>
<SidebarMenu>
<SidebarMenuItem>
<SidebarMenuButton size="lg" asChild>
<Link href="/dashboard" prefetch>
<AppLogo />
</Link>
</SidebarMenuButton>
</SidebarMenuItem>
</SidebarMenu>
</SidebarHeader>
<SidebarContent>
<NavMain title="Platform" items={mainNavItems} />
{auth?.user_is_admin && <NavMain title="Admin" items={adminMainNavItems} />}
</SidebarContent>
<SidebarFooter>
<NavFooter items={footerNavItems} className="mt-auto" />
<NavUser />
</SidebarFooter>
</Sidebar>
);
}