104 lines
2.8 KiB
Swift
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()
|
|
}
|