|
Bogdan Timofte
authored
a week ago
|
1
|
//
|
|
|
2
|
// MeterOverviewSectionView.swift
|
|
|
3
|
// USB Meter
|
|
|
4
|
//
|
|
|
5
|
// Created by Bogdan Timofte on 29/03/2026.
|
|
|
6
|
// Co-authored-by: GPT-5.3-Codex.
|
|
|
7
|
// Copyright © 2026 Bogdan Timofte. All rights reserved.
|
|
|
8
|
//
|
|
|
9
|
|
|
|
10
|
import SwiftUI
|
|
|
11
|
|
|
|
12
|
struct MeterOverviewSectionView: View {
|
|
|
13
|
let meter: Meter
|
|
|
14
|
|
|
|
15
|
var body: some View {
|
|
|
16
|
VStack(spacing: 14) {
|
|
|
17
|
MeterInfoCardView(title: "Overview", tint: meter.color) {
|
|
|
18
|
MeterInfoRowView(label: "Name", value: meter.name)
|
|
|
19
|
MeterInfoRowView(label: "Device Model", value: meter.deviceModelName)
|
|
|
20
|
MeterInfoRowView(label: "Advertised Model", value: meter.modelString)
|
|
|
21
|
MeterInfoRowView(label: "MAC", value: meter.btSerial.macAddress.description)
|
|
|
22
|
if meter.modelNumber != 0 {
|
|
|
23
|
MeterInfoRowView(label: "Model Identifier", value: "\(meter.modelNumber)")
|
|
|
24
|
}
|
|
|
25
|
MeterInfoRowView(label: "Working Voltage", value: meter.documentedWorkingVoltage)
|
|
|
26
|
MeterInfoRowView(label: "Temperature Unit", value: meter.temperatureUnitDescription)
|
|
|
27
|
MeterInfoRowView(label: "Last Seen", value: meterHistoryText(for: meter.lastSeen))
|
|
|
28
|
MeterInfoRowView(label: "Last Connected", value: meterHistoryText(for: meter.lastConnectedAt))
|
|
|
29
|
if meter.operationalState == .dataIsAvailable {
|
|
|
30
|
if !meter.firmwareVersion.isEmpty {
|
|
|
31
|
MeterInfoRowView(label: "Firmware", value: meter.firmwareVersion)
|
|
|
32
|
}
|
|
|
33
|
if meter.serialNumber != 0 {
|
|
|
34
|
MeterInfoRowView(label: "Serial", value: "\(meter.serialNumber)")
|
|
|
35
|
}
|
|
|
36
|
if meter.bootCount != 0 {
|
|
|
37
|
MeterInfoRowView(label: "Boot Count", value: "\(meter.bootCount)")
|
|
|
38
|
}
|
|
|
39
|
} else {
|
|
|
40
|
Text("Connect to the meter to load firmware, serial, and boot details.")
|
|
|
41
|
.font(.footnote)
|
|
|
42
|
.foregroundColor(.secondary)
|
|
|
43
|
.multilineTextAlignment(.leading)
|
|
|
44
|
}
|
|
|
45
|
}
|
|
|
46
|
|
|
|
47
|
}
|
|
|
48
|
.padding(.horizontal, 12)
|
|
|
49
|
}
|
|
|
50
|
|
|
|
51
|
private func meterHistoryText(for date: Date?) -> String {
|
|
|
52
|
guard let date else {
|
|
|
53
|
return "Never"
|
|
|
54
|
}
|
|
|
55
|
return date.format(as: "yyyy-MM-dd HH:mm")
|
|
|
56
|
}
|
|
|
57
|
}
|