CGMStateModel.swift 3.8 KB

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