From 283f7bb04c048f0a3afa6deafaa0d7e0586d9392 Mon Sep 17 00:00:00 2001 From: Stephen Heaps Date: Fri, 10 Nov 2023 16:45:25 -0500 Subject: [PATCH] Fix invalid presentation over panel while loading. --- .../BraveWallet/Panels/WalletPanelView.swift | 37 +++++++++++++++---- 1 file changed, 30 insertions(+), 7 deletions(-) diff --git a/Sources/BraveWallet/Panels/WalletPanelView.swift b/Sources/BraveWallet/Panels/WalletPanelView.swift index 09707428bde..9a7945f99be 100644 --- a/Sources/BraveWallet/Panels/WalletPanelView.swift +++ b/Sources/BraveWallet/Panels/WalletPanelView.swift @@ -146,14 +146,20 @@ public struct WalletPanelContainerView: View { } } .frame(idealWidth: 320, maxWidth: .infinity) - .onChange(of: keyringStore.isWalletCreated) { newValue in - if visibleScreen != .panel, !keyringStore.lockedManually { - presentWalletWithContext?(.panelUnlockOrSetup) - } - } .onChange(of: keyringStore.isWalletLocked) { newValue in - if visibleScreen != .panel, !keyringStore.lockedManually { - presentWalletWithContext?(.panelUnlockOrSetup) + guard keyringStore.isLoaded, newValue, !keyringStore.lockedManually else { return } + // Wallet was auto-locked with panel open + presentWalletWithContext?(.panelUnlockOrSetup) + } + .onChange(of: keyringStore.isLoaded) { newValue in + guard newValue else { return } // KeyringStore loaded + handleKeyringStoreLoaded() + } + .onAppear { + if keyringStore.isLoaded { + // If KeyringStore is loaded prior to view appearing on + // screen onChange won't be executed + handleKeyringStoreLoaded() } } .environment( @@ -163,6 +169,23 @@ public struct WalletPanelContainerView: View { return .handled })) } + + /// Flag to help prevent race condition between panel appearing on screen and KeyringStore `isLoaded`. + @State private var didHandleKeyringLoaded: Bool = false + /// Present unlock if displayed locked state (unless manually locked), or onboarding if displaying + /// onboarding state + private func handleKeyringStoreLoaded() { + guard !didHandleKeyringLoaded else { return } + didHandleKeyringLoaded = true + if visibleScreen == .onboarding { + // automatically open full wallet when displaying onboarding + presentWalletWithContext?(.panelUnlockOrSetup) + } else if visibleScreen == .unlock, !keyringStore.lockedManually { + // automatically open full unlock wallet view when displaying + // locked panel unless user locked manually + presentWalletWithContext?(.panelUnlockOrSetup) + } + } } struct WalletPanelView: View {