Spaces:
Running
Running
| <script lang="ts"> | |
| import { RadioGroup as RadioGroupPrimitive } from "bits-ui"; | |
| import CircleIcon from "@lucide/svelte/icons/circle"; | |
| import { cn, type WithoutChildrenOrChild } from "$lib/utils.js"; | |
| let { | |
| ref = $bindable(null), | |
| class: className, | |
| ...restProps | |
| } | |
| </script> | |
| <RadioGroupPrimitive.Item | |
| bind:ref | |
| data-slot="radio-group-item" | |
| class={cn( | |
| "border-input text-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 aspect-square size-4 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50", | |
| className | |
| )} | |
| {...restProps} | |
| > | |
| {#snippet children({ checked })} | |
| <div data-slot="radio-group-indicator" class="relative flex items-center justify-center"> | |
| {#if checked} | |
| <CircleIcon class="fill-primary text-primary-foreground size-2.5" /> | |
| {/if} | |
| </div> | |
| {/snippet} | |
| </RadioGroupPrimitive.Item> | |