12345678910111213141516171819 |
- import { usePage } from '@inertiajs/react';
- import { SharedData } from '@/common/types';
- import { SidebarProvider } from '@/shadcn/sidebar';
- interface AppShellProps {
- children: React.ReactNode;
- variant?: 'header' | 'sidebar';
- }
- export function AppShell({ children, variant = 'header' }: AppShellProps) {
- const isOpen = usePage<SharedData>().props.sidebarOpen;
- if (variant === 'header') {
- return <div className="flex min-h-screen w-full flex-col">{children}</div>;
- }
- return <SidebarProvider defaultOpen={isOpen}>{children}</SidebarProvider>;
- }
|