chore(tui): visual polish — detail sections, column headers, alert detail #37

Merged
lerko merged 20 commits from chore/ux-polish into main 2026-05-28 20:40:29 +00:00
Showing only changes of commit a84f4894f8 - Show all commits
+12 -8
View File
@@ -57,7 +57,7 @@ func fmtMaintMonitorW(monitorID int, sites []models.Site, maxW int) string {
return fmt.Sprintf("#%d", monitorID)
}
func fmtMaintTime(t time.Time) string {
func fmtMaintTime(t time.Time, colW int) string {
if t.IsZero() {
return subtleStyle.Render("—")
}
@@ -65,7 +65,10 @@ func fmtMaintTime(t time.Time) string {
if t.Year() == now.Year() && t.YearDay() == now.YearDay() {
return t.Format("15:04")
}
if colW >= 14 {
return t.Format("15:04 Jan 02")
}
return t.Format("Jan 02")
}
func (m Model) isMonitorInMaintenance(monitorID int) bool {
@@ -99,16 +102,17 @@ func (m Model) viewMaintTab() string {
cols := []colDef{
{"#", "#", 4, 4, false},
{"TITLE", "TITLE", 10, 28, true},
{"TITLE", "TITLE", 12, 24, false},
{"TYPE", "TYPE", 13, 14, false},
{"MON", "MONITORS", 10, 22, false},
{"ST", "STATUS", 8, 12, false},
{"START", "STARTED", 8, 16, false},
{"ENDS", "ENDS", 8, 16, false},
{"MON", "MONITORS", 14, 22, true},
{"ST", "STATUS", 11, 12, false},
{"START", "STARTED", 14, 16, false},
{"ENDS", "ENDS", 14, 16, false},
}
headers, widths := m.computeTableLayout(cols, 0)
titleW := widths[1]
monW := widths[3]
timeW := widths[5]
return m.renderTable(
headers,
@@ -124,8 +128,8 @@ func (m Model) viewMaintTab() string {
fmtMaintType(mw.Type),
fmtMaintMonitorW(mw.MonitorID, allSites, monW-2),
fmtMaintStatus(mw),
fmtMaintTime(mw.StartTime),
fmtMaintTime(mw.EndTime),
fmtMaintTime(mw.StartTime, timeW),
fmtMaintTime(mw.EndTime, timeW),
})
}
return rows