feat(compliance): add AEO compliance frontend
- CompliancePage: team tabs (STEAM/ACCESS-ENG), metric health cards with click-to-filter, device table with Active/Resolved tabs, hostname search, seen-count badges, notes indicator, empty/loading/error states - ComplianceUploadModal: phased flow (idle→upload→preview→commit→done), drag-and-drop xlsx drop zone, diff summary before commit - ComplianceDetailPanel: slide-out panel with failing metrics, surfaced extra fields (CVEs, SLA, OS, Splunk), upload history, notes timeline, per-metric note add with Ctrl+Enter submit - NavDrawer: add Compliance nav item (teal, ShieldCheck icon) - App.js: import and render CompliancePage on compliance route - Fix SQL join bug in compliance route (lu ON upload_id = lu.id) - Fix groupByHostname to use max last_seen across all metric rows
This commit is contained in:
@@ -200,9 +200,10 @@ function groupByHostname(rows, noteHostnames) {
|
||||
});
|
||||
// Use the highest seen_count and earliest first_seen across all metrics
|
||||
if ((row.seen_count || 1) > dev.seen_count) dev.seen_count = row.seen_count;
|
||||
if (row.first_seen && (!dev.first_seen || row.first_seen < dev.first_seen)) {
|
||||
if (row.first_seen && (!dev.first_seen || row.first_seen < dev.first_seen))
|
||||
dev.first_seen = row.first_seen;
|
||||
}
|
||||
if (row.last_seen && (!dev.last_seen || row.last_seen > dev.last_seen))
|
||||
dev.last_seen = row.last_seen;
|
||||
}
|
||||
|
||||
return Object.values(deviceMap);
|
||||
@@ -419,7 +420,7 @@ function createComplianceRouter(db, upload, requireAuth, requireRole) {
|
||||
ru.report_date AS resolved_on
|
||||
FROM compliance_items ci
|
||||
LEFT JOIN compliance_uploads fu ON ci.first_seen_upload_id = fu.id
|
||||
LEFT JOIN compliance_uploads lu ON ci.upload_id = fu.id
|
||||
LEFT JOIN compliance_uploads lu ON ci.upload_id = lu.id
|
||||
LEFT JOIN compliance_uploads ru ON ci.resolved_upload_id = ru.id
|
||||
WHERE ci.team = ? AND ci.status = ?
|
||||
ORDER BY ci.hostname, ci.metric_id`,
|
||||
@@ -466,7 +467,7 @@ function createComplianceRouter(db, upload, requireAuth, requireRole) {
|
||||
ru.report_date AS resolved_on
|
||||
FROM compliance_items ci
|
||||
LEFT JOIN compliance_uploads fu ON ci.first_seen_upload_id = fu.id
|
||||
LEFT JOIN compliance_uploads lu ON ci.upload_id = fu.id
|
||||
LEFT JOIN compliance_uploads lu ON ci.upload_id = lu.id
|
||||
LEFT JOIN compliance_uploads ru ON ci.resolved_upload_id = ru.id
|
||||
WHERE ci.hostname = ?
|
||||
ORDER BY ci.status DESC, ci.metric_id`,
|
||||
|
||||
Reference in New Issue
Block a user