@getpara/cosmos-wallet-connectors 1.7.1 → 2.0.0-alpha.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.
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
@@ -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) => {
@@ -52,97 +40,11 @@ var __async = (__this, __arguments, generator) => {
52
40
  };
53
41
 
54
42
  // 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";
43
+ import { createContext, useCallback, useEffect, useMemo, useRef } from "react";
141
44
  import {
142
45
  checkWallet,
143
46
  WalletType as GrazWalletType,
144
47
  useAccount,
145
- useActiveChainIds,
146
48
  useActiveWalletType,
147
49
  useConnect,
148
50
  useDisconnect,
@@ -169,100 +71,132 @@ var useExternalWalletStore = create(
169
71
  );
170
72
 
171
73
  // src/providers/CosmosExternalWalletContext.tsx
172
- import { jsx as jsx2 } from "react/jsx-runtime";
74
+ import { WalletType } from "@getpara/web-sdk";
75
+ import { jsx } from "react/jsx-runtime";
173
76
  var defaultCosmosExternalWallet = {
174
77
  wallets: [],
175
78
  chains: [],
176
79
  chainId: void 0,
177
80
  disconnect: () => Promise.resolve(),
178
81
  switchChain: () => Promise.resolve({}),
82
+ connectParaEmbedded: () => Promise.resolve({}),
179
83
  signMessage: () => Promise.resolve({}),
180
84
  signVerificationMessage: () => Promise.resolve({})
181
85
  };
182
- var CosmosExternalWalletContext = createContext2(defaultCosmosExternalWallet);
183
- function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
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
+ }) {
184
100
  var _a, _b;
185
- const {
186
- selectedChainId,
187
- wallets: incompleteWallets,
188
- chains,
189
- multiChain,
190
- shouldUseSuggestChainAndConnect,
191
- onSwitchChain
192
- } = useParaCosmos();
193
101
  const { suggestAndConnectAsync } = useSuggestChainAndConnect();
194
102
  const {
195
103
  data: account,
196
104
  isConnecting,
197
- isReconnecting
105
+ isReconnecting,
106
+ isConnected
198
107
  } = useAccount({
199
108
  chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId,
200
109
  multiChain
201
110
  });
202
- const activeChainIds = useActiveChainIds();
203
111
  const { connectAsync } = useConnect();
204
112
  const { disconnectAsync } = useDisconnect();
205
113
  const { walletType } = useActiveWalletType();
206
114
  const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
207
115
  const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
208
- const fullAuthWallets = useExternalWalletProviderStore2((state) => state.fullAuthWallets);
116
+ const verificationMessage = useRef();
209
117
  const bufferAddress = multiChain ? (_a = account == null ? void 0 : account[selectedChainId]) == null ? void 0 : _a.address.toString() : account == null ? void 0 : account.address.toString();
210
118
  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
119
  const reset = () => __async(this, null, function* () {
213
120
  yield disconnectAsync();
214
121
  yield para.logout();
215
122
  });
216
123
  const switchChain = (chainId) => __async(this, null, function* () {
124
+ var _a2;
217
125
  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];
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.";
227
145
  }
228
146
  }
229
- if (!error) {
147
+ onSwitchWallet(changeResp);
148
+ if (!changeResp.error) {
230
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
+ });
231
158
  }
232
159
  return { error };
233
160
  });
