@getpara/cosmos-wallet-connectors 1.7.1 → 1.9.0

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