feat(web): add IwoooS host collection order

This commit is contained in:
Your Name
2026-05-19 21:46:44 +08:00
parent c0eeca2ec6
commit 33e793bb76
11 changed files with 471 additions and 6 deletions

View File

@@ -95,6 +95,13 @@ type HostEvidenceReadinessItem = {
tone: 'steady' | 'warn' | 'locked'
}
type HostEvidenceCollectionStep = {
key: string
step: string
icon: typeof ShieldCheck
tone: 'steady' | 'warn' | 'locked'
}
const postureMetrics: PostureMetric[] = [
{ key: 'overall', value: '58%', tone: 'warn' },
{ key: 'framework', value: '80-85%', tone: 'steady' },
@@ -216,6 +223,16 @@ const hostEvidenceReadinessItems: HostEvidenceReadinessItem[] = [
{ key: 'redactedIngestion', gate: 'S1.6', icon: ShieldCheck, tone: 'locked' },
]
const hostEvidenceCollectionSteps: HostEvidenceCollectionStep[] = [
{ key: 'scopeFirst', step: '01', icon: Radar, tone: 'warn' },
{ key: 'ownerSecond', step: '02', icon: ClipboardCheck, tone: 'warn' },
{ key: 'credentialThird', step: '03', icon: Lock, tone: 'locked' },
{ key: 'maintenanceFourth', step: '04', icon: Clock3, tone: 'warn' },
{ key: 'rollbackFifth', step: '05', icon: FileWarning, tone: 'warn' },
{ key: 'validationSixth', step: '06', icon: CheckCircle2, tone: 'warn' },
{ key: 'redactedSeventh', step: '07', icon: ShieldCheck, tone: 'locked' },
]
const evidenceItems = [
'iwooos-posture-projection.snapshot.json',
'security-rollout-policy.snapshot.json',
@@ -546,6 +563,34 @@ function HostEvidenceReadinessCard({ item, index }: { item: HostEvidenceReadines
)
}
function HostEvidenceCollectionCard({ item }: { item: HostEvidenceCollectionStep }) {
const t = useTranslations('iwooos.hostEvidenceCollection')
const Icon = item.icon
return (
<div style={{ ...band, minHeight: 190, padding: 16 }}>
<div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between', gap: 12 }}>
<div style={{ display: 'flex', alignItems: 'center', gap: 9 }}>
<Icon size={18} color={toneColors[item.tone]} />
<span style={{ fontSize: 11, color: '#87867f' }}>{t('stepLabel')}</span>
</div>
<span style={{ fontSize: 11, color: '#9b978b' }}>{item.step}</span>
</div>
<h2 style={{ fontSize: 14, margin: '12px 0 6px', color: '#141413' }}>
{t(`items.${item.key}.title` as never)}
</h2>
<p style={{ fontSize: 12, lineHeight: 1.55, color: '#6f6d66', margin: 0 }}>
{t(`items.${item.key}.body` as never)}
</p>
<div style={{ marginTop: 10, display: 'grid', gap: 5 }}>
<div style={{ fontSize: 11, color: '#87867f' }}>{t('dependencyLabel')}</div>
<div style={{ fontSize: 11, color: toneColors[item.tone], lineHeight: 1.45 }}>
{t(`items.${item.key}.dependency` as never)}
</div>
</div>
</div>
)
}
export default function IwoooSPage({ params }: { params: { locale: string } }) {
const t = useTranslations('iwooos')
@@ -678,6 +723,26 @@ export default function IwoooSPage({ params }: { params: { locale: string } }) {
</div>
</section>
<section style={{ marginBottom: 14 }}>
<div style={{ marginBottom: 14 }}>
<h2 style={{ fontSize: 16, margin: 0 }}>{t('hostEvidenceCollection.title')}</h2>
<p style={{ fontSize: 12, color: '#6f6d66', margin: '6px 0 0', lineHeight: 1.55 }}>
{t('hostEvidenceCollection.subtitle')}
</p>
</div>
<div
style={{
display: 'grid',
gridTemplateColumns: 'repeat(auto-fit, minmax(210px, 1fr))',
gap: 12,
}}
>
{hostEvidenceCollectionSteps.map(item => (
<HostEvidenceCollectionCard key={item.key} item={item} />
))}
</div>
</section>
<section
style={{
display: 'grid',