38a347a82a
CI / detect-changes (push) Successful in 7s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / secret-scan (push) Has been skipped
CI / dep-audit (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / build-sha-integrity (push) Successful in 9s
CI / validate-canonical-controls (push) Successful in 12s
CI / loc-budget (push) Successful in 24s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Successful in 3m11s
CI / test-go (push) Has been skipped
CI / iace-gt-coverage (push) Has been skipped
CI / test-python-backend (push) Successful in 24s
CI / test-python-document-crawler (push) Has been skipped
CI / test-python-dsms-gateway (push) Has been skipped
AGB v2 (decision_method routing, 71%FP->~0) + DSE v3 (4-layer, recovered from container) + Architektur-Tab into /sdk/agent live path. Incl CI robustness (detect-changes.sh + PR-head checkout) + security (hardcoded Qdrant key removed, gitleaks allowlist). Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
49 lines
1.7 KiB
TypeScript
49 lines
1.7 KiB
TypeScript
'use client'
|
|
|
|
import React, { useState } from 'react'
|
|
import { ComplianceCheckTab } from './_components/ComplianceCheckTab'
|
|
import { ComplianceFAQ } from './_components/ComplianceFAQ'
|
|
import { SnapshotHistoryList } from './_components/SnapshotHistoryList'
|
|
import { ArchitekturView } from './_components/ArchitekturView'
|
|
|
|
export default function AgentPage() {
|
|
// Nach einem abgeschlossenen Check die Historie unten neu laden.
|
|
const [historyKey, setHistoryKey] = useState(0)
|
|
const [tab, setTab] = useState<'check' | 'architektur'>('check')
|
|
|
|
return (
|
|
<div className="space-y-6 max-w-4xl">
|
|
<div>
|
|
<h1 className="text-2xl font-bold text-gray-900">Compliance Agent</h1>
|
|
<p className="text-gray-500 mt-1">Webseiten + Dokumente auf DSGVO-Konformität prüfen.</p>
|
|
</div>
|
|
|
|
<div className="flex gap-1 border-b border-gray-200 dark:border-gray-700">
|
|
{([['check', 'Check'], ['architektur', 'Architektur']] as const).map(([id, label]) => (
|
|
<button
|
|
key={id}
|
|
onClick={() => setTab(id)}
|
|
className={`px-3 py-2 text-sm font-medium -mb-px border-b-2 transition-colors ${
|
|
tab === id
|
|
? 'border-purple-500 text-purple-600 dark:text-purple-400'
|
|
: 'border-transparent text-gray-500 hover:text-gray-700 dark:hover:text-gray-300'
|
|
}`}
|
|
>
|
|
{label}
|
|
</button>
|
|
))}
|
|
</div>
|
|
|
|
{tab === 'check' ? (
|
|
<>
|
|
<ComplianceCheckTab onComplete={() => setHistoryKey(k => k + 1)} />
|
|
<SnapshotHistoryList refreshKey={historyKey} />
|
|
<ComplianceFAQ />
|
|
</>
|
|
) : (
|
|
<ArchitekturView />
|
|
)}
|
|
</div>
|
|
)
|
|
}
|