@php use Filament\Support\Enums\Alignment; use Filament\Support\Enums\IconSize; @endphp @props([ 'aside' => false, 'collapsed' => false, 'collapsible' => false, 'compact' => false, 'contained' => true, 'contentBefore' => false, 'description' => null, 'footerActions' => [], 'footerActionsAlignment' => Alignment::Start, 'headerActions' => [], 'headerEnd' => null, 'heading' => null, 'icon' => null, 'iconColor' => 'gray', 'iconSize' => IconSize::Large, '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', 'fi-aside grid grid-cols-1 items-start gap-x-6 gap-y-4 md:grid-cols-3' => $aside && $contained, 'fi-aside grid grid-cols-1 items-start gap-x-6 gap-y-4 md:grid-cols-3 pt-4' => $aside && ! $contained, 'rounded-xl bg-white shadow-sm ring-1 ring-gray-950/5 dark:bg-gray-900 dark:ring-white/10' => $contained && ! $aside, ]) }} > @if ($hasHeader)
$collapsible, 'px-6 py-4' => $contained && ! $aside, 'px-4 py-2.5' => $compact && ! $aside, 'py-4' => ! $compact && ! $aside, ]) >
@if ($hasIcon) 'text-gray-400 dark:text-gray-500', default => 'fi-color-custom text-custom-500 dark:text-custom-400', }, is_string($iconColor) ? "fi-color-{$iconColor}" : null, match ($iconSize) { IconSize::Small, 'sm' => 'h-4 w-4 mt-1', IconSize::Medium, 'md' => 'h-5 w-5 mt-0.5', IconSize::Large, 'lg' => 'h-6 w-6', 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 && $contained, 'rounded-xl bg-white shadow-sm ring-1 ring-gray-950/5 dark:bg-gray-900 dark:ring-white/10 md:col-span-2' => $aside && $contained, 'md:col-span-2' => $aside && ! $contained, 'md:order-first' => $contentBefore, ]) >
! $contained && ! $aside, 'p-4' => $compact && $contained, 'p-6' => ! $compact && $contained, ]) > {{ $slot }}
@if ($hasFooterActions) @endif