@getpara/cosmos-wallet-connectors 1.12.0 → 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.
@@ -18,18 +18,6 @@ var __spreadValues = (a, b) => {
18
18
  return a;
19
19
  };
20
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
21
  var __async = (__this, __arguments, generator) => {
34
22
  return new Promise((resolve, reject) => {
35
23
  var fulfilled = (value) => {
@@ -54,6 +42,5 @@ var __async = (__this, __arguments, generator) => {
54
42
  export {
55
43
  __spreadValues,
56
44
  __spreadProps,
57
- __objRest,
58
45
  __async
59
46
  };
package/dist/index.d.ts CHANGED
@@ -1,3 +1,6 @@
1
- export { CosmosExternalWalletContext, CosmosExternalWalletProvider } from './providers/CosmosExternalWalletContext.js';
2
- export { ParaCosmosProvider, useParaCosmos } from './providers/ParaCosmosContext.js';
1
+ export { CosmosExternalWalletContext } from './providers/CosmosExternalWalletContext.js';
2
+ export type { CosmosExternalWalletContextType } from './providers/CosmosExternalWalletContext.js';
3
+ export { ParaCosmosProvider } from './providers/ParaCosmosContext.js';
4
+ export type { ParaCosmosProviderProps, ParaGrazProviderProps, ParaCosmosProviderConfig, } from './providers/ParaCosmosContext.js';
3
5
  export * from './wallets/connectors/index.js';
6
+ export type { WalletList } from './types/Wallet.js';
package/dist/index.js CHANGED
@@ -1,11 +1,9 @@
1
1
  "use client";
2
- import "./chunk-MMUBH76A.js";
3
- import { CosmosExternalWalletContext, CosmosExternalWalletProvider } from "./providers/CosmosExternalWalletContext.js";
4
- import { ParaCosmosProvider, useParaCosmos } from "./providers/ParaCosmosContext.js";
2
+ import "./chunk-IV3L3JVM.js";
3
+ import { CosmosExternalWalletContext } from "./providers/CosmosExternalWalletContext.js";
4
+ import { ParaCosmosProvider } from "./providers/ParaCosmosContext.js";
5
5
  export * from "./wallets/connectors/index.js";
6
6
  export {
7
7
  CosmosExternalWalletContext,
8
- CosmosExternalWalletProvider,
9
- ParaCosmosProvider,
10
- useParaCosmos
8
+ ParaCosmosProvider
11
9
  };
@@ -1,22 +1,20 @@
1
- import { ReactNode } from 'react';
2
- import ParaWeb, { CommonChain, CommonWallet } from '@getpara/react-sdk';
3
- export declare const defaultCosmosExternalWallet: {
4
- wallets: any[];
5
- chains: any[];
6
- chainId: any;
7
- disconnect: () => Promise<void>;
8
- switchChain: () => Promise<{}>;
9
- signMessage: () => Promise<{}>;
10
- signVerificationMessage: () => Promise<{}>;
11
- };
12
- export declare const CosmosExternalWalletContext: import("react").Context<{
1
+ import { PropsWithChildren } from 'react';
2
+ import { ParaCosmosProviderConfig } from './ParaCosmosContext.js';
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 = {
13
7
  wallets: CommonWallet[];
14
8
  chains: CommonChain[];
15
- chainId: string;
9
+ chainId?: string;
16
10
  disconnect: () => Promise<void>;
17
11
  switchChain: (chainId: string) => Promise<{
18
12
  error?: string[];
19
13
  }>;
14
+ connectParaEmbedded: () => Promise<{
15
+ result?: unknown;
16
+ error?: string;
17
+ }>;
20
18
  signMessage: (message: string) => Promise<{
21
19
  signature?: string;
22
20
  error?: string;
@@ -28,14 +26,18 @@ export declare const CosmosExternalWalletContext: import("react").Context<{
28
26
  cosmosSigner?: string;
29
27
  error?: string;
30
28
  }>;
31
- }>;
32
- interface CosmosExternalWalletProviderProps {
33
- children: ReactNode;
34
- para: ParaWeb;
35
- onSwitchWallet: (args: {
29
+ };
30
+ export type CosmosExternalWalletProviderConfig = {
31
+ onSwitchWallet?: (args: {
36
32
  address?: string;
37
33
  error?: string;
38
34
  }) => void;
39
- }
40
- export declare function CosmosExternalWalletProvider({ children, para, onSwitchWallet }: CosmosExternalWalletProviderProps): import("react/jsx-runtime").JSX.Element;
41
- export {};
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;
42
+ 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;
@@ -3,19 +3,13 @@ import {
3
3
  __async,
4
4
  __spreadProps,
5
5
  __spreadValues
6
- } from "../chunk-MMUBH76A.js";
6
+ } from "../chunk-IV3L3JVM.js";
7
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";
8
+ import { createContext, useCallback, useEffect, useMemo, useRef } from "react";
14
9
  import {
15
10
  checkWallet,
16
11
  WalletType as GrazWalletType,
17
12
  useAccount,
18
- useActiveChainIds,
19
13
  useActiveWalletType,
20
14
  useConnect,
21
15
  useDisconnect,
@@ -30,36 +24,40 @@ const defaultCosmosExternalWallet = {
30
24
  chainId: void 0,
31
25
  disconnect: () => Promise.resolve(),
32
26
  switchChain: () => Promise.resolve({}),
27
+ connectParaEmbedded: () => Promise.resolve({}),
33
28
  signMessage: () => Promise.resolve({}),
34
29
  signVerificationMessage: () => Promise.resolve({})
35
30
  };
36
31
  const CosmosExternalWalletContext = createContext(defaultCosmosExternalWallet);
37
- function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
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
+ }) {
38
45
  var _a, _b;
39
- const {
40
- selectedChainId,
41
- wallets: incompleteWallets,
42
- chains,
43
- multiChain,
44
- shouldUseSuggestChainAndConnect,
45
- onSwitchChain
46
- } = useParaCosmos();
47
46
  const { suggestAndConnectAsync } = useSuggestChainAndConnect();
48
47
  const {
49
48
  data: account,
50
49
  isConnecting,
51
- isReconnecting
50
+ isReconnecting,
51
+ isConnected
52
52
  } = useAccount({
53
53
  chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId,
54
54
  multiChain
55
55
  });
56
- const activeChainIds = useActiveChainIds();
57
56
  const { connectAsync } = useConnect();
58
57
  const { disconnectAsync } = useDisconnect();
59
58
  const { walletType } = useActiveWalletType();
60
59
  const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
61
60
  const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
62
- const fullAuthWallets = useExternalWalletProviderStore((state) => state.fullAuthWallets);
63
61
  const bufferAddress = multiChain ? (_a = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _a.address.toString() : account == null ? void 0 : account.address.toString();
64
62
  const address = multiChain ? (_b = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _b.bech32Address : account == null ? void 0 : account.bech32Address;
65
63
  const verificationMessage = useRef();
@@ -68,31 +66,53 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
68
66
  yield para.logout();
69
67
  });
70
68
  const switchChain = (chainId) => __async(this, null, function* () {
69
+ var _a2;
71
70
  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];
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.";
81
90
  }
82
91
  }
83
- if (!error) {
92
+ onSwitchWallet(changeResp);
93
+ if (!changeResp.error) {
84
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
+ });
85
103
  }
86
104
  return { error };
87
105
  });
88
- const login = (bufferAddress2, address2, grazWalletType, providerName) => __async(this, null, function* () {
106
+ const login = (bufferAddress2, address2, isFullAuthWallet, providerName) => __async(this, null, function* () {
89
107
  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())
108
+ return yield para.loginExternalWallet({
109
+ externalWallet: {
110
+ address: bufferAddress2,
111
+ type: "COSMOS",
112
+ provider: providerName,
113
+ addressBech32: address2,
114
+ withFullParaAuth: isFullAuthWallet
115
+ }
96
116
  });
97
117
  } catch (err) {
98
118
  yield reset();
@@ -101,22 +121,27 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
101
121
  });
102
122
  useEffect(() => {
103
123
  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) {
124
+ if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
117
125
  reset();
118
126
  }
119
- }, [isConnecting, isReconnecting]);
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]);
120
145
  const signMessage = (message) => __async(this, null, function* () {
121
146
  const wallet = grazGetWallet(walletType);
122
147
  if (!wallet) {
@@ -143,7 +168,10 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
143
168
  return signature;
144
169
  });
145
170
  const connect = (walletType2, chainId) => __async(this, null, function* () {
171
+ var _a2;
146
172
  updateExternalWalletState({ isConnecting: true });
173
+ const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
174
+ const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
147
175
  if (!chainId) {
148
176
  yield disconnectAsync();
149
177
  }
@@ -155,8 +183,7 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
155
183
  let address2;
156
184
  let bufferAddress2;
157
185
  let error;
158
- let userExists = false;
159
- let isVerified = false;
186
+ let authState;
160
187
  if (!walletType2) {
161
188
  console.error("Graz wallet type not provided.");
162
189
  return;
@@ -174,17 +201,16 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
174
201
  return;
175
202
  }
176
203
  }
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]) {
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]) {
182
209
  try {
183
- const loginResp = yield login(bufferAddress2, address2, walletType2, getProviderName(walletType2));
184
- userExists = loginResp.userExists;
185
- isVerified = loginResp.isVerified;
186
- verificationMessage.current = loginResp.signatureVerificationMessage;
210
+ authState = yield login(bufferAddress2, address2, isFullAuthWallet, getProviderName(walletType2));
211
+ verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
187
212
  } catch (err) {
213
+ authState = void 0;
188
214
  bufferAddress2 = void 0;
189
215
  address2 = void 0;
190
216
  error = err;
@@ -200,23 +226,19 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
200
226
  }
201
227
  }
202
228
  updateExternalWalletState({ isConnecting: false });
203
- return { address: address2, bufferAddress: bufferAddress2, error, userExists, isVerified };
229
+ return { authState, address: address2, bufferAddress: bufferAddress2, error };
204
230
  });
