1<script lang="ts">
2 import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui';
3 import CircleIcon from '@lucide/svelte/icons/circle';
4 import { cn, type WithoutChild } from '$lib/components/ui/utils.js';
5
6 let {
7 ref = $bindable(null),
8 class: className,
9 children: childrenProp,
10 ...restProps
11 }: WithoutChild<DropdownMenuPrimitive.RadioItemProps> = $props();
12</script>
13
14<DropdownMenuPrimitive.RadioItem
15 bind:ref
16 data-slot="dropdown-menu-radio-item"
17 class={cn(
18 "relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
19 className
20 )}
21 {...restProps}
22>
23 {#snippet children({ checked })}
24 <span class="pointer-events-none absolute left-2 flex size-3.5 items-center justify-center">
25 {#if checked}
26 <CircleIcon class="size-2 fill-current" />
27 {/if}
28 </span>
29 {@render childrenProp?.({ checked })}
30 {/snippet}
31</DropdownMenuPrimitive.RadioItem>