## Summary - cut over workspace-owned analysis and library surfaces to workspace shell ownership instead of inheriting remembered environment shell context - update the affected findings pages, scope resolution, navigation helpers, and related Blade views to keep environment focus explicit instead of implicit - add and update Spec 320 artifacts plus focused regression coverage for findings navigation context, workspace hub registration, and admin surface scope behavior ## Guardrails - Filament remains on v5 with Livewire v4 compliance unchanged - provider registration remains in apps/platform/bootstrap/providers.php - no new globally searchable resources were introduced or changed - no new destructive actions were introduced or changed - no Filament assets were added or changed, so the deploy requirement for filament:assets is unchanged ## Testing - `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Findings/FindingsAssignmentHygieneReportTest.php tests/Feature/Findings/FindingsIntakeQueueNavigationContextTest.php tests/Feature/Findings/FindingsIntakeQueueTest.php tests/Feature/Findings/MyFindingsInboxNavigationContextTest.php tests/Feature/Findings/MyWorkInboxTest.php tests/Feature/Navigation/WorkspaceHubRegistryTest.php tests/Unit/Support/OperateHub/OperateHubShellResolutionTest.php tests/Unit/Tenants/AdminSurfaceScopeTest.php` - `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent` Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #375
101 lines
6.0 KiB
PHP
101 lines
6.0 KiB
PHP
<x-filament-panels::page>
|
|
@php($scope = $this->appliedScope())
|
|
@php($summary = $this->summaryCounts())
|
|
@php($queueViews = $this->queueViews())
|
|
|
|
<div class="space-y-6">
|
|
<x-filament::section>
|
|
<div class="flex flex-col gap-4">
|
|
<div class="space-y-2">
|
|
<div class="inline-flex w-fit items-center gap-2 rounded-full border border-warning-200 bg-warning-50 px-3 py-1 text-xs font-medium text-warning-700 dark:border-warning-700/60 dark:bg-warning-950/40 dark:text-warning-300">
|
|
<x-filament::icon icon="heroicon-o-inbox-stack" class="h-3.5 w-3.5" />
|
|
Shared unassigned work
|
|
</div>
|
|
|
|
<div class="space-y-1">
|
|
<h1 class="text-2xl font-semibold tracking-tight text-gray-950 dark:text-white">
|
|
Findings intake
|
|
</h1>
|
|
|
|
<p class="max-w-3xl text-sm leading-6 text-gray-600 dark:text-gray-300">
|
|
Review visible unassigned open findings across entitled environments in one queue. An explicit environment filter can narrow the view, but the intake scope stays fixed.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="grid grid-cols-1 gap-3 md:grid-cols-2 xl:grid-cols-4">
|
|
<div class="rounded-2xl border border-gray-200 bg-white p-4 shadow-sm dark:border-white/10 dark:bg-white/5">
|
|
<div class="text-xs font-medium uppercase tracking-[0.14em] text-gray-500 dark:text-gray-400">
|
|
Visible unassigned
|
|
</div>
|
|
<div class="mt-2 text-3xl font-semibold text-gray-950 dark:text-white">
|
|
{{ $summary['visible_unassigned'] }}
|
|
</div>
|
|
<div class="mt-1 text-sm text-gray-600 dark:text-gray-300">
|
|
Visible unassigned intake rows after the current environment scope.
|
|
</div>
|
|
</div>
|
|
|
|
<div class="rounded-2xl border border-warning-200 bg-warning-50/70 p-4 shadow-sm dark:border-warning-700/50 dark:bg-warning-950/30">
|
|
<div class="text-xs font-medium uppercase tracking-[0.14em] text-warning-700 dark:text-warning-200">
|
|
Needs triage
|
|
</div>
|
|
<div class="mt-2 text-3xl font-semibold text-warning-950 dark:text-warning-100">
|
|
{{ $summary['visible_needs_triage'] }}
|
|
</div>
|
|
<div class="mt-1 text-sm text-warning-800 dark:text-warning-200">
|
|
Visible `new` and `reopened` intake rows that still need first routing.
|
|
</div>
|
|
</div>
|
|
|
|
<div class="rounded-2xl border border-danger-200 bg-danger-50/70 p-4 shadow-sm dark:border-danger-700/50 dark:bg-danger-950/30">
|
|
<div class="text-xs font-medium uppercase tracking-[0.14em] text-danger-700 dark:text-danger-200">
|
|
Overdue
|
|
</div>
|
|
<div class="mt-2 text-3xl font-semibold text-danger-950 dark:text-danger-100">
|
|
{{ $summary['visible_overdue'] }}
|
|
</div>
|
|
<div class="mt-1 text-sm text-danger-800 dark:text-danger-200">
|
|
Intake rows that are already past due.
|
|
</div>
|
|
</div>
|
|
|
|
<div class="rounded-2xl border border-gray-200 bg-white p-4 shadow-sm dark:border-white/10 dark:bg-white/5">
|
|
<div class="text-xs font-medium uppercase tracking-[0.14em] text-gray-500 dark:text-gray-400">
|
|
Applied scope
|
|
</div>
|
|
<div class="mt-2 text-sm font-semibold text-gray-950 dark:text-white">
|
|
{{ $scope['queue_view_label'] }}
|
|
</div>
|
|
<div class="mt-1 text-sm text-gray-600 dark:text-gray-300">
|
|
@if (($scope['tenant_prefilter_source'] ?? 'none') === 'explicit_filter')
|
|
Environment filter applied:
|
|
<span class="font-medium text-gray-950 dark:text-white">{{ $scope['tenant_label'] }}</span>
|
|
@else
|
|
All visible environments are currently included.
|
|
@endif
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="flex flex-wrap gap-2">
|
|
@foreach ($queueViews as $queueView)
|
|
<a
|
|
href="{{ $queueView['url'] }}"
|
|
class="inline-flex items-center gap-2 rounded-full border px-3 py-1.5 text-sm font-medium transition {{ $queueView['active'] ? 'border-primary-200 bg-primary-50 text-primary-700 dark:border-primary-700/60 dark:bg-primary-950/40 dark:text-primary-300' : 'border-gray-200 bg-white text-gray-700 hover:border-gray-300 hover:text-gray-950 dark:border-white/10 dark:bg-white/5 dark:text-gray-300 dark:hover:border-white/20 dark:hover:text-white' }}"
|
|
>
|
|
<span>{{ $queueView['label'] }}</span>
|
|
<span class="rounded-full bg-black/5 px-2 py-0.5 text-xs font-semibold dark:bg-white/10">
|
|
{{ $queueView['badge_count'] }}
|
|
</span>
|
|
<span class="text-[11px] uppercase tracking-[0.12em] opacity-70">Fixed</span>
|
|
</a>
|
|
@endforeach
|
|
</div>
|
|
</div>
|
|
</x-filament::section>
|
|
|
|
{{ $this->table }}
|
|
</div>
|
|
</x-filament-panels::page>
|