diff --git a/packages/react-components/package.json b/packages/react-components/package.json index 66dccb2..95c80e6 100644 --- a/packages/react-components/package.json +++ b/packages/react-components/package.json @@ -27,7 +27,7 @@ "build": "tsc" }, "dependencies": { - "@concordium/wallet-connectors": "^0.5.1" + "@concordium/wallet-connectors": "^0.6.0-alpha.4" }, "devDependencies": { "@tsconfig/recommended": "^1.0.1", diff --git a/packages/wallet-connectors/package.json b/packages/wallet-connectors/package.json index 5305da1..f2069d9 100644 --- a/packages/wallet-connectors/package.json +++ b/packages/wallet-connectors/package.json @@ -1,6 +1,6 @@ { "name": "@concordium/wallet-connectors", - "version": "0.6.0-alpha.3", + "version": "0.6.0-alpha.4", "description": "Utility interface for dApps to interact with wallets without depending on the underlying protocol and implementations for Concordium Browser Wallet and Wallet Connect v2.", "author": "Concordium Software", "license": "Apache-2.0", diff --git a/packages/wallet-connectors/src/WalletConnect.ts b/packages/wallet-connectors/src/WalletConnect.ts index f8c2521..7a713f8 100644 --- a/packages/wallet-connectors/src/WalletConnect.ts +++ b/packages/wallet-connectors/src/WalletConnect.ts @@ -26,7 +26,7 @@ import { WalletConnectModal } from '@walletconnect/modal'; import { MobileWallet } from '@walletconnect/modal-core'; import SignClient from '@walletconnect/sign-client'; import { ISignClient, ProposalTypes, SessionTypes, SignClientTypes } from '@walletconnect/types'; -import { CONCORDIUM_WALLET_CONNECT_PROJECT_ID } from '.'; +import { CONCORDIUM_WALLET_CONNECT_PROJECT_ID, MAINNET, TESTNET } from '.'; import { Network, Schema, @@ -57,74 +57,67 @@ export const WalletConnectEvents = { export type WalletConnectMethods = typeof WalletConnectMethods[keyof typeof WalletConnectMethods]; export type WalletConnectEvents = typeof WalletConnectEvents[keyof typeof WalletConnectEvents]; -export type WalletConnectMobileWallet = - | (MobileWallet & { - type: 'customLink'; - /** Url for an icon to represent the wallet */ - iconUrl?: string; - }) - | { - type: 'explorerId'; - /** The ID of the wallet in the wallet connect explorer: https://explorer.walletconnect.com/ */ - value: string; - }; +export type WalletConnectMobileWallet = MobileWallet & { + /** Url for an icon to represent the wallet */ + iconUrl?: string; +}; export const concordiumWalletMainnet: WalletConnectMobileWallet = { - type: 'explorerId', - value: '7dcb0e5eb1b4fc6e2e0b143201c489ea6c618259f49527527d4a349d1a95ba7b', + id: 'ConcordiumMainet', + name: 'Concordium Wallet', + links: { + native: 'concordiumwallet://', + }, + iconUrl: + '', }; export const concordiumWalletTestnet: WalletConnectMobileWallet = { - type: 'customLink', id: 'ConcordiumTestnet', name: 'Concordium Wallet (Testnet)', links: { native: 'concordiumwallettest://', }, - iconUrl: '', + iconUrl: + '', }; export const cryptoXWalletMainnet: WalletConnectMobileWallet = { - type: 'customLink', id: 'CryptoXMainnet', name: 'CryptoX Wallet', links: { native: 'cryptox://', }, - iconUrl: '', + iconUrl: + '', }; export const cryptoXWalletTestnet: WalletConnectMobileWallet = { - type: 'customLink', id: 'CryptoXTestnet', name: 'CryptoX Wallet (Testnet)', links: { native: 'cryptoXStage://', }, - iconUrl: '', + iconUrl: + '', }; async function connect( client: ISignClient, scope: ProposalTypes.RequiredNamespace, cancel: () => void, - mobileWallets?: WalletConnectMobileWallet[] + mobileWallets?: WalletConnectMobileWallet[], + enableExplorer = false ) { let modal: WalletConnectModal | undefined; const wallets: MobileWallet[] = []; - const explorerIds: string[] = []; const walletImages: Record = {}; - mobileWallets?.forEach(w => { - if (w.type === 'explorerId') { - explorerIds.push(w.value); - } else { - // eslint-disable-next-line @typescript-eslint/no-unused-vars - const { type: _, iconUrl, ...mw } = w; - wallets.push(mw); - if (iconUrl !== undefined) { - walletImages[mw.id] = iconUrl; - } + mobileWallets?.forEach((w) => { + const { iconUrl, ...mw } = w; + wallets.push(mw); + if (iconUrl !== undefined) { + walletImages[mw.id] = iconUrl; } }); @@ -140,9 +133,10 @@ async function connect( chains: scope.chains, mobileWallets: wallets, desktopWallets: [], - explorerRecommendedWalletIds: explorerIds, + explorerRecommendedWalletIds: 'NONE', explorerExcludedWalletIds: 'ALL', - walletImages + walletImages, + enableExplorer, }); // Open modal as we're not connecting to an existing pairing. modal.openModal({ uri }); @@ -512,14 +506,16 @@ export class WalletConnectConnector implements WalletConnector { * * @param methods - The methods to request permission to use for in the wallet * @param events - The events to request permission to read from the wallet - * @param mobileWallets - The (mobile) wallets to be selectable from the walletconnect modal + * @param [mobileWallets] - The (mobile) wallets to be selectable from the walletconnect modal + * @param [enableExplorer] - Whether to enable the wallet connect explorer. Defaults to false * * @returns the {@linkcode WalletConnectConnection}, or `undefined` if rejected from the wallet. */ async connectWithScope( methods: WalletConnectMethods[], events: WalletConnectEvents[], - mobileWallets?: WalletConnectMobileWallet[] + mobileWallets?: WalletConnectMobileWallet[], + enableExplorer = false ) { const { name } = this.network; @@ -530,7 +526,7 @@ export class WalletConnectConnector implements WalletConnector { events: events, }; const session = await new Promise((resolve) => { - connect(this.client, scope, () => resolve(undefined), mobileWallets).then(resolve); + connect(this.client, scope, () => resolve(undefined), mobileWallets, enableExplorer).then(resolve); }); if (!session) { // Connect was cancelled. @@ -553,7 +549,11 @@ export class WalletConnectConnector implements WalletConnector { WalletConnectMethods.RequestVerifiablePresentation, ], [WalletConnectEvents.AccountsChanged, WalletConnectEvents.ChainChanged], - [cryptoXWalletMainnet, concordiumWalletMainnet] + this.network === MAINNET + ? [cryptoXWalletMainnet, concordiumWalletMainnet] + : this.network === TESTNET + ? [cryptoXWalletTestnet, concordiumWalletTestnet] + : undefined ); }