From db7eb97f3b0f98495ff83d2c1dffbf7283e65169 Mon Sep 17 00:00:00 2001 From: Fabrizio Demaria Date: Fri, 29 Nov 2024 17:29:58 +0100 Subject: [PATCH] feat: Demo app waits for experience --- .../ConfidenceDemoApp/ContentView.swift | 48 ++++++++++++------- .../Helpers/DebugLoggerFake.swift | 8 ++++ 2 files changed, 38 insertions(+), 18 deletions(-) diff --git a/ConfidenceDemoApp/ConfidenceDemoApp/ContentView.swift b/ConfidenceDemoApp/ConfidenceDemoApp/ContentView.swift index 07793c96..6aec74cd 100644 --- a/ConfidenceDemoApp/ConfidenceDemoApp/ContentView.swift +++ b/ConfidenceDemoApp/ConfidenceDemoApp/ContentView.swift @@ -6,34 +6,46 @@ struct ContentView: View { @EnvironmentObject var status: ExperimentationFlags @AppStorage("loggedUser") private var loggedUser: String? @State var isLoggingOut: Bool = false + @State var loggedOut: Bool = false - private let color: Color private let confidence: Confidence init(confidence: Confidence) { self.confidence = confidence - self.color = ContentView.getColor(color: confidence.getValue(key: "swift-demoapp.color", defaultValue: "Gray")) } var body: some View { NavigationStack { - VStack { - Text("Hello World!") - .foregroundStyle(color) - } - .padding() - Button("Logout") { - loggedUser = nil - status.state = .loading - Task { - await confidence.removeContext(key: "user_id") - status.state = .ready + if (status.state == .loading && !isLoggingOut) { + VStack { + Spacer() + Text("Welcome \(loggedUser ?? "?")") + Text("We are preparing your experience...") + ProgressView() + Spacer() + } + } else { + VStack { + Text("Hello World!") + .font(.largeTitle) + .foregroundStyle(ContentView.getColor(color: confidence.getValue(key: "swift-demoapp.color", defaultValue: "Gray"))) + } + .padding() + Button("Logout") { + isLoggingOut = true + + loggedUser = nil + status.state = .loading + Task { + await confidence.removeContext(key: "user_id") + status.state = .ready + } + loggedUser = nil + loggedOut = true + } + .navigationDestination(isPresented: $loggedOut) { + LoginView(confidence: confidence) } - loggedUser = nil - isLoggingOut = true - } - .navigationDestination(isPresented: $isLoggingOut) { - LoginView(confidence: confidence) } } } diff --git a/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift b/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift index 20d24a95..e2a53282 100644 --- a/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift +++ b/Tests/ConfidenceTests/Helpers/DebugLoggerFake.swift @@ -29,6 +29,14 @@ internal class DebugLoggerFake: DebugLogger { // no-op } + func logFlags(action: String, flag: String, resolveToken: String) { + // no-op + } + + func logFlags(action: String, context: ConfidenceStruct) { + // no-op + } + func getUploadBatchSuccessCount() -> Int { return uploadBatchSuccessCounter.get() }