CGMStateModel.swift 3.9 KB

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