dimensionhub/dimensionhub/Views/DateNavView.swift
2025-02-20 16:20:12 +08:00

104 lines
2.8 KiB
Swift

//
// DateNavView.swift
// dimensionhub
//
// Created by on 2025/2/20.
//
import Foundation
import SwiftUI
struct DateNavView: View {
//
struct DateModel: Codable {
struct Month: Codable {
let name: String
let disabled: Bool
}
let year: String
let months: [Month]
}
@State var dateModels: [DateModel] = []
var body: some View {
VStack(alignment: .center) {
ForEach(dateModels, id: \.year) { item in
VStack(alignment: .leading, spacing: 10) {
Text(item.year)
HStack {
ForEach(item.months, id: \.name) { month in
if month.disabled {
DateDisabledItemView(datetime: month.name)
} else {
DateItemView(datetime: month.name, selected: false)
}
}
}
}
}
}
.task {
let response = await API.getDateIndex(as: [DateNavView.DateModel].self)
switch response {
case .error(let code, let message):
print(code)
print(message)
case .result(let result):
print(result)
self.dateModels = result
}
}
}
}
extension DateNavView {
struct DateItemView: View {
let datetime: String
let selected: Bool
var body: some View {
Rectangle()
.frame(width: 80, height: 50)
.foregroundColor(selected ? Color.black : Color.white)
.cornerRadius(10)
.overlay {
RoundedRectangle(cornerRadius: 10)
.stroke(Color.black, lineWidth: 1)
Text(datetime)
.foregroundColor(selected ? Color.white : Color.black)
.font(.system(size: 20, weight: .regular))
}
}
}
struct DateDisabledItemView: View {
let datetime: String
var body: some View {
Rectangle()
.frame(width: 80, height: 50)
.foregroundColor(Color.white)
.cornerRadius(10)
.overlay {
RoundedRectangle(cornerRadius: 10)
.stroke(style: StrokeStyle(lineWidth: 1, dash: [4]))
Text(datetime)
.foregroundColor(Color.yellow)
.font(.system(size: 20, weight: .regular))
}
}
}
}
#Preview {
DateNavView()
}