205
231
  const getWallet = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2);
206
232
  const getProviderName = (walletType2) => {
207
233
  var _a2;
208
234
  return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.name;
209
235
  };
210
- const getWalletId = (walletType2) => {
211
- var _a2;
212
- return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
213
- };
214
236
  const wallets = incompleteWallets.map((wallet) => {
215
237
  return __spreadProps(__spreadValues({
216
238
  connect: () => connect(wallet.grazType),
217
239
  connectMobile: () => connect(wallet.grazType),
218
240
  getQrUri: () => "",
219
- type: WalletType.COSMOS
241
+ type: "COSMOS"
220
242
  }, wallet), {
221
243
  installed: checkWallet(wallet.grazType)
222
244
  });
@@ -227,6 +249,19 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
227
249
  name: c.chainName
228
250
  };
229
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]);
230
265
  return /* @__PURE__ */ jsx(
231
266
  CosmosExternalWalletContext.Provider,
232
267
  {
@@ -237,10 +272,20 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
237
272
  chainId: selectedChainId,
238
273
  disconnect: disconnectAsync,
239
274
  switchChain,
275
+ connectParaEmbedded,
240
276
  signMessage,
241
277
  signVerificationMessage
242
278
  }),
243
- [wallets, formattedChains, selectedChainId, disconnectAsync, switchChain, signMessage, signVerificationMessage]
279
+ [
280
+ wallets,
281
+ formattedChains,
282
+ selectedChainId,
283
+ disconnectAsync,
284
+ switchChain,
285
+ connectParaEmbedded,
286
+ signMessage,
287
+ signVerificationMessage
288
+ ]
244
289
  ),
