Home / File/ sidebar-controlled.tsx — ui Source File

sidebar-controlled.tsx — ui Source File

Architecture documentation for sidebar-controlled.tsx, a tsx file in the ui codebase. 4 imports, 0 dependents.

File tsx DocumentationAtlas Changelog 4 imports 1 functions

Entity Profile

Dependency Diagram

graph LR
  bbce2e63_6d26_635d_07da_e53e2baa47f4["sidebar-controlled.tsx"]
  1d141819_425e_b5fd_4c8e_32f7c6a42cf2["react"]
  bbce2e63_6d26_635d_07da_e53e2baa47f4 --> 1d141819_425e_b5fd_4c8e_32f7c6a42cf2
  4544fa74_9b37_0912_c55e_f4ff161b8e83["button"]
  bbce2e63_6d26_635d_07da_e53e2baa47f4 --> 4544fa74_9b37_0912_c55e_f4ff161b8e83
  ae980154_1718_a5bc_ef81_3a801fffff75["sidebar"]
  bbce2e63_6d26_635d_07da_e53e2baa47f4 --> ae980154_1718_a5bc_ef81_3a801fffff75
  d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3["lucide-react"]
  bbce2e63_6d26_635d_07da_e53e2baa47f4 --> d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3
  style bbce2e63_6d26_635d_07da_e53e2baa47f4 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

"use client"

import * as React from "react"
import { Button } from "@/examples/base/ui/button"
import {
  Sidebar,
  SidebarContent,
  SidebarGroup,
  SidebarGroupContent,
  SidebarGroupLabel,
  SidebarInset,
  SidebarMenu,
  SidebarMenuButton,
  SidebarMenuItem,
  SidebarProvider,
} from "@/examples/base/ui/sidebar"
import {
  FrameIcon,
  LifeBuoyIcon,
  MapIcon,
  PanelLeftCloseIcon,
  PanelLeftOpenIcon,
  PieChartIcon,
  SendIcon,
} from "lucide-react"

const projects = [
  {
    name: "Design Engineering",
    url: "#",
    icon: FrameIcon,
  },
  {
    name: "Sales & Marketing",
    url: "#",
    icon: PieChartIcon,
  },
  {
    name: "Travel",
    url: "#",
    icon: MapIcon,
  },
  {
    name: "Support",
    url: "#",
    icon: LifeBuoyIcon,
  },
  {
    name: "Feedback",
    url: "#",
    icon: SendIcon,
  },
]

export default function AppSidebar() {
  const [open, setOpen] = React.useState(true)

  return (
    <SidebarProvider open={open} onOpenChange={setOpen}>
      <Sidebar>
        <SidebarContent>
          <SidebarGroup>
            <SidebarGroupLabel>Projects</SidebarGroupLabel>
            <SidebarGroupContent>
              <SidebarMenu>
                {projects.map((project) => (
                  <SidebarMenuItem key={project.name}>
                    <SidebarMenuButton render={<a href={project.url} />}>
                      <project.icon />
                      <span>{project.name}</span>
                    </SidebarMenuButton>
                  </SidebarMenuItem>
                ))}
              </SidebarMenu>
            </SidebarGroupContent>
          </SidebarGroup>
        </SidebarContent>
      </Sidebar>
      <SidebarInset>
        <header className="flex h-12 items-center justify-between px-4">
          <Button
            onClick={() => setOpen((open) => !open)}
            size="sm"
            variant="ghost"
          >
            {open ? <PanelLeftCloseIcon /> : <PanelLeftOpenIcon />}
            <span>{open ? "Close" : "Open"} Sidebar</span>
          </Button>
        </header>
      </SidebarInset>
    </SidebarProvider>
  )
}

Subdomains

Functions

Dependencies

  • button
  • lucide-react
  • react
  • sidebar

Frequently Asked Questions

What does sidebar-controlled.tsx do?
sidebar-controlled.tsx is a source file in the ui codebase, written in tsx. It belongs to the DocumentationAtlas domain, Changelog subdomain.
What functions are defined in sidebar-controlled.tsx?
sidebar-controlled.tsx defines 1 function(s): AppSidebar.
What does sidebar-controlled.tsx depend on?
sidebar-controlled.tsx imports 4 module(s): button, lucide-react, react, sidebar.
Where is sidebar-controlled.tsx in the architecture?
sidebar-controlled.tsx is located at apps/v4/examples/base/sidebar-controlled.tsx (domain: DocumentationAtlas, subdomain: Changelog, directory: apps/v4/examples/base).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free