55 lines
1.7 KiB
Svelte
55 lines
1.7 KiB
Svelte
<script lang="ts">
|
|
import NavFooter from '@/components/NavFooter.svelte';
|
|
import NavMain from '@/components/NavMain.svelte';
|
|
import NavUser from '@/components/NavUser.svelte';
|
|
import { Sidebar, SidebarContent, SidebarFooter, SidebarHeader, SidebarMenu, SidebarMenuButton, SidebarMenuItem } from '@/components/ui/sidebar';
|
|
import { type NavItem } from '@/types';
|
|
import { Link, page } from '@inertiajs/svelte';
|
|
import { BookOpen, Folder, LayoutGrid } from 'lucide-svelte';
|
|
import AppLogo from './AppLogo.svelte';
|
|
import Button from './ui/button/button.svelte';
|
|
|
|
const mainNavItems: NavItem[] = [
|
|
{
|
|
title: 'Dashboard',
|
|
href: '/dashboard',
|
|
icon: LayoutGrid,
|
|
},
|
|
];
|
|
|
|
const footerNavItems: NavItem[] = [
|
|
{
|
|
title: 'Admin Dashboard',
|
|
href: '/admin',
|
|
icon: LayoutGrid,
|
|
requireAdmin: true,
|
|
},
|
|
];
|
|
</script>
|
|
|
|
<Sidebar collapsible="icon" variant="inset">
|
|
<SidebarHeader>
|
|
<SidebarMenu>
|
|
<SidebarMenuItem>
|
|
<SidebarMenuButton size="lg">
|
|
<AppLogo />
|
|
</SidebarMenuButton>
|
|
</SidebarMenuItem>
|
|
</SidebarMenu>
|
|
</SidebarHeader>
|
|
|
|
<SidebarContent>
|
|
<NavMain items={mainNavItems} />
|
|
</SidebarContent>
|
|
|
|
<SidebarFooter>
|
|
<NavFooter items={footerNavItems} class="mt-auto" />
|
|
{#if $page.props.auth.user}
|
|
<NavUser />
|
|
{:else}
|
|
<Button>
|
|
<a href={route('auth.redirect')} class="flex items-center gap-2">Login</a>
|
|
</Button>
|
|
{/if}
|
|
</SidebarFooter>
|
|
</Sidebar>
|