From a4621a199ac3898b0b3f6e910c39275db5897c54 Mon Sep 17 00:00:00 2001 From: Gancho Radkov Date: Mon, 15 Jan 2024 14:47:40 +0200 Subject: [PATCH 1/2] fix: implements dynamic session list --- .../src/hooks/useWalletConnectEventsManager.ts | 7 ++++++- .../wallets/react-wallet-v2/src/pages/sessions.tsx | 7 ++++--- .../react-wallet-v2/src/store/SettingsStore.ts | 11 ++++++++--- .../src/views/SessionProposalModal.tsx | 2 ++ 4 files changed, 20 insertions(+), 7 deletions(-) diff --git a/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts b/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts index c0c7629ef..81984d6f5 100644 --- a/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts +++ b/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts @@ -125,7 +125,12 @@ export default function useWalletConnectEventsManager(initialized: boolean) { web3wallet.on('auth_request', onAuthRequest) // TODOs web3wallet.engine.signClient.events.on('session_ping', data => console.log('ping', data)) - web3wallet.on('session_delete', data => console.log('delete', data)) + web3wallet.on('session_delete', data => { + console.log('delete', data) + SettingsStore.setSessions(Object.values(web3wallet.getActiveSessions())) + }) + // load sessions on init + SettingsStore.setSessions(Object.values(web3wallet.getActiveSessions())) } }, [initialized, onAuthRequest, onSessionProposal, onSessionRequest]) } diff --git a/advanced/wallets/react-wallet-v2/src/pages/sessions.tsx b/advanced/wallets/react-wallet-v2/src/pages/sessions.tsx index cd785f729..f51c8bc9b 100644 --- a/advanced/wallets/react-wallet-v2/src/pages/sessions.tsx +++ b/advanced/wallets/react-wallet-v2/src/pages/sessions.tsx @@ -1,11 +1,12 @@ import PageHeader from '@/components/PageHeader' import SessionCard from '@/components/SessionCard' -import { web3wallet } from '@/utils/WalletConnectUtil' +import SettingsStore from '@/store/SettingsStore' import { Text } from '@nextui-org/react' -import { Fragment, useState } from 'react' +import { Fragment } from 'react' +import { useSnapshot } from 'valtio' export default function SessionsPage() { - const [sessions] = useState(Object.values(web3wallet.getActiveSessions())) + const { sessions } = useSnapshot(SettingsStore.state) if (!sessions.length) { return ( diff --git a/advanced/wallets/react-wallet-v2/src/store/SettingsStore.ts b/advanced/wallets/react-wallet-v2/src/store/SettingsStore.ts index 89a682d62..56edf6ad2 100644 --- a/advanced/wallets/react-wallet-v2/src/store/SettingsStore.ts +++ b/advanced/wallets/react-wallet-v2/src/store/SettingsStore.ts @@ -1,4 +1,4 @@ -import { Verify } from '@walletconnect/types' +import { Verify, SessionTypes } from '@walletconnect/types' import { proxy } from 'valtio' /** @@ -19,6 +19,7 @@ interface State { relayerRegionURL: string activeChainId: string currentRequestVerifyContext?: Verify.Context + sessions: SessionTypes.Struct[] } /** @@ -37,7 +38,8 @@ const state = proxy({ tronAddress: '', tezosAddress: '', kadenaAddress: '', - relayerRegionURL: '' + relayerRegionURL: '', + sessions: [] }) /** @@ -94,6 +96,9 @@ const SettingsStore = { setCurrentRequestVerifyContext(context: Verify.Context) { state.currentRequestVerifyContext = context }, + setSessions(sessions: SessionTypes.Struct[]) { + state.sessions = sessions + }, toggleTestNets() { state.testNets = !state.testNets @@ -102,7 +107,7 @@ const SettingsStore = { } else { localStorage.removeItem('TEST_NETS') } - }, + } } export default SettingsStore diff --git a/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx b/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx index ae73ad936..60aed4db9 100644 --- a/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx +++ b/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx @@ -33,6 +33,7 @@ import ChainAddressMini from '@/components/ChainAddressMini' import { getChainData } from '@/data/chainsUtil' import RequestModal from './RequestModal' import { useSnapshot } from 'valtio' +import SettingsStore from '@/store/SettingsStore' const StyledText = styled(Text, { fontWeight: 400 @@ -232,6 +233,7 @@ export default function SessionProposalModal() { id: proposal.id, namespaces }) + SettingsStore.setSessions(Object.values(web3wallet.getActiveSessions())) } catch (e) { setIsLoadingApprove(false) styledToast((e as Error).message, 'error') From f8946d79eda6c4d16a8e2f2f2696d49c9de74d81 Mon Sep 17 00:00:00 2001 From: Gancho Radkov Date: Mon, 15 Jan 2024 15:09:38 +0200 Subject: [PATCH 2/2] chore: updates log msg --- .../react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts b/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts index 81984d6f5..af4f6c2be 100644 --- a/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts +++ b/advanced/wallets/react-wallet-v2/src/hooks/useWalletConnectEventsManager.ts @@ -126,7 +126,7 @@ export default function useWalletConnectEventsManager(initialized: boolean) { // TODOs web3wallet.engine.signClient.events.on('session_ping', data => console.log('ping', data)) web3wallet.on('session_delete', data => { - console.log('delete', data) + console.log('session_delete event received', data) SettingsStore.setSessions(Object.values(web3wallet.getActiveSessions())) }) // load sessions on init