245
290
  children
246
291
  }
@@ -248,6 +293,5 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
248
293
  }
249
294
  export {
250
295
  CosmosExternalWalletContext,
251
- CosmosExternalWalletProvider,
252
- defaultCosmosExternalWallet
296
+ CosmosExternalWalletProvider
253
297
  };
@@ -1,17 +1,9 @@
1
- import { ReactNode } from 'react';
2
- import { WalletList, WalletWithType } from '../types/Wallet.js';
1
+ import { PropsWithChildren } from 'react';
2
+ import { WalletList } from '../types/Wallet.js';
3
+ import { CosmosExternalWalletProviderConfig } from './CosmosExternalWalletContext.js';
3
4
  import { ChainInfo } from '@keplr-wallet/types';
4
5
  import { ConfigureGrazArgs } from '@getpara/graz';
5
- export declare const ParaCosmosContext: import("react").Context<{
6
- selectedChainId?: string;
7
- wallets: WalletWithType[];
8
- chains: ChainInfo[];
9
- multiChain?: boolean;
10
- shouldUseSuggestChainAndConnect?: boolean;
11
- onSwitchChain: (chainId: string) => void;
12
- }>;
13
- interface ParaCosmosProviderProps extends Omit<ConfigureGrazArgs, 'chains'> {
14
- children: ReactNode;
6
+ export type ParaCosmosProviderConfig = {
15
7
  wallets: WalletList;
16
8
  chains: ChainInfo[];
17
9
  /**
@@ -33,14 +25,11 @@ interface ParaCosmosProviderProps extends Omit<ConfigureGrazArgs, 'chains'> {
33
25
  */
34
26
  shouldUseSuggestChainAndConnect?: boolean;
35
27
  onSwitchChain: (chainId: string) => void;
36
- }
37
- export declare function ParaCosmosProvider({ children, wallets, chains, selectedChainId, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain, ...grazOpts }: ParaCosmosProviderProps): import("react/jsx-runtime").JSX.Element;
38
- export declare const useParaCosmos: () => {
39
- selectedChainId?: string;
40
- wallets: WalletWithType[];
41
- chains: ChainInfo[];
42
- multiChain?: boolean;
43
- shouldUseSuggestChainAndConnect?: boolean;
44
- onSwitchChain: (chainId: string) => void;
45
28
  };
46
- export {};
29
+ export type ParaGrazProviderProps = Omit<ConfigureGrazArgs, 'config' | 'chains'>;
30
+ export type ParaCosmosProviderProps = {
31
+ config: ParaCosmosProviderConfig;
32
+ internalConfig: CosmosExternalWalletProviderConfig;
33
+ grazProviderProps: ParaGrazProviderProps;
34
+ };
35
+ export declare function ParaCosmosProvider({ children, config, internalConfig, grazProviderProps, }: ParaCosmosProviderProps & PropsWithChildren): import("react/jsx-runtime").JSX.Element;
@@ -1,90 +1,37 @@
1
1
  "use client";
2
2
  import {
3
- __async,
4
- __objRest,
5
3
  __spreadProps,
6
4
  __spreadValues
7
- } from "../chunk-MMUBH76A.js";
5
+ } from "../chunk-IV3L3JVM.js";
8
6
  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]);
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;
64
18
  const walletsWithType = [];
