@getpara/evm-wallet-connectors 2.0.0-alpha.3 → 2.0.0-alpha.6
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/chunk-MMUBH76A.js +59 -0
- package/dist/global.d.js +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +5 -952
- package/dist/package.json +3 -0
- package/dist/providers/EvmExternalWalletContext.d.ts +2 -0
- package/dist/providers/EvmExternalWalletContext.js +369 -0
- package/dist/providers/ParaEvmContext.js +81 -0
- package/dist/stores/useStore.js +22 -0
- package/dist/types/Wallet.js +1 -0
- package/dist/types/utils.d.ts +1 -1
- package/dist/types/utils.js +1 -0
- package/dist/utils/computeWalletConnectMetaData.js +18 -0
- package/dist/utils/getInjectedConnector.js +69 -0
- package/dist/utils/getWalletConnectConnector.js +61 -0
- package/dist/utils/getWalletConnectUri.js +22 -0
- package/dist/utils/isEIP6963Connector.js +9 -0
- package/dist/utils/omitUndefinedValues.js +11 -0
- package/dist/utils/uniqueBy.js +14 -0
- package/dist/wallets/connectors/coinbase/coinbase.js +35 -0
- package/dist/wallets/connectors/coinbase/coinbaseIcon.js +6 -0
- package/dist/wallets/connectors/index.d.ts +2 -1
- package/dist/wallets/connectors/index.js +28 -0
- package/dist/wallets/connectors/metaMask/metaMask.js +84 -0
- package/dist/wallets/connectors/metaMask/metaMaskIcon.js +6 -0
- package/dist/wallets/connectors/rabby/rabby.js +25 -0
- package/dist/wallets/connectors/rabby/rabbyIcon.js +6 -0
- package/dist/wallets/connectors/rainbow/rainbow.js +30 -0
- package/dist/wallets/connectors/rainbow/rainbowIcon.js +6 -0
- package/dist/wallets/connectors/safe/safe.d.ts +2 -0
- package/dist/wallets/connectors/safe/safe.js +26 -0
- package/dist/wallets/connectors/safe/safeIcon.d.ts +1 -0
- package/dist/wallets/connectors/safe/safeIcon.js +6 -0
- package/dist/wallets/connectors/walletConnect/walletConnect.js +22 -0
- package/dist/wallets/connectors/walletConnect/walletConnectIcon.js +6 -0
- package/dist/wallets/connectors/zerion/zerion.js +36 -0
- package/dist/wallets/connectors/zerion/zerionIcon.js +6 -0
- package/dist/wallets/connectorsForWallets.js +73 -0
- package/dist/window.d.js +1 -0
- package/package.json +11 -8
- package/dist/index.js.br +0 -0
- package/dist/index.js.gz +0 -0
package/dist/index.js
CHANGED
|
@@ -1,956 +1,9 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
9
|
-
var __spreadValues = (a, b) => {
|
|
10
|
-
for (var prop in b || (b = {}))
|
|
11
|
-
if (__hasOwnProp.call(b, prop))
|
|
12
|
-
__defNormalProp(a, prop, b[prop]);
|
|
13
|
-
if (__getOwnPropSymbols)
|
|
14
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
15
|
-
if (__propIsEnum.call(b, prop))
|
|
16
|
-
__defNormalProp(a, prop, b[prop]);
|
|
17
|
-
}
|
|
18
|
-
return a;
|
|
19
|
-
};
|
|
20
|
-
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
21
|
-
var __objRest = (source, exclude) => {
|
|
22
|
-
var target = {};
|
|
23
|
-
for (var prop in source)
|
|
24
|
-
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
25
|
-
target[prop] = source[prop];
|
|
26
|
-
if (source != null && __getOwnPropSymbols)
|
|
27
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
28
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
29
|
-
target[prop] = source[prop];
|
|
30
|
-
}
|
|
31
|
-
return target;
|
|
32
|
-
};
|
|
33
|
-
var __async = (__this, __arguments, generator) => {
|
|
34
|
-
return new Promise((resolve, reject) => {
|
|
35
|
-
var fulfilled = (value) => {
|
|
36
|
-
try {
|
|
37
|
-
step(generator.next(value));
|
|
38
|
-
} catch (e) {
|
|
39
|
-
reject(e);
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
var rejected = (value) => {
|
|
43
|
-
try {
|
|
44
|
-
step(generator.throw(value));
|
|
45
|
-
} catch (e) {
|
|
46
|
-
reject(e);
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
50
|
-
step((generator = generator.apply(__this, __arguments)).next());
|
|
51
|
-
});
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
// src/providers/EvmExternalWalletContext.tsx
|
|
55
|
-
import { createContext, useCallback, useEffect, useMemo, useRef } from "react";
|
|
56
|
-
import {
|
|
57
|
-
useAccount,
|
|
58
|
-
useSwitchChain,
|
|
59
|
-
useConnect,
|
|
60
|
-
useDisconnect,
|
|
61
|
-
useEnsName,
|
|
62
|
-
useEnsAvatar,
|
|
63
|
-
useSignMessage,
|
|
64
|
-
useSwitchAccount,
|
|
65
|
-
useConnections
|
|
66
|
-
} from "wagmi";
|
|
67
|
-
|
|
68
|
-
// src/utils/isEIP6963Connector.ts
|
|
69
|
-
var isEIP6963Connector = (wallet) => {
|
|
70
|
-
var _a;
|
|
71
|
-
return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.startsWith("data:image")) && wallet.uid && wallet.name);
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
// src/utils/getWalletConnectUri.ts
|
|
75
|
-
var getWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
|
|
76
|
-
const provider = yield connector.getProvider();
|
|
77
|
-
if (connector.type === "coinbaseWallet") {
|
|
78
|
-
return provider.qrUrl;
|
|
79
|
-
}
|
|
80
|
-
return new Promise(
|
|
81
|
-
(resolve) => (
|
|
82
|
-
// Wagmi v2 doesn't have a return type for provider yet
|
|
83
|
-
// @ts-expect-error
|
|
84
|
-
provider.once("display_uri", (uri) => {
|
|
85
|
-
resolve(uriConverter ? uriConverter(uri) : uri);
|
|
86
|
-
})
|
|
87
|
-
)
|
|
88
|
-
);
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
// src/providers/EvmExternalWalletContext.tsx
|
|
92
|
-
import { normalize } from "viem/ens";
|
|
93
|
-
|
|
94
|
-
// src/stores/useStore.ts
|
|
95
|
-
import { create } from "zustand";
|
|
96
|
-
import { syncTabs } from "zustand-sync-tabs";
|
|
97
|
-
var useExternalWalletStore = create(
|
|
98
|
-
syncTabs(
|
|
99
|
-
(set) => ({
|
|
100
|
-
isConnecting: false,
|
|
101
|
-
updateState: (state) => {
|
|
102
|
-
set(__spreadValues({}, state));
|
|
103
|
-
}
|
|
104
|
-
}),
|
|
105
|
-
{
|
|
106
|
-
name: "para-evm-external-wallet-state"
|
|
107
|
-
}
|
|
108
|
-
)
|
|
109
|
-
);
|
|
110
|
-
|
|
111
|
-
// src/providers/EvmExternalWalletContext.tsx
|
|
112
|
-
import { isMobile, WalletType } from "@getpara/web-sdk";
|
|
113
|
-
import { jsx } from "react/jsx-runtime";
|
|
114
|
-
var defaultEvmExternalWallet = {
|
|
115
|
-
wallets: [],
|
|
116
|
-
chains: [],
|
|
117
|
-
chainId: void 0,
|
|
118
|
-
username: void 0,
|
|
119
|
-
avatar: void 0,
|
|
120
|
-
disconnect: () => Promise.resolve(),
|
|
121
|
-
switchChain: () => Promise.resolve({}),
|
|
122
|
-
connectParaEmbedded: () => Promise.resolve({}),
|
|
123
|
-
signMessage: () => Promise.resolve({}),
|
|
124
|
-
signVerificationMessage: () => Promise.resolve({})
|
|
125
|
-
};
|
|
126
|
-
var EvmExternalWalletContext = createContext(defaultEvmExternalWallet);
|
|
127
|
-
function EvmExternalWalletProvider({
|
|
128
|
-
children,
|
|
129
|
-
onSwitchWallet,
|
|
130
|
-
para,
|
|
131
|
-
walletsWithFullAuth,
|
|
132
|
-
connectedWallet
|
|
133
|
-
}) {
|
|
134
|
-
const { connectAsync, connectors: untypedConnectors } = useConnect();
|
|
135
|
-
const connections = useConnections();
|
|
136
|
-
const {
|
|
137
|
-
address: wagmiAddress,
|
|
138
|
-
isConnecting,
|
|
139
|
-
isReconnecting,
|
|
140
|
-
chainId,
|
|
141
|
-
connector: connectedConnector,
|
|
142
|
-
isConnected
|
|
143
|
-
} = useAccount();
|
|
144
|
-
const { switchAccount: wagmiSwitchAccount } = useSwitchAccount();
|
|
145
|
-
const { chains, switchChainAsync } = useSwitchChain();
|
|
146
|
-
const { disconnectAsync } = useDisconnect();
|
|
147
|
-
const { data: ensName } = useEnsName({ address: wagmiAddress });
|
|
148
|
-
const { data: ensAvatar } = useEnsAvatar({ name: normalize(ensName) });
|
|
149
|
-
const { signMessageAsync } = useSignMessage();
|
|
150
|
-
const verificationMessage = useRef();
|
|
151
|
-
const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
|
|
152
|
-
const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
|
|
153
|
-
const getStoredExternalWallets = () => {
|
|
154
|
-
const storedExternalWalletsString = localStorage.getItem("@CAPSULE/externalWallets");
|
|
155
|
-
let storedExternalWallets = {};
|
|
156
|
-
if (storedExternalWalletsString) {
|
|
157
|
-
storedExternalWallets = JSON.parse(storedExternalWalletsString);
|
|
158
|
-
}
|
|
159
|
-
return storedExternalWallets;
|
|
160
|
-
};
|
|
161
|
-
const switchAccount = useCallback(
|
|
162
|
-
(connectorName) => {
|
|
163
|
-
var _a;
|
|
164
|
-
const connector = (_a = connections.find((c) => c.connector.name === connectorName)) == null ? void 0 : _a.connector;
|
|
165
|
-
if (!connector) {
|
|
166
|
-
console.warn(`connector not found: ${connectorName}`);
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
wagmiSwitchAccount({ connector });
|
|
170
|
-
},
|
|
171
|
-
[connections, wagmiSwitchAccount]
|
|
172
|
-
);
|
|
173
|
-
useEffect(() => {
|
|
174
|
-
const storedExternalWallet = getStoredExternalWallets()[wagmiAddress != null ? wagmiAddress : ""];
|
|
175
|
-
if (!isConnecting && !isReconnecting && !isLocalConnecting && !!wagmiAddress && !storedExternalWallet && (connectedConnector == null ? void 0 : connectedConnector.id) !== "para") {
|
|
176
|
-
reset();
|
|
177
|
-
}
|
|
178
|
-
}, [isConnecting, isReconnecting, isLocalConnecting, wagmiAddress, connectedConnector]);
|
|
179
|
-
useEffect(() => {
|
|
180
|
-
const storedExternalWallet = Object.values(para.externalWallets || {})[0];
|
|
181
|
-
if (!isLocalConnecting && !isConnecting && !isReconnecting && (storedExternalWallet == null ? void 0 : storedExternalWallet.type) === WalletType.EVM && (storedExternalWallet == null ? void 0 : storedExternalWallet.address) !== wagmiAddress && (connectedConnector == null ? void 0 : connectedConnector.id) !== "para") {
|
|
182
|
-
switchWallet(wagmiAddress);
|
|
183
|
-
}
|
|
184
|
-
}, [isLocalConnecting, wagmiAddress, isReconnecting, isConnecting]);
|
|
185
|
-
useEffect(() => {
|
|
186
|
-
if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedConnector && connectedWallet.type === WalletType.EVM && connectedConnector.name !== connectedWallet.name) {
|
|
187
|
-
switchAccount(connectedWallet.isExternal ? connectedWallet.name : "Para");
|
|
188
|
-
}
|
|
189
|
-
}, [isLocalConnecting, isConnecting, isReconnecting, connectedWallet, wagmiSwitchAccount]);
|
|
190
|
-
useEffect(() => {
|
|
191
|
-
if (!isLocalConnecting && !isConnecting && !isReconnecting && !isConnected && !connectedConnector) {
|
|
192
|
-
if (Object.values(para.wallets).length === 0) {
|
|
193
|
-
return;
|
|
194
|
-
}
|
|
195
|
-
connectParaEmbedded();
|
|
196
|
-
}
|
|
197
|
-
}, [isLocalConnecting, isConnecting, isReconnecting, isConnected, connectedConnector]);
|
|
198
|
-
const connectors = untypedConnectors;
|
|
199
|
-
const reset = () => __async(this, null, function* () {
|
|
200
|
-
yield disconnectAsync();
|
|
201
|
-
yield para.logout();
|
|
202
|
-
});
|
|
203
|
-
const signMessage = (message) => __async(this, null, function* () {
|
|
204
|
-
try {
|
|
205
|
-
const signature = yield signMessageAsync({
|
|
206
|
-
message,
|
|
207
|
-
account: wagmiAddress
|
|
208
|
-
});
|
|
209
|
-
return {
|
|
210
|
-
address: wagmiAddress,
|
|
211
|
-
signature
|
|
212
|
-
};
|
|
213
|
-
} catch (e) {
|
|
214
|
-
switch (e.name) {
|
|
215
|
-
case "UserRejectedRequestError": {
|
|
216
|
-
return { error: "Signature request rejected" };
|
|
217
|
-
}
|
|
218
|
-
default: {
|
|
219
|
-
return { error: "An unknown error occurred" };
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
});
|
|
224
|
-
const signVerificationMessage = () => __async(this, null, function* () {
|
|
225
|
-
const signature = yield signMessage(verificationMessage.current);
|
|
226
|
-
return signature;
|
|
227
|
-
});
|
|
228
|
-
const switchChain = (chainId2) => __async(this, null, function* () {
|
|
229
|
-
var _a, _b, _c;
|
|
230
|
-
let error;
|
|
231
|
-
try {
|
|
232
|
-
yield switchChainAsync({ chainId: chainId2 });
|
|
233
|
-
} catch (e) {
|
|
234
|
-
if (e.details.includes("Missing or invalid.")) {
|
|
235
|
-
const chain = chains.find((c) => c.id === chainId2);
|
|
236
|
-
error = [
|
|
237
|
-
"Network not supported.",
|
|
238
|
-
`You may need to add ${chain == null ? void 0 : chain.name} support to ${(_c = (_b = (_a = connectedConnector == null ? void 0 : connectedConnector.paraDetails) == null ? void 0 : _a.name) != null ? _b : connectedConnector == null ? void 0 : connectedConnector.name) != null ? _c : "the wallet"} manually.`
|
|
239
|
-
];
|
|
240
|
-
} else {
|
|
241
|
-
switch (e.name) {
|
|
242
|
-
case "UserRejectedRequestError": {
|
|
243
|
-
error = ["Change request rejected"];
|
|
244
|
-
break;
|
|
245
|
-
}
|
|
246
|
-
default: {
|
|
247
|
-
error = ["An unknown error occurred"];
|
|
248
|
-
break;
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
return { error };
|
|
254
|
-
});
|
|
255
|
-
const login = (_0) => __async(this, [_0], function* ({
|
|
256
|
-
address,
|
|
257
|
-
walletId,
|
|
258
|
-
connectorName
|
|
259
|
-
}) {
|
|
260
|
-
var _a;
|
|
261
|
-
try {
|
|
262
|
-
return yield para.loginExternalWallet({
|
|
263
|
-
externalWallet: {
|
|
264
|
-
address,
|
|
265
|
-
type: WalletType.EVM,
|
|
266
|
-
provider: connectorName,
|
|
267
|
-
withFullParaAuth: walletsWithFullAuth == null ? void 0 : walletsWithFullAuth.includes((_a = walletId == null ? void 0 : walletId.toUpperCase()) != null ? _a : "")
|
|
268
|
-
}
|
|
269
|
-
});
|
|
270
|
-
} catch (err) {
|
|
271
|
-
yield disconnectAsync();
|
|
272
|
-
yield para.logout();
|
|
273
|
-
throw "Error logging you in. Please try again.";
|
|
274
|
-
}
|
|
275
|
-
});
|
|
276
|
-
const switchWallet = (address) => __async(this, null, function* () {
|
|
277
|
-
var _a;
|
|
278
|
-
updateExternalWalletState({ isConnecting: true });
|
|
279
|
-
let error;
|
|
280
|
-
if (!address) {
|
|
281
|
-
yield para.logout();
|
|
282
|
-
} else {
|
|
283
|
-
if (para.isExternalWalletAuth) {
|
|
284
|
-
yield reset();
|
|
285
|
-
} else {
|
|
286
|
-
try {
|
|
287
|
-
yield login({
|
|
288
|
-
address,
|
|
289
|
-
connectorName: connectedConnector == null ? void 0 : connectedConnector.name,
|
|
290
|
-
walletId: (_a = getParaDetails(connectedConnector.id)) == null ? void 0 : _a.id
|
|
291
|
-
});
|
|
292
|
-
} catch (err) {
|
|
293
|
-
error = err;
|
|
294
|
-
}
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
onSwitchWallet == null ? void 0 : onSwitchWallet({ address, error });
|
|
298
|
-
updateExternalWalletState({ isConnecting: false });
|
|
299
|
-
});
|
|
300
|
-
const connect = (connector) => __async(this, null, function* () {
|
|
301
|
-
var _a, _b, _c, _d;
|
|
302
|
-
updateExternalWalletState({ isConnecting: true });
|
|
303
|
-
yield disconnectAsync();
|
|
304
|
-
const walletChainId = yield connector.getChainId();
|
|
305
|
-
let authState;
|
|
306
|
-
let address;
|
|
307
|
-
let error;
|
|
308
|
-
try {
|
|
309
|
-
const data = yield connectAsync({
|
|
310
|
-
// If the wallet is already on a supported chain, use that to avoid a chain switch prompt.
|
|
311
|
-
chainId: (_c = (_a = chains.find(({ id }) => id === walletChainId)) == null ? void 0 : _a.id) != null ? _c : (
|
|
312
|
-
// Fall back to the first chain provided.
|
|
313
|
-
(_b = chains[0]) == null ? void 0 : _b.id
|
|
314
|
-
),
|
|
315
|
-
connector
|
|
316
|
-
});
|
|
317
|
-
address = (_d = data.accounts) == null ? void 0 : _d[0];
|
|
318
|
-
if (address) {
|
|
319
|
-
try {
|
|
320
|
-
authState = yield login({ address, connectorName: connector.name, walletId: connector.paraDetails.id });
|
|
321
|
-
verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
|
|
322
|
-
} catch (err) {
|
|
323
|
-
address = void 0;
|
|
324
|
-
error = err;
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
} catch (e) {
|
|
328
|
-
switch (e.name) {
|
|
329
|
-
case "UserRejectedRequestError": {
|
|
330
|
-
error = "Connection request rejected";
|
|
331
|
-
break;
|
|
332
|
-
}
|
|
333
|
-
case "ResourceUnavailableRpcError": {
|
|
334
|
-
`${connector.name} not detected`;
|
|
335
|
-
break;
|
|
336
|
-
}
|
|
337
|
-
default: {
|
|
338
|
-
error = "An unknown error occurred";
|
|
339
|
-
break;
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
}
|
|
343
|
-
updateExternalWalletState({ isConnecting: false });
|
|
344
|
-
return { address, authState, error };
|
|
345
|
-
});
|
|
346
|
-
const connectMobile = (connector, isManualWalletConnect) => __async(this, null, function* () {
|
|
347
|
-
const _isMobile = isManualWalletConnect !== void 0 ? isManualWalletConnect : isMobile();
|
|
348
|
-
const _connector = connector.walletConnectModalConnector && _isMobile ? connector.walletConnectModalConnector : connector;
|
|
349
|
-
return yield connect(_connector);
|
|
350
|
-
});
|
|
351
|
-
const getQrUri = (connector) => () => {
|
|
352
|
-
var _a;
|
|
353
|
-
return getWalletConnectUri(connector, (_a = connector.paraDetails) == null ? void 0 : _a.getUri);
|
|
354
|
-
};
|
|
355
|
-
const nonEip6963ConnectorsByRdns = {};
|
|
356
|
-
let walletConnectModalConnector;
|
|
357
|
-
connectors.filter((c) => !isEIP6963Connector(c)).forEach((c) => {
|
|
358
|
-
if (c.paraDetails) {
|
|
359
|
-
nonEip6963ConnectorsByRdns[c.paraDetails.rdns] = c.paraDetails;
|
|
360
|
-
if (c.paraDetails.isWalletConnectModalConnector) {
|
|
361
|
-
walletConnectModalConnector = c;
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
});
|
|
365
|
-
const eip6963ids = connectors.filter((c) => isEIP6963Connector(c)).map((c) => c.id);
|
|
366
|
-
const dedupedConnectors = connectors.map((c) => {
|
|
367
|
-
var _a, _b, _c;
|
|
368
|
-
if ((_a = c.paraDetails) == null ? void 0 : _a.isWalletConnectModalConnector) {
|
|
369
|
-
return;
|
|
370
|
-
}
|
|
371
|
-
if (!isEIP6963Connector(c) && eip6963ids.includes((_b = c.paraDetails) == null ? void 0 : _b.rdns)) {
|
|
372
|
-
return;
|
|
373
|
-
}
|
|
374
|
-
if (isEIP6963Connector(c)) {
|
|
375
|
-
const paraMetadata = nonEip6963ConnectorsByRdns[c.id];
|
|
376
|
-
return __spreadProps(__spreadValues({}, c), { paraDetails: paraMetadata });
|
|
377
|
-
}
|
|
378
|
-
if (((_c = c.paraDetails) == null ? void 0 : _c.id) === "walletConnect" && walletConnectModalConnector) {
|
|
379
|
-
return __spreadProps(__spreadValues({}, c), { walletConnectModalConnector });
|
|
380
|
-
}
|
|
381
|
-
return c;
|
|
382
|
-
}).filter((c) => !!c);
|
|
383
|
-
const wallets = dedupedConnectors.map((c) => {
|
|
384
|
-
const connector = __spreadValues(__spreadValues({}, c), c.paraDetails);
|
|
385
|
-
return __spreadProps(__spreadValues({}, connector), {
|
|
386
|
-
connect: () => connect(connector),
|
|
387
|
-
connectMobile: (isManualWalletConnect) => connectMobile(connector, isManualWalletConnect),
|
|
388
|
-
type: WalletType.EVM,
|
|
389
|
-
getQrUri: getQrUri(connector)
|
|
390
|
-
});
|
|
391
|
-
});
|
|
392
|
-
const getParaDetails = (id) => {
|
|
393
|
-
var _a;
|
|
394
|
-
return (_a = connectors.find((w) => w.id === id)) == null ? void 0 : _a.paraDetails;
|
|
395
|
-
};
|
|
396
|
-
const formattedChains = chains.map((c) => {
|
|
397
|
-
return {
|
|
398
|
-
id: c.id,
|
|
399
|
-
name: c.name
|
|
400
|
-
};
|
|
401
|
-
});
|
|
402
|
-
const username = useMemo(() => ensName != null ? ensName : wagmiAddress, [ensName, wagmiAddress]);
|
|
403
|
-
const connectParaEmbedded = useCallback(() => __async(this, null, function* () {
|
|
404
|
-
const paraConnectorInstance = connectors.find((c) => c.id === "para");
|
|
405
|
-
if (!paraConnectorInstance) {
|
|
406
|
-
return { error: "No para connector instance" };
|
|
407
|
-
}
|
|
408
|
-
try {
|
|
409
|
-
const result = yield connectAsync({ connector: paraConnectorInstance });
|
|
410
|
-
return { result };
|
|
411
|
-
} catch (err) {
|
|
412
|
-
const error = err instanceof Error ? err.message : "Unknown error";
|
|
413
|
-
return { error };
|
|
414
|
-
}
|
|
415
|
-
}), [connectors]);
|
|
416
|
-
return /* @__PURE__ */ jsx(
|
|
417
|
-
EvmExternalWalletContext.Provider,
|
|
418
|
-
{
|
|
419
|
-
value: {
|
|
420
|
-
wallets,
|
|
421
|
-
chains: formattedChains,
|
|
422
|
-
chainId,
|
|
423
|
-
username,
|
|
424
|
-
avatar: ensAvatar,
|
|
425
|
-
disconnect: disconnectAsync,
|
|
426
|
-
switchChain,
|
|
427
|
-
connectParaEmbedded,
|
|
428
|
-
signMessage,
|
|
429
|
-
signVerificationMessage
|
|
430
|
-
},
|
|
431
|
-
children
|
|
432
|
-
}
|
|
433
|
-
);
|
|
434
|
-
}
|
|
435
|
-
|
|
436
|
-
// src/providers/ParaEvmContext.tsx
|
|
437
|
-
import { useMemo as useMemo2 } from "react";
|
|
438
|
-
import { createConfig, WagmiProvider } from "wagmi";
|
|
439
|
-
|
|
440
|
-
// src/utils/uniqueBy.ts
|
|
441
|
-
function uniqueBy(items, key) {
|
|
442
|
-
const filtered = [];
|
|
443
|
-
for (const item of items) {
|
|
444
|
-
if (!filtered.some((x) => x[key] === item[key])) {
|
|
445
|
-
filtered.push(item);
|
|
446
|
-
}
|
|
447
|
-
}
|
|
448
|
-
return filtered;
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
// src/utils/computeWalletConnectMetaData.ts
|
|
452
|
-
var computeWalletConnectMetaData = ({
|
|
453
|
-
appName,
|
|
454
|
-
appDescription,
|
|
455
|
-
appUrl,
|
|
456
|
-
appIcon
|
|
457
|
-
}) => {
|
|
458
|
-
return {
|
|
459
|
-
name: appName,
|
|
460
|
-
description: appDescription != null ? appDescription : appName,
|
|
461
|
-
url: appUrl != null ? appUrl : typeof window !== "undefined" ? window.location.href : "",
|
|
462
|
-
icons: [...appIcon ? [appIcon] : []]
|
|
463
|
-
};
|
|
464
|
-
};
|
|
465
|
-
|
|
466
|
-
// src/utils/omitUndefinedValues.ts
|
|
467
|
-
function omitUndefinedValues(obj) {
|
|
468
|
-
return Object.fromEntries(
|
|
469
|
-
//@ts-ignore
|
|
470
|
-
Object.entries(obj).filter(([_key, value]) => value !== void 0)
|
|
471
|
-
);
|
|
472
|
-
}
|
|
473
|
-
|
|
474
|
-
// src/wallets/connectorsForWallets.ts
|
|
475
|
-
var connectorsForWallets = (walletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }) => {
|
|
476
|
-
if (!walletList.length) {
|
|
477
|
-
return [];
|
|
478
|
-
}
|
|
479
|
-
let index = -1;
|
|
480
|
-
const connectors = [];
|
|
481
|
-
const wallets = [];
|
|
482
|
-
const walletConnectMetaData = computeWalletConnectMetaData({
|
|
483
|
-
appName,
|
|
484
|
-
appDescription,
|
|
485
|
-
appUrl,
|
|
486
|
-
appIcon
|
|
487
|
-
});
|
|
488
|
-
walletList.forEach((createWallet) => {
|
|
489
|
-
index++;
|
|
490
|
-
const wallet = createWallet({
|
|
491
|
-
projectId,
|
|
492
|
-
appName,
|
|
493
|
-
appIcon,
|
|
494
|
-
// `option` is being used only for `walletConnectWallet` wallet
|
|
495
|
-
options: __spreadValues({
|
|
496
|
-
metadata: walletConnectMetaData
|
|
497
|
-
}, walletConnectParameters),
|
|
498
|
-
// Every other wallet that supports walletConnect flow and is not
|
|
499
|
-
// `walletConnectWallet` wallet will have `walletConnectParameters` property
|
|
500
|
-
walletConnectParameters: __spreadValues({
|
|
501
|
-
metadata: walletConnectMetaData
|
|
502
|
-
}, walletConnectParameters)
|
|
503
|
-
});
|
|
504
|
-
const walletListItem = __spreadProps(__spreadValues({}, wallet), {
|
|
505
|
-
index
|
|
506
|
-
});
|
|
507
|
-
wallets.push(walletListItem);
|
|
508
|
-
});
|
|
509
|
-
const walletListItems = uniqueBy([...wallets], "id");
|
|
510
|
-
for (const _a of walletListItems) {
|
|
511
|
-
const _b = _a, { createConnector: createConnector4 } = _b, walletMeta = __objRest(_b, ["createConnector"]);
|
|
512
|
-
const walletMetaData = (additionalParaParams) => {
|
|
513
|
-
return {
|
|
514
|
-
paraDetails: omitUndefinedValues(__spreadValues(__spreadProps(__spreadValues({}, walletMeta), {
|
|
515
|
-
isParaConnector: true
|
|
516
|
-
}), additionalParaParams ? additionalParaParams : {}))
|
|
517
|
-
};
|
|
518
|
-
};
|
|
519
|
-
const isWalletConnectConnector = walletMeta.id === "walletConnect";
|
|
520
|
-
if (isWalletConnectConnector && createConnector4) {
|
|
521
|
-
connectors.push(
|
|
522
|
-
createConnector4(
|
|
523
|
-
walletMetaData({
|
|
524
|
-
isWalletConnectModalConnector: true,
|
|
525
|
-
showQrModal: true
|
|
526
|
-
})
|
|
527
|
-
)
|
|
528
|
-
);
|
|
529
|
-
}
|
|
530
|
-
if (createConnector4) {
|
|
531
|
-
connectors.push(createConnector4(walletMetaData()));
|
|
532
|
-
}
|
|
533
|
-
}
|
|
534
|
-
return connectors;
|
|
535
|
-
};
|
|
536
|
-
|
|
537
|
-
// src/providers/ParaEvmContext.tsx
|
|
538
|
-
import { http } from "viem";
|
|
539
|
-
import { paraConnector } from "@getpara/wagmi-v2-connector";
|
|
540
|
-
import { jsx as jsx2 } from "react/jsx-runtime";
|
|
541
|
-
var createDefaultTransports = (chains) => {
|
|
542
|
-
const transportsObject = chains.reduce((acc, chain) => {
|
|
543
|
-
const key = chain.id;
|
|
544
|
-
acc[key] = http();
|
|
545
|
-
return acc;
|
|
546
|
-
}, {});
|
|
547
|
-
return transportsObject;
|
|
548
|
-
};
|
|
549
|
-
function ParaEvmProvider({
|
|
550
|
-
children,
|
|
551
|
-
internalConfig,
|
|
552
|
-
config: _config,
|
|
553
|
-
wagmiProviderProps
|
|
554
|
-
}) {
|
|
555
|
-
const para = internalConfig.para;
|
|
556
|
-
const _a = _config, {
|
|
557
|
-
projectId,
|
|
558
|
-
appName,
|
|
559
|
-
appDescription,
|
|
560
|
-
appIcon,
|
|
561
|
-
appUrl,
|
|
562
|
-
wallets,
|
|
563
|
-
chains,
|
|
564
|
-
transports,
|
|
565
|
-
paraConnectorOptions
|
|
566
|
-
} = _a, wagmiConfigParams = __objRest(_a, [
|
|
567
|
-
"projectId",
|
|
568
|
-
"appName",
|
|
569
|
-
"appDescription",
|
|
570
|
-
"appIcon",
|
|
571
|
-
"appUrl",
|
|
572
|
-
"wallets",
|
|
573
|
-
"chains",
|
|
574
|
-
"transports",
|
|
575
|
-
"paraConnectorOptions"
|
|
576
|
-
]);
|
|
577
|
-
const paraConnectorInstance = useMemo2(() => {
|
|
578
|
-
return paraConnector({
|
|
579
|
-
para,
|
|
580
|
-
chains: [...chains],
|
|
581
|
-
disableModal: true,
|
|
582
|
-
appName,
|
|
583
|
-
options: paraConnectorOptions != null ? paraConnectorOptions : {}
|
|
584
|
-
});
|
|
585
|
-
}, [para]);
|
|
586
|
-
const config = useMemo2(() => {
|
|
587
|
-
const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
|
|
588
|
-
const baseConnectors = connectorsForWallets(wallets, {
|
|
589
|
-
projectId,
|
|
590
|
-
appName,
|
|
591
|
-
appDescription,
|
|
592
|
-
appUrl,
|
|
593
|
-
appIcon,
|
|
594
|
-
walletConnectParameters: { metadata: wcMetadata }
|
|
595
|
-
});
|
|
596
|
-
const allConnectors = [...baseConnectors, paraConnectorInstance];
|
|
597
|
-
return createConfig(__spreadProps(__spreadValues({}, wagmiConfigParams), {
|
|
598
|
-
chains,
|
|
599
|
-
transports: transports || createDefaultTransports(chains),
|
|
600
|
-
connectors: allConnectors
|
|
601
|
-
}));
|
|
602
|
-
}, [wallets, paraConnectorInstance]);
|
|
603
|
-
return /* @__PURE__ */ jsx2(WagmiProvider, __spreadProps(__spreadValues({ config }, wagmiProviderProps), { children: /* @__PURE__ */ jsx2(EvmExternalWalletProvider, __spreadProps(__spreadValues({}, internalConfig), { children })) }));
|
|
604
|
-
}
|
|
605
|
-
|
|
606
|
-
// src/wallets/connectors/metaMask/metaMask.ts
|
|
607
|
-
import { isAndroid, isIOS, isTelegram } from "@getpara/web-sdk";
|
|
608
|
-
|
|
609
|
-
// src/utils/getInjectedConnector.ts
|
|
610
|
-
import { createConnector } from "wagmi";
|
|
611
|
-
import { injected } from "wagmi/connectors";
|
|
612
|
-
function getExplicitInjectedProvider(flag) {
|
|
613
|
-
const _window = typeof window !== "undefined" ? window : void 0;
|
|
614
|
-
if (typeof _window === "undefined" || typeof _window.ethereum === "undefined") return;
|
|
615
|
-
const providers = _window.ethereum.providers;
|
|
616
|
-
return providers ? providers.find((provider) => provider[flag]) : _window.ethereum[flag] ? _window.ethereum : void 0;
|
|
617
|
-
}
|
|
618
|
-
function getWindowProviderNamespace(namespace) {
|
|
619
|
-
const providerSearch = (provider, namespace2) => {
|
|
620
|
-
const [property, ...path] = namespace2.split(".");
|
|
621
|
-
const _provider = provider[property];
|
|
622
|
-
if (_provider) {
|
|
623
|
-
if (path.length === 0) return _provider;
|
|
624
|
-
return providerSearch(_provider, path.join("."));
|
|
625
|
-
}
|
|
626
|
-
};
|
|
627
|
-
if (typeof window !== "undefined") return providerSearch(window, namespace);
|
|
628
|
-
}
|
|
629
|
-
function hasInjectedProvider({ flag, namespace }) {
|
|
630
|
-
if (namespace && typeof getWindowProviderNamespace(namespace) !== "undefined") return true;
|
|
631
|
-
if (flag && typeof getExplicitInjectedProvider(flag) !== "undefined") return true;
|
|
632
|
-
return false;
|
|
633
|
-
}
|
|
634
|
-
function getInjectedProvider({ flag, namespace }) {
|
|
635
|
-
var _a;
|
|
636
|
-
const _window = typeof window !== "undefined" ? window : void 0;
|
|
637
|
-
if (typeof _window === "undefined") return;
|
|
638
|
-
if (namespace) {
|
|
639
|
-
const windowProvider = getWindowProviderNamespace(namespace);
|
|
640
|
-
if (windowProvider) return windowProvider;
|
|
641
|
-
}
|
|
642
|
-
const providers = (_a = _window.ethereum) == null ? void 0 : _a.providers;
|
|
643
|
-
if (flag) {
|
|
644
|
-
const provider = getExplicitInjectedProvider(flag);
|
|
645
|
-
if (provider) return provider;
|
|
646
|
-
}
|
|
647
|
-
if (typeof providers !== "undefined" && providers.length > 0) return providers[0];
|
|
648
|
-
return _window.ethereum;
|
|
649
|
-
}
|
|
650
|
-
function createInjectedConnector(provider) {
|
|
651
|
-
return (walletDetails) => {
|
|
652
|
-
const injectedConfig = provider ? {
|
|
653
|
-
target: () => ({
|
|
654
|
-
id: walletDetails.paraDetails.id,
|
|
655
|
-
name: walletDetails.paraDetails.name,
|
|
656
|
-
provider
|
|
657
|
-
})
|
|
658
|
-
} : {};
|
|
659
|
-
return createConnector((config) => __spreadValues(__spreadValues({}, injected(injectedConfig)(config)), walletDetails));
|
|
660
|
-
};
|
|
661
|
-
}
|
|
662
|
-
function getInjectedConnector({
|
|
663
|
-
flag,
|
|
664
|
-
namespace,
|
|
665
|
-
target
|
|
666
|
-
}) {
|
|
667
|
-
const provider = target ? target : getInjectedProvider({ flag, namespace });
|
|
668
|
-
return createInjectedConnector(provider);
|
|
669
|
-
}
|
|
670
|
-
|
|
671
|
-
// src/utils/getWalletConnectConnector.ts
|
|
672
|
-
import { createConnector as createConnector2 } from "wagmi";
|
|
673
|
-
import { walletConnect } from "wagmi/connectors";
|
|
674
|
-
var walletConnectInstances = /* @__PURE__ */ new Map();
|
|
675
|
-
var getOrCreateWalletConnectInstance = ({
|
|
676
|
-
projectId,
|
|
677
|
-
walletConnectParameters,
|
|
678
|
-
paraDetailsShowQrModal
|
|
679
|
-
}) => {
|
|
680
|
-
let config = __spreadProps(__spreadValues({}, walletConnectParameters ? walletConnectParameters : {}), {
|
|
681
|
-
projectId,
|
|
682
|
-
showQrModal: false
|
|
683
|
-
// Required. Otherwise WalletConnect modal (Web3Modal) will popup during time of connection for a wallet
|
|
684
|
-
});
|
|
685
|
-
if (paraDetailsShowQrModal) {
|
|
686
|
-
config = __spreadProps(__spreadValues({}, config), { showQrModal: true });
|
|
687
|
-
}
|
|
688
|
-
const serializedConfig = JSON.stringify(config);
|
|
689
|
-
const sharedWalletConnector = walletConnectInstances.get(serializedConfig);
|
|
690
|
-
if (sharedWalletConnector) {
|
|
691
|
-
return sharedWalletConnector;
|
|
692
|
-
}
|
|
693
|
-
const newWalletConnectInstance = walletConnect(config);
|
|
694
|
-
walletConnectInstances.set(serializedConfig, newWalletConnectInstance);
|
|
695
|
-
return newWalletConnectInstance;
|
|
696
|
-
};
|
|
697
|
-
function createWalletConnectConnector({
|
|
698
|
-
projectId,
|
|
699
|
-
walletDetails,
|
|
700
|
-
walletConnectParameters
|
|
701
|
-
}) {
|
|
702
|
-
return createConnector2((config) => __spreadProps(__spreadValues(__spreadValues({}, getOrCreateWalletConnectInstance({
|
|
703
|
-
projectId,
|
|
704
|
-
walletConnectParameters,
|
|
705
|
-
// Used in `connectorsForWallets` to add another
|
|
706
|
-
// walletConnect wallet into Para with modal popup option
|
|
707
|
-
paraDetailsShowQrModal: walletDetails.paraDetails.showQrModal
|
|
708
|
-
})(config)), walletDetails), {
|
|
709
|
-
id: walletDetails.paraDetails.id
|
|
710
|
-
}));
|
|
711
|
-
}
|
|
712
|
-
function getWalletConnectConnector({
|
|
713
|
-
projectId,
|
|
714
|
-
walletConnectParameters
|
|
715
|
-
}) {
|
|
716
|
-
if (!projectId || projectId === "") {
|
|
717
|
-
return;
|
|
718
|
-
}
|
|
719
|
-
return (walletDetails) => createWalletConnectConnector({
|
|
720
|
-
projectId,
|
|
721
|
-
walletDetails,
|
|
722
|
-
walletConnectParameters
|
|
723
|
-
});
|
|
724
|
-
}
|
|
725
|
-
|
|
726
|
-
// src/wallets/connectors/metaMask/metaMaskIcon.ts
|
|
727
|
-
var icon = "";
|
|
728
|
-
|
|
729
|
-
// src/wallets/connectors/metaMask/metaMask.ts
|
|
730
|
-
function isMetaMask(ethereum) {
|
|
731
|
-
if (!(ethereum == null ? void 0 : ethereum.isMetaMask)) return false;
|
|
732
|
-
if (ethereum.isBraveWallet && !ethereum._events && !ethereum._state) return false;
|
|
733
|
-
if (ethereum.isApexWallet) return false;
|
|
734
|
-
if (ethereum.isAvalanche) return false;
|
|
735
|
-
if (ethereum.isBackpack) return false;
|
|
736
|
-
if (ethereum.isBifrost) return false;
|
|
737
|
-
if (ethereum.isBitKeep) return false;
|
|
738
|
-
if (ethereum.isBitski) return false;
|
|
739
|
-
if (ethereum.isBlockWallet) return false;
|
|
740
|
-
if (ethereum.isCoinbaseWallet) return false;
|
|
741
|
-
if (ethereum.isDawn) return false;
|
|
742
|
-
if (ethereum.isEnkrypt) return false;
|
|
743
|
-
if (ethereum.isExodus) return false;
|
|
744
|
-
if (ethereum.isFrame) return false;
|
|
745
|
-
if (ethereum.isFrontier) return false;
|
|
746
|
-
if (ethereum.isGamestop) return false;
|
|
747
|
-
if (ethereum.isHyperPay) return false;
|
|
748
|
-
if (ethereum.isImToken) return false;
|
|
749
|
-
if (ethereum.isKuCoinWallet) return false;
|
|
750
|
-
if (ethereum.isMathWallet) return false;
|
|
751
|
-
if (ethereum.isNestWallet) return false;
|
|
752
|
-
if (ethereum.isOkxWallet || ethereum.isOKExWallet) return false;
|
|
753
|
-
if (ethereum.isOneInchIOSWallet || ethereum.isOneInchAndroidWallet) return false;
|
|
754
|
-
if (ethereum.isOpera) return false;
|
|
755
|
-
if (ethereum.isPhantom) return false;
|
|
756
|
-
if (ethereum.isPortal) return false;
|
|
757
|
-
if (ethereum.isRabby) return false;
|
|
758
|
-
if (ethereum.isRainbow) return false;
|
|
759
|
-
if (ethereum.isStatus) return false;
|
|
760
|
-
if (ethereum.isTalisman) return false;
|
|
761
|
-
if (ethereum.isTally) return false;
|
|
762
|
-
if (ethereum.isTokenPocket) return false;
|
|
763
|
-
if (ethereum.isTokenary) return false;
|
|
764
|
-
if (ethereum.isTrust || ethereum.isTrustWallet) return false;
|
|
765
|
-
if (ethereum.isXDEFI) return false;
|
|
766
|
-
if (ethereum.isZeal) return false;
|
|
767
|
-
if (ethereum.isZerion) return false;
|
|
768
|
-
if (ethereum.__seif) return false;
|
|
769
|
-
return true;
|
|
770
|
-
}
|
|
771
|
-
var metaMaskWallet = ({ projectId, walletConnectParameters }) => {
|
|
772
|
-
var _a, _b, _c, _d;
|
|
773
|
-
let metaMaskTarget = typeof window !== "undefined" ? (_c = (_b = (_a = window.ethereum) == null ? void 0 : _a.providers) == null ? void 0 : _b.find(isMetaMask)) != null ? _c : window.ethereum : void 0;
|
|
774
|
-
const metaMaskInjectedProvider = metaMaskTarget ? metaMaskTarget : getInjectedProvider({ flag: "isMetaMask" });
|
|
775
|
-
const isMetaMaskInjected = !!metaMaskInjectedProvider && metaMaskInjectedProvider.isMetaMask;
|
|
776
|
-
const providerMapTarget = (_d = metaMaskTarget == null ? void 0 : metaMaskTarget.providerMap) == null ? void 0 : _d.get("MetaMask");
|
|
777
|
-
if (providerMapTarget) {
|
|
778
|
-
metaMaskTarget = providerMapTarget;
|
|
779
|
-
}
|
|
780
|
-
const getUri = (uri) => {
|
|
781
|
-
return isAndroid() ? `metamask://wc?uri=${encodeURIComponent(uri)}` : isIOS() ? !isTelegram() ? (
|
|
782
|
-
// currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
|
|
783
|
-
`metamask://wc?uri=${encodeURIComponent(uri)}`
|
|
784
|
-
) : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}` : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}`;
|
|
785
|
-
};
|
|
786
|
-
return {
|
|
787
|
-
id: "metaMask",
|
|
788
|
-
name: "MetaMask",
|
|
789
|
-
rdns: "io.metamask",
|
|
790
|
-
iconUrl: icon,
|
|
791
|
-
installed: isMetaMaskInjected,
|
|
792
|
-
isExtension: true,
|
|
793
|
-
isMobile: true,
|
|
794
|
-
downloadUrl: "https://metamask.io/download/",
|
|
795
|
-
getUri,
|
|
796
|
-
createConnector: isMetaMaskInjected ? getInjectedConnector({
|
|
797
|
-
target: metaMaskTarget
|
|
798
|
-
}) : getWalletConnectConnector({
|
|
799
|
-
projectId,
|
|
800
|
-
walletConnectParameters
|
|
801
|
-
})
|
|
802
|
-
};
|
|
803
|
-
};
|
|
804
|
-
|
|
805
|
-
// src/wallets/connectors/rainbow/rainbow.ts
|
|
806
|
-
import { isAndroid as isAndroid2, isIOS as isIOS2, isTelegram as isTelegram2 } from "@getpara/web-sdk";
|
|
807
|
-
|
|
808
|
-
// src/wallets/connectors/rainbow/rainbowIcon.ts
|
|
809
|
-
var icon2 = "";
|
|
810
|
-
|
|
811
|
-
// src/wallets/connectors/rainbow/rainbow.ts
|
|
812
|
-
var rainbowWallet = ({ projectId, walletConnectParameters }) => {
|
|
813
|
-
const isRainbowInjected = hasInjectedProvider({ flag: "isRainbow" });
|
|
814
|
-
const getUri = (uri) => {
|
|
815
|
-
return isAndroid2() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : isIOS2() ? !isTelegram2() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}`;
|
|
816
|
-
};
|
|
817
|
-
return {
|
|
818
|
-
id: "rainbow",
|
|
819
|
-
name: "Rainbow",
|
|
820
|
-
rdns: "me.rainbow",
|
|
821
|
-
iconUrl: icon2,
|
|
822
|
-
installed: isRainbowInjected,
|
|
823
|
-
isExtension: true,
|
|
824
|
-
isMobile: true,
|
|
825
|
-
downloadUrl: "https://rainbow.me/",
|
|
826
|
-
getUri,
|
|
827
|
-
createConnector: isRainbowInjected ? getInjectedConnector({ flag: "isRainbow" }) : getWalletConnectConnector({
|
|
828
|
-
projectId,
|
|
829
|
-
walletConnectParameters
|
|
830
|
-
})
|
|
831
|
-
};
|
|
832
|
-
};
|
|
833
|
-
|
|
834
|
-
// src/wallets/connectors/walletConnect/walletConnectIcon.ts
|
|
835
|
-
var icon3 = "";
|
|
836
|
-
|
|
837
|
-
// src/wallets/connectors/walletConnect/walletConnect.ts
|
|
838
|
-
var walletConnectWallet = ({ projectId, options }) => {
|
|
839
|
-
const getUri = (uri) => uri;
|
|
840
|
-
return {
|
|
841
|
-
id: "walletConnect",
|
|
842
|
-
name: "WalletConnect",
|
|
843
|
-
installed: void 0,
|
|
844
|
-
iconUrl: icon3,
|
|
845
|
-
isMobile: true,
|
|
846
|
-
getUri,
|
|
847
|
-
createConnector: getWalletConnectConnector({
|
|
848
|
-
projectId,
|
|
849
|
-
walletConnectParameters: options
|
|
850
|
-
})
|
|
851
|
-
};
|
|
852
|
-
};
|
|
853
|
-
|
|
854
|
-
// src/wallets/connectors/coinbase/coinbase.ts
|
|
855
|
-
import { createConnector as createConnector3 } from "wagmi";
|
|
856
|
-
import { coinbaseWallet as coinbaseWagmiWallet } from "wagmi/connectors";
|
|
857
|
-
|
|
858
|
-
// src/wallets/connectors/coinbase/coinbaseIcon.ts
|
|
859
|
-
var icon4 = "";
|
|
860
|
-
|
|
861
|
-
// src/wallets/connectors/coinbase/coinbase.ts
|
|
862
|
-
var coinbaseWallet = ({ appName, appIcon }) => {
|
|
863
|
-
const isCoinbaseInjected = hasInjectedProvider({ flag: "isCoinbaseWallet" });
|
|
864
|
-
const getUri = (uri) => uri;
|
|
865
|
-
return {
|
|
866
|
-
id: "coinbase",
|
|
867
|
-
name: "Coinbase Wallet",
|
|
868
|
-
rdns: "com.coinbase.wallet",
|
|
869
|
-
iconUrl: icon4,
|
|
870
|
-
// Note that we never resolve `installed` to `false` because the
|
|
871
|
-
// Coinbase Wallet SDK falls back to other connection methods if
|
|
872
|
-
// the injected connector isn't available
|
|
873
|
-
installed: isCoinbaseInjected,
|
|
874
|
-
isExtension: true,
|
|
875
|
-
isMobile: true,
|
|
876
|
-
downloadUrl: "https://www.coinbase.com/wallet/downloads",
|
|
877
|
-
getUri,
|
|
878
|
-
createConnector: (walletDetails) => createConnector3((config) => __spreadValues(__spreadValues({}, coinbaseWagmiWallet({
|
|
879
|
-
version: "4",
|
|
880
|
-
appName,
|
|
881
|
-
appLogoUrl: appIcon,
|
|
882
|
-
preference: "eoaOnly"
|
|
883
|
-
})(config)), walletDetails))
|
|
884
|
-
};
|
|
885
|
-
};
|
|
886
|
-
|
|
887
|
-
// src/wallets/connectors/zerion/zerion.ts
|
|
888
|
-
import { isIOS as isIOS3, isTelegram as isTelegram3 } from "@getpara/web-sdk";
|
|
889
|
-
|
|
890
|
-
// src/wallets/connectors/zerion/zerionIcon.ts
|
|
891
|
-
var icon5 = "";
|
|
892
|
-
|
|
893
|
-
// src/wallets/connectors/zerion/zerion.ts
|
|
894
|
-
var zerionWallet = ({ projectId, walletConnectParameters }) => {
|
|
895
|
-
const isZerionInjected = hasInjectedProvider({
|
|
896
|
-
namespace: "zerionWallet",
|
|
897
|
-
flag: "isZerion"
|
|
898
|
-
});
|
|
899
|
-
const getUri = (uri) => {
|
|
900
|
-
return isTelegram3() && isIOS3() ? `https://app.zerion.io/wc?uri=${encodeURIComponent(uri)}` : `zerion://wc?uri=${encodeURIComponent(uri)}`;
|
|
901
|
-
};
|
|
902
|
-
return {
|
|
903
|
-
id: "zerion",
|
|
904
|
-
name: "Zerion",
|
|
905
|
-
rdns: "io.zerion.wallet",
|
|
906
|
-
iconUrl: icon5,
|
|
907
|
-
installed: isZerionInjected,
|
|
908
|
-
isExtension: true,
|
|
909
|
-
isMobile: true,
|
|
910
|
-
getUri,
|
|
911
|
-
downloadUrl: "https://zerion.io/download",
|
|
912
|
-
createConnector: isZerionInjected ? getInjectedConnector({
|
|
913
|
-
namespace: "zerionWallet",
|
|
914
|
-
flag: "isZerion"
|
|
915
|
-
}) : getWalletConnectConnector({
|
|
916
|
-
projectId,
|
|
917
|
-
walletConnectParameters
|
|
918
|
-
})
|
|
919
|
-
};
|
|
920
|
-
};
|
|
921
|
-
|
|
922
|
-
// src/wallets/connectors/rabby/rabbyIcon.ts
|
|
923
|
-
var icon6 = "";
|
|
924
|
-
|
|
925
|
-
// src/wallets/connectors/rabby/rabby.ts
|
|
926
|
-
var rabbyWallet = ({ projectId, walletConnectParameters }) => {
|
|
927
|
-
const isRabbyInjected = hasInjectedProvider({ flag: "isRabby" });
|
|
928
|
-
return {
|
|
929
|
-
id: "rabby",
|
|
930
|
-
name: "Rabby Wallet",
|
|
931
|
-
rdns: "io.rabby",
|
|
932
|
-
iconUrl: icon6,
|
|
933
|
-
installed: isRabbyInjected,
|
|
934
|
-
isExtension: true,
|
|
935
|
-
isMobile: false,
|
|
936
|
-
downloadUrl: "https://rabby.io",
|
|
937
|
-
createConnector: isRabbyInjected ? getInjectedConnector({ flag: "isRabby" }) : getWalletConnectConnector({
|
|
938
|
-
projectId,
|
|
939
|
-
walletConnectParameters
|
|
940
|
-
})
|
|
941
|
-
};
|
|
942
|
-
};
|
|
943
|
-
|
|
944
|
-
// src/wallets/connectors/index.ts
|
|
945
|
-
var allWallets = [metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet];
|
|
2
|
+
import "./chunk-MMUBH76A.js";
|
|
3
|
+
import { EvmExternalWalletContext } from "./providers/EvmExternalWalletContext.js";
|
|
4
|
+
import { ParaEvmProvider } from "./providers/ParaEvmContext.js";
|
|
5
|
+
export * from "./wallets/connectors/index.js";
|
|
946
6
|
export {
|
|
947
7
|
EvmExternalWalletContext,
|
|
948
|
-
ParaEvmProvider
|
|
949
|
-
allWallets,
|
|
950
|
-
coinbaseWallet,
|
|
951
|
-
metaMaskWallet,
|
|
952
|
-
rabbyWallet,
|
|
953
|
-
rainbowWallet,
|
|
954
|
-
walletConnectWallet,
|
|
955
|
-
zerionWallet
|
|
8
|
+
ParaEvmProvider
|
|
956
9
|
};
|