CGMStateModel.swift 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. import CGMBLEKit
  2. import Combine
  3. import G7SensorKit
  4. import LoopKitUI
  5. import SwiftUI
  6. extension CGM {
  7. final class StateModel: BaseStateModel<Provider> {
  8. @Injected() var cgmManager: FetchGlucoseManager!
  9. @Injected() var calendarManager: CalendarManager!
  10. @Published var setupCGM: Bool = false
  11. @Published var cgm: CGMType = .nightscout
  12. // @Published var transmitterID = ""
  13. @Published var uploadGlucose = true
  14. @Published var smoothGlucose = false
  15. @Published var createCalendarEvents = false
  16. @Published var calendarIDs: [String] = []
  17. @Published var currentCalendarID: String = ""
  18. @Persisted(key: "CalendarManager.currentCalendarID") var storedCalendarID: String? = nil
  19. @Published var cgmTransmitterDeviceAddress: String? = nil
  20. override func subscribe() {
  21. cgm = settingsManager.settings.cgm
  22. currentCalendarID = storedCalendarID ?? ""
  23. calendarIDs = calendarManager.calendarIDs()
  24. cgmTransmitterDeviceAddress = UserDefaults.standard.cgmTransmitterDeviceAddress
  25. subscribeSetting(\.useCalendar, on: $createCalendarEvents) { createCalendarEvents = $0 }
  26. subscribeSetting(\.smoothGlucose, on: $smoothGlucose, initial: { smoothGlucose = $0 })
  27. $cgm
  28. .removeDuplicates()
  29. .sink { [weak self] value in
  30. guard let self = self else { return }
  31. guard self.cgmManager.cgmGlucoseSourceType != nil else {
  32. self.settingsManager.settings.cgm = .nightscout
  33. return
  34. }
  35. self.settingsManager.settings.cgm = value
  36. }
  37. .store(in: &lifetime)
  38. $createCalendarEvents
  39. .removeDuplicates()
  40. .flatMap { [weak self] ok -> AnyPublisher<Bool, Never> in
  41. guard ok, let self = self else { return Just(false).eraseToAnyPublisher() }
  42. return self.calendarManager.requestAccessIfNeeded()
  43. }
  44. .map { [weak self] ok -> [String] in
  45. guard ok, let self = self else { return [] }
  46. return self.calendarManager.calendarIDs()
  47. }
  48. .receive(on: DispatchQueue.main)
  49. .weakAssign(to: \.calendarIDs, on: self)
  50. .store(in: &lifetime)
  51. $currentCalendarID
  52. .removeDuplicates()
  53. .sink { [weak self] id in
  54. guard id.isNotEmpty else {
  55. self?.calendarManager.currentCalendarID = nil
  56. return
  57. }
  58. self?.calendarManager.currentCalendarID = id
  59. }
  60. .store(in: &lifetime)
  61. }
  62. }
  63. }
  64. extension CGM.StateModel: CompletionDelegate {
  65. func completionNotifyingDidComplete(_: CompletionNotifying) {
  66. setupCGM = false
  67. // if CGM was deleted
  68. if cgmManager.cgmGlucoseSourceType == nil {
  69. cgm = .nightscout
  70. }
  71. // refresh the upload options
  72. uploadGlucose = settingsManager.settings.uploadGlucose
  73. cgmManager.updateGlucoseSource()
  74. }
  75. }
  76. extension CGM.StateModel: CGMManagerOnboardingDelegate {
  77. func cgmManagerOnboarding(didCreateCGMManager manager: LoopKitUI.CGMManagerUI) {
  78. // Possibility add the dexcom number !
  79. if let dexcomG6Manager: G6CGMManager = manager as? G6CGMManager {
  80. UserDefaults.standard.dexcomTransmitterID = dexcomG6Manager.transmitter.ID
  81. } else if let dexcomG5Manager: G5CGMManager = manager as? G5CGMManager {
  82. UserDefaults.standard.dexcomTransmitterID = dexcomG5Manager.transmitter.ID
  83. }
  84. cgmManager.updateGlucoseSource()
  85. }
  86. func cgmManagerOnboarding(didOnboardCGMManager _: LoopKitUI.CGMManagerUI) {
  87. // nothing to do ?
  88. }
  89. }