aboutsummaryrefslogtreecommitdiffstats
path: root/code/frontend/src/components/ui/dropdown-menu/dropdown-menu-checkbox-item.svelte
blob: ea02af016ef41e52a4a2cb2d918076e543e92238 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<script lang="ts">
	import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'
	import Check from 'svelte-radix/Check.svelte'
	import { cn } from '$utils/ui'

	type $$Props = DropdownMenuPrimitive.CheckboxItemProps
	type $$Events = DropdownMenuPrimitive.CheckboxItemEvents

	let className: $$Props['class'] = undefined
	export let checked: $$Props['checked'] = undefined
	export { className as class }
</script>

<DropdownMenuPrimitive.CheckboxItem
	bind:checked
	class={cn(
		'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none data-[disabled]:pointer-events-none data-[highlighted]:bg-accent data-[highlighted]:text-accent-foreground data-[disabled]:opacity-50',
		className
	)}
	{...$$restProps}
	on:click
	on:keydown
	on:focusin
	on:focusout
	on:pointerdown
	on:pointerleave
	on:pointermove
>
	<span class="absolute left-2 flex h-3.5 w-3.5 items-center justify-center">
		<DropdownMenuPrimitive.CheckboxIndicator>
			<Check class="h-4 w-4" />
		</DropdownMenuPrimitive.CheckboxIndicator>
	</span>
	<slot />
</DropdownMenuPrimitive.CheckboxItem>