Skip to content
This repository has been archived by the owner on Aug 16, 2024. It is now read-only.

Commit

Permalink
Embed wallet images in code
Browse files Browse the repository at this point in the history
  • Loading branch information
soerenbf committed Apr 3, 2024
1 parent dbe1c17 commit b0a18da
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 22 deletions.
2 changes: 1 addition & 1 deletion packages/wallet-connectors/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@concordium/wallet-connectors",
"version": "0.6.0-alpha.2",
"version": "0.6.0-alpha.3",
"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",
Expand Down
80 changes: 59 additions & 21 deletions packages/wallet-connectors/src/WalletConnect.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,19 +57,51 @@ export const WalletConnectEvents = {
export type WalletConnectMethods = typeof WalletConnectMethods[keyof typeof WalletConnectMethods];
export type WalletConnectEvents = typeof WalletConnectEvents[keyof typeof WalletConnectEvents];

type WalletConnectMobileWallet = MobileWallet | string;
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 const concordiumWalletMainnet: WalletConnectMobileWallet = {
type: 'explorerId',
value: '7dcb0e5eb1b4fc6e2e0b143201c489ea6c618259f49527527d4a349d1a95ba7b',
};

/**
*
*/
export const concordiumWallet = '7dcb0e5eb1b4fc6e2e0b143201c489ea6c618259f49527527d4a349d1a95ba7b';
export const concordiumWalletTestnet: WalletConnectMobileWallet = {
type: 'customLink',
id: 'ConcordiumTestnet',
name: 'Concordium Wallet (Testnet)',
links: {
native: 'concordiumwallettest://',
},
iconUrl: '',
};

export const cryptoXWallet: MobileWallet = {
id: 'CryptoXWallet',
export const cryptoXWalletMainnet: WalletConnectMobileWallet = {
type: 'customLink',
id: 'CryptoXMainnet',
name: 'CryptoX Wallet',
links: {
native: 'cryptox://',
},
iconUrl: '',
};

export const cryptoXWalletTestnet: WalletConnectMobileWallet = {
type: 'customLink',
id: 'CryptoXTestnet',
name: 'CryptoX Wallet (Testnet)',
links: {
native: 'cryptoXStage://',
},
iconUrl: '',
};

async function connect(
Expand All @@ -79,18 +111,23 @@ async function connect(
mobileWallets?: WalletConnectMobileWallet[]
) {
let modal: WalletConnectModal | undefined;
const { mobile, explorer } = mobileWallets?.reduce<{ mobile: MobileWallet[]; explorer: string[] }>(
(acc, cur) => {
if (typeof cur === 'string') {
acc.explorer.push(cur);
} else {
acc.mobile.push(cur);

const wallets: MobileWallet[] = [];
const explorerIds: string[] = [];
const walletImages: Record<string, string> = {};
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;
}
}
});

return acc;
},
{ mobile: [], explorer: [] }
) ?? {};
try {
const { uri, approval } = await client.connect({
requiredNamespaces: {
Expand All @@ -101,10 +138,11 @@ async function connect(
modal = new WalletConnectModal({
projectId: CONCORDIUM_WALLET_CONNECT_PROJECT_ID,
chains: scope.chains,
mobileWallets: mobile,
mobileWallets: wallets,
desktopWallets: [],
explorerRecommendedWalletIds: explorer,
explorerRecommendedWalletIds: explorerIds,
explorerExcludedWalletIds: 'ALL',
walletImages
});
// Open modal as we're not connecting to an existing pairing.
modal.openModal({ uri });
Expand Down Expand Up @@ -476,7 +514,7 @@ export class WalletConnectConnector implements WalletConnector {
* @param events - The events to request permission to read from the wallet
* @param mobileWallets - The (mobile) wallets to be selectable from the walletconnect modal
*
* @returns the {@linkcode WalletConnectConnection}, or `undefined` if rejected from the wallet.
* @returns the {@linkcode WalletConnectConnection}, or `undefined` if rejected from the wallet.
*/
async connectWithScope(
methods: WalletConnectMethods[],
Expand Down Expand Up @@ -515,7 +553,7 @@ export class WalletConnectConnector implements WalletConnector {
WalletConnectMethods.RequestVerifiablePresentation,
],
[WalletConnectEvents.AccountsChanged, WalletConnectEvents.ChainChanged],
[cryptoXWallet, concordiumWallet]
[cryptoXWalletMainnet, concordiumWalletMainnet]
);
}

Expand Down

0 comments on commit b0a18da

Please sign in to comment.