@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('relative') // This is here for the "active" bar at the bottom to be positioned correctly... ->add($square ? '' : 'px-2.5!') ->add('text-text-secondary') // Styles for when this link is the "current" one... ->add('data-current:after:absolute data-current:after:-bottom-3 data-current:after:inset-x-0 data-current:after:h-[2px]') ->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)', 'data-current:after:bg-orange-primary', ], false => [ 'hover:text-text-primary', 'data-current:text-text-primary hover:bg-bg-elevated', 'data-current:after:bg-text-primary', ], }) ; @endphp
{{ $icon }}
isNotEmpty()): ?>
{{ $slot }}
{{ $iconTrailing }} $badgeColor, 'class' => 'ms-2']); ?> {{ $badge }}