@php use Filament\Support\Enums\Alignment; use Filament\Support\Enums\IconSize; @endphp @props([ 'aside' => false, 'collapsed' => false, 'collapsible' => false, 'compact' => false, 'contentBefore' => false, 'description' => null, 'footerActions' => [], 'footerActionsAlignment' => Alignment::Start, 'headerActions' => [], 'headerEnd' => null, 'heading' => null, 'icon' => null, 'iconColor' => 'theme', 'iconSize' => IconSize::ExtraLarge, 'persistCollapsed' => false, ]) @php $hasDescription = filled((string) $description); $hasHeading = filled($heading); $hasIcon = filled($icon); if (is_array($headerActions)) { $headerActions = array_filter( $headerActions, fn ($headerAction): bool => $headerAction->isVisible(), ); } if (is_array($footerActions)) { $footerActions = array_filter( $footerActions, fn ($footerAction): bool => $footerAction->isVisible(), ); } $hasHeaderActions = $headerActions instanceof \Illuminate\Contracts\Support\Htmlable ? ! \Filament\Support\is_slot_empty($headerActions) : filled($headerActions); $hasFooterActions = $footerActions instanceof \Illuminate\Contracts\Support\Htmlable ? ! \Filament\Support\is_slot_empty($footerActions) : filled($footerActions); $hasHeader = $hasIcon || $hasHeading || $hasDescription || $collapsible || $hasHeaderActions || filled((string) $headerEnd); @endphp
class([ 'fi-section', match ($aside) { true => 'fi-aside grid grid-cols-1 items-start gap-x-6 gap-y-4 lg:grid-cols-3', false => 'rounded-lg bg-white shadow-sm ring-1 ring-gray-950/5 dark:bg-gray-900 dark:ring-white/10', }, ]) }} > @if ($hasHeader)
$collapsible, match ($compact) { true => 'p-2', false => 'p-4', } => ! $aside, ]) >
@if ($hasIcon) 'text-gray-400 dark:text-gray-500', 't1'=> 'text-t1-400 dark:text-t1-600', 't2'=> 'text-t2-400 dark:text-t2-600', 't3'=> 'text-t3-400 dark:text-t3-600', 't4'=> 'text-t4-400 dark:text-t4-600', 'o1'=> 'text-o1-400 dark:text-o1-600', 'o2'=> 'text-o2-400 dark:text-o2-600', 'o3'=> 'text-o3-400 dark:text-o3-600', 'o4'=> 'text-o4-400 dark:text-o4-600', default => 'fi-color-slate text-slate-900 dark:text-slate-100', }, is_string($iconColor) ? "fi-color-{$iconColor}" : null, match ($iconSize) { IconSize::Tiny, 'xs' => 'h-2 w-2', IconSize::Small, 'sm' => 'h-4 w-4', IconSize::Medium, 'md' => 'h-6 w-6', IconSize::Large, 'lg' => 'h-8 w-8', IconSize::ExtraLarge, 'xl' => 'h-12 w-12', default => $iconSize, }, ]) @style([ \Filament\Support\get_color_css_variables( $iconColor, shades: [400, 500], alias: 'section.header.icon', ) => $iconColor !== 'gray', ]) /> @endif @if ($hasHeading || $hasDescription)
@if ($hasHeading) {{ $heading }} @endif @if ($hasDescription) {{ $description }} @endif
@endif @if ($hasHeaderActions) @endif {{ $headerEnd }} @if ($collapsible) @endif
@if ($hasHeaderActions)
@endif
@endif
$hasHeader && (! $aside), 'rounded-lg bg-white shadow-sm ring-1 ring-gray-950/5 dark:bg-gray-900 dark:ring-white/10 md:col-span-2' => $aside, 'md:order-first' => $contentBefore, ]) >
'p-0', false => 'p-0', }, ]) > {{ $slot }}
@if ($hasFooterActions) @endif