Spaces:
Running
Running
| <script lang="ts"> | |
| import { Switch as SwitchPrimitive } from 'bits-ui'; | |
| import { cn, type WithoutChildrenOrChild } from '$lib/utils.js'; | |
| let { | |
| ref = $bindable(null), | |
| class: className, | |
| checked = $bindable(false), | |
| size = 'default', | |
| ...restProps | |
| }: WithoutChildrenOrChild<SwitchPrimitive.RootProps> & { | |
| size?: 'sm' | 'default'; | |
| } = $props(); | |
| </script> | |
| <SwitchPrimitive.Root | |
| bind:ref | |
| bind:checked | |
| data-slot="switch" | |
| data-size={size} | |
| class={cn( | |
| 'data-checked:bg-primary data-unchecked:bg-input focus-visible:border-ring focus-visible:ring-ring/30 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:aria-invalid:border-destructive/50 dark:data-unchecked:bg-input/80 peer group/switch relative inline-flex shrink-0 items-center rounded-full border border-transparent transition-all outline-none after:absolute after:-inset-x-3 after:-inset-y-2 focus-visible:ring-2 aria-invalid:ring-2 data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[size=default]:h-[16.6px] data-[size=default]:w-[28px] data-[size=sm]:h-[14px] data-[size=sm]:w-[24px]', | |
| className | |
| )} | |
| {...restProps} | |
| > | |
| <SwitchPrimitive.Thumb | |
| data-slot="switch-thumb" | |
| class="bg-background dark:data-unchecked:bg-foreground dark:data-checked:bg-primary-foreground pointer-events-none block rounded-full ring-0 transition-transform group-data-[size=default]/switch:size-3.5 group-data-[size=sm]/switch:size-3 group-data-[size=default]/switch:data-checked:translate-x-[calc(100%-2px)] group-data-[size=sm]/switch:data-checked:translate-x-[calc(100%-2px)] group-data-[size=default]/switch:data-unchecked:translate-x-0 group-data-[size=sm]/switch:data-unchecked:translate-x-0 rtl:data-[state=checked]:translate-x-[calc(-100%)]" | |
| /> | |
| </SwitchPrimitive.Root> | |