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>