NotificationsConfigStateModel.swift 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. import SwiftUI
  2. extension NotificationsConfig {
  3. final class StateModel: BaseStateModel<Provider> {
  4. @Published var glucoseBadge = false
  5. @Published var glucoseNotificationsAlways = false
  6. @Published var useAlarmSound = false
  7. @Published var addSourceInfoToGlucoseNotifications = false
  8. @Published var lowGlucose: Decimal = 0
  9. @Published var highGlucose: Decimal = 0
  10. @Published var carbsRequiredThreshold: Decimal = 0
  11. var units: GlucoseUnits = .mmolL
  12. override func subscribe() {
  13. let units = settingsManager.settings.units
  14. self.units = units
  15. subscribeSetting(\.glucoseBadge, on: $glucoseBadge) { glucoseBadge = $0 }
  16. subscribeSetting(\.glucoseNotificationsAlways, on: $glucoseNotificationsAlways) { glucoseNotificationsAlways = $0 }
  17. subscribeSetting(\.useAlarmSound, on: $useAlarmSound) { useAlarmSound = $0 }
  18. subscribeSetting(\.addSourceInfoToGlucoseNotifications, on: $addSourceInfoToGlucoseNotifications) {
  19. addSourceInfoToGlucoseNotifications = $0 }
  20. subscribeSetting(\.lowGlucose, on: $lowGlucose, initial: {
  21. let value = max(min($0, 400), 40)
  22. lowGlucose = units == .mmolL ? value.asMmolL : value
  23. }, map: {
  24. guard units == .mmolL else { return $0 }
  25. return $0.asMgdL
  26. })
  27. subscribeSetting(\.highGlucose, on: $highGlucose, initial: {
  28. let value = max(min($0, 400), 40)
  29. highGlucose = units == .mmolL ? value.asMmolL : value
  30. }, map: {
  31. guard units == .mmolL else { return $0 }
  32. return $0.asMgdL
  33. })
  34. subscribeSetting(
  35. \.carbsRequiredThreshold,
  36. on: $carbsRequiredThreshold
  37. ) { carbsRequiredThreshold = $0 }
  38. }
  39. }
  40. }