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 class: className,
8 inset,
9 variant = 'default',
10 ...restProps
11 }: DropdownMenuPrimitive.ItemProps & {
12 inset?: boolean;
13 variant?: 'default' | 'destructive';
14 } = $props();
15</script>
16
17<DropdownMenuPrimitive.Item
18 bind:ref
19 data-slot="dropdown-menu-item"
20 data-inset={inset}
21 data-variant={variant}
22 class={cn(
23 "relative flex cursor-pointer items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-highlighted:bg-accent data-highlighted:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 data-[variant=destructive]:text-destructive data-[variant=destructive]:data-highlighted:bg-destructive/10 data-[variant=destructive]:data-highlighted:text-destructive dark:data-[variant=destructive]:data-highlighted:bg-destructive/20 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground data-[variant=destructive]:*:[svg]:!text-destructive",
24 className
25 )}
26 {...restProps}
27/>