Merge branch 'dev' into agent/rex/CUB-48-agent-status-badge

This commit is contained in:
2026-04-27 17:40:21 -04:00
3 changed files with 41 additions and 13 deletions

View File

@@ -0,0 +1,28 @@
// ============================================================================
// Hub Page — Responsive AgentCard Grid
// Desktop (≥1024px): 2×2 grid
// Mobile (<1024px): single-column stack
// ============================================================================
.hub-page {
display: grid;
grid-template-columns: 1fr;
gap: 16px;
padding: var(--cc-section-padding, 16px);
min-height: 400px;
overflow-x: hidden;
}
.hub-page__placeholder {
color: var(--cc-on-surface-variant);
font-size: 16px;
text-align: center;
padding: 24px 0;
}
// Desktop / kiosk breakpoint — 2-column grid
@media (min-width: 1024px) {
.hub-page {
grid-template-columns: repeat(2, 1fr);
}
}

View File

@@ -9,18 +9,7 @@ import { ChangeDetectionStrategy, Component } from '@angular/core';
<p class="hub-page__placeholder">Command Hub — Fleet status grid will render here</p> <p class="hub-page__placeholder">Command Hub — Fleet status grid will render here</p>
</div> </div>
`, `,
styles: [` styleUrl: './hub-page.component.scss',
.hub-page {
display: flex;
align-items: center;
justify-content: center;
min-height: 400px;
}
.hub-page__placeholder {
color: var(--cc-on-surface-variant);
font-size: 16px;
}
`],
changeDetection: ChangeDetectionStrategy.OnPush, changeDetection: ChangeDetectionStrategy.OnPush,
}) })
export class HubPageComponent {} export class HubPageComponent {}

View File

@@ -48,6 +48,17 @@ html {
// These are NOT part of the M3 tonal palette; they are semantic overrides. // These are NOT part of the M3 tonal palette; they are semantic overrides.
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
:root { :root {
// --- Tactical Dark Mode color palette (CUB-47) ---
--color-surface: #0F172A;
--color-surface-light: #1E293B;
--color-primary: #38BDF8;
--color-secondary: #2DD4BF;
--color-accent: #A78BFA;
--color-danger: #F87171;
--color-text-primary: #FFFFFF;
--color-text-secondary: #94A3B8;
--color-border: #334155;
// --- Status colors --- // --- Status colors ---
--status-active: #38BDF8; --status-active: #38BDF8;
--status-idle: #2DD4BF; --status-idle: #2DD4BF;
@@ -90,7 +101,7 @@ html {
// Global Body Styles // Global Body Styles
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
body { body {
background-color: var(--cc-background); background-color: var(--color-surface);
color: var(--cc-on-surface); color: var(--cc-on-surface);
font-family: 'Inter', 'Roboto', sans-serif; font-family: 'Inter', 'Roboto', sans-serif;
margin: 0; margin: 0;