app/dashboard/page.tsx
import type { CSSProperties, JSX } from "react";
import {
Breadcrumb,
BreadcrumbItem,
BreadcrumbLink,
BreadcrumbList,
BreadcrumbPage,
BreadcrumbSeparator,
Separator,
SidebarInset,
SidebarProvider,
SidebarTrigger,
} from "@codefast/ui";
import { AppSidebar } from "@/app/dashboard/_components/app-sidebar.tsx";
export default function Page(): JSX.Element {
return (
<SidebarProvider
style={
{
"--sidebar-width": "350px",
} as CSSProperties
}
>
<AppSidebar />
<SidebarInset>
<header className="bg-background sticky top-0 flex shrink-0 items-center gap-2 border-b p-4">
<SidebarTrigger className="-ml-1" />
<Separator className="mr-2 data-[orientation=vertical]:h-4" orientation="vertical" />
<Breadcrumb>
<BreadcrumbList>
<BreadcrumbItem className="hidden md:block">
<BreadcrumbLink href="#">All Inboxes</BreadcrumbLink>
</BreadcrumbItem>
<BreadcrumbSeparator className="hidden md:block" />
<BreadcrumbItem>
<BreadcrumbPage>Inbox</BreadcrumbPage>
</BreadcrumbItem>
</BreadcrumbList>
</Breadcrumb>
</header>
<div className="flex flex-1 flex-col gap-4 p-4">
{Array.from({ length: 24 }).map((_, index) => (
// eslint-disable-next-line react/no-array-index-key -- we need index
<div key={index} className="bg-muted/50 aspect-video h-12 w-full rounded-lg" />
))}
</div>
</SidebarInset>
</SidebarProvider>
);
}