1<script lang="ts">
 2	import CheckIcon from '@lucide/svelte/icons/check';
 3	import { Select as SelectPrimitive } from 'bits-ui';
 4	import { cn, type WithoutChild } from '$lib/components/ui/utils.js';
 5
 6	let {
 7		ref = $bindable(null),
 8		class: className,
 9		value,
10		label,
11		children: childrenProp,
12		...restProps
13	}: WithoutChild<SelectPrimitive.ItemProps> = $props();
14</script>
15
16<SelectPrimitive.Item
17	bind:ref
18	{value}
19	data-slot="select-item"
20	class={cn(
21		"relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2",
22		className
23	)}
24	{...restProps}
25>
26	{#snippet children({ selected, highlighted })}
27		<span class="absolute right-2 flex size-3.5 items-center justify-center">
28			{#if selected}
29				<CheckIcon class="size-4" />
30			{/if}
31		</span>
32		{#if childrenProp}
33			{@render childrenProp({ selected, highlighted })}
34		{:else}
35			{label || value}
36		{/if}
37	{/snippet}
38</SelectPrimitive.Item>