Implements Spec 082 updates to the Filament Action Surface Contract: - New required list/table slot: InspectAffordance (clickable row via recordUrl preferred; also supports View action or primary link column) - Retrofit view-only tables to remove lone View row action buttons and use clickable rows - Update validator + guard tests, add golden regression assertions - Add docs: docs/ui/action-surface-contract.md Tests (local via Sail): - vendor/bin/sail artisan test --compact tests/Feature/Guards/ActionSurfaceContractTest.php - vendor/bin/sail artisan test --compact tests/Feature/Guards/ActionSurfaceValidatorTest.php - vendor/bin/sail artisan test --compact tests/Feature/Rbac/ActionSurfaceRbacSemanticsTest.php - vendor/bin/sail artisan test --compact tests/Feature/Filament/EntraGroupSyncRunResourceTest.php Notes: - Filament v5 / Livewire v4 compatible. - No destructive-action behavior changed in this PR. Co-authored-by: Ahmed Darrazi <ahmeddarrazi@MacBookPro.fritz.box> Reviewed-on: #100
54 lines
1.2 KiB
PHP
54 lines
1.2 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Support\Ui\ActionSurface;
|
|
|
|
final class ActionSurfaceValidationResult
|
|
{
|
|
/**
|
|
* @param array<int, ActionSurfaceValidationIssue> $issues
|
|
*/
|
|
public function __construct(
|
|
private readonly array $issues,
|
|
private readonly int $componentCount,
|
|
) {}
|
|
|
|
public function hasIssues(): bool
|
|
{
|
|
return $this->issues !== [];
|
|
}
|
|
|
|
/**
|
|
* @return array<int, ActionSurfaceValidationIssue>
|
|
*/
|
|
public function issues(): array
|
|
{
|
|
return $this->issues;
|
|
}
|
|
|
|
public function componentCount(): int
|
|
{
|
|
return $this->componentCount;
|
|
}
|
|
|
|
public function formatForAssertion(): string
|
|
{
|
|
if (! $this->hasIssues()) {
|
|
return sprintf('Validated %d action-surface components with no issues.', $this->componentCount);
|
|
}
|
|
|
|
$lines = array_map(
|
|
static fn (ActionSurfaceValidationIssue $issue): string => '- '.$issue->format(),
|
|
$this->issues,
|
|
);
|
|
|
|
return sprintf(
|
|
"Action Surface Contract violations (%d/%d):\n%s",
|
|
count($this->issues),
|
|
$this->componentCount,
|
|
implode("\n", $lines),
|
|
);
|
|
}
|
|
}
|