@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.
- package/dist/{chunk-MMUBH76A.js → chunk-IV3L3JVM.js} +0 -13
- package/dist/index.d.ts +5 -2
- package/dist/index.js +4 -6
- package/dist/providers/CosmosExternalWalletContext.d.ts +23 -21
- package/dist/providers/CosmosExternalWalletContext.js +115 -71
- package/dist/providers/ParaCosmosContext.d.ts +11 -22
- package/dist/providers/ParaCosmosContext.js +22 -75
- package/dist/stores/useStore.js +1 -1
- package/dist/types/Wallet.d.ts +1 -1
- package/dist/utils/hasInstalledProvider.js +1 -1
- package/dist/wallets/connectors/index.d.ts +1 -0
- package/dist/wallets/connectors/index.js +3 -1
- package/dist/wallets/connectors/keplr/keplr.js +2 -2
- package/dist/wallets/connectors/keplr/keplrIcon.js +1 -1
- package/dist/wallets/connectors/leap/leap.js +2 -2
- package/dist/wallets/connectors/leap/leapIcon.js +1 -1
- package/package.json +15 -15
|
@@ -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
|
|
2
|
-
export {
|
|
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-
|
|
3
|
-
import { CosmosExternalWalletContext
|
|
4
|
-
import { ParaCosmosProvider
|
|
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
|
-
|
|
9
|
-
ParaCosmosProvider,
|
|
10
|
-
useParaCosmos
|
|
8
|
+
ParaCosmosProvider
|
|
11
9
|
};
|
|
@@ -1,22 +1,20 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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
|
|
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
|
-
|
|
33
|
-
|
|
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
|
-
|
|
41
|
-
|
|
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-
|
|
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({
|
|
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
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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
|
-
|
|
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,
|
|
106
|
+
const login = (bufferAddress2, address2, isFullAuthWallet, providerName) => __async(this, null, function* () {
|
|
89
107
|
try {
|
|
90
|
-
return yield para.
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
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 &&
|
|
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
|
|
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
|
|
178
|
-
const firstChain = typeof _chainId === "string" ? _chainId : _chainId[0];
|
|
179
|
-
address2 =
|
|
180
|
-
bufferAddress2 =
|
|
181
|
-
if (
|
|
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
|
-
|
|
184
|
-
|
|
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
|
|
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:
|
|
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
|
-
[
|
|
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 {
|
|
2
|
-
import { WalletList
|
|
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
|
|
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-
|
|
5
|
+
} from "../chunk-IV3L3JVM.js";
|
|
8
6
|
import { jsx } from "react/jsx-runtime";
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
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
|
|
70
|
-
() => ({
|
|
71
|
-
|
|
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
|
-
[
|
|
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
|
-
|
|
88
|
-
ParaCosmosProvider,
|
|
89
|
-
useParaCosmos
|
|
36
|
+
ParaCosmosProvider
|
|
90
37
|
};
|
package/dist/stores/useStore.js
CHANGED
package/dist/types/Wallet.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { WalletType } from '@getpara/graz';
|
|
2
|
-
import { WalletMetadata } from '@getpara/react-
|
|
2
|
+
import { type WalletMetadata } from '@getpara/react-common';
|
|
3
3
|
export type WalletList = (() => WalletWithType)[];
|
|
4
4
|
export type WalletWithType = {
|
|
5
5
|
grazType: WalletType;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import "../../chunk-
|
|
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-
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
3
|
import { icon } from "./keplrIcon.js";
|
|
4
4
|
import { WalletType } from "@getpara/graz";
|
|
5
|
-
import { isMobile } from "@getpara/
|
|
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-
|
|
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-
|
|
2
|
+
import "../../../chunk-IV3L3JVM.js";
|
|
3
3
|
import { icon } from "./leapIcon.js";
|
|
4
4
|
import { WalletType } from "@getpara/graz";
|
|
5
|
-
import { isMobile } from "@getpara/
|
|
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-
|
|
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": "
|
|
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
|
-
"
|
|
22
|
-
"@
|
|
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": "
|
|
42
|
+
"gitHead": "3ecfca088f24489f2e8fa5493d0f4459b08880e1"
|
|
43
43
|
}
|