From 22c8dcdec9c421f855d1d0148d65b19a2e1deba0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=BDiga=20Kokelj?= Date: Mon, 9 Dec 2024 14:36:56 +0100 Subject: [PATCH] refresh when new account is added to improve UX (#2191) --- .../components/providers/wallet-provider.tsx | 30 ++++++++++++------- 1 file changed, 20 insertions(+), 10 deletions(-) diff --git a/tools/walletextension/frontend/src/components/providers/wallet-provider.tsx b/tools/walletextension/frontend/src/components/providers/wallet-provider.tsx index 81ab3481ba..11c77be0af 100644 --- a/tools/walletextension/frontend/src/components/providers/wallet-provider.tsx +++ b/tools/walletextension/frontend/src/components/providers/wallet-provider.tsx @@ -67,9 +67,9 @@ export const WalletConnectionProvider = ({ setVersion(await fetchVersion()); } catch (error) { showToast( - ToastType.DESTRUCTIVE, - error instanceof Error ? error.message : "Error initializing wallet connection. Please refresh the page." - ); + ToastType.DESTRUCTIVE, + error instanceof Error ? error.message : "Error initializing wallet connection. Please refresh the page." + ); } finally { setLoading(false); } @@ -189,16 +189,26 @@ export const WalletConnectionProvider = ({ setProvider(providerInstance); initialize(providerInstance); - ethereum.on("accountsChanged", fetchUserAccounts); + const handleAccountsChanged = async (accounts: string[]) => { + if (accounts.length === 0) { + setAccounts(null); + setWalletConnected(false); + setToken(""); + } else { + window.location.reload(); + } + }; + + ethereum.on("accountsChanged", handleAccountsChanged); + + return () => { + if (ethereum && ethereum.removeListener) { + ethereum.removeListener("accountsChanged", handleAccountsChanged); + } + }; } else { setLoading(false); } - - return () => { - if (ethereum && ethereum.removeListener) { - ethereum.removeListener("accountsChanged", fetchUserAccounts); - } - }; // eslint-disable-next-line react-hooks/exhaustive-deps }, []);