Some checks failed
Main Confidence / confidence (push) Failing after 44s
## Summary - add the new admin findings intake queue at `/admin/findings/intake` with fixed `Unassigned` and `Needs triage` views, tenant-safe filtering, claim flow, and continuity into tenant finding detail and `My Findings` - add Spec 222 artifacts (`spec`, `plan`, `tasks`, `research`, `data model`, `quickstart`, contract, checklist) and register the new admin page - fix follow-up regressions uncovered during full-suite validation around findings action-surface declarations, findings list default columns, provider-blocked run messaging, operation catalog aliases, and workspace overview query volume ## Validation - `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent` - `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Findings/FindingsIntakeQueueTest.php tests/Feature/Authorization/FindingsIntakeAuthorizationTest.php tests/Feature/Findings/FindingsClaimHandoffTest.php` - `cd apps/platform && ./vendor/bin/sail artisan test --compact` ## Notes - Filament remains on v5 with Livewire v4-compatible patterns - provider registration remains unchanged in `apps/platform/bootstrap/providers.php` - no new assets or schema changes are introduced Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #260
104 lines
6.2 KiB
PHP
104 lines
6.2 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 tenants in one queue. Tenant context 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 tenant 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') === 'active_tenant_context')
|
|
Tenant prefilter from active context:
|
|
<span class="font-medium text-gray-950 dark:text-white">{{ $scope['tenant_label'] }}</span>
|
|
@elseif (($scope['tenant_prefilter_source'] ?? 'none') === 'explicit_filter')
|
|
Tenant filter applied:
|
|
<span class="font-medium text-gray-950 dark:text-white">{{ $scope['tenant_label'] }}</span>
|
|
@else
|
|
All visible tenants 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>
|