SettingsStateModel.swift 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. import LoopKit
  2. import LoopKitUI
  3. import SwiftUI
  4. extension Settings {
  5. final class StateModel: BaseStateModel<Provider> {
  6. @Injected() private var broadcaster: Broadcaster!
  7. @Injected() private var fileManager: FileManager!
  8. @Injected() private var nightscoutManager: NightscoutManager!
  9. @Injected() var pluginManager: PluginManager!
  10. @Injected() var fetchCgmManager: FetchGlucoseManager!
  11. @Published var closedLoop = false
  12. @Published var debugOptions = false
  13. @Published var animatedBackground = false
  14. @Published var serviceUIType: ServiceUI.Type?
  15. @Published var setupTidepool = false
  16. private(set) var buildNumber = ""
  17. private(set) var versionNumber = ""
  18. private(set) var branch = ""
  19. private(set) var copyrightNotice = ""
  20. override func subscribe() {
  21. subscribeSetting(\.debugOptions, on: $debugOptions) { debugOptions = $0 }
  22. subscribeSetting(\.closedLoop, on: $closedLoop) { closedLoop = $0 }
  23. broadcaster.register(SettingsObserver.self, observer: self)
  24. buildNumber = Bundle.main.infoDictionary?["CFBundleVersion"] as? String ?? "Unknown"
  25. versionNumber = Bundle.main.infoDictionary?["CFBundleShortVersionString"] as? String ?? "Unknown"
  26. branch = BuildDetails.default.branchAndSha
  27. copyrightNotice = Bundle.main.infoDictionary?["NSHumanReadableCopyright"] as? String ?? ""
  28. subscribeSetting(\.animatedBackground, on: $animatedBackground) { animatedBackground = $0 }
  29. serviceUIType = pluginManager.getServiceTypeByIdentifier("TidepoolService")
  30. }
  31. func logItems() -> [URL] {
  32. var items: [URL] = []
  33. if fileManager.fileExists(atPath: SimpleLogReporter.logFile) {
  34. items.append(URL(fileURLWithPath: SimpleLogReporter.logFile))
  35. }
  36. if fileManager.fileExists(atPath: SimpleLogReporter.logFilePrev) {
  37. items.append(URL(fileURLWithPath: SimpleLogReporter.logFilePrev))
  38. }
  39. return items
  40. }
  41. func uploadProfileAndSettings(_ force: Bool) {
  42. NSLog("SettingsState Upload Profile and Settings")
  43. nightscoutManager.uploadProfileAndSettings(force)
  44. }
  45. func hideSettingsModal() {
  46. hideModal()
  47. }
  48. func resetLoopDocuments() {
  49. guard let localDocuments = try? FileManager.default.url(
  50. for: .documentDirectory,
  51. in: .userDomainMask,
  52. appropriateFor: nil,
  53. create: true
  54. ) else {
  55. preconditionFailure("Could not get a documents directory URL.")
  56. }
  57. let storageURL = localDocuments.appendingPathComponent("PumpManagerState" + ".plist")
  58. try? FileManager.default.removeItem(at: storageURL)
  59. }
  60. }
  61. }
  62. extension Settings.StateModel: SettingsObserver {
  63. func settingsDidChange(_ settings: FreeAPSSettings) {
  64. closedLoop = settings.closedLoop
  65. debugOptions = settings.debugOptions
  66. }
  67. }
  68. extension Settings.StateModel: ServiceOnboardingDelegate {
  69. func serviceOnboarding(didCreateService service: Service) {
  70. debug(.nightscout, "Service with identifier \(service.pluginIdentifier) created")
  71. provider.tidepoolManager.addTidepoolService(service: service)
  72. }
  73. func serviceOnboarding(didOnboardService service: Service) {
  74. precondition(service.isOnboarded)
  75. debug(.nightscout, "Service with identifier \(service.pluginIdentifier) onboarded")
  76. }
  77. }
  78. extension Settings.StateModel: CompletionDelegate {
  79. func completionNotifyingDidComplete(_: CompletionNotifying) {
  80. setupTidepool = false
  81. provider.tidepoolManager.forceUploadData(device: fetchCgmManager.cgmManager?.cgmManagerStatus.device)
  82. }
  83. }