From 18eee6279ccca123a211e67769ff45a25f93f5a4 Mon Sep 17 00:00:00 2001 From: Martin Picco Date: Mon, 24 Apr 2023 10:25:40 -0300 Subject: [PATCH] Add option to configure wallet connect's session storage id in order to prevent conflict with sessions from other wallets. Add default value to this session id --- src/PeraWalletConnect.ts | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/PeraWalletConnect.ts b/src/PeraWalletConnect.ts index b8e3054..bc07155 100644 --- a/src/PeraWalletConnect.ts +++ b/src/PeraWalletConnect.ts @@ -44,10 +44,11 @@ import { WAIT_FOR_TAB_TRY_INTERVAL } from "./util/dom/domUtils"; -interface PeraWalletConnectOptions { +export interface PeraWalletConnectOptions { bridge?: string; shouldShowSignTxnToast?: boolean; chainId?: AlgorandChainIDs; + sessionStorageId?: string; } function generatePeraWalletConnectModalActions({ @@ -70,6 +71,7 @@ class PeraWalletConnect { connector: WalletConnect | null; shouldShowSignTxnToast: boolean; chainId?: number; + sessionStorageId: string; constructor(options?: PeraWalletConnectOptions) { this.bridge = options?.bridge || ""; @@ -81,6 +83,7 @@ class PeraWalletConnect { : options.shouldShowSignTxnToast; this.chainId = options?.chainId; + this.sessionStorageId = options?.sessionStorageId || 'pera-wallet-connect'; } get platform() { @@ -402,6 +405,7 @@ class PeraWalletConnect { // Create Connector instance this.connector = new WalletConnect({ bridge: this.bridge || bridgeURL || "https://bridge.walletconnect.org", + storageId: this.sessionStorageId, qrcodeModal: generatePeraWalletConnectModalActions({ isWebWalletAvailable, shouldDisplayNewBadge, @@ -492,7 +496,8 @@ class PeraWalletConnect { if (this.bridge) { this.connector = new WalletConnect({ - bridge: this.bridge + bridge: this.bridge, + storageId: this.sessionStorageId, }); resolve(this.connector?.accounts || []);