@props([
'color' => 'primary',
'darkMode' => false,
'disabled' => false,
'form' => null,
'icon' => null,
'keyBindings' => null,
'indicator' => null,
'label' => null,
'size' => 'md',
'tag' => 'button',
'tooltip' => null,
'type' => 'button',
])
@php
$buttonClasses = [
'filament-icon-button flex items-center justify-center rounded-full relative hover:bg-gray-500/5 focus:outline-none disabled:opacity-70 disabled:cursor-not-allowed disabled:pointer-events-none',
'text-primary-500 focus:bg-primary-500/10' => $color === 'primary',
'text-danger-500 focus:bg-danger-500/10' => $color === 'danger',
'text-gray-500 focus:bg-gray-500/10' => $color === 'secondary',
'text-success-500 focus:bg-success-500/10' => $color === 'success',
'text-warning-500 focus:bg-warning-500/10' => $color === 'warning',
'dark:hover:bg-gray-300/5' => $darkMode,
'w-10 h-10' => $size === 'md',
'w-8 h-8' => $size === 'sm',
'w-8 h-8 md:w-10 md:h-10' => $size === 'sm md:md',
'w-12 h-12' => $size === 'lg',
];
$iconClasses = \Illuminate\Support\Arr::toCssClasses([
'filament-icon-button-icon',
'w-5 h-5' => $size === 'md',
'w-4 h-4' => $size === 'sm',
'w-4 h-4 md:w-5 md:h-5' => $size === 'sm md:md',
'w-6 h-6' => $size === 'lg',
]);
$indicatorClasses = \Illuminate\Support\Arr::toCssClasses([
'filament-icon-button-indicator absolute rounded-full text-xs inline-block w-4 h-4 -top-0.5 -right-0.5',
'bg-primary-500/10' => $color === 'primary',
'bg-danger-500/10' => $color === 'danger',
'bg-gray-500/10' => $color === 'secondary',
'bg-success-500/10' => $color === 'success',
'bg-warning-500/10' => $color === 'warning',
]);
$hasLoadingIndicator = filled($attributes->get('wire:target')) || filled($attributes->get('wire:click')) || (($type === 'submit') && filled($form));
if ($hasLoadingIndicator) {
$loadingIndicatorTarget = \Illuminate\Support\Str::before(html_entity_decode($attributes->get('wire:target', $attributes->get('wire:click', $form)), ENT_QUOTES), '(');
}
@endphp
@if ($tag === 'button')
@elseif ($tag === 'a')
map(fn (string $keyBinding): string => str_replace('+', '-', $keyBinding))->implode('.') }}
@endif
@if ($label)
title="{{ $label }}"
@endif
@if ($tooltip)
x-tooltip.raw="{{ $tooltip }}"
@endif
@if ($keyBindings || $tooltip)
x-data="{}"
@endif
{{ $attributes->class($buttonClasses) }}
>
@if ($label)
{{ $label }}
@endif
@if ($indicator)
{{ $indicator }}
@endif
@endif