| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- import Charts
- import CoreData
- import SwiftDate
- import SwiftUI
- import Swinject
- extension Stat {
- struct RootView: BaseView {
- let resolver: Resolver
- @StateObject var state = StateModel()
- @FetchRequest(
- entity: TDD.entity(),
- sortDescriptors: [NSSortDescriptor(key: "timestamp", ascending: false)]
- ) var fetchedTDD: FetchedResults<TDD>
- @FetchRequest(
- entity: InsulinDistribution.entity(),
- sortDescriptors: [NSSortDescriptor(key: "date", ascending: false)]
- ) var fetchedInsulin: FetchedResults<InsulinDistribution>
- @Environment(\.colorScheme) var colorScheme
- enum Duration: String, CaseIterable, Identifiable {
- case Today
- case Day
- case Week
- case Month
- case Total
- var id: Self { self }
- }
- @State private var selectedDuration: Duration = .Today
- @State var paddingAmount: CGFloat? = 10
- @State var headline: Color = .secondary
- @State var days: Double = 0
- @State var pointSize: CGFloat = 3
- @State var conversionFactor = 0.0555
- private var color: LinearGradient {
- colorScheme == .dark ? LinearGradient(
- gradient: Gradient(colors: [
- Color.bgDarkBlue,
- Color.bgDarkerDarkBlue
- ]),
- startPoint: .top,
- endPoint: .bottom
- )
- :
- LinearGradient(
- gradient: Gradient(colors: [Color.gray.opacity(0.1)]),
- startPoint: .top,
- endPoint: .bottom
- )
- }
- @ViewBuilder func stats() -> some View {
- ZStack {
- Color.gray.opacity(0.05).ignoresSafeArea(.all)
- let filter = DateFilter()
- switch selectedDuration {
- case .Today:
- StatsView(
- filter: filter.today,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit
- )
- case .Day:
- StatsView(
- filter: filter.day,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit
- )
- case .Week:
- StatsView(
- filter: filter.week,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit
- )
- case .Month:
- StatsView(
- filter: filter.month,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit
- )
- case .Total:
- StatsView(
- filter: filter.total,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit
- )
- }
- }
- }
- @ViewBuilder func chart() -> some View {
- let filter = DateFilter()
- switch selectedDuration {
- case .Today:
- ChartsView(
- filter: filter.today,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit,
- $state.layingChart
- )
- case .Day:
- ChartsView(
- filter: filter.day,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit,
- $state.layingChart
- )
- case .Week:
- ChartsView(
- filter: filter.week,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit,
- $state.layingChart
- )
- case .Month:
- ChartsView(
- filter: filter.month,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit,
- $state.layingChart
- )
- case .Total:
- ChartsView(
- filter: filter.total,
- $state.highLimit,
- $state.lowLimit,
- $state.units,
- $state.overrideUnit,
- $state.layingChart
- )
- }
- }
- var body: some View {
- VStack(alignment: .center) {
- chart().padding(.top, 20)
- Picker("Duration", selection: $selectedDuration) {
- ForEach(Duration.allCases) { duration in
- Text(NSLocalizedString(duration.rawValue, comment: "")).tag(Optional(duration))
- }
- }
- .pickerStyle(.segmented).background(.cyan.opacity(0.2))
- stats()
- }.background(color)
- .onAppear(perform: configureView)
- .navigationBarTitle("Statistics")
- .navigationBarTitleDisplayMode(.inline)
- .toolbar {
- ToolbarItem(placement: .topBarLeading) {
- Button("Close") {
- state.hideModal()
- }
- }
- }
- }
- }
- }
|