1<script lang="ts">
2 import { cn } from '$lib/components/ui/utils.js';
3 import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui';
4
5 let {
6 ref = $bindable(null),
7 sideOffset = 4,
8 portalProps,
9 class: className,
10 ...restProps
11 }: DropdownMenuPrimitive.ContentProps & {
12 portalProps?: DropdownMenuPrimitive.PortalProps;
13 } = $props();
14</script>
15
16<DropdownMenuPrimitive.Portal {...portalProps}>
17 <DropdownMenuPrimitive.Content
18 bind:ref
19 data-slot="dropdown-menu-content"
20 {sideOffset}
21 class={cn(
22 'z-50 max-h-(--bits-dropdown-menu-content-available-height) min-w-[8rem] origin-(--bits-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md outline-none data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:fade-in-0 data-[state=open]:zoom-in-95 dark:border-border/20',
23 className
24 )}
25 {...restProps}
26 />
27</DropdownMenuPrimitive.Portal>