@aware([ 'size' ]) @props([ 'iconTrailing' => null, 'iconVariant' => null, 'label' => null, 'icon' => null, 'size' => null, ]) @php $classes = Flux::classes() ->add('flex whitespace-nowrap flex-1 justify-center items-center gap-2') ->add('rounded-md data-checked:shadow-xs') ->add('text-sm font-medium text-zinc-600 hover:text-zinc-800 dark:hover:text-white dark:text-white/70 data-checked:text-zinc-800 dark:data-checked:text-white') ->add('data-checked:bg-white dark:data-checked:bg-white/20') ->add('[&[disabled]]:opacity-50 dark:[&[disabled]]:opacity-75 [&[disabled]]:cursor-default [&[disabled]]:pointer-events-none') ->add(match ($size) { 'sm' => 'px-3 text-sm', default => 'px-4', }) ; $iconVariant ??= 'mini'; $iconClasses = Flux::classes('text-zinc-500 dark:text-zinc-400 [ui-radio[data-checked]_&]:text-zinc-800 dark:[ui-radio[data-checked]_&]:text-white') // When using the outline icon variant, we need to size it down to match the default icon sizes... ->add($iconVariant === 'outline' ? 'size-5' : '') ; @endphp {{-- We have to put tabindex="-1" here because otherwise, Livewire requests will wipe out tabindex state, --}} {{-- even with durable attributes for some reason... --}} class($classes) }} data-flux-control data-flux-radio-segmented tabindex="-1"> {{ $label ?? $slot }}