From 4e138ba4582bff940359a27fada31f78a0412b94 Mon Sep 17 00:00:00 2001
From: Stefano Faieta <9802152+stefanofa@users.noreply.github.com>
Date: Thu, 16 Jan 2025 16:26:02 +0100
Subject: [PATCH] feat(react): return isReconnecting from useWallet (#330)
---
docs/guides/react-quick-start.md | 8 +++++++-
packages/use-wallet-react/src/index.tsx | 9 +++++++--
2 files changed, 14 insertions(+), 3 deletions(-)
diff --git a/docs/guides/react-quick-start.md b/docs/guides/react-quick-start.md
index 80f81517..677e7791 100644
--- a/docs/guides/react-quick-start.md
+++ b/docs/guides/react-quick-start.md
@@ -49,7 +49,11 @@ Now, in any component, you can use the `useWallet` hook to access the wallet man
import { useWallet } from '@txnlab/use-wallet-react'
function WalletMenu() {
- const { wallets, activeWallet, activeAccount } = useWallet()
+ const { wallets, activeWallet, activeAccount, isReconnecting } = useWallet()
+
+ if (isReconnecting) {
+ return
Reconnecting to wallet...
+ }
return (
@@ -76,6 +80,8 @@ function WalletMenu() {
}
```
+The `isReconnecting` state is a boolean that helps manage wallet reconnection flows. It starts as `true` during both SSR and initial client-side mounting. During the first mount, the `WalletProvider` automatically attempts to restore any previously connected wallet sessions. Once this reconnection process completes - whether successful or not - `isReconnecting` switches to `false`.
+
## Signing Transactions
To sign and send transactions, you can use the library's `algodClient` instance and the `transactionSigner` provided by the active wallet.
diff --git a/packages/use-wallet-react/src/index.tsx b/packages/use-wallet-react/src/index.tsx
index 6d8e2b4b..a8755a1f 100644
--- a/packages/use-wallet-react/src/index.tsx
+++ b/packages/use-wallet-react/src/index.tsx
@@ -7,6 +7,7 @@ export * from '@txnlab/use-wallet'
interface IWalletContext {
manager: WalletManager
+ isReconnecting: boolean
algodClient: algosdk.Algodv2
setAlgodClient: React.Dispatch>
}
@@ -33,7 +34,7 @@ export const useWallet = () => {
throw new Error('useWallet must be used within the WalletProvider')
}
- const { manager, algodClient, setAlgodClient } = context
+ const { manager, isReconnecting, algodClient, setAlgodClient } = context
const activeNetwork = useStore(manager.store, (state) => state.activeNetwork)
@@ -108,6 +109,7 @@ export const useWallet = () => {
return {
wallets,
+ isReconnecting,
algodClient,
activeNetwork,
activeWallet,
@@ -129,6 +131,7 @@ interface WalletProviderProps {
export const WalletProvider = ({ manager, children }: WalletProviderProps): JSX.Element => {
const [algodClient, setAlgodClient] = React.useState(manager.algodClient)
+ const [isReconnecting, setIsReconnecting] = React.useState(true)
React.useEffect(() => {
manager.algodClient = algodClient
@@ -142,6 +145,8 @@ export const WalletProvider = ({ manager, children }: WalletProviderProps): JSX.
await manager.resumeSessions()
} catch (error) {
console.error('Error resuming sessions:', error)
+ } finally {
+ setIsReconnecting(false)
}
}
@@ -152,7 +157,7 @@ export const WalletProvider = ({ manager, children }: WalletProviderProps): JSX.
}, [manager])
return (
-
+
{children}
)