mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-25 13:46:07 +00:00
* feat: add base and radix docs * feat: transform code for display * fix * fix * fix * fix * fix * chore: remove claude files * fix * fix * fix * chore: run format:write * fix * feat: add more examples * fix * feat: add aspect-ratio * feat: add avatar * feat: add badge * feat: add breadcrumb * fix * feat: add button * fix * fix * fix * feat: add calendar and card * feat: add carousel * fix: chart * feat: add checkbox * feat: add collapsible * feat: add combobox * feat: add command * feat: add context menu * feat: add data-table dialog and drawer * feat: dropdown-menu * feat: add date-picker * feat: add empty * feat: add field and hover-card * fix: input * feat: add input * feat: add input-group * feat: add input-otp * feat: add item * feat: add kbd and label * feat: add menubar * feat: add native-select * feat: add more components * feat: more components * feat: more components * feat: add skeleton, slider and sonner * feat: add spinner and switch * feat: add more components * fix: tabs * fix: tabs * feat: add docs for sidebar * fix * fix * fi * docs: update * fix: create page * fix * fix * chore: add changelog * fix
94 lines
2.1 KiB
TypeScript
94 lines
2.1 KiB
TypeScript
"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>
|
|
)
|
|
}
|