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>