67 lines
2.1 KiB
TypeScript
67 lines
2.1 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import { Check, ChevronsUpDown, GalleryVerticalEnd } from "lucide-react"
|
|
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuTrigger,
|
|
} from "@/components/ui/dropdown-menu"
|
|
import {
|
|
SidebarMenu,
|
|
SidebarMenuButton,
|
|
SidebarMenuItem,
|
|
} from "@/components/ui/sidebar"
|
|
|
|
type VersionSwitcherProps = {
|
|
versions: string[]
|
|
defaultVersion: string
|
|
label?: string
|
|
}
|
|
|
|
export function VersionSwitcher({
|
|
versions,
|
|
defaultVersion,
|
|
label = "Documentation",
|
|
}: VersionSwitcherProps) {
|
|
const [selectedVersion, setSelectedVersion] = React.useState(defaultVersion)
|
|
|
|
return (
|
|
<SidebarMenu>
|
|
<SidebarMenuItem>
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>
|
|
<SidebarMenuButton
|
|
size="lg"
|
|
className="data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground"
|
|
>
|
|
<div className="bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg">
|
|
<GalleryVerticalEnd className="size-4" />
|
|
</div>
|
|
<div className="flex flex-col gap-0.5 leading-none">
|
|
<span className="font-medium">{label}</span>
|
|
<span className="text-xs text-muted-foreground">{selectedVersion}</span>
|
|
</div>
|
|
<ChevronsUpDown className="ml-auto" />
|
|
</SidebarMenuButton>
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent
|
|
className="w-(--radix-dropdown-menu-trigger-width)"
|
|
align="start"
|
|
>
|
|
{versions.map((version) => (
|
|
<DropdownMenuItem
|
|
key={version}
|
|
onSelect={() => setSelectedVersion(version)}
|
|
>
|
|
{version} {version === selectedVersion && <Check className="ml-auto" />}
|
|
</DropdownMenuItem>
|
|
))}
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
</SidebarMenuItem>
|
|
</SidebarMenu>
|
|
)
|
|
}
|