@getpara/evm-wallet-connectors 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/index.d.ts +3 -0
  2. package/dist/index.js +3 -0
  3. package/dist/providers/EvmExternalWalletContext.d.ts +33 -0
  4. package/dist/providers/EvmExternalWalletContext.js +228 -0
  5. package/dist/providers/ParaEvmContext.d.ts +23 -0
  6. package/dist/providers/ParaEvmContext.js +94 -0
  7. package/dist/types/CommonTypes.d.ts +27 -0
  8. package/dist/types/CommonTypes.js +1 -0
  9. package/dist/types/Wallet.d.ts +32 -0
  10. package/dist/types/Wallet.js +1 -0
  11. package/dist/types/utils.d.ts +37 -0
  12. package/dist/types/utils.js +1 -0
  13. package/dist/utils/computeWalletConnectMetaData.d.ts +9 -0
  14. package/dist/utils/computeWalletConnectMetaData.js +8 -0
  15. package/dist/utils/getInjectedConnector.d.ts +11 -0
  16. package/dist/utils/getInjectedConnector.js +81 -0
  17. package/dist/utils/getWalletConnectConnector.d.ts +7 -0
  18. package/dist/utils/getWalletConnectConnector.js +43 -0
  19. package/dist/utils/getWalletConnectUri.d.ts +2 -0
  20. package/dist/utils/getWalletConnectUri.js +22 -0
  21. package/dist/utils/isEIP6963Connector.d.ts +2 -0
  22. package/dist/utils/isEIP6963Connector.js +4 -0
  23. package/dist/utils/omitUndefinedValues.d.ts +1 -0
  24. package/dist/utils/omitUndefinedValues.js +5 -0
  25. package/dist/utils/uniqueBy.d.ts +1 -0
  26. package/dist/utils/uniqueBy.js +9 -0
  27. package/dist/wallets/connectors/coinbase/coinbase.d.ts +6 -0
  28. package/dist/wallets/connectors/coinbase/coinbase.js +28 -0
  29. package/dist/wallets/connectors/coinbase/coinbaseIcon.d.ts +1 -0
  30. package/dist/wallets/connectors/coinbase/coinbaseIcon.js +1 -0
  31. package/dist/wallets/connectors/index.d.ts +7 -0
  32. package/dist/wallets/connectors/index.js +7 -0
  33. package/dist/wallets/connectors/metaMask/metaMask.d.ts +3 -0
  34. package/dist/wallets/connectors/metaMask/metaMask.js +122 -0
  35. package/dist/wallets/connectors/metaMask/metaMaskIcon.d.ts +1 -0
  36. package/dist/wallets/connectors/metaMask/metaMaskIcon.js +1 -0
  37. package/dist/wallets/connectors/rabby/rabby.d.ts +3 -0
  38. package/dist/wallets/connectors/rabby/rabby.js +22 -0
  39. package/dist/wallets/connectors/rabby/rabbyIcon.d.ts +1 -0
  40. package/dist/wallets/connectors/rabby/rabbyIcon.js +1 -0
  41. package/dist/wallets/connectors/rainbow/rainbow.d.ts +3 -0
  42. package/dist/wallets/connectors/rainbow/rainbow.js +33 -0
  43. package/dist/wallets/connectors/rainbow/rainbowIcon.d.ts +1 -0
  44. package/dist/wallets/connectors/rainbow/rainbowIcon.js +1 -0
  45. package/dist/wallets/connectors/walletConnect/walletConnect.d.ts +6 -0
  46. package/dist/wallets/connectors/walletConnect/walletConnect.js +17 -0
  47. package/dist/wallets/connectors/walletConnect/walletConnectIcon.d.ts +1 -0
  48. package/dist/wallets/connectors/walletConnect/walletConnectIcon.js +1 -0
  49. package/dist/wallets/connectors/zerion/zerion.d.ts +3 -0
  50. package/dist/wallets/connectors/zerion/zerion.js +35 -0
  51. package/dist/wallets/connectors/zerion/zerionIcon.d.ts +1 -0
  52. package/dist/wallets/connectors/zerion/zerionIcon.js +1 -0
  53. package/dist/wallets/connectorsForWallets.d.ts +15 -0
  54. package/dist/wallets/connectorsForWallets.js +68 -0
  55. package/package.json +38 -0
