@getpara/cosmos-wallet-connectors 1.2.0 → 1.3.0

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,3 @@
1
1
  export { CosmosExternalWalletContext, CosmosExternalWalletProvider } from './providers/CosmosExternalWalletContext.js';
2
- export { ParaCosmosProvider } from './providers/ParaCosmosContext.js';
2
+ export { ParaCosmosProvider, useParaCosmos } from './providers/ParaCosmosContext.js';
3
3
  export * from './wallets/connectors/index.js';
package/dist/index.js CHANGED
@@ -1,3 +1,2 @@
1
- export { CosmosExternalWalletContext, CosmosExternalWalletProvider } from './providers/CosmosExternalWalletContext.js';
2
- export { ParaCosmosProvider } from './providers/ParaCosmosContext.js';
3
- export * from './wallets/connectors/index.js';
1
+ "use client";
2
+ import{createContext as AM,useEffect as F,useMemo as zM,useState as yM}from"react";import{createContext as $,useCallback as MM,useContext as IM,useEffect as f,useMemo as DM}from"react";import{useClient as gM,useExternalWalletProviderStore as k}from"@getpara/react-sdk";import{GrazProvider as NM,WalletType as jM,connect as R}from"@getpara/graz";import{jsx as v}from"react/jsx-runtime";var B=$({wallets:[],chains:[],onSwitchChain:()=>{}});function TM({children:w,wallets:x,chains:E,selectedChainId:g,multiChain:e,shouldUseSuggestChainAndConnect:c,onSwitchChain:z,...o}){let t=k(I=>I.updateState),C=k(I=>I.CosmosProvider),i=k(I=>I.cosmosContext),T=o.para??gM(),u=MM(async()=>{if(!T)return{error:"No para instance available"};try{let I=e?E.map(L=>L.chainId):g;return{result:await R({walletType:jM.PARA,chainId:I})}}catch(I){return{error:I instanceof Error?I.message:"Unknown error"}}},[T,R]);f(()=>{(!i||!C)&&t({CosmosProvider:h,cosmosContext:S})},[]),f(()=>{t({connectParaCosmosWallet:u})},[T]);let O=[];x.forEach(I=>{let y=I();O.push(y)});let d=DM(()=>({selectedChainId:g,wallets:O,chains:E,multiChain:e,shouldUseSuggestChainAndConnect:c,onSwitchChain:z}),[g,O,E,e,c,z]);return!i||!C?null:v(NM,{grazOptions:{chains:E,autoReconnect:!0,...o,para:T},children:v(B.Provider,{value:d,children:w})})}var m=()=>IM(B);import{WalletType as p}from"@getpara/react-sdk";import{checkWallet as xM,WalletType as J,useAccount as iM,useActiveChainIds as EM,useActiveWalletType as eM,useConnect as cM,useDisconnect as uM,useSuggestChainAndConnect as oM,getChainInfo as OM}from"@getpara/graz";import{jsx as CM}from"react/jsx-runtime";var tM={wallets:[],chains:[],chainId:void 0,disconnect:()=>Promise.resolve(),switchChain:()=>Promise.resolve({})},S=AM(tM);function h({children:w,para:x,onSwitchWallet:E}){let{selectedChainId:g,wallets:e,chains:c,multiChain:z,shouldUseSuggestChainAndConnect:o,onSwitchChain:t}=m(),{suggestAndConnectAsync:C}=oM(),{data:i,isConnecting:T,isReconnecting:u}=iM({chainId:z?c.map(M=>M.chainId):g,multiChain:z}),O=EM(),{connectAsync:d}=cM(),{disconnectAsync:I}=uM(),{walletType:y}=eM(),[L,r]=yM(!1),n=z?i?.[g]?.address.toString():i?.address.toString(),a=z?i?.[g]?.bech32Address:i?.bech32Address,W=async()=>{await I(),await x.logout()},P=async M=>{let D;if(!O.includes(M)){r(!0);let j;j=await Q(y,M),E(j),r(!1),j.error&&(D=[j?.error])}return D||t(M),{error:D}},_=async(M,D,N)=>{try{await x.externalWalletLogin({address:M,type:p.COSMOS,provider:N,addressBech32:D})}catch{throw await W(),"Error logging you in. Please try again."}};F(()=>{let M=x.externalWallets[n??""];!T&&!u&&!L&&a&&M&&M.address!==a&&y!==J.PARA&&x.setExternalWallet({address:n,type:p.COSMOS,provider:Z(y),addressBech32:a})},[T,u,a]),F(()=>{let M=x.externalWallets[n??""];!T&&!u&&!L&&n&&!M&&y!==J.PARA&&W()},[T,u]);let Q=async(M,D)=>{r(!0),D||await I();let N=D??(z?c.map(A=>A.chainId):g);if(!N){console.error("Chain id not provided.");return}let j,s,l;if(M)try{let A;if(o){if(typeof N!="string"){console.error("multiChain is not compatible with shouldUseSuggestChainAndConnect.");return}if(A=OM({chainId:N}),!A){console.error("Chain not found.");return}}let U=await(o?C({walletType:M,chainInfo:A}):d({walletType:M,chainId:N})),Y=typeof N=="string"?N:N[0];if(j=U.accounts[Y].bech32Address,s=U.accounts[Y].address.toString(),U.accounts[Y])try{await _(s,j,Z(M))}catch(q){s=void 0,j=void 0,l=q}}catch(A){A.message==="No wallet exists"?l=A.message:(console.error("Graz connection error:",A),l="An unknown error occurred.")}else{console.error("Graz wallet type not provided.");return}return r(!1),{address:j,bufferAddress:s,error:l}},Z=M=>e.find(D=>D.grazType===M||D.grazMobileType===M)?.name,b=e.map(M=>({connect:()=>Q(M.grazType),connectMobile:()=>Q(M.grazMobileType),getQrUri:()=>"",type:p.COSMOS,...M,installed:xM(M.grazType)})).filter(M=>!!M),G=c.map(M=>({id:M.chainId,name:M.chainName}));return CM(S.Provider,{value:zM(()=>({wallets:b,chains:G,chainId:g,disconnect:I,switchChain:P}),[b,G,g,I,P]),children:w})}var V="";import{WalletType as H}from"@getpara/graz";import{isMobile as LM}from"@getpara/react-sdk";var rM=()=>({id:"keplr",name:"Keplr",iconUrl:V,isExtension:!0,isMobile:LM()&&!0,downloadUrl:"https://www.keplr.app/get",grazType:H.KEPLR,grazMobileType:H.WC_KEPLR_MOBILE});var X="";import{WalletType as K}from"@getpara/graz";import{isMobile as nM}from"@getpara/react-sdk";var aM=()=>({id:"leap",name:"Leap",iconUrl:X,isExtension:!0,isMobile:nM()&&!0,downloadUrl:"https://www.leapwallet.io/download",grazType:K.LEAP,grazMobileType:K.WC_LEAP_MOBILE});export{S as CosmosExternalWalletContext,h as CosmosExternalWalletProvider,TM as ParaCosmosProvider,rM as keplrWallet,aM as leapWallet,m as useParaCosmos};
Binary file
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/cosmos-wallet-connectors",
3
- "version": "1.2.0",
3
+ "version": "1.3.0",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -9,10 +9,11 @@
9
9
  "./connectors": "./dist/wallets/connectors/index.js"
