index.blade.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. @php
  2. use Filament\Support\Enums\IconPosition;
  3. use Filament\Support\Enums\IconSize;
  4. use Filament\Support\Enums\Size;
  5. use Filament\Support\View\Components\BadgeComponent;
  6. use Filament\Support\View\Components\ButtonComponent;
  7. use Illuminate\View\ComponentAttributeBag;
  8. @endphp
  9. @props([
  10. 'badge' => null,
  11. 'badgeColor' => 'primary',
  12. 'badgeSize' => Size::ExtraSmall,
  13. 'color' => 'primary',
  14. 'disabled' => false,
  15. 'form' => null,
  16. 'formId' => null,
  17. 'href' => null,
  18. 'icon' => null,
  19. 'iconAlias' => null,
  20. 'iconPosition' => IconPosition::Before,
  21. 'iconSize' => null,
  22. 'keyBindings' => null,
  23. 'labeledFrom' => null,
  24. 'labelSrOnly' => false,
  25. 'loadingIndicator' => true,
  26. 'outlined' => false,
  27. 'size' => Size::Medium,
  28. 'spaMode' => null,
  29. 'tag' => 'button',
  30. 'target' => null,
  31. 'tooltip' => null,
  32. 'type' => 'button',
  33. ])
  34. @php
  35. if (! $iconPosition instanceof IconPosition) {
  36. $iconPosition = filled($iconPosition) ? (IconPosition::tryFrom($iconPosition) ?? $iconPosition) : null;
  37. }
  38. if (! $size instanceof Size) {
  39. $size = filled($size) ? (Size::tryFrom($size) ?? $size) : null;
  40. }
  41. if (! $badgeSize instanceof Size) {
  42. $badgeSize = filled($badgeSize) ? (Size::tryFrom($badgeSize) ?? $badgeSize) : null;
  43. }
  44. if (filled($iconSize) && (! $iconSize instanceof IconSize)) {
  45. $iconSize = IconSize::tryFrom($iconSize) ?? $iconSize;
  46. }
  47. $iconSize ??= match ($size) {
  48. Size::ExtraSmall, Size::Small => IconSize::Small,
  49. default => null,
  50. };
  51. $wireTarget = $loadingIndicator ? $attributes->whereStartsWith(['wire:target', 'wire:click'])->filter(fn ($value): bool => filled($value))->first() : null;
  52. $hasFormProcessingLoadingIndicator = $type === 'submit' && filled($form);
  53. $hasLoadingIndicator = filled($wireTarget) || $hasFormProcessingLoadingIndicator;
  54. if ($hasLoadingIndicator) {
  55. $loadingIndicatorTarget = html_entity_decode($wireTarget ?: $form, ENT_QUOTES);
  56. }
  57. $hasTooltip = filled($tooltip);
  58. @endphp
  59. @if ($labeledFrom)
  60. <x-filament::icon-button
  61. :badge="$badge"
  62. :badge-color="$badgeColor"
  63. :badge-size="$badgeSize"
  64. :color="$color"
  65. :disabled="$disabled"
  66. :form="$form"
  67. :form-id="$formId"
  68. :href="$href"
  69. :icon="$icon"
  70. :icon-alias="$iconAlias"
  71. :icon-size="$iconSize"
  72. :key-bindings="$keyBindings"
  73. :label="$slot"
  74. :loading-indicator="$loadingIndicator"
  75. :size="$size"
  76. :spa-mode="$spaMode"
  77. :tag="$tag"
  78. :target="$target"
  79. :tooltip="$tooltip"
  80. :type="$type"
  81. :attributes="\Filament\Support\prepare_inherited_attributes($attributes)"
  82. />
  83. @endif
  84. <{{ $tag }}
  85. @if (($tag === 'a') && (! ($disabled && $hasTooltip)))
  86. {{ \Filament\Support\generate_href_html($href, $target === '_blank', $spaMode) }}
  87. @endif
  88. @if ($keyBindings)
  89. x-bind:id="$id('key-bindings')"
  90. x-mousetrap.global.{{ collect($keyBindings)->map(fn (string $keyBinding): string => str_replace('+', '-', $keyBinding))->implode('.') }}="document.getElementById($el.id)?.click()"
  91. @endif
  92. @if ($hasTooltip)
  93. x-tooltip="{
  94. content: @js($tooltip),
  95. theme: $store.theme,
  96. allowHTML: @js($tooltip instanceof \Illuminate\Contracts\Support\Htmlable),
  97. }"
  98. @endif
  99. @if ($hasFormProcessingLoadingIndicator)
  100. x-data="filamentFormButton"
  101. x-bind:class="{ 'fi-processing': isProcessing }"
  102. @endif
  103. {{
  104. $attributes
  105. ->merge([
  106. 'aria-disabled' => $disabled ? 'true' : null,
  107. 'aria-label' => $labelSrOnly ? trim(strip_tags($slot->toHtml())) : null,
  108. 'disabled' => $disabled && blank($tooltip),
  109. 'form' => $formId,
  110. 'type' => $tag === 'button' ? $type : null,
  111. 'wire:loading.attr' => $tag === 'button' ? 'disabled' : null,
  112. 'wire:target' => ($hasLoadingIndicator && $loadingIndicatorTarget) ? $loadingIndicatorTarget : null,
  113. 'x-bind:disabled' => $hasFormProcessingLoadingIndicator ? 'isProcessing' : null,
  114. 'x-bind:aria-label' => ($labelSrOnly && $hasFormProcessingLoadingIndicator) ? ('isProcessing ? processingMessage : ' . \Illuminate\Support\Js::from(trim(strip_tags($slot->toHtml())))) : null,
  115. ], escape: false)
  116. ->when(
  117. $disabled && $hasTooltip,
  118. fn (ComponentAttributeBag $attributes) => $attributes->filter(
  119. fn (mixed $value, string $key): bool => ! str($key)->startsWith(['href', 'x-on:', 'wire:click']),
  120. ),
  121. )
  122. ->class([
  123. 'fi-btn',
  124. 'fi-disabled' => $disabled,
  125. 'fi-outlined' => $outlined,
  126. ($size instanceof Size) ? "fi-size-{$size->value}" : (is_string($size) ? $size : ''),
  127. is_string($labeledFrom) ? "fi-labeled-from-{$labeledFrom}" : null,
  128. ])
  129. ->color(app(ButtonComponent::class, ['isOutlined' => $outlined]), $color)
  130. }}
  131. >
  132. @if ($iconPosition === IconPosition::Before)
  133. @if ($icon)
  134. {{
  135. \Filament\Support\generate_icon_html($icon, $iconAlias, (new \Illuminate\View\ComponentAttributeBag([
  136. 'wire:loading.remove.delay.' . config('filament.livewire_loading_delay', 'default') => $hasLoadingIndicator,
  137. 'wire:target' => $hasLoadingIndicator ? $loadingIndicatorTarget : false,
  138. ])), size: $iconSize)
  139. }}
  140. @endif
  141. @if ($hasLoadingIndicator)
  142. {{
  143. \Filament\Support\generate_loading_indicator_html((new \Illuminate\View\ComponentAttributeBag([
  144. 'wire:loading.delay.' . config('filament.livewire_loading_delay', 'default') => '',
  145. 'wire:target' => $loadingIndicatorTarget,
  146. ])), size: $iconSize)
  147. }}
  148. @endif
  149. @if ($hasFormProcessingLoadingIndicator)
  150. {{
  151. \Filament\Support\generate_loading_indicator_html((new \Illuminate\View\ComponentAttributeBag([
  152. 'x-cloak' => 'x-cloak',
  153. 'x-show' => 'isProcessing',
  154. ])), size: $iconSize)
  155. }}
  156. @endif
  157. @endif
  158. @if (! $labelSrOnly)
  159. @if ($hasFormProcessingLoadingIndicator)
  160. <span x-show="! isProcessing">
  161. {{ $slot }}
  162. </span>
  163. @else
  164. {{ $slot }}
  165. @endif
  166. @endif
  167. @if ($hasFormProcessingLoadingIndicator && (! $labelSrOnly))
  168. <span
  169. x-cloak
  170. x-show="isProcessing"
  171. x-text="processingMessage"
  172. ></span>
  173. @endif
  174. @if ($iconPosition === IconPosition::After)
  175. @if ($icon)
  176. {{
  177. \Filament\Support\generate_icon_html($icon, $iconAlias, (new \Illuminate\View\ComponentAttributeBag([
  178. 'wire:loading.remove.delay.' . config('filament.livewire_loading_delay', 'default') => $hasLoadingIndicator,
  179. 'wire:target' => $hasLoadingIndicator ? $loadingIndicatorTarget : false,
  180. ])), size: $iconSize)
  181. }}
  182. @endif
  183. @if ($hasLoadingIndicator)
  184. {{
  185. \Filament\Support\generate_loading_indicator_html((new \Illuminate\View\ComponentAttributeBag([
  186. 'wire:loading.delay.' . config('filament.livewire_loading_delay', 'default') => '',
  187. 'wire:target' => $loadingIndicatorTarget,
  188. ])), size: $iconSize)
  189. }}
  190. @endif
  191. @if ($hasFormProcessingLoadingIndicator)
  192. {{
  193. \Filament\Support\generate_loading_indicator_html((new \Illuminate\View\ComponentAttributeBag([
  194. 'x-cloak' => 'x-cloak',
  195. 'x-show' => 'isProcessing',
  196. ])), size: $iconSize)
  197. }}
  198. @endif
  199. @endif
  200. @if (filled($badge))
  201. <div class="fi-btn-badge-ctn">
  202. @if ($badge instanceof \Illuminate\View\ComponentSlot)
  203. {{ $badge }}
  204. @else
  205. <span
  206. {{
  207. (new ComponentAttributeBag)->color(BadgeComponent::class, $badgeColor)->class([
  208. 'fi-badge',
  209. ($badgeSize instanceof Size) ? "fi-size-{$badgeSize->value}" : (is_string($badgeSize) ? $badgeSize : ''),
  210. ])
  211. }}
  212. >
  213. {{ $badge }}
  214. </span>
  215. @endif
  216. </div>
  217. @endif
  218. </{{ $tag }}>