@@ -0,0 +1,43 @@
1
+ import { createConnector } from 'wagmi';
2
+ import { walletConnect } from 'wagmi/connectors';
3
+ const walletConnectInstances = new Map();
4
+ // Function to get or create a walletConnect instance
5
+ const getOrCreateWalletConnectInstance = ({ projectId, walletConnectParameters, paraDetailsShowQrModal, }) => {
6
+ let config = Object.assign(Object.assign({}, (walletConnectParameters ? walletConnectParameters : {})), { projectId, showQrModal: false });
7
+ // `paraDetailsShowQrModal` should always be `true`
8
+ if (paraDetailsShowQrModal) {
9
+ config = Object.assign(Object.assign({}, config), { showQrModal: true });
10
+ }
11
+ const serializedConfig = JSON.stringify(config);
12
+ const sharedWalletConnector = walletConnectInstances.get(serializedConfig);
13
+ if (sharedWalletConnector) {
14
+ return sharedWalletConnector;
15
+ }
16
+ // Create a new walletConnect instance and store it
17
+ const newWalletConnectInstance = walletConnect(config);
18
+ walletConnectInstances.set(serializedConfig, newWalletConnectInstance);
19
+ return newWalletConnectInstance;
20
+ };
21
+ // Creates a WalletConnect connector with the given project ID and additional options.
22
+ function createWalletConnectConnector({ projectId, walletDetails, walletConnectParameters, }) {
23
+ // Create and configure the WalletConnect connector with project ID and options.
24
+ return createConnector(config => (Object.assign(Object.assign(Object.assign({}, getOrCreateWalletConnectInstance({
25
+ projectId,
26
+ walletConnectParameters,
27
+ // Used in `connectorsForWallets` to add another
28
+ // walletConnect wallet into Para with modal popup option
29
+ paraDetailsShowQrModal: walletDetails.paraDetails.showQrModal,
30
+ })(config)), walletDetails), { id: walletDetails.paraDetails.id })));
31
+ }
32
+ // Factory function to obtain a configured WalletConnect connector.
33
+ export function getWalletConnectConnector({ projectId, walletConnectParameters, }) {
34
+ if (!projectId || projectId === '') {
35
+ throw new Error('No projectId found. Every dApp must now provide a WalletConnect Cloud projectId to enable WalletConnect v2. Sign up for your free key at https://cloud.walletconnect.com/sign-in');
36
+ }
37
+ // Return a function that merges additional wallet details with `CreateConnectorFn`.
38
+ return (walletDetails) => createWalletConnectConnector({
39
+ projectId,
40
+ walletDetails,
41
+ walletConnectParameters,
42
+ });
43
+ }
@@ -0,0 +1,2 @@
1
+ import { Connector } from 'wagmi';
2
+ export declare const getWalletConnectUri: (connector: Connector, uriConverter?: (uri: string) => string) => Promise<string>;
@@ -0,0 +1,22 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ export const getWalletConnectUri = (connector, uriConverter) => __awaiter(void 0, void 0, void 0, function* () {
11
+ const provider = yield connector.getProvider();
12
+ if (connector.type === 'coinbaseWallet') {
13
+ // @ts-expect-error
14
+ return provider.qrUrl;
15
+ }
16
+ return new Promise(resolve =>
17
+ // Wagmi v2 doesn't have a return type for provider yet
18
+ // @ts-expect-error
19
+ provider.once('display_uri', uri => {
20
+ resolve(uriConverter ? uriConverter(uri) : uri);
21
+ }));
22
+ });
@@ -0,0 +1,2 @@
1
+ import { WagmiConnectorInstance } from '../types/Wallet.js';
2
+ export declare const isEIP6963Connector: (wallet: WagmiConnectorInstance) => boolean;
@@ -0,0 +1,4 @@
1
+ export const isEIP6963Connector = (wallet) => {
2
+ var _a;
3
+ return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) === null || _a === void 0 ? void 0 : _a.startsWith('data:image')) && wallet.uid && wallet.name);
4
+ };
@@ -0,0 +1 @@
1
+ export declare function omitUndefinedValues<T>(obj: T): T;
@@ -0,0 +1,5 @@
1
+ export function omitUndefinedValues(obj) {
2
+ return Object.fromEntries(
3
+ //@ts-ignore
4
+ Object.entries(obj).filter(([_key, value]) => value !== undefined));
5
+ }
@@ -0,0 +1 @@
1
+ export declare function uniqueBy<key extends string, item extends Record<key, any>>(items: item[], key: key): item[];
@@ -0,0 +1,9 @@
1
+ export function uniqueBy(items, key) {
2
+ const filtered = [];
3
+ for (const item of items) {
4
+ if (!filtered.some(x => x[key] === item[key])) {
5
+ filtered.push(item);
6
+ }
7
+ }
8
+ return filtered;
9
+ }
@@ -0,0 +1,6 @@
1
+ import { Wallet } from '../../../types/Wallet.js';
2
+ export interface CoinbaseWalletOptions {
3
+ appName: string;
4
+ appIcon?: string;
5
+ }
6
+ export declare const coinbaseWallet: ({ appName, appIcon }: CoinbaseWalletOptions) => Wallet;
@@ -0,0 +1,28 @@
1
+ import { createConnector } from 'wagmi';
2
+ import { coinbaseWallet as coinbaseWagmiWallet } from 'wagmi/connectors';
3
+ import { icon } from './coinbaseIcon.js';
4
+ import { hasInjectedProvider } from '../../../utils/getInjectedConnector.js';
5
+ export const coinbaseWallet = ({ appName, appIcon }) => {
6
+ const isCoinbaseInjected = hasInjectedProvider({ flag: 'isCoinbaseWallet' });
7
+ const getUri = (uri) => uri;
8
+ return {
9
+ id: 'coinbase',
10
+ name: 'Coinbase Wallet',
11
+ rdns: 'com.coinbase.wallet',
12
+ iconUrl: icon,
13
+ // Note that we never resolve `installed` to `false` because the
14
+ // Coinbase Wallet SDK falls back to other connection methods if
15
+ // the injected connector isn't available
16
+ installed: isCoinbaseInjected,
17
+ isExtension: true,
18
+ isMobile: true,
19
+ downloadUrl: 'https://www.coinbase.com/wallet/downloads',
20
+ getUri,
21
+ createConnector: (walletDetails) => createConnector(config => (Object.assign(Object.assign({}, coinbaseWagmiWallet({
22
+ version: '4',
23
+ appName,
24
+ appLogoUrl: appIcon,
25
+ preference: 'eoaOnly',
26
+ })(config)), walletDetails))),
27
+ };
28
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,7 @@
1
+ import { metaMaskWallet } from './metaMask/metaMask.js';
2
+ import { rainbowWallet } from './rainbow/rainbow.js';
3
+ import { walletConnectWallet } from './walletConnect/walletConnect.js';
4
+ import { coinbaseWallet } from './coinbase/coinbase.js';
5
+ import { zerionWallet } from './zerion/zerion.js';
6
+ import { rabbyWallet } from './rabby/rabby.js';
7
+ export { metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet };
@@ -0,0 +1,7 @@
1
+ import { metaMaskWallet } from './metaMask/metaMask.js';
2
+ import { rainbowWallet } from './rainbow/rainbow.js';
3
+ import { walletConnectWallet } from './walletConnect/walletConnect.js';
4
+ import { coinbaseWallet } from './coinbase/coinbase.js';
5
+ import { zerionWallet } from './zerion/zerion.js';
6
+ import { rabbyWallet } from './rabby/rabby.js';
7
+ export { metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet };
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type MetaMaskWalletOptions = DefaultWalletOptions;
3
+ export declare const metaMaskWallet: ({ projectId, walletConnectParameters }: MetaMaskWalletOptions) => Wallet;
@@ -0,0 +1,122 @@
1
+ import { isAndroid, isIOS, isTelegram } from '@getpara/react-sdk';
2
+ import { getInjectedConnector, hasInjectedProvider } from '../../../utils/getInjectedConnector.js';
3
+ import { getWalletConnectConnector } from '../../../utils/getWalletConnectConnector.js';
4
+ import { icon } from './metaMaskIcon.js';
5
+ function isMetaMask(ethereum) {
6
+ // Logic borrowed from wagmi's MetaMaskConnector
7
+ // https://github.com/wagmi-dev/references/blob/main/packages/connectors/src/metaMask.ts
8
+ if (!(ethereum === null || ethereum === void 0 ? void 0 : ethereum.isMetaMask))
9
+ return false;
10
+ // Brave tries to make itself look like MetaMask
11
+ // Could also try RPC `web3_clientVersion` if following is unreliable
12
+ if (ethereum.isBraveWallet && !ethereum._events && !ethereum._state)
13
+ return false;
14
+ if (ethereum.isApexWallet)
15
+ return false;
16
+ if (ethereum.isAvalanche)
17
+ return false;
18
+ if (ethereum.isBackpack)
19
+ return false;
20
+ if (ethereum.isBifrost)
21
+ return false;
22
+ if (ethereum.isBitKeep)
23
+ return false;
24
+ if (ethereum.isBitski)
25
+ return false;
26
+ if (ethereum.isBlockWallet)
27
+ return false;
28
+ if (ethereum.isCoinbaseWallet)
29
+ return false;
30
+ if (ethereum.isDawn)
31
+ return false;
32
+ if (ethereum.isEnkrypt)
33
+ return false;
34
+ if (ethereum.isExodus)
35
+ return false;
36
+ if (ethereum.isFrame)
37
+ return false;
38
+ if (ethereum.isFrontier)
39
+ return false;
40
+ if (ethereum.isGamestop)
41
+ return false;
42
+ if (ethereum.isHyperPay)
43
+ return false;
44
+ if (ethereum.isImToken)
45
+ return false;
46
+ if (ethereum.isKuCoinWallet)
47
+ return false;
48
+ if (ethereum.isMathWallet)
49
+ return false;
50
+ if (ethereum.isNestWallet)
51
+ return false;
52
+ if (ethereum.isOkxWallet || ethereum.isOKExWallet)
53
+ return false;
54
+ if (ethereum.isOneInchIOSWallet || ethereum.isOneInchAndroidWallet)
55
+ return false;
56
+ if (ethereum.isOpera)
57
+ return false;
58
+ if (ethereum.isPhantom)
59
+ return false;
60
+ if (ethereum.isPortal)
61
+ return false;
62
+ if (ethereum.isRabby)
63
+ return false;
64
+ if (ethereum.isRainbow)
65
+ return false;
66
+ if (ethereum.isStatus)
67
+ return false;
68
+ if (ethereum.isTalisman)
69
+ return false;
70
+ if (ethereum.isTally)
71
+ return false;
72
+ if (ethereum.isTokenPocket)
73
+ return false;
74
+ if (ethereum.isTokenary)
75
+ return false;
76
+ if (ethereum.isTrust || ethereum.isTrustWallet)
77
+ return false;
78
+ if (ethereum.isXDEFI)
79
+ return false;
80
+ if (ethereum.isZeal)
81
+ return false;
82
+ if (ethereum.isZerion)
83
+ return false;
84
+ if (ethereum.__seif)
85
+ return false;
86
+ return true;
87
+ }
88
+ export const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
89
+ var _a, _b, _c;
90
+ const isMetaMaskInjected = hasInjectedProvider({ flag: 'isMetaMask' });
91
+ const getUri = (uri) => {
92
+ return isAndroid()
93
+ ? `metamask://wc?uri=${encodeURIComponent(uri)}`
94
+ : isIOS()
95
+ ? !isTelegram()
96
+ ? // currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
97
+ `metamask://wc?uri=${encodeURIComponent(uri)}`
98
+ : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}`
99
+ : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}`;
100
+ };
101
+ return {
102
+ id: 'metaMask',
103
+ name: 'MetaMask',
104
+ rdns: 'io.metamask',
105
+ iconUrl: icon,
106
+ installed: isMetaMaskInjected,
107
+ isExtension: true,
108
+ isMobile: true,
109
+ downloadUrl: 'https://metamask.io/download/',
110
+ getUri,
111
+ createConnector: isMetaMaskInjected
112
+ ? getInjectedConnector({
113
+ target: typeof window !== 'undefined'
114
+ ? ((_c = (_b = (_a = window.ethereum) === null || _a === void 0 ? void 0 : _a.providers) === null || _b === void 0 ? void 0 : _b.find(isMetaMask)) !== null && _c !== void 0 ? _c : window.ethereum)
115
+ : undefined,
116
+ })
117
+ : getWalletConnectConnector({
118
+ projectId,
119
+ walletConnectParameters,
120
+ }),
121
+ };
122
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type RabbyWalletOptions = DefaultWalletOptions;
3
+ export declare const rabbyWallet: ({ projectId, walletConnectParameters }: RabbyWalletOptions) => Wallet;
@@ -0,0 +1,22 @@
1
+ import { getInjectedConnector, hasInjectedProvider } from '../../../utils/getInjectedConnector.js';
2
+ import { getWalletConnectConnector } from '../../../utils/getWalletConnectConnector.js';
3
+ import { icon } from './rabbyIcon.js';
4
+ export const rabbyWallet = ({ projectId, walletConnectParameters }) => {
5
+ const isRabbyInjected = hasInjectedProvider({ flag: 'isRabby' });
6
+ return {
7
+ id: 'rabby',
8
+ name: 'Rabby Wallet',
9
+ rdns: 'io.rabby',
10
+ iconUrl: icon,
11
+ installed: isRabbyInjected,
12
+ isExtension: true,
13
+ isMobile: false,
14
+ downloadUrl: 'https://rabby.io',
15
+ createConnector: isRabbyInjected
16
+ ? getInjectedConnector({ flag: 'isRabby' })
17
+ : getWalletConnectConnector({
18
+ projectId,
19
+ walletConnectParameters,
20
+ }),
21
+ };
22
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type RainbowWalletOptions = DefaultWalletOptions;
3
+ export declare const rainbowWallet: ({ projectId, walletConnectParameters }: RainbowWalletOptions) => Wallet;
@@ -0,0 +1,33 @@
1
+ import { isAndroid, isIOS, isTelegram } from '@getpara/react-sdk';
2
+ import { getInjectedConnector, hasInjectedProvider } from '../../../utils/getInjectedConnector.js';
3
+ import { getWalletConnectConnector } from '../../../utils/getWalletConnectConnector.js';
4
+ import { icon } from './rainbowIcon.js';
5
+ export const rainbowWallet = ({ projectId, walletConnectParameters }) => {
6
+ const isRainbowInjected = hasInjectedProvider({ flag: 'isRainbow' });
7
+ const getUri = (uri) => {
8
+ return isAndroid()
9
+ ? `rainbow://wc?uri=${encodeURIComponent(uri)}`
10
+ : isIOS()
11
+ ? !isTelegram()
12
+ ? `rainbow://wc?uri=${encodeURIComponent(uri)}`
13
+ : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}`
14
+ : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}`;
15
+ };
16
+ return {
17
+ id: 'rainbow',
18
+ name: 'Rainbow',
19
+ rdns: 'me.rainbow',
20
+ iconUrl: icon,
21
+ installed: isRainbowInjected,
22
+ isExtension: true,
23
+ isMobile: true,
24
+ downloadUrl: 'https://rainbow.me/',
25
+ getUri,
26
+ createConnector: isRainbowInjected
27
+ ? getInjectedConnector({ flag: 'isRainbow' })
28
+ : getWalletConnectConnector({
29
+ projectId,
30
+ walletConnectParameters,
31
+ }),
32
+ };
33
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,6 @@
1
+ import { ParaWalletConnectParameters, Wallet } from '../../../types/Wallet.js';
2
+ export interface WalletConnectWalletOptions {
3
+ projectId: string;
4
+ options?: ParaWalletConnectParameters;
5
+ }
6
+ export declare const walletConnectWallet: ({ projectId, options }: WalletConnectWalletOptions) => Wallet;
@@ -0,0 +1,17 @@
1
+ import { getWalletConnectConnector } from '../../../utils/getWalletConnectConnector.js';
2
+ import { icon } from './walletConnectIcon.js';
3
+ export const walletConnectWallet = ({ projectId, options }) => {
4
+ const getUri = (uri) => uri;
5
+ return {
6
+ id: 'walletConnect',
7
+ name: 'WalletConnect',
8
+ installed: undefined,
9
+ iconUrl: icon,
10
+ isMobile: true,
11
+ getUri,
12
+ createConnector: getWalletConnectConnector({
13
+ projectId,
14
+ walletConnectParameters: options,
15
+ }),
16
+ };
17
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type ZerionWalletOptions = DefaultWalletOptions;
3
+ export declare const zerionWallet: ({ projectId, walletConnectParameters }: ZerionWalletOptions) => Wallet;
@@ -0,0 +1,35 @@
1
+ import { isIOS, isTelegram } from '@getpara/react-sdk';
2
+ import { getInjectedConnector, hasInjectedProvider } from '../../../utils/getInjectedConnector.js';
3
+ import { getWalletConnectConnector } from '../../../utils/getWalletConnectConnector.js';
4
+ import { icon } from './zerionIcon.js';
5
+ export const zerionWallet = ({ projectId, walletConnectParameters }) => {
6
+ const isZerionInjected = hasInjectedProvider({
7
+ namespace: 'zerionWallet',
8
+ flag: 'isZerion',
9
+ });
10
+ const getUri = (uri) => {
11
+ return isTelegram() && isIOS()
12
+ ? `https://app.zerion.io/wc?uri=${encodeURIComponent(uri)}`
13
+ : `zerion://wc?uri=${encodeURIComponent(uri)}`;
14
+ };
15
+ return {
16
+ id: 'zerion',
17
+ name: 'Zerion',
18
+ rdns: 'io.zerion.wallet',
19
+ iconUrl: icon,
20
+ installed: isZerionInjected,
21
+ isExtension: true,
22
+ isMobile: true,
23
+ getUri,
24
+ downloadUrl: 'https://zerion.io/download',
25
+ createConnector: isZerionInjected
26
+ ? getInjectedConnector({
27
+ namespace: 'zerionWallet',
28
+ flag: 'isZerion',
29
+ })
30
+ : getWalletConnectConnector({
31
+ projectId,
32
+ walletConnectParameters,
33
+ }),
34
+ };
35
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1 @@
1
+ export const icon = '';
@@ -0,0 +1,15 @@
1
+ import type { CreateConnectorFn } from 'wagmi';
2
+ import type { WalletList } from '../types/Wallet.js';
3
+ import type { ParaWalletConnectParameters, Wallet } from '../types/Wallet.js';
4
+ export interface WalletListItem extends Wallet {
5
+ index: number;
6
+ }
7
+ export interface ConnectorsForWalletsParameters {
8
+ projectId: string;
9
+ appName: string;
10
+ appDescription?: string;
11
+ appUrl?: string;
12
+ appIcon?: string;
13
+ walletConnectParameters?: ParaWalletConnectParameters;
14
+ }
15
+ export declare const connectorsForWallets: (walletList: WalletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }: ConnectorsForWalletsParameters) => CreateConnectorFn[];
@@ -0,0 +1,68 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { uniqueBy } from '../utils/uniqueBy.js';
13
+ import { computeWalletConnectMetaData } from '../utils/computeWalletConnectMetaData.js';
14
+ import { omitUndefinedValues } from '../utils/omitUndefinedValues.js';
15
+ export const connectorsForWallets = (walletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }) => {
16
+ if (!walletList.length) {
17
+ throw new Error('No wallet list was provided');
18
+ }
19
+ let index = -1;
20
+ const connectors = [];
21
+ const wallets = [];
22
+ const walletConnectMetaData = computeWalletConnectMetaData({
23
+ appName,
24
+ appDescription,
25
+ appUrl,
26
+ appIcon,
27
+ });
28
+ walletList.forEach(createWallet => {
29
+ index++;
30
+ const wallet = createWallet({
31
+ projectId,
32
+ appName,
33
+ appIcon,
34
+ // `option` is being used only for `walletConnectWallet` wallet
35
+ options: Object.assign({ metadata: walletConnectMetaData }, walletConnectParameters),
36
+ // Every other wallet that supports walletConnect flow and is not
37
+ // `walletConnectWallet` wallet will have `walletConnectParameters` property
38
+ walletConnectParameters: Object.assign({ metadata: walletConnectMetaData }, walletConnectParameters),
39
+ });
40
+ const walletListItem = Object.assign(Object.assign({}, wallet), { index });
41
+ wallets.push(walletListItem);
42
+ });
43
+ // Filtering out duplicated wallets in case there is any.
44
+ // We process the known visible wallets first so that the potentially
45
+ // hidden wallets have access to the complete list of resolved wallets
46
+ const walletListItems = uniqueBy([...wallets], 'id');
47
+ for (let _a of walletListItems) {
48
+ const { createConnector } = _a, walletMeta = __rest(_a, ["createConnector"]);
49
+ const walletMetaData = (
50
+ // For now we should only use these as the additional parameters
51
+ additionalParaParams) => {
52
+ return {
53
+ paraDetails: omitUndefinedValues(Object.assign(Object.assign(Object.assign({}, walletMeta), { isParaConnector: true }), (additionalParaParams ? additionalParaParams : {}))),
54
+ };
55
+ };
56
+ const isWalletConnectConnector = walletMeta.id === 'walletConnect';
57
+ if (isWalletConnectConnector) {
58
+ connectors.push(createConnector(walletMetaData({
59
+ isWalletConnectModalConnector: true,
60
+ showQrModal: true,
61
+ })));
62
+ }
63
+ if (createConnector) {
64
+ connectors.push(createConnector(walletMetaData()));
65
+ }
66
+ }
67
+ return connectors;
68
+ };