@getpara/cosmos-wallet-connectors 2.0.0-alpha.3 → 2.0.0-alpha.5
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-IV3L3JVM.js +46 -0
- package/dist/index.js +5 -422
- package/dist/package.json +3 -0
- package/dist/providers/CosmosExternalWalletContext.js +297 -0
- package/dist/providers/ParaCosmosContext.js +37 -0
- package/dist/stores/useStore.js +22 -0
- package/dist/types/Wallet.js +1 -0
- package/dist/utils/hasInstalledProvider.js +6 -0
- package/dist/wallets/connectors/index.js +10 -0
- package/dist/wallets/connectors/keplr/keplr.js +20 -0
- package/dist/wallets/connectors/keplr/keplrIcon.js +6 -0
- package/dist/wallets/connectors/leap/leap.js +20 -0
- package/dist/wallets/connectors/leap/leapIcon.js +6 -0
- package/package.json +6 -6
- package/dist/index.js.br +0 -0
- package/dist/index.js.gz +0 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
5
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
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 __async = (__this, __arguments, generator) => {
|
|
22
|
+
return new Promise((resolve, reject) => {
|
|
23
|
+
var fulfilled = (value) => {
|
|
24
|
+
try {
|
|
25
|
+
step(generator.next(value));
|
|
26
|
+
} catch (e) {
|
|
27
|
+
reject(e);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
var rejected = (value) => {
|
|
31
|
+
try {
|
|
32
|
+
step(generator.throw(value));
|
|
33
|
+
} catch (e) {
|
|
34
|
+
reject(e);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
38
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export {
|
|
43
|
+
__spreadValues,
|
|
44
|
+
__spreadProps,
|
|
45
|
+
__async
|
|
46
|
+
};
|
package/dist/index.js
CHANGED
|
@@ -1,426 +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 __async = (__this, __arguments, generator) => {
|
|
22
|
-
return new Promise((resolve, reject) => {
|
|
23
|
-
var fulfilled = (value) => {
|
|
24
|
-
try {
|
|
25
|
-
step(generator.next(value));
|
|
26
|
-
} catch (e) {
|
|
27
|
-
reject(e);
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
var rejected = (value) => {
|
|
31
|
-
try {
|
|
32
|
-
step(generator.throw(value));
|
|
33
|
-
} catch (e) {
|
|
34
|
-
reject(e);
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
38
|
-
step((generator = generator.apply(__this, __arguments)).next());
|
|
39
|
-
});
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
// src/providers/CosmosExternalWalletContext.tsx
|
|
43
|
-
import { createContext, useCallback, useEffect, useMemo, useRef } from "react";
|
|
44
|
-
import {
|
|
45
|
-
checkWallet,
|
|
46
|
-
WalletType as GrazWalletType,
|
|
47
|
-
useAccount,
|
|
48
|
-
useActiveWalletType,
|
|
49
|
-
useConnect,
|
|
50
|
-
useDisconnect,
|
|
51
|
-
useSuggestChainAndConnect,
|
|
52
|
-
getChainInfo,
|
|
53
|
-
getWallet as grazGetWallet
|
|
54
|
-
} from "@getpara/graz";
|
|
55
|
-
|
|
56
|
-
// src/stores/useStore.ts
|
|
57
|
-
import { create } from "zustand";
|
|
58
|
-
import { syncTabs } from "zustand-sync-tabs";
|
|
59
|
-
var useExternalWalletStore = create(
|
|
60
|
-
syncTabs(
|
|
61
|
-
(set) => ({
|
|
62
|
-
isConnecting: false,
|
|
63
|
-
updateState: (state) => {
|
|
64
|
-
set(__spreadValues({}, state));
|
|
65
|
-
}
|
|
66
|
-
}),
|
|
67
|
-
{
|
|
68
|
-
name: "para-cosmos-external-wallet-state"
|
|
69
|
-
}
|
|
70
|
-
)
|
|
71
|
-
);
|
|
72
|
-
|
|
73
|
-
// src/providers/CosmosExternalWalletContext.tsx
|
|
74
|
-
import { WalletType } from "@getpara/web-sdk";
|
|
75
|
-
import { jsx } from "react/jsx-runtime";
|
|
76
|
-
var defaultCosmosExternalWallet = {
|
|
77
|
-
wallets: [],
|
|
78
|
-
chains: [],
|
|
79
|
-
chainId: void 0,
|
|
80
|
-
disconnect: () => Promise.resolve(),
|
|
81
|
-
switchChain: () => Promise.resolve({}),
|
|
82
|
-
connectParaEmbedded: () => Promise.resolve({}),
|
|
83
|
-
signMessage: () => Promise.resolve({}),
|
|
84
|
-
signVerificationMessage: () => Promise.resolve({})
|
|
85
|
-
};
|
|
86
|
-
var CosmosExternalWalletContext = createContext(defaultCosmosExternalWallet);
|
|
87
|
-
function CosmosExternalWalletProvider({
|
|
88
|
-
children,
|
|
89
|
-
onSwitchWallet,
|
|
90
|
-
selectedChainId,
|
|
91
|
-
wallets: incompleteWallets,
|
|
92
|
-
chains,
|
|
93
|
-
multiChain,
|
|
94
|
-
shouldUseSuggestChainAndConnect,
|
|
95
|
-
onSwitchChain,
|
|
96
|
-
para,
|
|
97
|
-
walletsWithFullAuth,
|
|
98
|
-
connectedWallet
|
|
99
|
-
}) {
|
|
100
|
-
var _a, _b;
|
|
101
|
-
const { suggestAndConnectAsync } = useSuggestChainAndConnect();
|
|
102
|
-
const {
|
|
103
|
-
data: account,
|
|
104
|
-
isConnecting,
|
|
105
|
-
isReconnecting,
|
|
106
|
-
isConnected
|
|
107
|
-
} = useAccount({
|
|
108
|
-
chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId,
|
|
109
|
-
multiChain
|
|
110
|
-
});
|
|
111
|
-
const { connectAsync } = useConnect();
|
|
112
|
-
const { disconnectAsync } = useDisconnect();
|
|
113
|
-
const { walletType } = useActiveWalletType();
|
|
114
|
-
const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
|
|
115
|
-
const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
|
|
116
|
-
const verificationMessage = useRef();
|
|
117
|
-
const bufferAddress = multiChain ? (_a = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _a.address.toString() : account == null ? void 0 : account.address.toString();
|
|
118
|
-
const address = multiChain ? (_b = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _b.bech32Address : account == null ? void 0 : account.bech32Address;
|
|
119
|
-
const reset = () => __async(this, null, function* () {
|
|
120
|
-
yield disconnectAsync();
|
|
121
|
-
yield para.logout();
|
|
122
|
-
});
|
|
123
|
-
const switchChain = (chainId) => __async(this, null, function* () {
|
|
124
|
-
var _a2;
|
|
125
|
-
let error;
|
|
126
|
-
let changeResp = {};
|
|
127
|
-
try {
|
|
128
|
-
let chainInfo;
|
|
129
|
-
if (shouldUseSuggestChainAndConnect) {
|
|
130
|
-
chainInfo = getChainInfo({ chainId });
|
|
131
|
-
if (!chainInfo) {
|
|
132
|
-
console.error("Chain not found.");
|
|
133
|
-
return;
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType, chainInfo }) : connectAsync({ walletType, chainId });
|
|
137
|
-
changeResp.address = connectedWallet2.accounts[chainId].bech32Address;
|
|
138
|
-
changeResp.bufferAddress = connectedWallet2.accounts[chainId].address.toString();
|
|
139
|
-
} catch (err) {
|
|
140
|
-
if (err.message === "No wallet exists") {
|
|
141
|
-
changeResp.error = err.message;
|
|
142
|
-
} else {
|
|
143
|
-
console.error("Graz connection error:", err);
|
|
144
|
-
changeResp.error = "An unknown error occurred.";
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
onSwitchWallet(changeResp);
|
|
148
|
-
if (!changeResp.error) {
|
|
149
|
-
onSwitchChain(chainId);
|
|
150
|
-
const storedExternalWallet = para.externalWallets[(_a2 = changeResp.bufferAddress) != null ? _a2 : ""];
|
|
151
|
-
para.setExternalWallet({
|
|
152
|
-
address: changeResp.bufferAddress,
|
|
153
|
-
type: WalletType.COSMOS,
|
|
154
|
-
provider: getProviderName(walletType),
|
|
155
|
-
addressBech32: changeResp.address,
|
|
156
|
-
withFullParaAuth: storedExternalWallet.isExternalWithParaAuth
|
|
157
|
-
});
|
|
158
|
-
}
|
|
159
|
-
return { error };
|
|
160
|
-
});
|
|
161
|
-
const login = (bufferAddress2, address2, isFullAuthWallet, providerName) => __async(this, null, function* () {
|
|
162
|
-
try {
|
|
163
|
-
return yield para.loginExternalWallet({
|
|
164
|
-
externalWallet: {
|
|
165
|
-
address: bufferAddress2,
|
|
166
|
-
type: WalletType.COSMOS,
|
|
167
|
-
provider: providerName,
|
|
168
|
-
addressBech32: address2,
|
|
169
|
-
withFullParaAuth: isFullAuthWallet
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
} catch (err) {
|
|
173
|
-
yield reset();
|
|
174
|
-
throw "Error logging you in. Please try again.";
|
|
175
|
-
}
|
|
176
|
-
});
|
|
177
|
-
useEffect(() => {
|
|
178
|
-
const storedExternalWallet = para.externalWallets[bufferAddress != null ? bufferAddress : ""];
|
|
179
|
-
if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
|
|
180
|
-
reset();
|
|
181
|
-
}
|
|
182
|
-
}, [isConnecting, isLocalConnecting, isReconnecting, isConnected]);
|
|
183
|
-
useEffect(() => {
|
|
184
|
-
const connect2 = () => __async(this, null, function* () {
|
|
185
|
-
var _a2;
|
|
186
|
-
if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedWallet.type === WalletType.COSMOS && (connectedWallet.isExternal ? walletType !== ((_a2 = connectedWallet.name) == null ? void 0 : _a2.toLowerCase()) : walletType !== "para")) {
|
|
187
|
-
const isLoggedIn = yield para.isFullyLoggedIn();
|
|
188
|
-
if (!isLoggedIn) {
|
|
189
|
-
return;
|
|
190
|
-
}
|
|
191
|
-
const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
192
|
-
yield connectAsync({
|
|
193
|
-
walletType: connectedWallet.isExternal ? connectedWallet.name.toLowerCase() : GrazWalletType.PARA,
|
|
194
|
-
chainId
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
connect2();
|
|
199
|
-
}, [isLocalConnecting, isConnecting, isReconnecting, walletType, connectedWallet]);
|
|
200
|
-
const signMessage = (message) => __async(this, null, function* () {
|
|
201
|
-
const wallet = grazGetWallet(walletType);
|
|
202
|
-
if (!wallet) {
|
|
203
|
-
return { error: "Connected wallet not found" };
|
|
204
|
-
}
|
|
205
|
-
try {
|
|
206
|
-
const publicKey = (yield wallet.getKey(selectedChainId)).pubKey;
|
|
207
|
-
const signature = yield wallet.signArbitrary(selectedChainId, address, message);
|
|
208
|
-
return {
|
|
209
|
-
address: bufferAddress,
|
|
210
|
-
signature: signature.signature,
|
|
211
|
-
cosmosPublicKeyHex: Buffer.from(publicKey).toString("hex"),
|
|
212
|
-
cosmosSigner: address
|
|
213
|
-
};
|
|
214
|
-
} catch (e) {
|
|
215
|
-
if (e.message.includes("Request rejected")) {
|
|
216
|
-
return { error: "Signature request rejected" };
|
|
217
|
-
}
|
|
218
|
-
return { error: "An unknown error occurred" };
|
|
219
|
-
}
|
|
220
|
-
});
|
|
221
|
-
const signVerificationMessage = () => __async(this, null, function* () {
|
|
222
|
-
const signature = yield signMessage(verificationMessage.current);
|
|
223
|
-
return signature;
|
|
224
|
-
});
|
|
225
|
-
const connect = (walletType2, chainId) => __async(this, null, function* () {
|
|
226
|
-
var _a2;
|
|
227
|
-
updateExternalWalletState({ isConnecting: true });
|
|
228
|
-
const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
|
|
229
|
-
const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
|
|
230
|
-
if (!chainId) {
|
|
231
|
-
yield disconnectAsync();
|
|
232
|
-
}
|
|
233
|
-
const _chainId = chainId != null ? chainId : multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
234
|
-
if (!_chainId) {
|
|
235
|
-
console.error("Chain id not provided.");
|
|
236
|
-
return;
|
|
237
|
-
}
|
|
238
|
-
let address2;
|
|
239
|
-
let bufferAddress2;
|
|
240
|
-
let error;
|
|
241
|
-
let authState;
|
|
242
|
-
if (!walletType2) {
|
|
243
|
-
console.error("Graz wallet type not provided.");
|
|
244
|
-
return;
|
|
245
|
-
} else {
|
|
246
|
-
try {
|
|
247
|
-
let chainInfo;
|
|
248
|
-
if (shouldUseSuggestChainAndConnect) {
|
|
249
|
-
if (typeof _chainId !== "string") {
|
|
250
|
-
console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");
|
|
251
|
-
return;
|
|
252
|
-
}
|
|
253
|
-
chainInfo = getChainInfo({ chainId: _chainId });
|
|
254
|
-
if (!chainInfo) {
|
|
255
|
-
console.error("Chain not found.");
|
|
256
|
-
return;
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId });
|
|
260
|
-
const firstChain = !chainId ? selectedChainId : typeof _chainId === "string" ? _chainId : _chainId[0];
|
|
261
|
-
address2 = connectedWallet2.accounts[firstChain].bech32Address;
|
|
262
|
-
bufferAddress2 = connectedWallet2.accounts[firstChain].address.toString();
|
|
263
|
-
if (connectedWallet2.accounts[firstChain]) {
|
|
264
|
-
try {
|
|
265
|
-
authState = yield login(bufferAddress2, address2, isFullAuthWallet, getProviderName(walletType2));
|
|
266
|
-
verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
|
|
267
|
-
} catch (err) {
|
|
268
|
-
authState = void 0;
|
|
269
|
-
bufferAddress2 = void 0;
|
|
270
|
-
address2 = void 0;
|
|
271
|
-
error = err;
|
|
272
|
-
}
|
|
273
|
-
}
|
|
274
|
-
} catch (err) {
|
|
275
|
-
if (err.message === "No wallet exists") {
|
|
276
|
-
error = err.message;
|
|
277
|
-
} else {
|
|
278
|
-
console.error("Graz connection error:", err);
|
|
279
|
-
error = "An unknown error occurred.";
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
}
|
|
283
|
-
updateExternalWalletState({ isConnecting: false });
|
|
284
|
-
return { authState, address: address2, bufferAddress: bufferAddress2, error };
|
|
285
|
-
});
|
|
286
|
-
const getWallet = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2);
|
|
287
|
-
const getProviderName = (walletType2) => {
|
|
288
|
-
var _a2;
|
|
289
|
-
return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.name;
|
|
290
|
-
};
|
|
291
|
-
const wallets = incompleteWallets.map((wallet) => {
|
|
292
|
-
return __spreadProps(__spreadValues({
|
|
293
|
-
connect: () => connect(wallet.grazType),
|
|
294
|
-
connectMobile: () => connect(wallet.grazType),
|
|
295
|
-
getQrUri: () => "",
|
|
296
|
-
type: WalletType.COSMOS
|
|
297
|
-
}, wallet), {
|
|
298
|
-
installed: checkWallet(wallet.grazType)
|
|
299
|
-
});
|
|
300
|
-
}).filter((w) => !!w);
|
|
301
|
-
const formattedChains = chains.map((c) => {
|
|
302
|
-
return {
|
|
303
|
-
id: c.chainId,
|
|
304
|
-
name: c.chainName
|
|
305
|
-
};
|
|
306
|
-
});
|
|
307
|
-
const connectParaEmbedded = useCallback(() => __async(this, null, function* () {
|
|
308
|
-
if (!para) {
|
|
309
|
-
return { error: "No para instance available" };
|
|
310
|
-
}
|
|
311
|
-
try {
|
|
312
|
-
const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
313
|
-
const result = yield connectAsync({ walletType: GrazWalletType.PARA, chainId });
|
|
314
|
-
return { result };
|
|
315
|
-
} catch (err) {
|
|
316
|
-
const error = err instanceof Error ? err.message : "Unknown error";
|
|
317
|
-
return { error };
|
|
318
|
-
}
|
|
319
|
-
}), [para, multiChain, chains, selectedChainId]);
|
|
320
|
-
return /* @__PURE__ */ jsx(
|
|
321
|
-
CosmosExternalWalletContext.Provider,
|
|
322
|
-
{
|
|
323
|
-
value: useMemo(
|
|
324
|
-
() => ({
|
|
325
|
-
wallets,
|
|
326
|
-
chains: formattedChains,
|
|
327
|
-
chainId: selectedChainId,
|
|
328
|
-
disconnect: disconnectAsync,
|
|
329
|
-
switchChain,
|
|
330
|
-
connectParaEmbedded,
|
|
331
|
-
signMessage,
|
|
332
|
-
signVerificationMessage
|
|
333
|
-
}),
|
|
334
|
-
[
|
|
335
|
-
wallets,
|
|
336
|
-
formattedChains,
|
|
337
|
-
selectedChainId,
|
|
338
|
-
disconnectAsync,
|
|
339
|
-
switchChain,
|
|
340
|
-
connectParaEmbedded,
|
|
341
|
-
signMessage,
|
|
342
|
-
signVerificationMessage
|
|
343
|
-
]
|
|
344
|
-
),
|
|
345
|
-
children
|
|
346
|
-
}
|
|
347
|
-
);
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
// src/providers/ParaCosmosContext.tsx
|
|
351
|
-
import { useMemo as useMemo2 } from "react";
|
|
352
|
-
import { GrazProvider } from "@getpara/graz";
|
|
353
|
-
import { jsx as jsx2 } from "react/jsx-runtime";
|
|
354
|
-
function ParaCosmosProvider({
|
|
355
|
-
children,
|
|
356
|
-
config,
|
|
357
|
-
internalConfig,
|
|
358
|
-
grazProviderProps
|
|
359
|
-
}) {
|
|
360
|
-
const para = internalConfig.para;
|
|
361
|
-
const { chains, wallets } = config;
|
|
362
|
-
const walletsWithType = [];
|
|
363
|
-
wallets.forEach((w) => {
|
|
364
|
-
const wallet = w();
|
|
365
|
-
walletsWithType.push(wallet);
|
|
366
|
-
});
|
|
367
|
-
const cosmosExternalWalletProviderProps = useMemo2(
|
|
368
|
-
() => __spreadProps(__spreadValues(__spreadValues({}, config), internalConfig), {
|
|
369
|
-
wallets: walletsWithType
|
|
370
|
-
}),
|
|
371
|
-
[walletsWithType, config, internalConfig]
|
|
372
|
-
);
|
|
373
|
-
return (
|
|
374
|
-
// Casting Para as any here to avoid ts errors due to the graz version being behind.
|
|
375
|
-
// TODO: update graz para sdk to current version
|
|
376
|
-
/* @__PURE__ */ jsx2(GrazProvider, { grazOptions: __spreadValues({ chains, autoReconnect: true, para }, grazProviderProps), children: /* @__PURE__ */ jsx2(CosmosExternalWalletProvider, __spreadProps(__spreadValues({}, cosmosExternalWalletProviderProps), { children })) })
|
|
377
|
-
);
|
|
378
|
-
}
|
|
379
|
-
|
|
380
|
-
// src/wallets/connectors/keplr/keplrIcon.ts
|
|
381
|
-
var icon = "";
|
|
382
|
-
|
|
383
|
-
// src/wallets/connectors/keplr/keplr.ts
|
|
384
|
-
import { WalletType as WalletType2 } from "@getpara/graz";
|
|
385
|
-
import { isMobile } from "@getpara/web-sdk";
|
|
386
|
-
var keplrWallet = () => {
|
|
387
|
-
return {
|
|
388
|
-
id: "keplr",
|
|
389
|
-
name: "Keplr",
|
|
390
|
-
iconUrl: icon,
|
|
391
|
-
isExtension: true,
|
|
392
|
-
isMobile: isMobile() && true,
|
|
393
|
-
downloadUrl: "https://www.keplr.app/get",
|
|
394
|
-
grazType: WalletType2.KEPLR,
|
|
395
|
-
grazMobileType: WalletType2.WC_KEPLR_MOBILE
|
|
396
|
-
};
|
|
397
|
-
};
|
|
398
|
-
|
|
399
|
-
// src/wallets/connectors/leap/leapIcon.ts
|
|
400
|
-
var icon2 = "";
|
|
401
|
-
|
|
402
|
-
// src/wallets/connectors/leap/leap.ts
|
|
403
|
-
import { WalletType as WalletType3 } from "@getpara/graz";
|
|
404
|
-
import { isMobile as isMobile2 } from "@getpara/web-sdk";
|
|
405
|
-
var leapWallet = () => {
|
|
406
|
-
return {
|
|
407
|
-
id: "leap",
|
|
408
|
-
name: "Leap",
|
|
409
|
-
iconUrl: icon2,
|
|
410
|
-
isExtension: true,
|
|
411
|
-
isMobile: isMobile2() && true,
|
|
412
|
-
downloadUrl: "https://www.leapwallet.io/download",
|
|
413
|
-
grazType: WalletType3.LEAP,
|
|
414
|
-
grazMobileType: WalletType3.WC_LEAP_MOBILE
|
|
415
|
-
};
|
|
416
|
-
};
|
|
417
|
-
|
|
418
|
-
// src/wallets/connectors/index.ts
|
|
419
|
-
var allWallets = [keplrWallet, leapWallet];
|
|
2
|
+
import "./chunk-IV3L3JVM.js";
|
|
3
|
+
import { CosmosExternalWalletContext } from "./providers/CosmosExternalWalletContext.js";
|
|
4
|
+
import { ParaCosmosProvider } from "./providers/ParaCosmosContext.js";
|
|
5
|
+
export * from "./wallets/connectors/index.js";
|
|
420
6
|
export {
|
|
421
7
|
CosmosExternalWalletContext,
|
|
422
|
-
ParaCosmosProvider
|
|
423
|
-
allWallets,
|
|
424
|
-
keplrWallet,
|
|
425
|
-
leapWallet
|
|
8
|
+
ParaCosmosProvider
|
|
426
9
|
};
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__async,
|
|
4
|
+
__spreadProps,
|
|
5
|
+
__spreadValues
|
|
6
|
+
} from "../chunk-IV3L3JVM.js";
|
|
7
|
+
import { jsx } from "react/jsx-runtime";
|
|
8
|
+
import { createContext, useCallback, useEffect, useMemo, useRef } from "react";
|
|
9
|
+
import {
|
|
10
|
+
checkWallet,
|
|
11
|
+
WalletType as GrazWalletType,
|
|
12
|
+
useAccount,
|
|
13
|
+
useActiveWalletType,
|
|
14
|
+
useConnect,
|
|
15
|
+
useDisconnect,
|
|
16
|
+
useSuggestChainAndConnect,
|
|
17
|
+
getChainInfo,
|
|
18
|
+
getWallet as grazGetWallet
|
|
19
|
+
} from "@getpara/graz";
|
|
20
|
+
import { useExternalWalletStore } from "../stores/useStore.js";
|
|
21
|
+
const defaultCosmosExternalWallet = {
|
|
22
|
+
wallets: [],
|
|
23
|
+
chains: [],
|
|
24
|
+
chainId: void 0,
|
|
25
|
+
disconnect: () => Promise.resolve(),
|
|
26
|
+
switchChain: () => Promise.resolve({}),
|
|
27
|
+
connectParaEmbedded: () => Promise.resolve({}),
|
|
28
|
+
signMessage: () => Promise.resolve({}),
|
|
29
|
+
signVerificationMessage: () => Promise.resolve({})
|
|
30
|
+
};
|
|
31
|
+
const CosmosExternalWalletContext = createContext(defaultCosmosExternalWallet);
|
|
32
|
+
function CosmosExternalWalletProvider({
|
|
33
|
+
children,
|
|
34
|
+
onSwitchWallet,
|
|
35
|
+
selectedChainId,
|
|
36
|
+
wallets: incompleteWallets,
|
|
37
|
+
chains,
|
|
38
|
+
multiChain,
|
|
39
|
+
shouldUseSuggestChainAndConnect,
|
|
40
|
+
onSwitchChain,
|
|
41
|
+
para,
|
|
42
|
+
walletsWithFullAuth,
|
|
43
|
+
connectedWallet
|
|
44
|
+
}) {
|
|
45
|
+
var _a, _b;
|
|
46
|
+
const { suggestAndConnectAsync } = useSuggestChainAndConnect();
|
|
47
|
+
const {
|
|
48
|
+
data: account,
|
|
49
|
+
isConnecting,
|
|
50
|
+
isReconnecting,
|
|
51
|
+
isConnected
|
|
52
|
+
} = useAccount({
|
|
53
|
+
chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId,
|
|
54
|
+
multiChain
|
|
55
|
+
});
|
|
56
|
+
const { connectAsync } = useConnect();
|
|
57
|
+
const { disconnectAsync } = useDisconnect();
|
|
58
|
+
const { walletType } = useActiveWalletType();
|
|
59
|
+
const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
|
|
60
|
+
const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
|
|
61
|
+
const bufferAddress = multiChain ? (_a = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _a.address.toString() : account == null ? void 0 : account.address.toString();
|
|
62
|
+
const address = multiChain ? (_b = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _b.bech32Address : account == null ? void 0 : account.bech32Address;
|
|
63
|
+
const verificationMessage = useRef();
|
|
64
|
+
const reset = () => __async(this, null, function* () {
|
|
65
|
+
yield disconnectAsync();
|
|
66
|
+
yield para.logout();
|
|
67
|
+
});
|
|
68
|
+
const switchChain = (chainId) => __async(this, null, function* () {
|
|
69
|
+
var _a2;
|
|
70
|
+
let error;
|
|
71
|
+
let changeResp = {};
|
|
72
|
+
try {
|
|
73
|
+
let chainInfo;
|
|
74
|
+
if (shouldUseSuggestChainAndConnect) {
|
|
75
|
+
chainInfo = getChainInfo({ chainId });
|
|
76
|
+
if (!chainInfo) {
|
|
77
|
+
console.error("Chain not found.");
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType, chainInfo }) : connectAsync({ walletType, chainId });
|
|
82
|
+
changeResp.address = connectedWallet2.accounts[chainId].bech32Address;
|
|
83
|
+
changeResp.bufferAddress = connectedWallet2.accounts[chainId].address.toString();
|
|
84
|
+
} catch (err) {
|
|
85
|
+
if (err.message === "No wallet exists") {
|
|
86
|
+
changeResp.error = err.message;
|
|
87
|
+
} else {
|
|
88
|
+
console.error("Graz connection error:", err);
|
|
89
|
+
changeResp.error = "An unknown error occurred.";
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
onSwitchWallet(changeResp);
|
|
93
|
+
if (!changeResp.error) {
|
|
94
|
+
onSwitchChain(chainId);
|
|
95
|
+
const storedExternalWallet = para.externalWallets[(_a2 = changeResp.bufferAddress) != null ? _a2 : ""];
|
|
96
|
+
para.setExternalWallet({
|
|
97
|
+
address: changeResp.bufferAddress,
|
|
98
|
+
type: "COSMOS",
|
|
99
|
+
provider: getProviderName(walletType),
|
|
100
|
+
addressBech32: changeResp.address,
|
|
101
|
+
withFullParaAuth: storedExternalWallet.isExternalWithParaAuth
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
return { error };
|
|
105
|
+
});
|
|
106
|
+
const login = (bufferAddress2, address2, isFullAuthWallet, providerName) => __async(this, null, function* () {
|
|
107
|
+
try {
|
|
108
|
+
return yield para.loginExternalWallet({
|
|
109
|
+
externalWallet: {
|
|
110
|
+
address: bufferAddress2,
|
|
111
|
+
type: "COSMOS",
|
|
112
|
+
provider: providerName,
|
|
113
|
+
addressBech32: address2,
|
|
114
|
+
withFullParaAuth: isFullAuthWallet
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
} catch (err) {
|
|
118
|
+
yield reset();
|
|
119
|
+
throw "Error logging you in. Please try again.";
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
useEffect(() => {
|
|
123
|
+
const storedExternalWallet = para.externalWallets[bufferAddress != null ? bufferAddress : ""];
|
|
124
|
+
if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
|
|
125
|
+
reset();
|
|
126
|
+
}
|
|
127
|
+
}, [isConnecting, isLocalConnecting, isReconnecting, isConnected]);
|
|
128
|
+
useEffect(() => {
|
|
129
|
+
const connect2 = () => __async(this, null, function* () {
|
|
130
|
+
var _a2;
|
|
131
|
+
if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedWallet.type === "COSMOS" && (connectedWallet.isExternal ? walletType !== ((_a2 = connectedWallet.name) == null ? void 0 : _a2.toLowerCase()) : walletType !== "para")) {
|
|
132
|
+
const isLoggedIn = yield para.isFullyLoggedIn();
|
|
133
|
+
if (!isLoggedIn) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
137
|
+
yield connectAsync({
|
|
138
|
+
walletType: connectedWallet.isExternal ? connectedWallet.name.toLowerCase() : GrazWalletType.PARA,
|
|
139
|
+
chainId
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
connect2();
|
|
144
|
+
}, [isLocalConnecting, isConnecting, isReconnecting, walletType, connectedWallet]);
|
|
145
|
+
const signMessage = (message) => __async(this, null, function* () {
|
|
146
|
+
const wallet = grazGetWallet(walletType);
|
|
147
|
+
if (!wallet) {
|
|
148
|
+
return { error: "Connected wallet not found" };
|
|
149
|
+
}
|
|
150
|
+
try {
|
|
151
|
+
const publicKey = (yield wallet.getKey(selectedChainId)).pubKey;
|
|
152
|
+
const signature = yield wallet.signArbitrary(selectedChainId, address, message);
|
|
153
|
+
return {
|
|
154
|
+
address: bufferAddress,
|
|
155
|
+
signature: signature.signature,
|
|
156
|
+
cosmosPublicKeyHex: Buffer.from(publicKey).toString("hex"),
|
|
157
|
+
cosmosSigner: address
|
|
158
|
+
};
|
|
159
|
+
} catch (e) {
|
|
160
|
+
if (e.message.includes("Request rejected")) {
|
|
161
|
+
return { error: "Signature request rejected" };
|
|
162
|
+
}
|
|
163
|
+
return { error: "An unknown error occurred" };
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
const signVerificationMessage = () => __async(this, null, function* () {
|
|
167
|
+
const signature = yield signMessage(verificationMessage.current);
|
|
168
|
+
return signature;
|
|
169
|
+
});
|
|
170
|
+
const connect = (walletType2, chainId) => __async(this, null, function* () {
|
|
171
|
+
var _a2;
|
|
172
|
+
updateExternalWalletState({ isConnecting: true });
|
|
173
|
+
const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
|
|
174
|
+
const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
|
|
175
|
+
if (!chainId) {
|
|
176
|
+
yield disconnectAsync();
|
|
177
|
+
}
|
|
178
|
+
const _chainId = chainId != null ? chainId : multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
179
|
+
if (!_chainId) {
|
|
180
|
+
console.error("Chain id not provided.");
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
let address2;
|
|
184
|
+
let bufferAddress2;
|
|
185
|
+
let error;
|
|
186
|
+
let authState;
|
|
187
|
+
if (!walletType2) {
|
|
188
|
+
console.error("Graz wallet type not provided.");
|
|
189
|
+
return;
|
|
190
|
+
} else {
|
|
191
|
+
try {
|
|
192
|
+
let chainInfo;
|
|
193
|
+
if (shouldUseSuggestChainAndConnect) {
|
|
194
|
+
if (typeof _chainId !== "string") {
|
|
195
|
+
console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
chainInfo = getChainInfo({ chainId: _chainId });
|
|
199
|
+
if (!chainInfo) {
|
|
200
|
+
console.error("Chain not found.");
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId });
|
|
205
|
+
const firstChain = !chainId ? selectedChainId : typeof _chainId === "string" ? _chainId : _chainId[0];
|
|
206
|
+
address2 = connectedWallet2.accounts[firstChain].bech32Address;
|
|
207
|
+
bufferAddress2 = connectedWallet2.accounts[firstChain].address.toString();
|
|
208
|
+
if (connectedWallet2.accounts[firstChain]) {
|
|
209
|
+
try {
|
|
210
|
+
authState = yield login(bufferAddress2, address2, isFullAuthWallet, getProviderName(walletType2));
|
|
211
|
+
verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
|
|
212
|
+
} catch (err) {
|
|
213
|
+
authState = void 0;
|
|
214
|
+
bufferAddress2 = void 0;
|
|
215
|
+
address2 = void 0;
|
|
216
|
+
error = err;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
} catch (err) {
|
|
220
|
+
if (err.message === "No wallet exists") {
|
|
221
|
+
error = err.message;
|
|
222
|
+
} else {
|
|
223
|
+
console.error("Graz connection error:", err);
|
|
224
|
+
error = "An unknown error occurred.";
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
updateExternalWalletState({ isConnecting: false });
|
|
229
|
+
return { authState, address: address2, bufferAddress: bufferAddress2, error };
|
|
230
|
+
});
|
|
231
|
+
const getWallet = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2);
|
|
232
|
+
const getProviderName = (walletType2) => {
|
|
233
|
+
var _a2;
|
|
234
|
+
return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.name;
|
|
235
|
+
};
|
|
236
|
+
const wallets = incompleteWallets.map((wallet) => {
|
|
237
|
+
return __spreadProps(__spreadValues({
|
|
238
|
+
connect: () => connect(wallet.grazType),
|
|
239
|
+
connectMobile: () => connect(wallet.grazType),
|
|
240
|
+
getQrUri: () => "",
|
|
241
|
+
type: "COSMOS"
|
|
242
|
+
}, wallet), {
|
|
243
|
+
installed: checkWallet(wallet.grazType)
|
|
244
|
+
});
|
|
245
|
+
}).filter((w) => !!w);
|
|
246
|
+
const formattedChains = chains.map((c) => {
|
|
247
|
+
return {
|
|
248
|
+
id: c.chainId,
|
|
249
|
+
name: c.chainName
|
|
250
|
+
};
|
|
251
|
+
});
|
|
252
|
+
const connectParaEmbedded = useCallback(() => __async(this, null, function* () {
|
|
253
|
+
if (!para) {
|
|
254
|
+
return { error: "No para instance available" };
|
|
255
|
+
}
|
|
256
|
+
try {
|
|
257
|
+
const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
|
|
258
|
+
const result = yield connectAsync({ walletType: GrazWalletType.PARA, chainId });
|
|
259
|
+
return { result };
|
|
260
|
+
} catch (err) {
|
|
261
|
+
const error = err instanceof Error ? err.message : "Unknown error";
|
|
262
|
+
return { error };
|
|
263
|
+
}
|
|
264
|
+
}), [para, multiChain, chains, selectedChainId]);
|
|
265
|
+
return /* @__PURE__ */ jsx(
|
|
266
|
+
CosmosExternalWalletContext.Provider,
|
|
267
|
+
{
|
|
268
|
+
value: useMemo(
|
|
269
|
+
() => ({
|
|
270
|
+
wallets,
|
|
271
|
+
chains: formattedChains,
|
|
272
|
+
chainId: selectedChainId,
|
|
273
|
+
disconnect: disconnectAsync,
|
|
274
|
+
switchChain,
|
|
275
|
+
connectParaEmbedded,
|
|
276
|
+
signMessage,
|
|
277
|
+
signVerificationMessage
|
|
278
|
+
}),
|
|
279
|
+
[
|
|
280
|
+
wallets,
|
|
281
|
+
formattedChains,
|
|
282
|
+
selectedChainId,
|
|
283
|
+
disconnectAsync,
|
|
284
|
+
switchChain,
|
|
285
|
+
connectParaEmbedded,
|
|
286
|
+
signMessage,
|
|
287
|
+
signVerificationMessage
|
|
288
|
+
]
|
|
289
|
+
),
|
|
290
|
+
children
|
|
291
|
+
}
|
|
292
|
+
);
|
|
293
|
+
}
|
|
294
|
+
export {
|
|
295
|
+
CosmosExternalWalletContext,
|
|
296
|
+
CosmosExternalWalletProvider
|
|
297
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadProps,
|
|
4
|
+
__spreadValues
|
|
5
|
+
} from "../chunk-IV3L3JVM.js";
|
|
6
|
+
import { jsx } from "react/jsx-runtime";
|
|
7
|
+
import { useMemo } from "react";
|
|
8
|
+
import { CosmosExternalWalletProvider } from "./CosmosExternalWalletContext.js";
|
|
9
|
+
import { GrazProvider } from "@getpara/graz";
|
|
10
|
+
function ParaCosmosProvider({
|
|
11
|
+
children,
|
|
12
|
+
config,
|
|
13
|
+
internalConfig,
|
|
14
|
+
grazProviderProps
|
|
15
|
+
}) {
|
|
16
|
+
const para = internalConfig.para;
|
|
17
|
+
const { chains, wallets } = config;
|
|
18
|
+
const walletsWithType = [];
|
|
19
|
+
wallets.forEach((w) => {
|
|
20
|
+
const wallet = w();
|
|
21
|
+
walletsWithType.push(wallet);
|
|
22
|
+
});
|
|
23
|
+
const cosmosExternalWalletProviderProps = useMemo(
|
|
24
|
+
() => __spreadProps(__spreadValues(__spreadValues({}, config), internalConfig), {
|
|
25
|
+
wallets: walletsWithType
|
|
26
|
+
}),
|
|
27
|
+
[walletsWithType, config, internalConfig]
|
|
28
|
+
);
|
|
29
|
+
return (
|
|
30
|
+
// Casting Para as any here to avoid ts errors due to the graz version being behind.
|
|
31
|
+
// TODO: update graz para sdk to current version
|
|
32
|
+
/* @__PURE__ */ jsx(GrazProvider, { grazOptions: __spreadValues({ chains, autoReconnect: true, para }, grazProviderProps), children: /* @__PURE__ */ jsx(CosmosExternalWalletProvider, __spreadProps(__spreadValues({}, cosmosExternalWalletProviderProps), { children })) })
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
export {
|
|
36
|
+
ParaCosmosProvider
|
|
37
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadValues
|
|
4
|
+
} from "../chunk-IV3L3JVM.js";
|
|
5
|
+
import { create } from "zustand";
|
|
6
|
+
import { syncTabs } from "zustand-sync-tabs";
|
|
7
|
+
const useExternalWalletStore = create(
|
|
8
|
+
syncTabs(
|
|
9
|
+
(set) => ({
|
|
10
|
+
isConnecting: false,
|
|
11
|
+
updateState: (state) => {
|
|
12
|
+
set(__spreadValues({}, state));
|
|
13
|
+
}
|
|
14
|
+
}),
|
|
15
|
+
{
|
|
16
|
+
name: "para-cosmos-external-wallet-state"
|
|
17
|
+
}
|
|
18
|
+
)
|
|
19
|
+
);
|
|
20
|
+
export {
|
|
21
|
+
useExternalWalletStore
|
|
22
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use client";
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
|
+
import { icon } from "./keplrIcon.js";
|
|
4
|
+
import { WalletType } from "@getpara/graz";
|
|
5
|
+
import { isMobile } from "@getpara/web-sdk";
|
|
6
|
+
const keplrWallet = () => {
|
|
7
|
+
return {
|
|
8
|
+
id: "keplr",
|
|
9
|
+
name: "Keplr",
|
|
10
|
+
iconUrl: icon,
|
|
11
|
+
isExtension: true,
|
|
12
|
+
isMobile: isMobile() && true,
|
|
13
|
+
downloadUrl: "https://www.keplr.app/get",
|
|
14
|
+
grazType: WalletType.KEPLR,
|
|
15
|
+
grazMobileType: WalletType.WC_KEPLR_MOBILE
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export {
|
|
19
|
+
keplrWallet
|
|
20
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
|
+
const icon = "";
|
|
4
|
+
export {
|
|
5
|
+
icon
|
|
6
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
|
+
import { icon } from "./leapIcon.js";
|
|
4
|
+
import { WalletType } from "@getpara/graz";
|
|
5
|
+
import { isMobile } from "@getpara/web-sdk";
|
|
6
|
+
const leapWallet = () => {
|
|
7
|
+
return {
|
|
8
|
+
id: "leap",
|
|
9
|
+
name: "Leap",
|
|
10
|
+
iconUrl: icon,
|
|
11
|
+
isExtension: true,
|
|
12
|
+
isMobile: isMobile() && true,
|
|
13
|
+
downloadUrl: "https://www.leapwallet.io/download",
|
|
14
|
+
grazType: WalletType.LEAP,
|
|
15
|
+
grazMobileType: WalletType.WC_LEAP_MOBILE
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export {
|
|
19
|
+
leapWallet
|
|
20
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
|
+
const icon = "";
|
|
4
|
+
export {
|
|
5
|
+
icon
|
|
6
|
+
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@getpara/cosmos-wallet-connectors",
|
|
3
|
-
"version": "2.0.0-alpha.
|
|
3
|
+
"version": "2.0.0-alpha.5",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -17,16 +17,16 @@
|
|
|
17
17
|
"@cosmjs/cosmwasm-stargate": "<=0.31.3",
|
|
18
18
|
"@cosmjs/launchpad": "*",
|
|
19
19
|
"@cosmjs/proto-signing": "<=0.31.3",
|
|
20
|
-
"@cosmjs/stargate": "<=0.
|
|
20
|
+
"@cosmjs/stargate": "<=0.33.1",
|
|
21
21
|
"@cosmjs/tendermint-rpc": "<=0.31.3",
|
|
22
|
-
"@getpara/graz": "^1.0.0-dev.
|
|
23
|
-
"@getpara/web-sdk": "2.0.0-alpha.
|
|
22
|
+
"@getpara/graz": "^1.0.0-dev.2",
|
|
23
|
+
"@getpara/web-sdk": "2.0.0-alpha.5",
|
|
24
24
|
"@leapwallet/cosmos-social-login-capsule-provider": "^0.0.41",
|
|
25
25
|
"zustand": "^4.5.2",
|
|
26
26
|
"zustand-sync-tabs": "^0.2.2"
|
|
27
27
|
},
|
|
28
28
|
"devDependencies": {
|
|
29
|
-
"@getpara/react-common": "2.0.0-alpha.
|
|
29
|
+
"@getpara/react-common": "2.0.0-alpha.5",
|
|
30
30
|
"@types/react": "^18.0.31",
|
|
31
31
|
"@types/react-dom": "^18.2.7",
|
|
32
32
|
"typescript": "^5.4.3"
|
|
@@ -39,5 +39,5 @@
|
|
|
39
39
|
"dist",
|
|
40
40
|
"package.json"
|
|
41
41
|
],
|
|
42
|
-
"gitHead": "
|
|
42
|
+
"gitHead": "3ecfca088f24489f2e8fa5493d0f4459b08880e1"
|
|
43
43
|
}
|
package/dist/index.js.br
DELETED
|
Binary file
|
package/dist/index.js.gz
DELETED
|
Binary file
|