mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-27 06:34:12 +00:00
67 lines
2.3 KiB
TypeScript
67 lines
2.3 KiB
TypeScript
"use client"
|
|
|
|
import Link from "next/link"
|
|
import { usePathname } from "next/navigation"
|
|
|
|
import type { source } from "@/lib/source"
|
|
import {
|
|
Sidebar,
|
|
SidebarContent,
|
|
SidebarGroup,
|
|
SidebarGroupContent,
|
|
SidebarGroupLabel,
|
|
SidebarMenu,
|
|
SidebarMenuButton,
|
|
SidebarMenuItem,
|
|
} from "@/registry/new-york-v4/ui/sidebar"
|
|
|
|
export function DocsSidebar({
|
|
tree,
|
|
...props
|
|
}: React.ComponentProps<typeof Sidebar> & { tree: typeof source.pageTree }) {
|
|
const pathname = usePathname()
|
|
|
|
return (
|
|
<Sidebar
|
|
className="sticky top-[calc(var(--header-height)+1px)] z-30 hidden h-[calc(100svh-var(--footer-height)+2rem)] bg-transparent lg:flex"
|
|
collapsible="none"
|
|
{...props}
|
|
>
|
|
<SidebarContent className="no-scrollbar px-2 pb-12">
|
|
<div className="h-(--top-spacing) shrink-0" />
|
|
{tree.children.map((item) => (
|
|
<SidebarGroup key={item.$id}>
|
|
<SidebarGroupLabel className="text-muted-foreground font-medium">
|
|
{item.name}
|
|
</SidebarGroupLabel>
|
|
<SidebarGroupContent>
|
|
{item.type === "folder" && (
|
|
<SidebarMenu className="gap-0.5">
|
|
{item.children.map((item) => {
|
|
return (
|
|
item.type === "page" && (
|
|
<SidebarMenuItem key={item.url}>
|
|
<SidebarMenuButton
|
|
asChild
|
|
isActive={item.url === pathname}
|
|
className="data-[active=true]:bg-accent data-[active=true]:border-accent 3xl:fixed:w-full 3xl:fixed:max-w-48 relative h-[30px] w-fit overflow-visible border border-transparent text-[0.8rem] font-medium after:absolute after:inset-x-0 after:-inset-y-1 after:z-0 after:rounded-md"
|
|
>
|
|
<Link href={item.url}>
|
|
<span className="absolute inset-0 flex w-(--sidebar-width) bg-transparent" />
|
|
{item.name}
|
|
</Link>
|
|
</SidebarMenuButton>
|
|
</SidebarMenuItem>
|
|
)
|
|
)
|
|
})}
|
|
</SidebarMenu>
|
|
)}
|
|
</SidebarGroupContent>
|
|
</SidebarGroup>
|
|
))}
|
|
</SidebarContent>
|
|
</Sidebar>
|
|
)
|
|
}
|