AppShell.tsx 580 B

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