@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.
@@ -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
- 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
- // 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,3 @@
1
+ {
2
+ "type": "module"
3
+ }
@@ -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,6 @@
1
+ "use client";
2
+ import "../chunk-IV3L3JVM.js";
3
+ const hasInstalledExtension = (id) => !!window[id];
4
+ export {
5
+ hasInstalledExtension
6
+ };
@@ -0,0 +1,10 @@
1
+ "use client";
2
+ import "../../chunk-IV3L3JVM.js";
3
+ import { keplrWallet } from "./keplr/keplr.js";
4
+ import { leapWallet } from "./leap/leap.js";
5
+ const allWallets = [keplrWallet, leapWallet];
6
+ export {
7
+ allWallets,
8
+ keplrWallet,
9
+ leapWallet
10
+ };
@@ -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",
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.31.3",
20
+ "@cosmjs/stargate": "<=0.33.1",
21
21
  "@cosmjs/tendermint-rpc": "<=0.31.3",
22
- "@getpara/graz": "^1.0.0-dev.1",
23
- "@getpara/web-sdk": "2.0.0-alpha.3",
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.3",
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": "77a1e04b06258842ca9c81e3db2a2b0092517659"
42
+ "gitHead": "3ecfca088f24489f2e8fa5493d0f4459b08880e1"
43
43
  }
package/dist/index.js.br DELETED
Binary file
package/dist/index.js.gz DELETED
Binary file