234
- const login = (bufferAddress2, address2, grazWalletType, providerName) => __async(this, null, function* () {
161
+ const login = (bufferAddress2, address2, isFullAuthWallet, providerName) => __async(this, null, function* () {
235
162
  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())
163
+ return yield para.loginExternalWallet({
164
+ externalWallet: {
165
+ address: bufferAddress2,
166
+ type: WalletType.COSMOS,
167
+ provider: providerName,
168
+ addressBech32: address2,
169
+ withFullParaAuth: isFullAuthWallet
170
+ }
242
171
  });
243
172
  } catch (err) {
244
173
  yield reset();
245
174
  throw "Error logging you in. Please try again.";
246
175
  }
247
176
  });
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(() => {
177
+ useEffect(() => {
261
178
  const storedExternalWallet = para.externalWallets[bufferAddress != null ? bufferAddress : ""];
262
- if (!isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
179
+ if (isConnected && !isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
263
180
  reset();
264
181
  }
265
- }, [isConnecting, isReconnecting]);
182
+ }, [isConnecting, isLocalConnecting, isReconnecting, isConnected]);
183
+ useEffect(() => {
184
+ const connect2 = () => __async(this, null, function* () {
185
+ var _a2;
186
+ if (!isLocalConnecting && !isConnecting && !isReconnecting && connectedWallet && connectedWallet.type === WalletType.COSMOS && (connectedWallet.isExternal ? walletType !== ((_a2 = connectedWallet.name) == null ? void 0 : _a2.toLowerCase()) : walletType !== "para")) {
187
+ const isLoggedIn = yield para.isFullyLoggedIn();
188
+ if (!isLoggedIn) {
189
+ return;
190
+ }
191
+ const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
192
+ yield connectAsync({
193
+ walletType: connectedWallet.isExternal ? connectedWallet.name.toLowerCase() : GrazWalletType.PARA,
194
+ chainId
195
+ });
196
+ }
197
+ });
198
+ connect2();
199
+ }, [isLocalConnecting, isConnecting, isReconnecting, walletType, connectedWallet]);
266
200
  const signMessage = (message) => __async(this, null, function* () {
267
201
  const wallet = grazGetWallet(walletType);
268
202
  if (!wallet) {
@@ -288,8 +222,11 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
288
222
  const signature = yield signMessage(verificationMessage.current);
289
223
  return signature;
290
224
  });
291
- const connect2 = (walletType2, chainId) => __async(this, null, function* () {
225
+ const connect = (walletType2, chainId) => __async(this, null, function* () {
226
+ var _a2;
292
227
  updateExternalWalletState({ isConnecting: true });
228
+ const walletId = (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
229
+ const isFullAuthWallet = walletsWithFullAuth.includes(walletId.toUpperCase());
293
230
  if (!chainId) {
294
231
  yield disconnectAsync();
295
232
  }
@@ -301,8 +238,7 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
301
238
  let address2;
302
239
  let bufferAddress2;
303
240
  let error;
304
- let userExists = false;
305
- let isVerified = false;
241
+ let authState;
306
242
  if (!walletType2) {
307
243
  console.error("Graz wallet type not provided.");
308
244
  return;
@@ -320,17 +256,16 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
320
256
  return;
321
257
  }
322
258
  }
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]) {
259
+ const connectedWallet2 = yield shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId });
260
+ const firstChain = !chainId ? selectedChainId : typeof _chainId === "string" ? _chainId : _chainId[0];
261
+ address2 = connectedWallet2.accounts[firstChain].bech32Address;
262
+ bufferAddress2 = connectedWallet2.accounts[firstChain].address.toString();
263
+ if (connectedWallet2.accounts[firstChain]) {
328
264
  try {
329
- const loginResp = yield login(bufferAddress2, address2, walletType2, getProviderName(walletType2));
330
- userExists = loginResp.userExists;
331
- isVerified = loginResp.isVerified;
332
- verificationMessage.current = loginResp.signatureVerificationMessage;
265
+ authState = yield login(bufferAddress2, address2, isFullAuthWallet, getProviderName(walletType2));
266
+ verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
333
267
  } catch (err) {
268
+ authState = void 0;
334
269
  bufferAddress2 = void 0;
335
270
  address2 = void 0;
336
271
  error = err;
@@ -346,23 +281,19 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
346
281
  }
347
282
  }
348
283
  updateExternalWalletState({ isConnecting: false });
349
- return { address: address2, bufferAddress: bufferAddress2, error, userExists, isVerified };
284
+ return { authState, address: address2, bufferAddress: bufferAddress2, error };
350
285
  });
351
286
  const getWallet = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2);
352
287
  const getProviderName = (walletType2) => {
353
288
  var _a2;
354
289
  return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.name;
355
290
  };
356
- const getWalletId = (walletType2) => {
357
- var _a2;
358
- return (_a2 = getWallet(walletType2)) == null ? void 0 : _a2.id;
359
- };
360
291
  const wallets = incompleteWallets.map((wallet) => {
361
292
  return __spreadProps(__spreadValues({
362
- connect: () => connect2(wallet.grazType),
363
- connectMobile: () => connect2(wallet.grazType),
293
+ connect: () => connect(wallet.grazType),
294
+ connectMobile: () => connect(wallet.grazType),
364
295
  getQrUri: () => "",
365
- type: WalletType2.COSMOS
296
+ type: WalletType.COSMOS
366
297
  }, wallet), {
367
298
  installed: checkWallet(wallet.grazType)
368
299
  });
@@ -373,32 +304,85 @@ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
373
304
  name: c.chainName
374
305
  };
375
306
  });
