@php $iconTrailing ??= $attributes->pluck('icon:trailing'); @endphp @php $iconVariant ??= $attributes->pluck('icon:variant'); @endphp @aware([ 'variant' ]) @props([ 'iconVariant' => 'outline', 'iconTrailing' => null, 'badgeColor' => null, 'variant' => null, 'iconDot' => null, 'accent' => true, 'square' => null, '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-6' : 'size-5'); $classes = Flux::classes() ->add('px-3 h-8 flex items-center rounded-lg') ->add($square ? '' : 'px-2.5!') ->add('text-text-secondary') ->add([ '[--hover-fill:var(--color-bg-elevated)]', ]) ->add(match ($accent) { true => [ 'hover:text-text-primary', 'data-current:text-text-primary hover:data-current:text-text-primary hover:bg-bg-elevated hover:data-current:bg-(--hover-fill)', ], false => [ 'hover:text-text-primary', 'data-current:text-text-primary hover:bg-bg-elevated', ], }) ; @endphp
{{ $icon }}
isNotEmpty()): ?>
{{ $slot }}
{{ $iconTrailing }} $badgeColor, 'class' => 'ms-2']); ?> {{ $badge }}