80 lines
2.9 KiB
PHP
80 lines
2.9 KiB
PHP
@php $iconTrailing = $iconTrailing ??= $attributes->pluck('icon:trailing'); @endphp
|
|
@php $iconVariant = $iconVariant ??= $attributes->pluck('icon:variant'); @endphp
|
|
|
|
@props([
|
|
'iconTrailing' => null,
|
|
'iconVariant' => 'mini',
|
|
'variant' => 'default',
|
|
'suffix' => null,
|
|
'value' => null,
|
|
'icon' => null,
|
|
'kbd' => null,
|
|
])
|
|
|
|
@php
|
|
if ($kbd) $suffix = $kbd;
|
|
|
|
$iconClasses = Flux::classes()
|
|
->add('me-2')
|
|
// When using the outline icon variant, we need to size it down to match the default icon sizes...
|
|
->add($iconVariant === 'outline' ? 'size-5' : null)
|
|
;
|
|
|
|
$trailingIconClasses = Flux::classes()
|
|
->add('ms-auto text-zinc-400 [[data-flux-menu-item-icon]:hover_&]:text-current')
|
|
// When using the outline icon variant, we need to size it down to match the default icon sizes...
|
|
->add($iconVariant === 'outline' ? 'size-5' : null)
|
|
;
|
|
|
|
$classes = Flux::classes()
|
|
->add('flex items-center px-2 py-1.5 w-full focus:outline-hidden')
|
|
->add('rounded-md')
|
|
->add('text-start text-sm font-medium')
|
|
->add('[&[disabled]]:opacity-50')
|
|
->add(match ($variant) {
|
|
'danger' => [
|
|
'text-zinc-800 data-active:text-red-600 data-active:bg-red-50 dark:text-white dark:data-active:bg-red-400/20 dark:data-active:text-red-400',
|
|
'**:data-flux-menu-item-icon:text-zinc-400 dark:**:data-flux-menu-item-icon:text-white/60 [&[data-active]_[data-flux-menu-item-icon]]:text-current',
|
|
],
|
|
'default' => [
|
|
'text-zinc-800 data-active:bg-zinc-50 dark:text-white dark:data-active:bg-zinc-600',
|
|
'**:data-flux-menu-item-icon:text-zinc-400 dark:**:data-flux-menu-item-icon:text-white/60 [&[data-active]_[data-flux-menu-item-icon]]:text-current',
|
|
]
|
|
})
|
|
;
|
|
|
|
$suffixClasses = Flux::classes()
|
|
->add('ms-auto text-xs text-zinc-400')
|
|
;
|
|
@endphp
|
|
|
|
<flux:button-or-link :attributes="$attributes->class($classes)" data-flux-menu-item :data-flux-menu-item-has-icon="!! $icon">
|
|
<?php if (is_string($icon) && $icon !== ''): ?>
|
|
<flux:icon :$icon :variant="$iconVariant" :class="$iconClasses" data-flux-menu-item-icon />
|
|
<?php elseif ($icon): ?>
|
|
{{ $icon }}
|
|
<?php else: ?>
|
|
<div class="w-7 hidden [[data-flux-menu]:has(>[data-flux-menu-item-has-icon])_&]:block"></div>
|
|
<?php endif; ?>
|
|
|
|
{{ $slot }}
|
|
|
|
<?php if ($suffix): ?>
|
|
<?php if (is_string($suffix)): ?>
|
|
<div class="{{ $suffixClasses }}">
|
|
{{ $suffix }}
|
|
</div>
|
|
<?php else: ?>
|
|
{{ $suffix }}
|
|
<?php endif; ?>
|
|
<?php endif; ?>
|
|
|
|
<?php if (is_string($iconTrailing) && $iconTrailing !== ''): ?>
|
|
<flux:icon :icon="$iconTrailing" :variant="$iconVariant" :class="$trailingIconClasses" data-flux-menu-item-icon />
|
|
<?php elseif ($iconTrailing): ?>
|
|
{{ $iconTrailing }}
|
|
<?php endif; ?>
|
|
|
|
{{ $submenu ?? '' }}
|
|
</flux:button-or-link>
|