376
- return /* @__PURE__ */ jsx2(
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(
377
321
  CosmosExternalWalletContext.Provider,
378
322
  {
379
- value: useMemo2(
323
+ value: useMemo(
380
324
  () => ({
381
325
  wallets,
382
326
  chains: formattedChains,
383
327
  chainId: selectedChainId,
384
328
  disconnect: disconnectAsync,
385
329
  switchChain,
330
+ connectParaEmbedded,
386
331
  signMessage,
387
332
  signVerificationMessage
388
333
  }),
389
- [wallets, formattedChains, selectedChainId, disconnectAsync, switchChain, signMessage, signVerificationMessage]
334
+ [
335
+ wallets,
336
+ formattedChains,
337
+ selectedChainId,
338
+ disconnectAsync,
339
+ switchChain,
340
+ connectParaEmbedded,
341
+ signMessage,
342
+ signVerificationMessage
343
+ ]
390
344
  ),
391
345
  children
392
346
  }
393
347
  );
394
348
  }
395
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
+
396
380
  // src/wallets/connectors/keplr/keplrIcon.ts
397
381
  var icon = "";
398
382
 
399
383
  // src/wallets/connectors/keplr/keplr.ts
400
- import { WalletType as WalletType3 } from "@getpara/graz";
401
- import { isMobile } from "@getpara/react-sdk";
384
+ import { WalletType as WalletType2 } from "@getpara/graz";
385
+ import { isMobile } from "@getpara/web-sdk";
402
386
  var keplrWallet = () => {
403
387
  return {
404
388
  id: "keplr",
@@ -407,8 +391,8 @@ var keplrWallet = () => {
407
391
  isExtension: true,
408
392
  isMobile: isMobile() && true,
409
393
  downloadUrl: "https://www.keplr.app/get",
410
- grazType: WalletType3.KEPLR,
411
- grazMobileType: WalletType3.WC_KEPLR_MOBILE
394
+ grazType: WalletType2.KEPLR,
395
+ grazMobileType: WalletType2.WC_KEPLR_MOBILE
412
396
  };
413
397
  };
414
398
 
@@ -416,8 +400,8 @@ var keplrWallet = () => {
416
400
  var icon2 = "";
417
401
 
418
402
  // src/wallets/connectors/leap/leap.ts
419
- import { WalletType as WalletType4 } from "@getpara/graz";
420
- import { isMobile as isMobile2 } from "@getpara/react-sdk";
403
+ import { WalletType as WalletType3 } from "@getpara/graz";
404
+ import { isMobile as isMobile2 } from "@getpara/web-sdk";
421
405
  var leapWallet = () => {
422
406
  return {
423
407
  id: "leap",
@@ -426,15 +410,17 @@ var leapWallet = () => {
426
410
  isExtension: true,
427
411
  isMobile: isMobile2() && true,
428
412
  downloadUrl: "https://www.leapwallet.io/download",
429
- grazType: WalletType4.LEAP,
430
- grazMobileType: WalletType4.WC_LEAP_MOBILE
413
+ grazType: WalletType3.LEAP,
414
+ grazMobileType: WalletType3.WC_LEAP_MOBILE
431
415
  };
432
416
  };
417
+
418
+ // src/wallets/connectors/index.ts
419
+ var allWallets = [keplrWallet, leapWallet];
433
420
  export {
434
421
  CosmosExternalWalletContext,
435
- CosmosExternalWalletProvider,
436
422
  ParaCosmosProvider,
423
+ allWallets,
437
424
  keplrWallet,
438
- leapWallet,
439
- useParaCosmos
425
+ leapWallet
440
426
  };
package/dist/index.js.br CHANGED
Binary file
package/dist/index.js.gz CHANGED
Binary file
@@ -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;
@@ -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,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,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)[];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/cosmos-wallet-connectors",
3
- "version": "1.7.1",
3
+ "version": "2.0.0-alpha.3",
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.7.1",
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.31.3",
21
+ "@cosmjs/tendermint-rpc": "<=0.31.3",
22
+ "@getpara/graz": "^1.0.0-dev.1",
23
+ "@getpara/web-sdk": "2.0.0-alpha.3",
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.3",
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.31.3",
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": "767395af96d4a724946a092de760e9137a73369a"
42
+ "gitHead": "77a1e04b06258842ca9c81e3db2a2b0092517659"
43
43
  }
package/dist/package.json DELETED
@@ -1,4 +0,0 @@
1
- {
2
- "type": "module",
3
- "sideEffects": false
4
- }