Add live agent views and improve Codex monitoring

This commit is contained in:
William Valentin
2026-03-20 13:59:51 -07:00
parent a87bbc6983
commit 687a7aa79d
10 changed files with 1408 additions and 184 deletions
+356 -1
View File
@@ -475,6 +475,51 @@ tr.expandable:hover .expand-icon::before {
border-top: 1px solid var(--border);
}
.session-run-detail {
background: var(--bg);
padding: 1rem 1.1rem;
border-top: 1px solid var(--border);
}
.session-run-spans {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
}
.session-span-pill {
min-width: 180px;
max-width: 100%;
display: flex;
flex-direction: column;
gap: 0.18rem;
padding: 0.55rem 0.7rem;
border-radius: var(--radius);
border: 1px solid var(--border-soft);
background: var(--surface);
}
.session-span-pill.tool {
border-color: rgba(34, 211, 238, 0.2);
}
.session-span-pill.agent {
border-color: rgba(167, 139, 250, 0.2);
}
.session-span-name {
font-family: var(--font-mono);
font-size: 0.74rem;
color: var(--text-bright);
}
.session-span-meta {
font-size: 0.72rem;
color: var(--text-dim);
line-height: 1.4;
word-break: break-word;
}
/* ── Empty state ───────────────────────────────────────────── */
.empty-state {
text-align: center;
@@ -855,6 +900,12 @@ tr.expandable:hover .expand-icon::before {
font-size: 0.78rem;
}
.timeline-event-body.subagent-name {
font-family: var(--font-mono);
color: var(--purple);
font-size: 0.78rem;
}
.timeline-event-body.message-preview {
color: var(--text-dim);
font-style: italic;
@@ -1340,6 +1391,20 @@ tr.expandable:hover .expand-icon::before {
50% { opacity: 0.5; }
}
.session-status-line {
display: inline-flex;
align-items: center;
gap: 0.45rem;
margin-top: 0.6rem;
font-family: var(--font-mono);
font-size: 0.75rem;
color: var(--text-dim);
}
.session-status-text {
color: var(--text-bright);
}
/* ── Meta tiles ───────────────────────────────────────────── */
.meta-tiles {
display: grid;
@@ -1482,6 +1547,37 @@ tr.expandable:hover .expand-icon::before {
flex-wrap: wrap;
}
.agents-toolbar {
display: flex;
justify-content: flex-end;
margin-bottom: 1rem;
}
.view-toggle {
display: inline-flex;
gap: 0.35rem;
padding: 0.25rem;
background: var(--surface);
border: 1px solid var(--border);
border-radius: 999px;
}
.view-toggle-btn {
border: none;
background: transparent;
color: var(--text-dim);
font-family: var(--font-mono);
font-size: 0.72rem;
padding: 0.45rem 0.8rem;
border-radius: 999px;
cursor: pointer;
}
.view-toggle-btn.active {
background: var(--accent-dim);
color: var(--text-bright);
}
.agents-summary-stat {
background: var(--surface);
border: 1px solid var(--border);
@@ -1502,7 +1598,7 @@ tr.expandable:hover .expand-icon::before {
.agent-lanes {
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
gap: 1.25rem;
}
@@ -1519,6 +1615,7 @@ tr.expandable:hover .expand-icon::before {
display: flex;
flex-direction: column;
overflow: hidden;
cursor: pointer;
}
.agent-lane-header {
@@ -1541,6 +1638,13 @@ tr.expandable:hover .expand-icon::before {
letter-spacing: 0.06em;
}
.agent-lane-meta {
margin-top: 0.2rem;
font-family: var(--font-mono);
font-size: 0.68rem;
color: var(--text-dim);
}
.agent-lane-dot {
width: 7px;
height: 7px;
@@ -1596,6 +1700,11 @@ tr.expandable:hover .expand-icon::before {
border-color: rgba(8, 145, 178, 0.2);
}
.active-op.subagent {
background: rgba(167, 139, 250, 0.12);
border-color: rgba(167, 139, 250, 0.22);
}
.active-op.stale {
opacity: 0.5;
}
@@ -1622,6 +1731,10 @@ tr.expandable:hover .expand-icon::before {
font-weight: 500;
}
.active-op.subagent .active-op-name {
color: var(--purple);
}
.active-op-time {
font-family: var(--font-mono);
color: var(--text-dim);
@@ -1678,6 +1791,239 @@ tr.expandable:hover .expand-icon::before {
font-size: 0.78rem;
}
.agents-live-layout {
display: grid;
grid-template-columns: 300px minmax(0, 1fr);
gap: 1.25rem;
}
.agents-live-sidebar,
.agents-live-main,
.agents-live-card {
background: var(--surface);
border: 1px solid var(--border);
border-radius: var(--radius-lg);
}
.agents-live-sidebar {
padding: 1rem;
align-self: start;
}
.agent-picker {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.agent-picker-item {
width: 100%;
display: flex;
align-items: flex-start;
gap: 0.65rem;
padding: 0.75rem 0.85rem;
background: transparent;
border: 1px solid var(--border-soft);
border-radius: var(--radius);
text-align: left;
cursor: pointer;
color: inherit;
}
.agent-picker-item.active {
border-color: rgba(34, 211, 238, 0.28);
background: var(--accent-dim);
}
.agent-picker-dot {
width: 8px;
height: 8px;
border-radius: 50%;
margin-top: 0.3rem;
flex-shrink: 0;
}
.agent-picker-dot.online {
background: var(--success);
}
.agent-picker-dot.offline {
background: var(--text-dim);
opacity: 0.5;
}
.agent-picker-main {
display: flex;
flex-direction: column;
gap: 0.2rem;
min-width: 0;
}
.agent-picker-name {
font-family: var(--font-display);
font-size: 0.82rem;
font-weight: 700;
color: var(--text-bright);
}
.agent-picker-meta {
font-family: var(--font-mono);
font-size: 0.68rem;
color: var(--text-dim);
}
.agents-live-main {
padding: 1rem;
}
.agents-live-header {
display: flex;
justify-content: space-between;
gap: 1rem;
align-items: flex-start;
margin-bottom: 1rem;
}
.agents-live-badges {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.agents-live-badge {
padding: 0.38rem 0.7rem;
background: var(--surface-2);
border: 1px solid var(--border-soft);
border-radius: 999px;
font-family: var(--font-mono);
font-size: 0.68rem;
color: var(--text-dim);
}
.agents-live-cards {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 1rem;
margin-bottom: 1rem;
}
.agents-live-card {
padding: 1rem;
}
.agents-live-card-title {
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.08em;
color: var(--text-dim);
margin-bottom: 0.75rem;
}
.live-kv {
display: flex;
flex-direction: column;
gap: 0.18rem;
padding: 0.45rem 0;
border-bottom: 1px solid var(--border-soft);
}
.live-kv:last-child {
border-bottom: none;
}
.live-kv span {
font-size: 0.68rem;
color: var(--text-dim);
text-transform: uppercase;
letter-spacing: 0.06em;
}
.live-kv strong {
font-size: 0.8rem;
color: var(--text-bright);
word-break: break-word;
}
.agents-live-timeline {
display: flex;
flex-direction: column;
gap: 0.65rem;
}
.live-run-group {
border: 1px solid var(--border);
border-radius: var(--radius-lg);
background: var(--surface);
overflow: hidden;
}
.live-run-group-header {
display: flex;
justify-content: space-between;
gap: 1rem;
align-items: flex-start;
padding: 0.85rem 1rem;
border-bottom: 1px solid var(--border-soft);
}
.live-run-group-title {
font-family: var(--font-display);
font-size: 0.9rem;
font-weight: 700;
color: var(--text-bright);
}
.live-run-group-meta {
display: flex;
flex-wrap: wrap;
gap: 0.65rem;
font-family: var(--font-mono);
font-size: 0.68rem;
color: var(--text-dim);
}
.live-run-events {
display: flex;
flex-direction: column;
gap: 0.65rem;
padding: 0.8rem;
}
.live-event {
padding: 0.8rem 1rem;
}
.live-detail-grid {
display: flex;
flex-direction: column;
gap: 0.3rem;
margin-top: 0.55rem;
}
.live-detail-row {
display: grid;
grid-template-columns: 64px minmax(0, 1fr);
gap: 0.6rem;
font-size: 0.74rem;
}
.live-detail-row .k {
font-family: var(--font-mono);
color: var(--text-dim);
text-transform: uppercase;
}
.live-detail-row .v {
color: var(--text);
word-break: break-word;
}
.live-detail-row.ids .v {
font-family: var(--font-mono);
color: var(--text-dim);
}
/* ── Mobile layout ────────────────────────────────────────── */
@media (max-width: 640px) {
main {
@@ -1692,6 +2038,15 @@ tr.expandable:hover .expand-icon::before {
padding: 0.375rem 0.5rem;
font-size: 0.75rem;
}
.agents-live-layout,
.agents-live-cards {
grid-template-columns: 1fr;
}
.agents-live-header {
flex-direction: column;
}
}
@media (max-width: 480px) {