Spaces:
Running
Running
opencs2-dataset-viewer / src /lib /components /ui /dropdown-menu /dropdown-menu-checkbox-item.svelte
| <script lang="ts"> | |
| import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'; | |
| import MinusIcon from 'phosphor-svelte/lib/Minus'; | |
| import CheckIcon from 'phosphor-svelte/lib/Check'; | |
| import { cn, type WithoutChildrenOrChild } from '$lib/utils.js'; | |
| import type { Snippet } from 'svelte'; | |
| let { | |
| ref = $bindable(null), | |
| checked = $bindable(false), | |
| indeterminate = $bindable(false), | |
| class: className, | |
| children: childrenProp, | |
| ...restProps | |
| }: WithoutChildrenOrChild{ | |
| children?: Snippet; | |
| } = $props(); | |
| </script> | |
| <DropdownMenuPrimitive.CheckboxItem | |
| bind:ref | |
| bind:checked | |
| bind:indeterminate | |
| data-slot="dropdown-menu-checkbox-item" | |
| class={cn( | |
| "focus:bg-accent focus:text-accent-foreground focus:**:text-accent-foreground relative flex min-h-7 cursor-default items-center gap-2 rounded-md py-1.5 pr-8 pl-2 text-xs outline-hidden select-none data-inset:pl-7.5 data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-3.5", | |
| className | |
| )} | |
| {...restProps} | |
| > | |
| {#snippet children({ checked, indeterminate })} | |
| <span | |
| class="pointer-events-none absolute right-2 flex items-center justify-center" | |
| data-slot="dropdown-menu-checkbox-item-indicator" | |
| > | |
| {#if indeterminate} | |
| <MinusIcon /> | |
| {:else if checked} | |
| <CheckIcon /> | |
| {/if} | |
| </span> | |
| {@render childrenProp?.()} | |
| {/snippet} | |
| </DropdownMenuPrimitive.CheckboxItem> | |