65
19
  wallets.forEach((w) => {
66
20
  const wallet = w();
67
21
  walletsWithType.push(wallet);
68
22
  });
69
- const value = useMemo(
70
- () => ({
71
- selectedChainId,
72
- wallets: walletsWithType,
73
- chains,
74
- multiChain,
75
- shouldUseSuggestChainAndConnect,
76
- onSwitchChain
23
+ const cosmosExternalWalletProviderProps = useMemo(
24
+ () => __spreadProps(__spreadValues(__spreadValues({}, config), internalConfig), {
25
+ wallets: walletsWithType
77
26
  }),
78
- [selectedChainId, walletsWithType, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain]
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 })) })
79
33
  );
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
34
  }
85
- const useParaCosmos = () => useContext(ParaCosmosContext);
86
35
  export {
87
- ParaCosmosContext,
88
- ParaCosmosProvider,
89
- useParaCosmos
36
+ ParaCosmosProvider
90
37
  };
@@ -1,7 +1,7 @@
1
1
  "use client";
2
2
  import {
3
3
  __spreadValues
4
- } from "../chunk-MMUBH76A.js";
4
+ } from "../chunk-IV3L3JVM.js";
5
5
  import { create } from "zustand";
6
6
  import { syncTabs } from "zustand-sync-tabs";
