@getpara/cosmos-wallet-connectors 1.4.3 → 1.4.4

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.js CHANGED
@@ -1,2 +1,323 @@
1
1
  "use client";
2
- import{createContext as zM,useEffect as J,useMemo as eM}from"react";import{createContext as MM,useCallback as IM,useContext as DM,useEffect as R,useMemo as gM}from"react";import{useClient as NM,useExternalWalletProviderStore as k}from"@getpara/react-sdk";import{GrazProvider as jM,WalletType as TM,connect as v}from"@getpara/graz";import{jsx as B}from"react/jsx-runtime";var F=MM({wallets:[],chains:[],onSwitchChain:()=>{}});function AM({children:u,wallets:T,chains:y,selectedChainId:g,multiChain:E,shouldUseSuggestChainAndConnect:t,onSwitchChain:x,...o}){let r=k(I=>I.updateState),n=k(I=>I.CosmosProvider),e=k(I=>I.cosmosContext),A=o.para??NM(),c=IM(async()=>{if(!A)return{error:"No para instance available"};try{let I=E?y.map(C=>C.chainId):g;return{result:await v({walletType:TM.PARA,chainId:I})}}catch(I){return{error:I instanceof Error?I.message:"Unknown error"}}},[A,v]);R(()=>{(!e||!n)&&r({CosmosProvider:p,cosmosContext:w})},[]),R(()=>{r({connectParaCosmosWallet:c})},[A]);let O=[];T.forEach(I=>{let z=I();O.push(z)});let d=gM(()=>({selectedChainId:g,wallets:O,chains:y,multiChain:E,shouldUseSuggestChainAndConnect:t,onSwitchChain:x}),[g,O,y,E,t,x]);return!e||!n?null:B(jM,{grazOptions:{chains:y,autoReconnect:!0,...o,para:A},children:B(F.Provider,{value:d,children:u})})}var m=()=>DM(F);import{WalletType as h}from"@getpara/react-sdk";import{checkWallet as yM,WalletType as V,useAccount as EM,useActiveChainIds as tM,useActiveWalletType as cM,useConnect as uM,useDisconnect as oM,useSuggestChainAndConnect as OM,getChainInfo as rM}from"@getpara/graz";import{create as iM}from"zustand";import{syncTabs as xM}from"zustand-sync-tabs";var W=iM(xM(u=>({isConnecting:!1,updateState:T=>{u({...T})}}),{name:"para-cosmos-external-wallet-state"}));import{jsx as CM}from"react/jsx-runtime";var nM={wallets:[],chains:[],chainId:void 0,disconnect:()=>Promise.resolve(),switchChain:()=>Promise.resolve({})},w=zM(nM);function p({children:u,para:T,onSwitchWallet:y}){let{selectedChainId:g,wallets:E,chains:t,multiChain:x,shouldUseSuggestChainAndConnect:o,onSwitchChain:r}=m(),{suggestAndConnectAsync:n}=OM(),{data:e,isConnecting:A,isReconnecting:c}=EM({chainId:x?t.map(M=>M.chainId):g,multiChain:x}),O=tM(),{connectAsync:d}=uM(),{disconnectAsync:I}=oM(),{walletType:z}=cM(),C=W(M=>M.isConnecting),a=W(M=>M.updateState),L=x?e?.[g]?.address.toString():e?.address.toString(),s=x?e?.[g]?.bech32Address:e?.bech32Address,P=async()=>{await I(),await T.logout()},b=async M=>{let D;if(!O.includes(M)){a({isConnecting:!0});let j;j=await Q(z,M),y(j),a({isConnecting:!1}),j.error&&(D=[j?.error])}return D||r(M),{error:D}},q=async(M,D,N)=>{try{await T.externalWalletLogin({address:M,type:h.COSMOS,provider:N,addressBech32:D})}catch{throw await P(),"Error logging you in. Please try again."}};J(()=>{let M=T.externalWallets[L??""];!A&&!c&&!C&&s&&M&&M.address!==s&&z!==V.PARA&&T.setExternalWallet({address:L,type:h.COSMOS,provider:f(z),addressBech32:s})},[A,c,s]),J(()=>{let M=T.externalWallets[L??""];!A&&!c&&!C&&L&&!M&&z!==V.PARA&&P()},[A,c]);let Q=async(M,D)=>{a({isConnecting:!0}),D||await I();let N=D??(x?t.map(i=>i.chainId):g);if(!N){console.error("Chain id not provided.");return}let j,l,S;if(M)try{let i;if(o){if(typeof N!="string"){console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");return}if(i=rM({chainId:N}),!i){console.error("Chain not found.");return}}let U=await(o?n({walletType:M,chainInfo:i}):d({walletType:M,chainId:N})),Y=typeof N=="string"?N:N[0];if(j=U.accounts[Y].bech32Address,l=U.accounts[Y].address.toString(),U.accounts[Y])try{await q(l,j,f(M))}catch($){l=void 0,j=void 0,S=$}}catch(i){i.message==="No wallet exists"?S=i.message:(console.error("Graz connection error:",i),S="An unknown error occurred.")}else{console.error("Graz wallet type not provided.");return}return a({isConnecting:!1}),{address:j,bufferAddress:l,error:S}},f=M=>E.find(D=>D.grazType===M||D.grazMobileType===M)?.name,Z=E.map(M=>({connect:()=>Q(M.grazType),connectMobile:()=>Q(M.grazMobileType),getQrUri:()=>"",type:h.COSMOS,...M,installed:yM(M.grazType)})).filter(M=>!!M),G=t.map(M=>({id:M.chainId,name:M.chainName}));return CM(w.Provider,{value:eM(()=>({wallets:Z,chains:G,chainId:g,disconnect:I,switchChain:b}),[Z,G,g,I,b]),children:u})}var H="";import{WalletType as X}from"@getpara/graz";import{isMobile as aM}from"@getpara/react-sdk";var LM=()=>({id:"keplr",name:"Keplr",iconUrl:H,isExtension:!0,isMobile:aM()&&!0,downloadUrl:"https://www.keplr.app/get",grazType:X.KEPLR,grazMobileType:X.WC_KEPLR_MOBILE});var K="";import{WalletType as _}from"@getpara/graz";import{isMobile as sM}from"@getpara/react-sdk";var lM=()=>({id:"leap",name:"Leap",iconUrl:K,isExtension:!0,isMobile:sM()&&!0,downloadUrl:"https://www.leapwallet.io/download",grazType:_.LEAP,grazMobileType:_.WC_LEAP_MOBILE});export{w as CosmosExternalWalletContext,p as CosmosExternalWalletProvider,AM as ParaCosmosProvider,LM as keplrWallet,lM as leapWallet,m as useParaCosmos};
2
+
3
+ // src/providers/CosmosExternalWalletContext.tsx
4
+ import { createContext as createContext2, useEffect as useEffect2, useMemo as useMemo2 } from "react";
5
+
6
+ // src/providers/ParaCosmosContext.tsx
7
+ import { createContext, useCallback, useContext, useEffect, useMemo } from "react";
8
+ import { useClient, useExternalWalletProviderStore } from "@getpara/react-sdk";
9
+ import { GrazProvider, WalletType, connect } from "@getpara/graz";
10
+ import { jsx } from "react/jsx-runtime";
11
+ var ParaCosmosContext = createContext({ wallets: [], chains: [], onSwitchChain: () => {
12
+ } });
13
+ function ParaCosmosProvider({
14
+ children,
15
+ wallets,
16
+ chains,
17
+ selectedChainId,
18
+ multiChain,
19
+ shouldUseSuggestChainAndConnect,
20
+ onSwitchChain,
21
+ ...grazOpts
22
+ }) {
23
+ const updateExternalWalletProviderState = useExternalWalletProviderStore((state) => state.updateState);
24
+ const CosmosProvider = useExternalWalletProviderStore((state) => state.CosmosProvider);
25
+ const cosmosContext = useExternalWalletProviderStore((state) => state.cosmosContext);
26
+ const para = grazOpts.para ?? useClient();
27
+ const connectParaCosmosWallet = useCallback(async () => {
28
+ if (!para) {
29
+ return { error: "No para instance available" };
30
+ }
31
+ try {
32
+ const chainId = multiChain ? chains.map((c) => c.chainId) : selectedChainId;
33
+ const result = await connect({ walletType: WalletType.PARA, chainId });
34
+ return { result };
35
+ } catch (err) {
36
+ const error = err instanceof Error ? err.message : "Unknown error";
37
+ return { error };
38
+ }
39
+ }, [para, connect]);
40
+ useEffect(() => {
41
+ if (!cosmosContext || !CosmosProvider) {
42
+ updateExternalWalletProviderState({
43
+ CosmosProvider: CosmosExternalWalletProvider,
44
+ cosmosContext: CosmosExternalWalletContext
45
+ });
46
+ }
47
+ }, []);
48
+ useEffect(() => {
49
+ updateExternalWalletProviderState({
50
+ connectParaCosmosWallet
51
+ });
52
+ }, [para]);
53
+ const walletsWithType = [];
54
+ wallets.forEach((w) => {
55
+ const wallet = w();
56
+ walletsWithType.push(wallet);
57
+ });
58
+ const value = useMemo(
59
+ () => ({
60
+ selectedChainId,
61
+ wallets: walletsWithType,
62
+ chains,
63
+ multiChain,
64
+ shouldUseSuggestChainAndConnect,
65
+ onSwitchChain
66
+ }),
67
+ [selectedChainId, walletsWithType, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain]
68
+ );
69
+ if (!cosmosContext || !CosmosProvider) {
70
+ return null;
71
+ }
72
+ return /* @__PURE__ */ jsx(GrazProvider, { grazOptions: { chains, autoReconnect: true, ...grazOpts, para }, children: /* @__PURE__ */ jsx(ParaCosmosContext.Provider, { value, children }) });
73
+ }
74
+ var useParaCosmos = () => useContext(ParaCosmosContext);
75
+
76
+ // src/providers/CosmosExternalWalletContext.tsx
77
+ import { WalletType as WalletType2 } from "@getpara/react-sdk";
78
+ import {
79
+ checkWallet,
80
+ WalletType as GrazWalletType,
81
+ useAccount,
82
+ useActiveChainIds,
83
+ useActiveWalletType,
84
+ useConnect,
85
+ useDisconnect,
86
+ useSuggestChainAndConnect,
87
+ getChainInfo
88
+ } from "@getpara/graz";
89
+
90
+ // src/stores/useStore.ts
91
+ import { create } from "zustand";
92
+ import { syncTabs } from "zustand-sync-tabs";
93
+ var useExternalWalletStore = create(
94
+ syncTabs(
95
+ (set) => ({
96
+ isConnecting: false,
97
+ updateState: (state) => {
98
+ set({ ...state });
99
+ }
100
+ }),
101
+ {
102
+ name: "para-cosmos-external-wallet-state"
103
+ }
104
+ )
105
+ );
106
+
107
+ // src/providers/CosmosExternalWalletContext.tsx
108
+ import { jsx as jsx2 } from "react/jsx-runtime";
109
+ var defaultCosmosExternalWallet = {
110
+ wallets: [],
111
+ chains: [],
112
+ chainId: void 0,
113
+ disconnect: () => Promise.resolve(),
114
+ switchChain: () => Promise.resolve({})
115
+ };
116
+ var CosmosExternalWalletContext = createContext2(defaultCosmosExternalWallet);
117
+ function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
118
+ const {
119
+ selectedChainId,
120
+ wallets: incompleteWallets,
121
+ chains,
122
+ multiChain,
123
+ shouldUseSuggestChainAndConnect,
124
+ onSwitchChain
125
+ } = useParaCosmos();
126
+ const { suggestAndConnectAsync } = useSuggestChainAndConnect();
127
+ const {
128
+ data: account,
129
+ isConnecting,
130
+ isReconnecting
131
+ } = useAccount({
132
+ chainId: multiChain ? chains.map((c) => c.chainId) : selectedChainId,
133
+ multiChain
134
+ });
135
+ const activeChainIds = useActiveChainIds();
136
+ const { connectAsync } = useConnect();
137
+ const { disconnectAsync } = useDisconnect();
138
+ const { walletType } = useActiveWalletType();
139
+ const isLocalConnecting = useExternalWalletStore((state) => state.isConnecting);
140
+ const updateExternalWalletState = useExternalWalletStore((state) => state.updateState);
141
+ const bufferAddress = multiChain ? account?.[selectedChainId]?.address.toString() : account?.address.toString();
142
+ const address = multiChain ? account?.[selectedChainId]?.bech32Address : account?.bech32Address;
143
+ const reset = async () => {
144
+ await disconnectAsync();
145
+ await para.logout();
146
+ };
147
+ const switchChain = async (chainId) => {
148
+ let error;
149
+ const hasActiveChain = activeChainIds.includes(chainId);
150
+ if (!hasActiveChain) {
151
+ updateExternalWalletState({ isConnecting: true });
152
+ let changeResp;
153
+ changeResp = await connect2(walletType, chainId);
154
+ onSwitchWallet(changeResp);
155
+ updateExternalWalletState({ isConnecting: false });
156
+ if (changeResp.error) {
157
+ error = [changeResp?.error];
158
+ }
159
+ }
160
+ if (!error) {
161
+ onSwitchChain(chainId);
162
+ }
163
+ return { error };
164
+ };
165
+ const login = async (bufferAddress2, address2, providerName) => {
166
+ try {
167
+ await para.externalWalletLogin({
168
+ address: bufferAddress2,
169
+ type: WalletType2.COSMOS,
170
+ provider: providerName,
171
+ addressBech32: address2
172
+ });
173
+ } catch (err) {
174
+ await reset();
175
+ throw "Error logging you in. Please try again.";
176
+ }
177
+ };
178
+ useEffect2(() => {
179
+ const storedExternalWallet = para.externalWallets[bufferAddress ?? ""];
180
+ if (!isConnecting && !isReconnecting && !isLocalConnecting && address && storedExternalWallet && storedExternalWallet.address !== address && walletType !== GrazWalletType.PARA) {
181
+ para.setExternalWallet({
182
+ address: bufferAddress,
183
+ type: WalletType2.COSMOS,
184
+ provider: getProviderName(walletType),
185
+ addressBech32: address
186
+ });
187
+ }
188
+ }, [isConnecting, isReconnecting, address]);
189
+ useEffect2(() => {
190
+ const storedExternalWallet = para.externalWallets[bufferAddress ?? ""];
191
+ if (!isConnecting && !isReconnecting && !isLocalConnecting && !!bufferAddress && !storedExternalWallet && walletType !== GrazWalletType.PARA) {
192
+ reset();
193
+ }
194
+ }, [isConnecting, isReconnecting]);
195
+ const connect2 = async (walletType2, chainId) => {
196
+ updateExternalWalletState({ isConnecting: true });
197
+ if (!chainId) {
198
+ await disconnectAsync();
199
+ }
200
+ const _chainId = chainId ?? (multiChain ? chains.map((c) => c.chainId) : selectedChainId);
201
+ if (!_chainId) {
202
+ console.error("Chain id not provided.");
203
+ return;
204
+ }
205
+ let address2;
206
+ let bufferAddress2;
207
+ let error;
208
+ if (!walletType2) {
209
+ console.error("Graz wallet type not provided.");
210
+ return;
211
+ } else {
212
+ try {
213
+ let chainInfo;
214
+ if (shouldUseSuggestChainAndConnect) {
215
+ if (typeof _chainId !== "string") {
216
+ console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");
217
+ return;
218
+ }
219
+ chainInfo = getChainInfo({ chainId: _chainId });
220
+ if (!chainInfo) {
221
+ console.error("Chain not found.");
222
+ return;
223
+ }
224
+ }
225
+ const connectedWallet = await (shouldUseSuggestChainAndConnect ? suggestAndConnectAsync({ walletType: walletType2, chainInfo }) : connectAsync({ walletType: walletType2, chainId: _chainId }));
226
+ const firstChain = typeof _chainId === "string" ? _chainId : _chainId[0];
227
+ address2 = connectedWallet.accounts[firstChain].bech32Address;
228
+ bufferAddress2 = connectedWallet.accounts[firstChain].address.toString();
229
+ if (connectedWallet.accounts[firstChain]) {
230
+ try {
231
+ await login(bufferAddress2, address2, getProviderName(walletType2));
232
+ } catch (err) {
233
+ bufferAddress2 = void 0;
234
+ address2 = void 0;
235
+ error = err;
236
+ }
237
+ }
238
+ } catch (err) {
239
+ if (err.message === "No wallet exists") {
240
+ error = err.message;
241
+ } else {
242
+ console.error("Graz connection error:", err);
243
+ error = "An unknown error occurred.";
244
+ }
245
+ }
246
+ }
247
+ updateExternalWalletState({ isConnecting: false });
248
+ return { address: address2, bufferAddress: bufferAddress2, error };
249
+ };
250
+ const getProviderName = (walletType2) => incompleteWallets.find((w) => w.grazType === walletType2 || w.grazMobileType === walletType2)?.name;
251
+ const wallets = incompleteWallets.map((wallet) => {
252
+ return {
253
+ connect: () => connect2(wallet.grazType),
254
+ connectMobile: () => connect2(wallet.grazMobileType),
255
+ getQrUri: () => "",
256
+ type: WalletType2.COSMOS,
257
+ ...wallet,
258
+ installed: checkWallet(wallet.grazType)
259
+ };
260
+ }).filter((w) => !!w);
261
+ const formattedChains = chains.map((c) => {
262
+ return {
263
+ id: c.chainId,
264
+ name: c.chainName
265
+ };
266
+ });
267
+ return /* @__PURE__ */ jsx2(
268
+ CosmosExternalWalletContext.Provider,
269
+ {
270
+ value: useMemo2(
271
+ () => ({ wallets, chains: formattedChains, chainId: selectedChainId, disconnect: disconnectAsync, switchChain }),
272
+ [wallets, formattedChains, selectedChainId, disconnectAsync, switchChain]
273
+ ),
274
+ children
275
+ }
276
+ );
277
+ }
278
+
279
+ // src/wallets/connectors/keplr/keplrIcon.ts
280
+ var icon = "";
281
+
282
+ // src/wallets/connectors/keplr/keplr.ts
283
+ import { WalletType as WalletType3 } from "@getpara/graz";
284
+ import { isMobile } from "@getpara/react-sdk";
285
+ var keplrWallet = () => {
286
+ return {
287
+ id: "keplr",
288
+ name: "Keplr",
289
+ iconUrl: icon,
290
+ isExtension: true,
291
+ isMobile: isMobile() && true,
292
+ downloadUrl: "https://www.keplr.app/get",
293
+ grazType: WalletType3.KEPLR,
294
+ grazMobileType: WalletType3.WC_KEPLR_MOBILE
295
+ };
296
+ };
297
+
298
+ // src/wallets/connectors/leap/leapIcon.ts
299
+ var icon2 = "";
300
+
301
+ // src/wallets/connectors/leap/leap.ts
302
+ import { WalletType as WalletType4 } from "@getpara/graz";
303
+ import { isMobile as isMobile2 } from "@getpara/react-sdk";
304
+ var leapWallet = () => {
305
+ return {
306
+ id: "leap",
307
+ name: "Leap",
308
+ iconUrl: icon2,
309
+ isExtension: true,
310
+ isMobile: isMobile2() && true,
311
+ downloadUrl: "https://www.leapwallet.io/download",
312
+ grazType: WalletType4.LEAP,
313
+ grazMobileType: WalletType4.WC_LEAP_MOBILE
314
+ };
315
+ };
316
+ export {
317
+ CosmosExternalWalletContext,
318
+ CosmosExternalWalletProvider,
319
+ ParaCosmosProvider,
320
+ keplrWallet,
321
+ leapWallet,
322
+ useParaCosmos
323
+ };
package/dist/index.js.br CHANGED
Binary file
package/dist/index.js.gz CHANGED
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/cosmos-wallet-connectors",
3
- "version": "1.4.3",
3
+ "version": "1.4.4",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -9,7 +9,7 @@
9
9
  "./connectors": "./dist/wallets/connectors/index.js"
10
10
  },
11
11
  "dependencies": {
12
- "@getpara/react-sdk": "1.4.3",
12
+ "@getpara/react-sdk": "1.4.4",
13
13
  "zustand": "^4.5.2",
14
14
  "zustand-sync-tabs": "^0.2.2"
15
15
  },
@@ -39,5 +39,5 @@
39
39
  "dist",
40
40
  "package.json"
41
41
  ],
42
- "gitHead": "1af7abd51e994057ff4afc90bd13650a47f6b26e"
42
+ "gitHead": "9a4086c4b352fff2143d3b931d288c5ebaf127fb"
43
43
  }