62 lines
1.8 KiB
Vue
62 lines
1.8 KiB
Vue
<script setup lang="ts">
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuTrigger,
|
|
} from '@/registry/new-york/ui/dropdown-menu'
|
|
|
|
import {
|
|
SidebarMenu,
|
|
SidebarMenuButton,
|
|
SidebarMenuItem,
|
|
} from '@/registry/new-york/ui/sidebar'
|
|
import { Check, ChevronsUpDown, GalleryVerticalEnd } from 'lucide-vue-next'
|
|
|
|
import { ref } from 'vue'
|
|
|
|
const props = defineProps<{
|
|
versions: string[]
|
|
defaultVersion: string
|
|
}>()
|
|
|
|
const selectedVersion = ref(props.defaultVersion)
|
|
</script>
|
|
|
|
<template>
|
|
<SidebarMenu>
|
|
<SidebarMenuItem>
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger as-child>
|
|
<SidebarMenuButton
|
|
size="lg"
|
|
class="data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground"
|
|
>
|
|
<div class="flex aspect-square size-8 items-center justify-center rounded-lg bg-sidebar-primary text-sidebar-primary-foreground">
|
|
<GalleryVerticalEnd class="size-4" />
|
|
</div>
|
|
<div class="flex flex-col gap-0.5 leading-none">
|
|
<span class="font-semibold">Documentation</span>
|
|
<span class="">v{{ selectedVersion }}</span>
|
|
</div>
|
|
<ChevronsUpDown class="ml-auto" />
|
|
</SidebarMenuButton>
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent
|
|
class="w-[--reka-dropdown-menu-trigger-width]"
|
|
align="start"
|
|
>
|
|
<DropdownMenuItem
|
|
v-for="version in versions"
|
|
:key="version"
|
|
@select="selectedVersion = version"
|
|
>
|
|
v{{ version }}
|
|
<Check v-if="version === selectedVersion" class="ml-auto" />
|
|
</DropdownMenuItem>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
</SidebarMenuItem>
|
|
</SidebarMenu>
|
|
</template>
|