@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.
- package/dist/index.d.ts +3 -0
- package/dist/index.js +3 -0
- package/dist/providers/EvmExternalWalletContext.d.ts +33 -0
- package/dist/providers/EvmExternalWalletContext.js +228 -0
- package/dist/providers/ParaEvmContext.d.ts +23 -0
- package/dist/providers/ParaEvmContext.js +94 -0
- package/dist/types/CommonTypes.d.ts +27 -0
- package/dist/types/CommonTypes.js +1 -0
- package/dist/types/Wallet.d.ts +32 -0
- package/dist/types/Wallet.js +1 -0
- package/dist/types/utils.d.ts +37 -0
- package/dist/types/utils.js +1 -0
- package/dist/utils/computeWalletConnectMetaData.d.ts +9 -0
- package/dist/utils/computeWalletConnectMetaData.js +8 -0
- package/dist/utils/getInjectedConnector.d.ts +11 -0
- package/dist/utils/getInjectedConnector.js +81 -0
- package/dist/utils/getWalletConnectConnector.d.ts +7 -0
- package/dist/utils/getWalletConnectConnector.js +43 -0
- package/dist/utils/getWalletConnectUri.d.ts +2 -0
- package/dist/utils/getWalletConnectUri.js +22 -0
- package/dist/utils/isEIP6963Connector.d.ts +2 -0
- package/dist/utils/isEIP6963Connector.js +4 -0
- package/dist/utils/omitUndefinedValues.d.ts +1 -0
- package/dist/utils/omitUndefinedValues.js +5 -0
- package/dist/utils/uniqueBy.d.ts +1 -0
- package/dist/utils/uniqueBy.js +9 -0
- package/dist/wallets/connectors/coinbase/coinbase.d.ts +6 -0
- package/dist/wallets/connectors/coinbase/coinbase.js +28 -0
- package/dist/wallets/connectors/coinbase/coinbaseIcon.d.ts +1 -0
- package/dist/wallets/connectors/coinbase/coinbaseIcon.js +1 -0
- package/dist/wallets/connectors/index.d.ts +7 -0
- package/dist/wallets/connectors/index.js +7 -0
- package/dist/wallets/connectors/metaMask/metaMask.d.ts +3 -0
- package/dist/wallets/connectors/metaMask/metaMask.js +122 -0
- package/dist/wallets/connectors/metaMask/metaMaskIcon.d.ts +1 -0
- package/dist/wallets/connectors/metaMask/metaMaskIcon.js +1 -0
- package/dist/wallets/connectors/rabby/rabby.d.ts +3 -0
- package/dist/wallets/connectors/rabby/rabby.js +22 -0
- package/dist/wallets/connectors/rabby/rabbyIcon.d.ts +1 -0
- package/dist/wallets/connectors/rabby/rabbyIcon.js +1 -0
- package/dist/wallets/connectors/rainbow/rainbow.d.ts +3 -0
- package/dist/wallets/connectors/rainbow/rainbow.js +33 -0
- package/dist/wallets/connectors/rainbow/rainbowIcon.d.ts +1 -0
- package/dist/wallets/connectors/rainbow/rainbowIcon.js +1 -0
- package/dist/wallets/connectors/walletConnect/walletConnect.d.ts +6 -0
- package/dist/wallets/connectors/walletConnect/walletConnect.js +17 -0
- package/dist/wallets/connectors/walletConnect/walletConnectIcon.d.ts +1 -0
- package/dist/wallets/connectors/walletConnect/walletConnectIcon.js +1 -0
- package/dist/wallets/connectors/zerion/zerion.d.ts +3 -0
- package/dist/wallets/connectors/zerion/zerion.js +35 -0
- package/dist/wallets/connectors/zerion/zerionIcon.d.ts +1 -0
- package/dist/wallets/connectors/zerion/zerionIcon.js +1 -0
- package/dist/wallets/connectorsForWallets.d.ts +15 -0
- package/dist/wallets/connectorsForWallets.js +68 -0
- 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,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 @@
|
|
|
1
|
+
export declare function omitUndefinedValues<T>(obj: T): T;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function uniqueBy<key extends string, item extends Record<key, any>>(items: item[], key: key): item[];
|
|
@@ -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,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,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,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,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
|
+
};
|