@getpara/cosmos-wallet-connectors 2.0.0-dev.1 → 2.0.0-dev.3

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.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  export { CosmosExternalWalletContext } from './providers/CosmosExternalWalletContext.js';
2
- export type { CosmosExternalWalletContextType } from './providers/CosmosExternalWalletContext.js';
2
+ export { type CosmosExternalWalletContextType, type CosmosSignResult } from './providers/CosmosExternalWalletContext.js';
3
3
  export { ParaCosmosProvider } from './providers/ParaCosmosContext.js';
4
4
  export type { ParaCosmosProviderProps, ParaGrazProviderProps, ParaCosmosProviderConfig, } from './providers/ParaCosmosContext.js';
5
5
  export * from './wallets/connectors/index.js';
6
6
  export type { WalletList } from './types/Wallet.js';
7
+ export type * from './types/ExternalHooks.js';
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.externalWalletLogin({
164
- address: bufferAddress2,
165
- type: WalletType.COSMOS,
166
- provider: providerName,
167
- addressBech32: address2,
168
- withFullParaAuth: isFullAuthWallet
169
- });
170
- } catch (err) {
171
- yield reset();
172
- throw "Error logging you in. Please try again.";
173
- }
174
- });
175
- useEffect(() => {
176
- const storedExternalWallet = para.externalWallets[bufferAddress != null ? bufferAddress : ""];
177
- if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
178
- reset();
179
- }
180
- }, [isConnecting, isLocalConnecting, isReconnecting, isConnected]);
181
- useEffect(() => {
182
- const connect2 = () => __async(this, null, function* () {
183
- var _a2;
184
- if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedWallet.type === WalletType.COSMOS && (connectedWallet.isExternal ? walletType !== ((_a2 = connectedWallet.name) == null ? void 0 : _a2.toLowerCase()) : walletType !== "para")) {
185
- const isLoggedIn = yield para.isFullyLoggedIn();
186
- if (!isLoggedIn) {
187
- return;
188
- }
189
- const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
190
- yield connectAsync({
191
- walletType: connectedWallet.isExternal ? connectedWallet.name.toLowerCase() : GrazWalletType.PARA,
192
- chainId
193
- });
194
- }
195
- });
196
- connect2();
197
- }, [isLocalConnecting, isConnecting, isReconnecting, walletType, connectedWallet]);
198
- const signMessage = (message) => __async(this, null, function* () {
199
- const wallet = grazGetWallet(walletType);
200
- if (!wallet) {
201
- return { error: "Connected wallet not found" };
202
- }
203
- try {
204
- const publicKey = (yield wallet.getKey(selectedChainId)).pubKey;
205
- const signature = yield wallet.signArbitrary(selectedChainId, address, message);
206
- return {
207
- address: bufferAddress,
208
- signature: signature.signature,
209
- cosmosPublicKeyHex: Buffer.from(publicKey).toString("hex"),
210
- cosmosSigner: address
211
- };
212
- } catch (e) {
213
- if (e.message.includes("Request rejected")) {
214
- return { error: "Signature request rejected" };
215
- }
216
- return { error: "An unknown error occurred" };
217
- }
218
- });
219
- const signVerificationMessage = () => __async(this, null, function* () {
220
- const signature = yield signMessage(verificationMessage.current);
221
- return signature;
222
- });
223
- const connect = (walletType2, chainId) => __async(this, null, function* () {
224
- var _a2;
225
- updateExternalWalletState({ isConnecting: true });
226
- const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
227
- const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
228
- if (!chainId) {
229
- yield disconnectAsync();
230
- }
231
- const _chainId = chainId != null ? chainId : multiChain ? chains.map((c) => c.chainId) : selectedChainId;
232
- if (!_chainId) {
233
- console.error("Chain id not provided.");
234
- return;
235
- }
236
- let address2;
237
- let bufferAddress2;
238
- let error;
239
- let userExists = false;
240
- let isVerified = false;
241
- if (!walletType2) {
242
- console.error("Graz wallet type not provided.");
243
- return;
244
- } else {
245
- try {
246
- let chainInfo;
247
- if (shouldUseSuggestChainAndConnect) {
248
- if (typeof _chainId !== "string") {
249
- console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");
250
- return;
251
- }
252
- chainInfo = getChainInfo({ chainId: _chainId });
253
- if (!chainInfo) {
254
- console.error("Chain not found.");
255
- return;
256
- }
257
- }
258
- const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId });
259
- const firstChain = !chainId ? selectedChainId : typeof _chainId === "string" ? _chainId : _chainId[0];
260
- address2 = connectedWallet2.accounts[firstChain].bech32Address;
261
- bufferAddress2 = connectedWallet2.accounts[firstChain].address.toString();
262
- if (connectedWallet2.accounts[firstChain]) {
263
- try {
264
- const loginResp = yield login(bufferAddress2, address2, isFullAuthWallet, getProviderName(walletType2));
265
- userExists = loginResp.userExists;
266
- isVerified = loginResp.isVerified;
267
- verificationMessage.current = loginResp.signatureVerificationMessage;
268
- } catch (err) {
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 { address: address2, bufferAddress: bufferAddress2, error, userExists, isVerified };
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
+ }
@@ -1,43 +1,15 @@
1
1
  import { PropsWithChildren } from 'react';
2
2
  import { ParaCosmosProviderConfig } from './ParaCosmosContext.js';
3
3
  import { WalletWithType } from '../types/Wallet.js';
4
- import ParaWeb, { Wallet } from '@getpara/web-sdk';
5
- import type { CommonChain, CommonWallet, TExternalWallet } from '@getpara/react-common';
6
- export type CosmosExternalWalletContextType = {
7
- wallets: CommonWallet[];
8
- chains: CommonChain[];
9
- chainId?: string;
10
- disconnect: () => Promise<void>;
11
- switchChain: (chainId: string) => Promise<{
12
- error?: string[];
13
- }>;
14
- connectParaEmbedded: () => Promise<{
15
- result?: unknown;
16
- error?: string;
17
- }>;
18
- signMessage: (message: string) => Promise<{
19
- signature?: string;
20
- error?: string;
21
- }>;
22
- signVerificationMessage: () => Promise<{
23
- address?: string;
24
- signature?: string;
25
- cosmosPublicKeyHex?: string;
26
- cosmosSigner?: string;
27
- error?: string;
28
- }>;
4
+ import { type ChainManagement, type ConnectParaEmbedded, type ExternalWalletContextType, type ExternalWalletProviderConfig, type ExternalWalletProviderConfigBase, type SignResult } from '@getpara/react-common';
5
+ import { TExternalHooks } from './externalHooks.js';
6
+ export type CosmosSignResult = SignResult & {
7
+ cosmosPublicKeyHex?: string;
8
+ cosmosSigner?: string;
9
+ addressBech32?: string;
29
10
  };
30
- export type CosmosExternalWalletProviderConfig = {
31
- onSwitchWallet?: (args: {
32
- address?: string;
33
- error?: string;
34
- }) => void;
35
- para: ParaWeb;
36
- walletsWithFullAuth: TExternalWallet[];
37
- connectedWallet?: Omit<Wallet, 'signer'> | null;
38
- };
39
- export type CosmosExternalWalletProviderConfigFull = {
40
- wallets: WalletWithType[];
41
- } & Omit<ParaCosmosProviderConfig, 'wallets'> & CosmosExternalWalletProviderConfig;
11
+ export type CosmosExternalWalletContextType = ExternalWalletContextType<CosmosSignResult> & ChainManagement<string> & TExternalHooks & ConnectParaEmbedded;
12
+ export type CosmosExternalWalletProviderConfig = ExternalWalletProviderConfigBase;
13
+ export type CosmosExternalWalletProviderConfigFull = ExternalWalletProviderConfig<WalletWithType, Omit<ParaCosmosProviderConfig, 'wallets'>>;
42
14
  export declare const CosmosExternalWalletContext: import("react").Context<CosmosExternalWalletContextType>;
43
- export declare function CosmosExternalWalletProvider({ children, onSwitchWallet, selectedChainId, wallets: incompleteWallets, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain, para, walletsWithFullAuth, connectedWallet, }: CosmosExternalWalletProviderConfigFull & PropsWithChildren): import("react/jsx-runtime").JSX.Element;
15
+ export declare function CosmosExternalWalletProvider({ children, onSwitchWallet, selectedChainId, wallets: incompleteWallets, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain, para, walletsWithFullAuth, connectedWallet, includeWalletVerification, connectionOnly, }: CosmosExternalWalletProviderConfigFull & PropsWithChildren): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,372 @@
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
+ import { rawSecp256k1PubkeyToRawAddress } from "@getpara/web-sdk";
22
+ import {
23
+ defaultCosmosExternalWallet
24
+ } from "@getpara/react-common";
25
+ import { formatEthHexAddress } from "../utils/formatEthHexAddress.js";
26
+ import { externalHooks } from "./externalHooks.js";
27
+ const CosmosExternalWalletContext = createContext(defaultCosmosExternalWallet);
28
+ function CosmosExternalWalletProvider({
29
+ children,
30
+ onSwitchWallet,
31
+ selectedChainId,
32
+ wallets: incompleteWallets,
33
+ chains,
34
+ multiChain,
35
+ shouldUseSuggestChainAndConnect,
36
+ onSwitchChain,
37
+ para,
38
+ walletsWithFullAuth,
39
+ connectedWallet,
40
+ includeWalletVerification,
41
+ connectionOnly
42
+ }) {
43
+ var _a, _b, _c, _d;
44
+ const { suggestAndConnectAsync } = useSuggestChainAndConnect();
45
+ const {
46
+ data: account,
47
+ isConnecting,
48
+ isReconnecting,
49
+ isConnected
50
+ } = useAccount({
51
+ chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId != null ? selectedChainId : "",
52
+ multiChain
53
+ });
54
+ const { connectAsync } = useConnect();
55
+ const { disconnectAsync } = useDisconnect();
56
+ const { walletType } = useActiveWalletType();
57
+ const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
58
+ const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
59
+ const ethAddress = multiChain ? (_b = (_a = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _a.ethereumHexAddress) == null ? void 0 : _b.toLowerCase() : (_c = account == null ? void 0 : account.ethereumHexAddress) == null ? void 0 : _c.toLowerCase();
60
+ const address = multiChain ? (_d = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _d.bech32Address : account == null ? void 0 : account.bech32Address;
61
+ const isLinkingAccount = useRef(false);
62
+ const verificationMessage = useRef();
63
+ const reset = () => __async(this, null, function* () {
64
+ yield disconnectAsync();
65
+ yield para.logout();
66
+ });
67
+ const switchChain = (chainId) => __async(this, null, function* () {
68
+ var _a2;
69
+ let error;
70
+ let changeResp = {};
71
+ try {
72
+ let chainInfo;
73
+ if (shouldUseSuggestChainAndConnect) {
74
+ chainInfo = getChainInfo({ chainId });
75
+ if (!chainInfo) {
76
+ console.error("Chain not found.");
77
+ return;
78
+ }
79
+ }
80
+ const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType, chainInfo }) : connectAsync({ walletType, chainId });
81
+ changeResp.address = connectedWallet2.accounts[chainId].bech32Address;
82
+ changeResp.ethAddress = formatEthHexAddress(connectedWallet2.accounts[chainId].address);
83
+ } catch (err) {
84
+ if (err.message === "No wallet exists") {
85
+ changeResp.error = err.message;
86
+ } else {
87
+ console.error("Graz connection error:", err);
88
+ changeResp.error = "An unknown error occurred.";
89
+ }
90
+ }
91
+ onSwitchWallet(changeResp);
92
+ if (!changeResp.error) {
93
+ onSwitchChain(chainId);
94
+ const storedExternalWallet = para.externalWallets[(_a2 = changeResp.ethAddress) != null ? _a2 : ""];
95
+ const { provider, providerId } = getProvider(walletType);
96
+ para.setExternalWallet({
97
+ address: changeResp.ethAddress,
98
+ type: "COSMOS",
99
+ provider,
100
+ providerId,
101
+ addressBech32: changeResp.address,
102
+ withFullParaAuth: storedExternalWallet.isExternalWithParaAuth,
103
+ withVerification: includeWalletVerification,
104
+ isConnectionOnly: connectionOnly
105
+ });
106
+ }
107
+ return { error };
108
+ });
109
+ const login = (_0) => __async(this, [_0], function* ({
110
+ address: address2,
111
+ addressBech32,
112
+ withFullParaAuth,
113
+ providerId,
114
+ provider
115
+ }) {
116
+ try {
117
+ return yield para.loginExternalWallet({
118
+ externalWallet: {
119
+ address: address2,
120
+ type: "COSMOS",
121
+ provider,
122
+ providerId,
123
+ addressBech32,
124
+ withFullParaAuth,
125
+ withVerification: includeWalletVerification,
126
+ isConnectionOnly: connectionOnly
127
+ }
128
+ });
129
+ } catch (err) {
130
+ yield reset();
131
+ throw "Error logging you in. Please try again.";
132
+ }
133
+ });
134
+ useEffect(() => {
135
+ const storedExternalWallet = para.externalWallets[ethAddress != null ? ethAddress : ""];
136
+ if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!ethAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA && !isLinkingAccount.current) {
137
+ reset();
138
+ }
139
+ }, [isConnecting, isLocalConnecting, isReconnecting, isConnected]);
140
+ useEffect(() => {
141
+ const connect2 = () => __async(this, null, function* () {
142
+ var _a2;
143
+ if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedWallet.type === "COSMOS" && (connectedWallet.isExternal ? walletType !== ((_a2 = connectedWallet.name) == null ? void 0 : _a2.toLowerCase()) : walletType !== "para") && !isLinkingAccount.current) {
144
+ const isLoggedIn = yield para.isFullyLoggedIn();
145
+ if (!isLoggedIn) {
146
+ return;
147
+ }
148
+ const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
149
+ yield connectAsync({
150
+ walletType: connectedWallet.isExternal ? connectedWallet.name.toLowerCase() : GrazWalletType.PARA,
151
+ chainId
152
+ });
153
+ }
154
+ });
155
+ connect2();
156
+ }, [isLocalConnecting, isConnecting, isReconnecting, walletType, connectedWallet]);
157
+ const signMessage = (_0) => __async(this, [_0], function* ({ message, externalWallet }) {
158
+ let wallet, signAddress, signEthAddress;
159
+ if (externalWallet) {
160
+ const commonWallet = wallets.find((w) => w.internalId === externalWallet.providerId);
161
+ wallet = grazGetWallet(commonWallet == null ? void 0 : commonWallet.grazType);
162
+ signAddress = externalWallet.addressBech32;
163
+ signEthAddress = externalWallet.address;
164
+ } else {
165
+ wallet = grazGetWallet(walletType);
166
+ signAddress = address;
167
+ signEthAddress = ethAddress;
168
+ }
169
+ if (!wallet) {
170
+ return { error: "Connected wallet not found" };
171
+ }
172
+ try {
173
+ const publicKey = (yield wallet.getKey(selectedChainId)).pubKey;
174
+ const signature = yield wallet.signArbitrary(selectedChainId, signAddress, message);
175
+ return {
176
+ address: signEthAddress,
177
+ addressBech32: signAddress,
178
+ signature: signature.signature,
179
+ cosmosPublicKeyHex: Buffer.from(publicKey).toString("hex"),
180
+ cosmosSigner: signAddress
181
+ };
182
+ } catch (e) {
183
+ if (e.message.includes("Request rejected")) {
184
+ return { error: "Signature request rejected" };
185
+ }
186
+ return { error: "An unknown error occurred" };
187
+ }
188
+ });
189
+ const signVerificationMessage = () => __async(this, null, function* () {
190
+ const signature = yield signMessage({ message: verificationMessage.current });
191
+ return signature;
192
+ });
193
+ const connectBase = (walletType2, chainId) => __async(this, null, function* () {
194
+ var _a2;
195
+ if (!chainId) {
196
+ yield disconnectAsync();
197
+ }
198
+ const _chainId = chainId != null ? chainId : multiChain ? chains.map((c) => c.chainId) : selectedChainId;
199
+ if (!_chainId) {
200
+ throw new Error("Chain id not provided.");
201
+ }
202
+ if (!walletType2) {
203
+ throw new Error("Graz wallet type not provided.");
204
+ }
205
+ try {
206
+ let chainInfo;
207
+ if (shouldUseSuggestChainAndConnect) {
208
+ if (typeof _chainId !== "string") {
209
+ console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");
210
+ return;
211
+ }
212
+ chainInfo = getChainInfo({ chainId: _chainId });
213
+ if (!chainInfo) {
214
+ console.error("Chain not found.");
215
+ return;
216
+ }
217
+ }
218
+ const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId });
219
+ const firstChain = !chainId ? selectedChainId : typeof _chainId === "string" ? _chainId : _chainId[0];
220
+ const addressBech32 = connectedWallet2.accounts[firstChain].bech32Address;
221
+ let rawAddress;
222
+ const accountAddress = connectedWallet2.accounts[firstChain].address;
223
+ if (!accountAddress || accountAddress.length === 0 || accountAddress.byteLength === 0) {
224
+ const pubKey = connectedWallet2.accounts[firstChain].pubKey;
225
+ rawAddress = rawSecp256k1PubkeyToRawAddress(pubKey);
226
+ } else {
227
+ rawAddress = accountAddress;
228
+ }
229
+ const address2 = formatEthHexAddress(rawAddress);
230
+ const { provider, providerId } = getProvider(walletType2);
231
+ return {
232
+ type: "COSMOS",
233
+ address: address2,
234
+ addressBech32,
235
+ provider,
236
+ providerId
237
+ };
238
+ } catch (e) {
239
+ let error;
240
+ if (e.message === "No wallet exists") {
241
+ error = e.message;
242
+ } else {
243
+ error = `Graz connection error: ${(_a2 = e == null ? void 0 : e.message) != null ? _a2 : e}`;
244
+ }
245
+ throw error;
246
+ }
247
+ });
248
+ const connect = (walletType2, chainId) => __async(this, null, function* () {
249
+ var _a2, _b2;
250
+ updateExternalWalletState({ isConnecting: true });
251
+ const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
252
+ const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
253
+ try {
254
+ const externalWallet = yield connectBase(walletType2, chainId);
255
+ const authState = yield login(__spreadProps(__spreadValues({}, externalWallet), {
256
+ withFullParaAuth: isFullAuthWallet
257
+ }));
258
+ verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
259
+ return {
260
+ address: externalWallet.address,
261
+ authState
262
+ };
263
+ } catch (e) {
264
+ return {
265
+ error: (_b2 = e == null ? void 0 : e.message) != null ? _b2 : e
266
+ };
267
+ } finally {
268
+ updateExternalWalletState({ isConnecting: false });
269
+ }
270
+ });
271
+ const getWallet = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2);
272
+ const getProvider = (walletType2) => {
273
+ const wallet = getWallet(walletType2);
274
+ return {
275
+ provider: wallet == null ? void 0 : wallet.name,
276
+ providerId: wallet == null ? void 0 : wallet.internalId
277
+ };
278
+ };
279
+ const wallets = incompleteWallets.map((wallet) => {
280
+ return __spreadProps(__spreadValues({
281
+ connect: () => connect(wallet.grazType),
282
+ connectMobile: () => connect(wallet.grazType),
283
+ getQrUri: () => "",
284
+ type: "COSMOS"
285
+ }, wallet), {
286
+ installed: checkWallet(wallet.grazType)
287
+ });
288
+ }).filter((w) => !!w);
289
+ const formattedChains = chains.map((c) => {
290
+ return {
291
+ id: c.chainId,
292
+ name: c.chainName
293
+ };
294
+ });
295
+ const connectParaEmbedded = useCallback(() => __async(this, null, function* () {
296
+ if (!para) {
297
+ return { error: "No para instance available" };
298
+ }
299
+ try {
300
+ const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
301
+ const result = yield connectAsync({ walletType: GrazWalletType.PARA, chainId });
302
+ return { result };
303
+ } catch (err) {
304
+ const error = err instanceof Error ? err.message : "Unknown error";
305
+ return { error };
306
+ }
307
+ }), [para, multiChain, chains, selectedChainId]);
308
+ const requestInfo = (providerId) => __async(this, null, function* () {
309
+ var _a2;
310
+ const wallet = wallets.find((w) => w.internalId === providerId);
311
+ if (!wallet) {
312
+ throw new Error(`Wallet for provider ${providerId} not found`);
313
+ }
314
+ isLinkingAccount.current = true;
315
+ try {
316
+ const externalWallet = yield connectBase(
317
+ wallet.grazType,
318
+ multiChain ? chains.map((c) => c.chainId) : selectedChainId
319
+ );
320
+ return externalWallet;
321
+ } catch (e) {
322
+ console.error("Error linking account:", e);
323
+ throw new Error((_a2 = e == null ? void 0 : e.message) != null ? _a2 : e);
324
+ }
325
+ });
326
+ const disconnectBase = () => __async(this, null, function* () {
327
+ var _a2;
328
+ isLinkingAccount.current = true;
329
+ try {
330
+ yield disconnectAsync();
331
+ } catch (e) {
332
+ console.error("Error linking account:", e);
333
+ throw new Error((_a2 = e == null ? void 0 : e.message) != null ? _a2 : e);
334
+ }
335
+ });
336
+ return /* @__PURE__ */ jsx(
337
+ CosmosExternalWalletContext.Provider,
338
+ {
339
+ value: useMemo(
340
+ () => __spreadValues({
341
+ wallets,
342
+ chains: formattedChains,
343
+ chainId: selectedChainId,
344
+ disconnect: disconnectAsync,
345
+ switchChain,
346
+ connectParaEmbedded,
347
+ signMessage,
348
+ signVerificationMessage,
349
+ requestInfo,
350
+ disconnectBase
351
+ }, externalHooks),
352
+ [
353
+ wallets,
354
+ formattedChains,
355
+ selectedChainId,
356
+ disconnectAsync,
357
+ switchChain,
358
+ connectParaEmbedded,
359
+ signMessage,
360
+ signVerificationMessage,
361
+ requestInfo,
362
+ disconnectBase
363
+ ]
364
+ ),
365
+ children
366
+ }
367
+ );
368
+ }
369
+ export {
370
+ CosmosExternalWalletContext,
371
+ CosmosExternalWalletProvider
372
+ };
@@ -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,8 @@
1
+ import { useAccount } from '@getpara/graz';
2
+ import { MultiChainHookArgs } from '../types/ExternalHooks.js';
3
+ export type TExternalHooks = {
4
+ useAccount: typeof useAccount<MultiChainHookArgs>;
5
+ };
6
+ export declare const externalHooks: {
7
+ useAccount: typeof useAccount;
8
+ };
@@ -0,0 +1,7 @@
1
+ "use client";
2
+ import "../chunk-IV3L3JVM.js";
3
+ import { useAccount } from "@getpara/graz";
4
+ const externalHooks = { useAccount };
5
+ export {
6
+ externalHooks
7
+ };
@@ -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,8 @@
1
+ import { UseAccountArgs } from '@getpara/graz';
2
+ type ChainId$1 = string | string[];
3
+ export interface MultiChainHookArgs {
4
+ chainId?: ChainId$1;
5
+ multiChain?: boolean;
6
+ }
7
+ export type UseAccountParameters = UseAccountArgs & MultiChainHookArgs;
8
+ export {};
@@ -0,0 +1 @@
1
+ "use client";
@@ -0,0 +1 @@
1
+ "use client";
@@ -0,0 +1 @@
1
+ export declare function formatEthHexAddress(address: Uint8Array): string;
@@ -0,0 +1,8 @@
1
+ "use client";
2
+ import "../chunk-IV3L3JVM.js";
3
+ function formatEthHexAddress(address) {
4
+ return `0x${Buffer.from(address).toString("hex")}`.toLowerCase();
5
+ }
6
+ export {
7
+ formatEthHexAddress
8
+ };
@@ -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,2 @@
1
+ import { WalletWithType } from '../../../types/Wallet.js';
2
+ export declare const cosmostationWallet: () => WalletWithType;
@@ -0,0 +1,21 @@
1
+ "use client";
2
+ import "../../../chunk-IV3L3JVM.js";
3
+ import { icon } from "./cosmostationIcon.js";
4
+ import { WalletType } from "@getpara/graz";
5
+ import { isMobile } from "@getpara/web-sdk";
6
+ const cosmostationWallet = () => {
7
+ return {
8
+ id: "cosmostation",
9
+ internalId: "COSMOSTATION",
10
+ name: "Cosmostation",
11
+ iconUrl: icon,
12
+ isExtension: true,
13
+ isMobile: isMobile() && true,
14
+ downloadUrl: "https://www.cosmostation.io/products/cosmostation_extension",
15
+ grazType: WalletType.COSMOSTATION,
16
+ grazMobileType: WalletType.WC_COSMOSTATION_MOBILE
17
+ };
18
+ };
19
+ export {
20
+ cosmostationWallet
21
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import "../../../chunk-IV3L3JVM.js";
3
+ const icon = "";
4
+ export {
5
+ icon
6
+ };
@@ -1,4 +1,5 @@
1
1
  import { keplrWallet } from './keplr/keplr.js';
2
2
  import { leapWallet } from './leap/leap.js';
3
- export { keplrWallet, leapWallet };
3
+ import { cosmostationWallet } from './cosmostation/cosmostation.js';
4
+ export { keplrWallet, leapWallet, cosmostationWallet };
4
5
  export declare const allWallets: (() => import("../../types/Wallet.js").WalletWithType)[];
@@ -0,0 +1,12 @@
1
+ "use client";
2
+ import "../../chunk-IV3L3JVM.js";
3
+ import { keplrWallet } from "./keplr/keplr.js";
4
+ import { leapWallet } from "./leap/leap.js";
5
+ import { cosmostationWallet } from "./cosmostation/cosmostation.js";
6
+ const allWallets = [keplrWallet, leapWallet, cosmostationWallet];
7
+ export {
8
+ allWallets,
9
+ cosmostationWallet,
10
+ keplrWallet,
11
+ leapWallet
12
+ };
@@ -0,0 +1,21 @@
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
+ internalId: "KEPLR",
10
+ name: "Keplr",
11
+ iconUrl: icon,
12
+ isExtension: true,
13
+ isMobile: isMobile() && true,
14
+ downloadUrl: "https://www.keplr.app/get",
15
+ grazType: WalletType.KEPLR,
16
+ grazMobileType: WalletType.WC_KEPLR_MOBILE
17
+ };
18
+ };
19
+ export {
20
+ keplrWallet
21
+ };
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import "../../../chunk-IV3L3JVM.js";
3
+ const icon = "";
4
+ export {
5
+ icon
6
+ };
@@ -0,0 +1,21 @@
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
+ internalId: "LEAP",
10
+ name: "Leap",
11
+ iconUrl: icon,
12
+ isExtension: true,
13
+ isMobile: isMobile() && true,
14
+ downloadUrl: "https://www.leapwallet.io/download",
15
+ grazType: WalletType.LEAP,
16
+ grazMobileType: WalletType.WC_LEAP_MOBILE
17
+ };
18
+ };
19
+ export {
20
+ leapWallet
21
+ };
@@ -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,43 +1,41 @@
1
1
  {
2
2
  "name": "@getpara/cosmos-wallet-connectors",
3
- "version": "2.0.0-dev.1",
4
- "type": "module",
5
- "main": "dist/index.js",
6
- "types": "dist/index.d.ts",
7
- "exports": {
8
- ".": "./dist/index.js",
9
- "./connectors": "./dist/wallets/connectors/index.js"
10
- },
11
- "scripts": {
12
- "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
13
- "typegen": "tsc --emitDeclarationOnly",
14
- "test": "vitest run --coverage"
15
- },
3
+ "version": "2.0.0-dev.3",
16
4
  "dependencies": {
17
- "@cosmjs/cosmwasm-stargate": "<=0.31.3",
18
- "@cosmjs/launchpad": "*",
19
- "@cosmjs/proto-signing": "<=0.31.3",
20
- "@cosmjs/stargate": "<=0.31.3",
21
- "@cosmjs/tendermint-rpc": "<=0.31.3",
22
- "@getpara/graz": "^1.0.0-dev.1",
23
- "@getpara/web-sdk": "^2.0.0-dev.1",
5
+ "@getpara/graz": "2.0.0-alpha.3",
6
+ "@getpara/react-common": "2.0.0-dev.3",
7
+ "@getpara/web-sdk": "2.0.0-dev.3",
24
8
  "@leapwallet/cosmos-social-login-capsule-provider": "^0.0.41",
9
+ "starknet": "^6.11.0",
25
10
  "zustand": "^4.5.2",
26
11
  "zustand-sync-tabs": "^0.2.2"
27
12
  },
28
13
  "devDependencies": {
29
- "@getpara/react-common": "^2.0.0-dev.1",
14
+ "@getpara/graz": "2.0.0-alpha.3",
30
15
  "@types/react": "^18.0.31",
31
16
  "@types/react-dom": "^18.2.7",
32
- "typescript": "^5.4.3"
17
+ "typescript": "^5.8.3"
33
18
  },
34
- "peerDependencies": {
35
- "react": ">=18",
36
- "react-dom": ">=18"
19
+ "exports": {
20
+ ".": "./dist/index.js",
21
+ "./connectors": "./dist/wallets/connectors/index.js"
37
22
  },
38
23
  "files": [
39
24
  "dist",
40
25
  "package.json"
41
26
  ],
42
- "gitHead": "426e843bd6084fb2e5f30ab87b02c79fc2f52832"
27
+ "gitHead": "ffe34f7d8df2dd3c2327ca1f35bcc9764e0a68a2",
28
+ "main": "dist/index.js",
29
+ "peerDependencies": {
30
+ "@getpara/graz": "2.0.0-alpha.3",
31
+ "react": ">=18",
32
+ "react-dom": ">=18"
33
+ },
34
+ "scripts": {
35
+ "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
36
+ "test": "vitest run --coverage",
37
+ "typegen": "tsc --emitDeclarationOnly"
38
+ },
39
+ "type": "module",
40
+ "types": "dist/index.d.ts"
43
41
  }
package/dist/index.js.br DELETED
Binary file
package/dist/index.js.gz DELETED
Binary file