first commit
This commit is contained in:
71
resources/js/components/app-sidebar.tsx
Normal file
71
resources/js/components/app-sidebar.tsx
Normal file
@@ -0,0 +1,71 @@
|
||||
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 { type NavItem } from '@/types';
|
||||
import { Link, usePage } from '@inertiajs/react';
|
||||
import { LayoutGrid, UserCog } from 'lucide-react';
|
||||
import AppLogo from './app-logo';
|
||||
import { SharedData } from '@/types';
|
||||
|
||||
const mainNavItems: NavItem[] = [
|
||||
{
|
||||
title: 'Dashboard',
|
||||
href: route('dashboard'),
|
||||
icon: LayoutGrid,
|
||||
},
|
||||
];
|
||||
|
||||
const adminMainNavItems: NavItem[] = [
|
||||
{
|
||||
title: 'Admin Dashboard',
|
||||
href: route('admin.dashboard'),
|
||||
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>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user