@php $iconTrailing = $iconTrailing ??= $attributes->pluck('icon:trailing'); @endphp @php $iconVariant = $iconVariant ??= $attributes->pluck('icon:variant'); @endphp @aware([ 'variant' ]) @props([ 'iconVariant' => 'outline', 'iconTrailing' => null, 'badgeColor' => null, 'variant' => null, 'iconDot' => null, 'accent' => true, 'badge' => null, 'icon' => null, ]) @php // Button should be a square if it has no text contents... $square ??= $slot->isEmpty(); // Size-up icons in square/icon-only buttons... $iconClasses = Flux::classes($square ? 'size-5!' : 'size-4!'); $classes = Flux::classes() ->add('h-10 lg:h-8 relative flex items-center gap-3 rounded-lg') ->add($square ? 'px-2.5!' : '') ->add('py-0 text-start w-full px-3 my-px') ->add('text-zinc-500 dark:text-white/80') ->add(match ($variant) { 'outline' => match ($accent) { true => [ 'data-current:text-(--color-accent-content) hover:data-current:text-(--color-accent-content)', 'data-current:bg-white dark:data-current:bg-white/[7%] data-current:border data-current:border-zinc-200 dark:data-current:border-transparent', 'hover:text-zinc-800 dark:hover:text-white dark:hover:bg-white/[7%] hover:bg-zinc-800/5 ', 'border border-transparent', ], false => [ 'data-current:text-zinc-800 dark:data-current:text-zinc-100 data-current:border-zinc-200', 'data-current:bg-white dark:data-current:bg-white/10 data-current:border data-current:border-zinc-200 dark:data-current:border-white/10 data-current:shadow-xs', 'hover:text-zinc-800 dark:hover:text-white', ], }, default => match ($accent) { true => [ 'data-current:text-(--color-accent-content) hover:data-current:text-(--color-accent-content)', 'data-current:bg-zinc-800/[4%] dark:data-current:bg-white/[7%]', 'hover:text-zinc-800 dark:hover:text-white hover:bg-zinc-800/[4%] dark:hover:bg-white/[7%]', ], false => [ 'data-current:text-zinc-800 dark:data-current:text-zinc-100', 'data-current:bg-zinc-800/[4%] dark:data-current:bg-white/10', 'hover:text-zinc-800 dark:hover:text-white hover:bg-zinc-800/[4%] dark:hover:bg-white/10', ], }, }) ; @endphp
{{ $icon }}
isNotEmpty()): ?>
{{ $slot }}
{{ $iconTrailing }} {{ $badge }}