## Summary - add the shared operator explanation layer with explanation families, trustworthiness semantics, count descriptors, and centralized badge mappings - adopt explanation-first rendering across baseline compare, governance operation run detail, baseline snapshot presentation, tenant review detail, and review register rows - extend reason translation, artifact-truth presentation, fallback ops UX messaging, and focused regression coverage for operator explanation semantics ## Testing - vendor/bin/sail bin pint --dirty --format agent - vendor/bin/sail artisan test --compact tests/Feature/Monitoring/OperationsTenantScopeTest.php tests/Feature/Operations/OperationRunBlockedExecutionPresentationTest.php - vendor/bin/sail artisan test --compact ## Notes - Livewire v4 compatible - panel provider registration remains in bootstrap/providers.php - no destructive Filament actions were added or changed in this PR - no new global-search behavior was introduced in this slice Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #191
93 lines
3.3 KiB
PHP
93 lines
3.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Support\Ui\GovernanceArtifactTruth;
|
|
|
|
use App\Support\ReasonTranslation\NextStepOption;
|
|
use App\Support\ReasonTranslation\ReasonResolutionEnvelope;
|
|
use App\Support\Ui\OperatorExplanation\TrustworthinessLevel;
|
|
|
|
final readonly class ArtifactTruthCause
|
|
{
|
|
/**
|
|
* @param array<int, string> $nextSteps
|
|
*/
|
|
public function __construct(
|
|
public ?string $reasonCode,
|
|
public ?string $translationArtifact,
|
|
public ?string $operatorLabel,
|
|
public ?string $shortExplanation,
|
|
public ?string $diagnosticCode,
|
|
public string $trustImpact,
|
|
public ?string $absencePattern,
|
|
public array $nextSteps = [],
|
|
) {}
|
|
|
|
public static function fromReasonResolutionEnvelope(
|
|
?ReasonResolutionEnvelope $reason,
|
|
?string $translationArtifact = null,
|
|
): ?self {
|
|
if (! $reason instanceof ReasonResolutionEnvelope) {
|
|
return null;
|
|
}
|
|
|
|
return new self(
|
|
reasonCode: $reason->internalCode,
|
|
translationArtifact: $translationArtifact,
|
|
operatorLabel: $reason->operatorLabel,
|
|
shortExplanation: $reason->shortExplanation,
|
|
diagnosticCode: $reason->diagnosticCode(),
|
|
trustImpact: $reason->trustImpact,
|
|
absencePattern: $reason->absencePattern,
|
|
nextSteps: array_values(array_map(
|
|
static fn (NextStepOption $nextStep): string => $nextStep->label,
|
|
$reason->nextSteps,
|
|
)),
|
|
);
|
|
}
|
|
|
|
public function toReasonResolutionEnvelope(): ReasonResolutionEnvelope
|
|
{
|
|
return new ReasonResolutionEnvelope(
|
|
internalCode: $this->reasonCode ?? 'artifact_truth_reason',
|
|
operatorLabel: $this->operatorLabel ?? 'Operator attention required',
|
|
shortExplanation: $this->shortExplanation ?? 'Technical diagnostics are available for this result.',
|
|
actionability: $this->absencePattern === 'true_no_result' ? 'non_actionable' : 'prerequisite_missing',
|
|
nextSteps: array_map(
|
|
static fn (string $label): NextStepOption => NextStepOption::instruction($label),
|
|
$this->nextSteps,
|
|
),
|
|
diagnosticCodeLabel: $this->diagnosticCode,
|
|
trustImpact: $this->trustImpact !== '' ? $this->trustImpact : TrustworthinessLevel::LimitedConfidence->value,
|
|
absencePattern: $this->absencePattern,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return array{
|
|
* reasonCode: ?string,
|
|
* translationArtifact: ?string,
|
|
* operatorLabel: ?string,
|
|
* shortExplanation: ?string,
|
|
* diagnosticCode: ?string,
|
|
* trustImpact: string,
|
|
* absencePattern: ?string,
|
|
* nextSteps: array<int, string>
|
|
* }
|
|
*/
|
|
public function toArray(): array
|
|
{
|
|
return [
|
|
'reasonCode' => $this->reasonCode,
|
|
'translationArtifact' => $this->translationArtifact,
|
|
'operatorLabel' => $this->operatorLabel,
|
|
'shortExplanation' => $this->shortExplanation,
|
|
'diagnosticCode' => $this->diagnosticCode,
|
|
'trustImpact' => $this->trustImpact,
|
|
'absencePattern' => $this->absencePattern,
|
|
'nextSteps' => $this->nextSteps,
|
|
];
|
|
}
|
|
}
|