LiveActivitySettingsRootView.swift 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. import ActivityKit
  2. import SwiftUI
  3. import Swinject
  4. extension LiveActivitySettings {
  5. struct RootView: BaseView {
  6. let resolver: Resolver
  7. @StateObject var state = StateModel()
  8. @State private var shouldDisplayHint: Bool = false
  9. @State var hintDetent = PresentationDetent.large
  10. @State var selectedVerboseHint: AnyView?
  11. @State var hintLabel: String?
  12. @State private var decimalPlaceholder: Decimal = 0.0
  13. @State private var booleanPlaceholder: Bool = false
  14. @State private var systemLiveActivitySetting: Bool = {
  15. if #available(iOS 16.2, *) {
  16. ActivityAuthorizationInfo().areActivitiesEnabled
  17. } else {
  18. false
  19. }
  20. }()
  21. @Environment(\.colorScheme) var colorScheme
  22. private var color: LinearGradient {
  23. colorScheme == .dark ? LinearGradient(
  24. gradient: Gradient(colors: [
  25. Color.bgDarkBlue,
  26. Color.bgDarkerDarkBlue
  27. ]),
  28. startPoint: .top,
  29. endPoint: .bottom
  30. )
  31. :
  32. LinearGradient(
  33. gradient: Gradient(colors: [Color.gray.opacity(0.1)]),
  34. startPoint: .top,
  35. endPoint: .bottom
  36. )
  37. }
  38. var body: some View {
  39. List {
  40. if !systemLiveActivitySetting {
  41. Section(
  42. header: Text("Display Live Data From Trio"),
  43. content: {
  44. Text("Live Activities must be enabled under iOS Settings to allow Trio to display live data.")
  45. }
  46. ).listRowBackground(Color.chart)
  47. Section {
  48. Button {
  49. UIApplication.shared.open(URL(string: UIApplication.openSettingsURLString)!)
  50. }
  51. label: { Label("Open iOS Settings", systemImage: "gear.circle").font(.title3).padding() }
  52. .frame(maxWidth: .infinity, alignment: .center)
  53. .buttonStyle(.bordered)
  54. }
  55. .listRowBackground(Color.clear)
  56. } else {
  57. SettingInputSection(
  58. decimalValue: $decimalPlaceholder,
  59. booleanValue: $state.useLiveActivity,
  60. shouldDisplayHint: $shouldDisplayHint,
  61. selectedVerboseHint: Binding(
  62. get: { selectedVerboseHint },
  63. set: {
  64. selectedVerboseHint = $0.map { AnyView($0) }
  65. hintLabel = "Enable Live Activity"
  66. }
  67. ),
  68. units: state.units,
  69. type: .boolean,
  70. label: "Enable Live Activity",
  71. miniHint: "Live Activities display Trio's glucose readings and other current data on the iPhone Lock Screen and in the Dynamic Island",
  72. verboseHint: VStack {
  73. Text("""
  74. With Live Activities, Trio displays your choice of the following current data on your iPhone's Lock Screen and in the Dynamic Island:
  75. ● Current Glucose Reading
  76. ● IOB: Insulin On Board
  77. ● COB: Carbohydrates On Board
  78. ● Last Updated: Time of Last Loop Cycle
  79. ● Glucose Trend Chart
  80. It allows you to refer to live information at a glance and perform quick actions in your diabetes management.
  81. """)
  82. },
  83. headerText: "Display Live Data From Trio"
  84. )
  85. if state.useLiveActivity {
  86. Section {
  87. VStack {
  88. Picker(
  89. selection: $state.lockScreenView,
  90. label: Text("Lock Screen Widget Style")
  91. ) {
  92. ForEach(LockScreenView.allCases) { selection in
  93. Text(selection.displayName).tag(selection)
  94. }
  95. }.padding(.top)
  96. HStack(alignment: .top) {
  97. Text(
  98. "Trio Live Activities can be simplistic or detailed in their information display. See hint for more details."
  99. )
  100. .font(.footnote)
  101. .foregroundColor(.secondary)
  102. .lineLimit(nil)
  103. Spacer()
  104. Button(
  105. action: {
  106. hintLabel = "Lock Screen Widget Style"
  107. selectedVerboseHint =
  108. AnyView(
  109. Text("""
  110. Trio's Simple Lock Screen Widget only display current glucose reading, trend arrow, delta and the timestamp of the current reading.
  111. The Detailed Lock Screen Widget offers users a glucose chart as well as the ability to customize the information provided in the Detailed Widget using the following options:
  112. ● Current Glucose Reading
  113. ● IOB: Insulin On Board
  114. ● COB: Carbohydrates On Board
  115. ● Last Updated: Time of Last Loop Cycle
  116. """)
  117. )
  118. shouldDisplayHint.toggle()
  119. },
  120. label: {
  121. HStack {
  122. Image(systemName: "questionmark.circle")
  123. }
  124. }
  125. ).buttonStyle(BorderlessButtonStyle())
  126. }.padding(.top)
  127. }.padding(.bottom)
  128. if state.lockScreenView == .detailed {
  129. HStack {
  130. NavigationLink(
  131. "Widget Configuration",
  132. destination: LiveActivityWidgetConfiguration(
  133. resolver: resolver,
  134. state: state
  135. )
  136. ).foregroundStyle(Color.accentColor)
  137. }
  138. }
  139. }.listRowBackground(Color.chart)
  140. }
  141. }
  142. }
  143. .onReceive(resolver.resolve(LiveActivityBridge.self)!.$systemEnabled, perform: {
  144. self.systemLiveActivitySetting = $0
  145. })
  146. .sheet(isPresented: $shouldDisplayHint) {
  147. SettingInputHintView(
  148. hintDetent: $hintDetent,
  149. shouldDisplayHint: $shouldDisplayHint,
  150. hintLabel: hintLabel ?? "",
  151. hintText: selectedVerboseHint ?? AnyView(EmptyView()),
  152. sheetTitle: "Help"
  153. )
  154. }
  155. .scrollContentBackground(.hidden).background(color)
  156. .onAppear(perform: configureView)
  157. .navigationTitle("Live Activity")
  158. .navigationBarTitleDisplayMode(.automatic)
  159. }
  160. }
  161. }