10
10
  },
11
11
  "dependencies": {
12
- "@getpara/react-sdk": "1.2.0"
12
+ "@getpara/react-sdk": "1.3.0"
13
13
  },
14
14
  "scripts": {
15
- "build": "rm -rf dist && tsc",
15
+ "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
16
+ "typegen": "tsc --emitDeclarationOnly",
16
17
  "test": "vitest run --coverage"
17
18
  },
18
19
  "devDependencies": {
@@ -36,5 +37,5 @@
36
37
  "dist",
37
38
  "package.json"
38
39
  ],
39
- "gitHead": "a9162c59be1456292d46c56787c1d5bf313bf24b"
40
+ "gitHead": "2d421556a0a1497abd08e18dca94f08ec3ad640b"
40
41
  }
@@ -1,179 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- import { jsx as _jsx } from "react/jsx-runtime";
11
- import { createContext, useEffect, useMemo, useState } from 'react';
12
- import { useParaCosmos } from './ParaCosmosContext.js';
13
- import { WalletType } from '@getpara/react-sdk';
14
- import { checkWallet, WalletType as GrazWalletType, useAccount, useActiveChainIds, useActiveWalletType, useConnect, useDisconnect, useSuggestChainAndConnect, getChainInfo, } from '@getpara/graz';
15
- export const defaultCosmosExternalWallet = {
16
- wallets: [],
17
- chains: [],
18
- chainId: undefined,
19
- disconnect: () => Promise.resolve(),
20
- switchChain: () => Promise.resolve({}),
21
- };
22
- export const CosmosExternalWalletContext = createContext(defaultCosmosExternalWallet);
23
- export function CosmosExternalWalletProvider({ children, para, onSwitchWallet }) {
24
- var _a, _b;
25
- const { selectedChainId, wallets: incompleteWallets, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain, } = useParaCosmos();
26
- const { suggestAndConnectAsync } = useSuggestChainAndConnect();
27
- const { data: account, isConnecting, isReconnecting, } = useAccount({
28
- chainId: multiChain ? chains.map(c => c.chainId) : selectedChainId,
29
- multiChain,
30
- });
31
- const activeChainIds = useActiveChainIds();
32
- const { connectAsync } = useConnect();
33
- const { disconnectAsync } = useDisconnect();
34
- const { walletType } = useActiveWalletType();
35
- const [isLocalConnecting, setIsLocalConnecting] = useState(false);
36
- const bufferAddress = multiChain ? (_a = account === null || account === void 0 ? void 0 : account[selectedChainId]) === null || _a === void 0 ? void 0 : _a.address.toString() : account === null || account === void 0 ? void 0 : account.address.toString();
37
- const address = multiChain ? (_b = account === null || account === void 0 ? void 0 : account[selectedChainId]) === null || _b === void 0 ? void 0 : _b.bech32Address : account === null || account === void 0 ? void 0 : account.bech32Address;
38
- const reset = () => __awaiter(this, void 0, void 0, function* () {
39
- yield disconnectAsync();
40
- yield para.logout();
41
- });
42
- const switchChain = (chainId) => __awaiter(this, void 0, void 0, function* () {
43
- let error;
44
- const hasActiveChain = activeChainIds.includes(chainId);
45
- if (!hasActiveChain) {
46
- setIsLocalConnecting(true);
47
- let changeResp;
48
- changeResp = yield connect(walletType, chainId);
49
- // Calling onSwitchWallet here so the modal correctly processes any error from the reconnection.
50
- onSwitchWallet(changeResp);
51
- setIsLocalConnecting(false);
52
- if (changeResp.error) {
53
- error = [changeResp === null || changeResp === void 0 ? void 0 : changeResp.error];
54
- }
55
- }
56
- if (!error) {
57
- onSwitchChain(chainId);
58
- }
59
- return { error };
60
- });
61
- const login = (bufferAddress, address, providerName) => __awaiter(this, void 0, void 0, function* () {
62
- try {
63
- yield para.externalWalletLogin({
64
- address: bufferAddress,
65
- type: WalletType.COSMOS,
66
- provider: providerName,
67
- addressBech32: address,
68
- });
69
- }
70
- catch (err) {
71
- yield reset();
72
- throw 'Error logging you in. Please try again.';
73
- }
74
- });
75
- useEffect(() => {
76
- const storedExternalWallet = para.externalWallets[bufferAddress !== null && bufferAddress !== void 0 ? bufferAddress : ''];
77
- if (!isConnecting &&
78
- !isReconnecting &&
79
- !isLocalConnecting &&
80
- address &&
81
- storedExternalWallet &&
82
- storedExternalWallet.address !== address &&
83
- walletType !== GrazWalletType.PARA) {
84
- para.setExternalWallet({
85
- address: bufferAddress,
86
- type: WalletType.COSMOS,
87
- provider: getProviderName(walletType),
88
- addressBech32: address,
89
- });
90
- }
91
- }, [isConnecting, isReconnecting, address]);
92
- useEffect(() => {
93
- const storedExternalWallet = para.externalWallets[bufferAddress !== null && bufferAddress !== void 0 ? bufferAddress : ''];
94
- if (!isConnecting &&
95
- !isReconnecting &&
96
- !isLocalConnecting &&
97
- !!bufferAddress &&
98
- !storedExternalWallet &&
99
- walletType !== GrazWalletType.PARA) {
100
- reset();
101
- }
102
- }, [isConnecting, isReconnecting]);
103
- const connect = (walletType, chainId) => __awaiter(this, void 0, void 0, function* () {
104
- setIsLocalConnecting(true);
105
- // chainID is passed in when switching chains, in that case we can skip disconnecting
106
- if (!chainId) {
107
- yield disconnectAsync();
108
- }
109
- const _chainId = chainId !== null && chainId !== void 0 ? chainId : (multiChain ? chains.map(c => c.chainId) : selectedChainId);
110
- if (!_chainId) {
111
- console.error('Chain id not provided.');
112
- return;
113
- }
114
- let address;
115
- let bufferAddress;
116
- let error;
117
- // The logic in the modal should prevent this from happening, logging for edge cases.
118
- if (!walletType) {
119
- console.error('Graz wallet type not provided.');
120
- return;
121
- }
122
- else {
123
- try {
124
- let chainInfo;
125
- if (shouldUseSuggestChainAndConnect) {
126
- if (typeof _chainId !== 'string') {
127
- console.error('multiChain is not compatible with shouldUseSuggestChainAndConnect.');
128
- return;
129
- }
130
- chainInfo = getChainInfo({ chainId: _chainId });
131
- if (!chainInfo) {
132
- console.error('Chain not found.');
133
- return;
134
- }
135
- }
136
- const connectedWallet = yield (shouldUseSuggestChainAndConnect
137
- ? suggestAndConnectAsync({ walletType, chainInfo })
138
- : connectAsync({ walletType, chainId: _chainId }));
139
- const firstChain = typeof _chainId === 'string' ? _chainId : _chainId[0];
140
- address = connectedWallet.accounts[firstChain].bech32Address;
141
- bufferAddress = connectedWallet.accounts[firstChain].address.toString();
142
- if (connectedWallet.accounts[firstChain]) {
143
- try {
144
- yield login(bufferAddress, address, getProviderName(walletType));
145
- }
146
- catch (err) {
147
- bufferAddress = undefined;
148
- address = undefined;
149
- error = err;
150
- }
151
- }
152
- }
153
- catch (err) {
154
- if (err.message === 'No wallet exists') {
155
- error = err.message;
156
- }
157
- else {
158
- console.error('Graz connection error:', err);
159
- error = 'An unknown error occurred.';
160
- }
161
- }
162
- }
163
- setIsLocalConnecting(false);
164
- return { address, bufferAddress, error };
165
- });
166
- const getProviderName = (walletType) => { var _a; return (_a = incompleteWallets.find(w => w.grazType === walletType || w.grazMobileType === walletType)) === null || _a === void 0 ? void 0 : _a.name; };
167
- const wallets = incompleteWallets
168
- .map(wallet => {
169
- return Object.assign(Object.assign({ connect: () => connect(wallet.grazType), connectMobile: () => connect(wallet.grazMobileType), getQrUri: () => '', type: WalletType.COSMOS }, wallet), { installed: checkWallet(wallet.grazType) });
170
- })
171
- .filter(w => !!w);
172
- const formattedChains = chains.map(c => {
173
- return {
174
- id: c.chainId,
175
- name: c.chainName,
176
- };
177
- });
178
- return (_jsx(CosmosExternalWalletContext.Provider, { value: useMemo(() => ({ wallets, chains: formattedChains, chainId: selectedChainId, disconnect: disconnectAsync, switchChain }), [wallets, formattedChains, selectedChainId, disconnectAsync, switchChain]), children: children }));
179
- }
@@ -1,79 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- var __rest = (this && this.__rest) || function (s, e) {
11
- var t = {};
12
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
13
- t[p] = s[p];
14
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
15
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
16
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
17
- t[p[i]] = s[p[i]];
18
- }
19
- return t;
20
- };
21
- import { jsx as _jsx } from "react/jsx-runtime";
22
- import { createContext, useCallback, useContext, useEffect, useMemo } from 'react';
23
- import { useClient, useExternalWalletProviderStore } from '@getpara/react-sdk';
24
- import { CosmosExternalWalletContext, CosmosExternalWalletProvider } from './CosmosExternalWalletContext.js';
25
- import { GrazProvider, WalletType, connect } from '@getpara/graz';
26
- export const ParaCosmosContext = createContext({ wallets: [], chains: [], onSwitchChain: () => { } });
27
- export function ParaCosmosProvider(_a) {
28
- var _b;
29
- var { children, wallets, chains, selectedChainId, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain } = _a, grazOpts = __rest(_a, ["children", "wallets", "chains", "selectedChainId", "multiChain", "shouldUseSuggestChainAndConnect", "onSwitchChain"]);
30
- const updateExternalWalletProviderState = useExternalWalletProviderStore(state => state.updateState);
31
- const CosmosProvider = useExternalWalletProviderStore(state => state.CosmosProvider);
32
- const cosmosContext = useExternalWalletProviderStore(state => state.cosmosContext);
33
- const para = (_b = grazOpts.para) !== null && _b !== void 0 ? _b : useClient();
34
- const connectParaCosmosWallet = useCallback(() => __awaiter(this, void 0, void 0, function* () {
35
- if (!para) {
36
- return { error: 'No para instance available' };
37
- }
38
- try {
39
- const chainId = multiChain ? chains.map(c => c.chainId) : selectedChainId;
40
- const result = yield connect({ walletType: WalletType.PARA, chainId });
41
- return { result };
42
- }
43
- catch (err) {
44
- const error = err instanceof Error ? err.message : 'Unknown error';
45
- return { error };
46
- }
47
- }), [para, connect]);
48
- useEffect(() => {
49
- if (!cosmosContext || !CosmosProvider) {
50
- updateExternalWalletProviderState({
51
- CosmosProvider: CosmosExternalWalletProvider,
52
- cosmosContext: CosmosExternalWalletContext,
53
- });
54
- }
55
- }, []);
56
- useEffect(() => {
57
- updateExternalWalletProviderState({
58
- connectParaCosmosWallet,
59
- });
60
- }, [para]);
61
- const walletsWithType = [];
62
- wallets.forEach(w => {
63
- const wallet = w();
64
- walletsWithType.push(wallet);
65
- });
66
- const value = useMemo(() => ({
67
- selectedChainId,
68
- wallets: walletsWithType,
69
- chains,
70
- multiChain,
71
- shouldUseSuggestChainAndConnect,
72
- onSwitchChain,
73
- }), [selectedChainId, walletsWithType, chains, multiChain, shouldUseSuggestChainAndConnect, onSwitchChain]);
74
- if (!cosmosContext || !CosmosProvider) {
75
- return null;
76
- }
77
- return (_jsx(GrazProvider, { grazOptions: Object.assign(Object.assign({ chains, autoReconnect: true }, grazOpts), { para }), children: _jsx(ParaCosmosContext.Provider, { value: value, children: children }) }));
78
- }
79
- export const useParaCosmos = () => useContext(ParaCosmosContext);
@@ -1 +0,0 @@
1
- export {};
@@ -1 +0,0 @@
1
- export {};
@@ -1 +0,0 @@
1
- export const hasInstalledExtension = (id) => !!window[id];
@@ -1,3 +0,0 @@
1
- import { keplrWallet } from './keplr/keplr.js';
2
- import { leapWallet } from './leap/leap.js';
3
- export { keplrWallet, leapWallet };
@@ -1,15 +0,0 @@
1
- import { icon } from './keplrIcon.js';
2
- import { WalletType } from '@getpara/graz';
3
- import { isMobile } from '@getpara/react-sdk';
4
- export const keplrWallet = () => {
5
- return {
6
- id: 'keplr',
7
- name: 'Keplr',
8
- iconUrl: icon,
9
- isExtension: true,
10
- isMobile: isMobile() && true,
11
- downloadUrl: 'https://www.keplr.app/get',
12
- grazType: WalletType.KEPLR,
13
- grazMobileType: WalletType.WC_KEPLR_MOBILE,
14
- };
15
- };
@@ -1 +0,0 @@
1
- export const icon = '';
@@ -1,15 +0,0 @@
1
- import { icon } from './leapIcon.js';
2
- import { WalletType } from '@getpara/graz';
3
- import { isMobile } from '@getpara/react-sdk';
4
- export const leapWallet = () => {
5
- return {
6
- id: 'leap',
7
- name: 'Leap',
8
- iconUrl: icon,
9
- isExtension: true,
10
- isMobile: isMobile() && true,
11
- downloadUrl: 'https://www.leapwallet.io/download',
12
- grazType: WalletType.LEAP,
13
- grazMobileType: WalletType.WC_LEAP_MOBILE,
14
- };
15
- };
@@ -1 +0,0 @@
1
- export const icon = '';