7
7
  const useExternalWalletStore = create(
@@ -1,5 +1,5 @@
1
1
  import { WalletType } from '@getpara/graz';
2
- import { WalletMetadata } from '@getpara/react-sdk';
2
+ import { type WalletMetadata } from '@getpara/react-common';
3
3
  export type WalletList = (() => WalletWithType)[];
4
4
  export type WalletWithType = {
5
5
  grazType: WalletType;
@@ -1,5 +1,5 @@
1
1
  "use client";
2
- import "../chunk-MMUBH76A.js";
2
+ import "../chunk-IV3L3JVM.js";
3
3
  const hasInstalledExtension = (id) => !!window[id];
4
4
  export {
5
5
  hasInstalledExtension
@@ -1,3 +1,4 @@
1
1
  import { keplrWallet } from './keplr/keplr.js';
2
2
  import { leapWallet } from './leap/leap.js';
3
3
  export { keplrWallet, leapWallet };
4
+ export declare const allWallets: (() => import("../../types/Wallet.js").WalletWithType)[];
@@ -1,8 +1,10 @@
1
1
  "use client";
2
- import "../../chunk-MMUBH76A.js";
2
+ import "../../chunk-IV3L3JVM.js";
3
3
  import { keplrWallet } from "./keplr/keplr.js";
4
4
  import { leapWallet } from "./leap/leap.js";
5
+ const allWallets = [keplrWallet, leapWallet];
5
6
  export {
7
+ allWallets,
6
8
  keplrWallet,
7
9
  leapWallet
8
10
  };
@@ -1,8 +1,8 @@
1
1
  "use client";
2
- import "../../../chunk-MMUBH76A.js";
2
+ import "../../../chunk-IV3L3JVM.js";
3
3
  import { icon } from "./keplrIcon.js";
4
4
  import { WalletType } from "@getpara/graz";
5
- import { isMobile } from "@getpara/react-sdk";
5
+ import { isMobile } from "@getpara/web-sdk";
6
6
  const keplrWallet = () => {
7
7
  return {
8
8
  id: "keplr",
@@ -1,5 +1,5 @@
1
1
  "use client";
2
- import "../../../chunk-MMUBH76A.js";
2
+ import "../../../chunk-IV3L3JVM.js";
3
3
  const icon = "";
4
4
  export {
5
5
  icon
@@ -1,8 +1,8 @@
1
1
  "use client";
2
- import "../../../chunk-MMUBH76A.js";
2
+ import "../../../chunk-IV3L3JVM.js";
3
3
  import { icon } from "./leapIcon.js";
4
4
  import { WalletType } from "@getpara/graz";
5
- import { isMobile } from "@getpara/react-sdk";
5
+ import { isMobile } from "@getpara/web-sdk";
6
6
  const leapWallet = () => {
7
7
  return {
8
8
  id: "leap",
@@ -1,5 +1,5 @@
1
1
  "use client";
2
- import "../../../chunk-MMUBH76A.js";
2
+ import "../../../chunk-IV3L3JVM.js";
3
3
  const icon = "";
4
4
  export {
5
5
  icon
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/cosmos-wallet-connectors",
3
- "version": "1.12.0",
3
+ "version": "2.0.0-alpha.5",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -8,30 +8,30 @@
8
8
  ".": "./dist/index.js",
9
9
  "./connectors": "./dist/wallets/connectors/index.js"
10
10
  },
11
- "dependencies": {
12
- "@getpara/react-sdk": "1.12.0",
13
- "zustand": "^4.5.2",
14
- "zustand-sync-tabs": "^0.2.2"
15
- },
16
11
  "scripts": {
17
12
  "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
18
13
  "typegen": "tsc --emitDeclarationOnly",
19
14
  "test": "vitest run --coverage"
20
15
  },
21
- "devDependencies": {
22
- "@getpara/graz": "^0.1.0",
16
+ "dependencies": {
17
+ "@cosmjs/cosmwasm-stargate": "<=0.31.3",
18
+ "@cosmjs/launchpad": "*",
19
+ "@cosmjs/proto-signing": "<=0.31.3",
20
+ "@cosmjs/stargate": "<=0.33.1",
21
+ "@cosmjs/tendermint-rpc": "<=0.31.3",
22
+ "@getpara/graz": "^1.0.0-dev.2",
23
+ "@getpara/web-sdk": "2.0.0-alpha.5",
23
24
  "@leapwallet/cosmos-social-login-capsule-provider": "^0.0.41",
25
+ "zustand": "^4.5.2",
26
+ "zustand-sync-tabs": "^0.2.2"
27
+ },
28
+ "devDependencies": {
29
+ "@getpara/react-common": "2.0.0-alpha.5",
24
30
  "@types/react": "^18.0.31",
25
31
  "@types/react-dom": "^18.2.7",
26
32
  "typescript": "^5.4.3"
27
33
  },
28
34
  "peerDependencies": {
29
- "@cosmjs/cosmwasm-stargate": "<=0.31.3",
30
- "@cosmjs/launchpad": "*",
31
- "@cosmjs/proto-signing": "<=0.31.3",
32
- "@cosmjs/stargate": "<=0.33.1",
33
- "@cosmjs/tendermint-rpc": "<=0.31.3",
34
- "@getpara/graz": "^0.1.0",
35
35
  "react": ">=18",
36
36
  "react-dom": ">=18"
37
37
  },
@@ -39,5 +39,5 @@
39
39
  "dist",
40
40
  "package.json"
41
41
  ],
42
- "gitHead": "748afcf08c9d307a2d3eaf0716f73132f3eb8529"
42
+ "gitHead": "3ecfca088f24489f2e8fa5493d0f4459b08880e1"
43
43
  }