@rango-dev/wallets-core 0.5.1-next.2 → 0.5.1-next.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/constants.d.ts +2 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/helpers.d.ts +10 -3
- package/dist/helpers.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +4 -4
- package/dist/persistor.d.ts +11 -0
- package/dist/persistor.d.ts.map +1 -0
- package/dist/provider.d.ts.map +1 -1
- package/dist/types.d.ts +1 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/constants.ts +1 -0
- package/src/helpers.ts +63 -2
- package/src/persistor.ts +19 -0
- package/src/provider.tsx +17 -0
- package/src/types.ts +1 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,uBAAuB,2BAA2B,CAAC"}
|
package/dist/helpers.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Network, WalletType } from '@rango-dev/wallets-shared';
|
|
2
|
-
import { State, WalletProvider, WalletProviders } from './types';
|
|
3
|
-
import { Options, State as WalletState } from './wallet';
|
|
1
|
+
import { Network, WalletConfig, WalletType } from '@rango-dev/wallets-shared';
|
|
2
|
+
import { State, WalletActions, WalletProvider, WalletProviders } from './types';
|
|
3
|
+
import Wallet, { Options, State as WalletState } from './wallet';
|
|
4
4
|
import type { BlockchainMeta } from 'rango-types';
|
|
5
5
|
export declare function choose(wallets: any[], type: WalletType): any | null;
|
|
6
6
|
export declare const defaultWalletState: WalletState;
|
|
@@ -18,4 +18,11 @@ export declare function isAsync(fn: Function): boolean;
|
|
|
18
18
|
export declare function needsCheckInstallation(options: Options): boolean;
|
|
19
19
|
export declare function isWalletDerivedFromWalletConnect(wallet_type: WalletType): boolean;
|
|
20
20
|
export declare function getComptaibleProvider(supportedChains: BlockchainMeta[], provider: any, type: WalletType): any;
|
|
21
|
+
export declare function persistWallet(type: WalletType): Promise<void>;
|
|
22
|
+
export declare function removeWalletFromPersist(type: WalletType): void;
|
|
23
|
+
export declare function clearPersistStorage(): void;
|
|
24
|
+
export declare function autoConnect(wallets: WalletProviders, addWalletRef: (wallet: {
|
|
25
|
+
actions: WalletActions;
|
|
26
|
+
config: WalletConfig;
|
|
27
|
+
}) => Wallet<any>): Promise<void>;
|
|
21
28
|
//# sourceMappingURL=helpers.d.ts.map
|
package/dist/helpers.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,OAAO,EACP,UAAU,EAEX,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,OAAO,EACP,YAAY,EACZ,UAAU,EAEX,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAChF,OAAO,MAAM,EAAE,EAAE,OAAO,EAAE,KAAK,IAAI,WAAW,EAAE,MAAM,UAAU,CAAC;AACjE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAKlD,wBAAgB,MAAM,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,UAAU,GAAG,GAAG,GAAG,IAAI,CAEnE;AAED,eAAO,MAAM,kBAAkB,EAAE,WAOhC,CAAC;AAEF,wBAAgB,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,SA0BtD;AAED,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,UAGzB;AAED,wBAAgB,2BAA2B,CACzC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAC1B,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,YAOzB;AAED,wBAAgB,kBAAkB,CAAC,kBAAkB,EAAE,MAAM,GAAG;IAC9D,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;CAClB,CAOA;AAED,wBAAgB,gBAAgB,CAAC,cAAc,EAAE,KAAK,GAAG,UAAU,EAAE,CAQpE;AAED,wBAAgB,gBAAgB,CAAC,cAAc,EAAE,KAAK,GAAG,UAAU,EAAE,CAIpE;AAED,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,cAAc,EAAE,GAAG,eAAe,CAY5E;AAGD,wBAAgB,OAAO,CAAC,EAAE,EAAE,QAAQ,WAEnC;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,WAGtD;AAOD,wBAAgB,gCAAgC,CAAC,WAAW,EAAE,UAAU,WAEvE;AAED,wBAAgB,qBAAqB,CACnC,eAAe,EAAE,cAAc,EAAE,EACjC,QAAQ,EAAE,GAAG,EACb,IAAI,EAAE,UAAU,OAejB;AAED,wBAAsB,aAAa,CAAC,IAAI,EAAE,UAAU,iBAOnD;AAED,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,UAAU,QAQvD;AAED,wBAAgB,mBAAmB,SAIlC;AAED,wBAAsB,WAAW,CAC/B,OAAO,EAAE,eAAe,EACxB,YAAY,EAAE,CAAC,MAAM,EAAE;IACrB,OAAO,EAAE,aAAa,CAAC;IACvB,MAAM,EAAE,YAAY,CAAC;CACtB,KAAK,MAAM,CAAC,GAAG,CAAC,iBA0BlB"}
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var
|
|
1
|
+
var L=Object.defineProperty;var i=(e,t)=>L(e,"name",{value:t,configurable:!0});import G from"@walletconnect/ethereum-provider";import{convertEvmBlockchainMetaToEvmChainInfo as U,evmChainsToRpcMap as _,WalletTypes as R}from"@rango-dev/wallets-shared";import{isEvmBlockchain as D}from"rango-types";var h=class{getItem(t){let n=localStorage.getItem(t);return n?JSON.parse(n):null}setItem(t,n){localStorage.setItem(t,JSON.stringify(n))}removeItem(t){localStorage.removeItem(t)}};i(h,"Persistor");var p="last-connected-wallets";function ut(e,t){return e.find(n=>n.type===t)||null}i(ut,"choose");var v={connected:!1,connecting:!1,reachable:!1,installed:!1,accounts:null,network:null};function S(e,t){if(t.type==="new_state"){let n=e[t.wallet];return n?{...e,[t.wallet]:{...n,[t.name]:t.value}}:{...e,[t.wallet]:{...v,[t.name]:t.value}}}return e}i(S,"state_reducer");function F(e,t){return`${t||""}:${e}`}i(F,"formatAddressWithNetwork");function g(e,t){return e?e.map(n=>F(n,t)):[]}i(g,"accountAddressesWithNetwork");function pt(e){let[t,n]=e.split(":");return{network:t,address:n}}i(pt,"readAccountAddress");function N(e){return Object.entries(e).filter(([,t])=>t?.connected).map(([t])=>t)}i(N,"connectedWallets");function T(e){return Object.entries(e).map(([t])=>t)}i(T,"availableWallets");function P(e){let t=new Map;return e.forEach(n=>{let{config:o,...a}=n;t.set(o.type,{actions:a,config:o})}),t}i(P,"checkWalletProviders");function ft(e){return e?.constructor?.name==="AsyncFunction"}i(ft,"isAsync");function W(e){let{checkInstallation:t=!0}=e.config;return t}i(W,"needsCheckInstallation");function $(e){return e===R.WALLET_CONNECT}i($,"isWalletDerivedFromWalletConnect");function x(e,t,n){if($(n)){let o=e.filter(D),a=_(U(o));return new G({qrcode:!1,rpc:a,connector:t,chainId:t.chainId})}return t}i(x,"getComptaibleProvider");async function E(e){let t=new h,n=t.getItem(p),o=!!n?.find(a=>a===e);n&&!o?t.setItem(p,n.concat(e)):t.setItem(p,[e])}i(E,"persistWallet");function C(e){let t=new h,n=t.getItem(p);n&&t.setItem(p,n.filter(o=>o!==e))}i(C,"removeWalletFromPersist");function A(){let e=new h;e.getItem(p)&&e.removeItem(p)}i(A,"clearPersistStorage");async function b(e,t){let o=new h().getItem(p);if(o&&o.length){let a=[];o.forEach(s=>{let d=e.get(s);if(d){let r=t(d);a.push({walletType:s,connect:r.connect.bind(r)})}});for(let{connect:s,walletType:d}of a)try{await s()}catch{C(d)}}}i(b,"autoConnect");import Y,{createContext as j,useContext as q,useEffect as k,useReducer as J,useRef as K}from"react";import{getBlockChainNameFromId as m,Networks as w}from"@rango-dev/wallets-shared";var B=(d=>(d.CONNECTED="connected",d.CONNECTING="connecting",d.REACHABLE="reachable",d.INSTALLED="installed",d.ACCOUNTS="accounts",d.NETWORK="network",d))(B||{});var y=class{constructor(t,n){this.actions=n,this.options=t,this.provider=null,this.meta=[],this.state={connected:!1,connecting:!1,reachable:!1,installed:!1,accounts:null,network:null},W(t)||this.setInstalledAs(!0)}async eagerConnection(){return this.state.connected&&this.provider?{accounts:this.state.accounts,network:this.state.network,provider:this.provider}:null}async connect(t){if(this.state.connecting)throw new Error("Connecting...");let n=await this.eagerConnection(),o=this.state.network,a=t||o||this.options.config.defaultNetwork;if(n){let c=o!==a&&!!a;if(o===a)return n;if(c&&this.actions.switchNetwork)return await this.actions.switchNetwork({instance:this.provider,meta:this.meta,network:a,newInstance:this.tryGetInstance.bind(this)}),{accounts:n.accounts,network:a,provider:this.provider}}let s=await this.tryGetInstance({network:t});this.updateState({connecting:!0}),this.setInstalledAs(!0);try{var d=await this.actions.connect({instance:s,network:a||void 0,meta:this.meta||[]})}catch(c){throw this.resetState(),c}this.updateState({connected:!0,reachable:!0,connecting:!1});let r=[],l=null;if(Array.isArray(d))r=d.flatMap(u=>{let f=u.chainId||w.Unknown,I=m(f,this.meta)||w.Unknown;return g(u.accounts,I)}).filter(Boolean),l=a||this.options.config.defaultNetwork;else{let c=d.chainId||w.Unknown,u=m(c,this.meta)||w.Unknown;r=g(d.accounts,u),l=u}return r.length>0&&this.updateState({accounts:r,network:l}),{accounts:this.state.accounts,network:this.state.network,provider:this.provider}}async disconnect(){this.resetState(),this.actions.disconnect&&this.actions.disconnect({instance:this.provider,destroyInstance:()=>{this.setProvider(null)}})}getSigners(t){return this.actions.getSigners(t)}getWalletInfo(t){return this.actions.getWalletInfo(t)}canSwitchNetworkTo(t,n){let o=this.actions.canSwitchNetworkTo;return o?o({network:t,meta:this.meta,provider:n}):!1}onInit(){this.options.config.isAsyncInstance||this.actions.getInstance()&&!this.state.installed&&this.setInstalledAs(!0)}setProvider(t){this.provider=t,t&&this.actions.subscribe&&this.actions.subscribe({instance:t,state:this.state,meta:this.meta,connect:this.connect.bind(this),disconnect:this.disconnect.bind(this),updateAccounts:(n,o)=>{let a=this.state.network;o&&(a=m(o,this.meta)||w.Unknown);let s=g(n,a);s.length>0&&this.updateState({accounts:s})},updateChainId:n=>{let o=n?m(n,this.meta):w.Unknown;this.updateState({network:o})}})}setMeta(t){this.meta=t}setHandler(t){this.options.handler=t}getState(){return this.state}updateState(t){let n=[];typeof t.connected<"u"&&(this.state.connected=t.connected,n.push(["connected",t.connected])),typeof t.connecting<"u"&&(this.state.connecting=t.connecting,n.push(["connecting",t.connecting])),typeof t.reachable<"u"&&(this.state.reachable=t.reachable,n.push(["reachable",t.reachable])),typeof t.installed<"u"&&(this.state.installed=t.installed,n.push(["installed",t.installed])),typeof t.accounts<"u"&&(this.state.accounts=t.accounts,n.push(["accounts",t.accounts])),typeof t.network<"u"&&(this.state.network=t.network,n.push(["network",t.network]));let o=this.getState();n.forEach(([a,s])=>{this.options.handler(this.options.config.type,a,s,o,this.meta)})}resetState(){this.updateState({connected:!1,connecting:!1,reachable:!1,accounts:null,network:null})}setInstalledAs(t){!W(this.options)&&t===!1||this.updateState({installed:t})}async tryGetInstance({network:t,force:n}){let o=null;if(this.setProvider(null),this.options.config.isAsyncInstance){let a={currentProvider:this.provider,meta:this.meta,force:n||!1,updateChainId:s=>{let d=s?m(s,this.meta):w.Unknown;this.updateState({network:d})}};t&&(a.network=t),o=await this.actions.getInstance(a)}else o=this.actions.getInstance();if(!o){this.setInstalledAs(!1),this.resetState();let a=`It seems your selected wallet (${this.options.config.type}) isn't installed.`;throw new Error(a)}return this.setProvider(o),o}};i(y,"Wallet");var O=y;var H=j({});function M(e,t){return i((o,a,s,d,r)=>{e({type:"new_state",wallet:o,name:a,value:s}),t&&t(o,a,s,d,r)},"handler")}i(M,"makeEventHandler");function z(e){let t=K({});function n(o){let a=o.config.type;return typeof t.current[a]>"u"&&(t.current[a]=new O({config:o.config,handler:e},o.actions)),t.current[a]}return i(n,"updater"),n}i(z,"useInitializers");function Q(e){let[t,n]=J(S,{}),o=z(M(n,e.onUpdateState)),a=e.providers,s=P(a),d={async connect(r,l){let c=s.get(r);if(!c)throw new Error(`You should add ${r} to provider first.`);let f=await o(c).connect(l);return e.autoConnect&&E(r),f},async disconnect(r){let l=s.get(r);if(!l)throw new Error(`You should add ${r} to provider first.`);await o(l).disconnect(),e.autoConnect&&C(r)},async disconnectAll(){let r=[];return N(t).forEach(l=>{let c=s.get(l);if(c){let u=o(c);r.push(u.disconnect())}}),e.autoConnect&&A(),await Promise.allSettled(r)},state(r){return t[r]||v},canSwitchNetworkTo(r,l){let c=s.get(r);if(!c)return!1;let u=o(c);return u.canSwitchNetworkTo?u.canSwitchNetworkTo(l,u.provider):!1},providers(){let r={};return T(t).forEach(l=>{let c=s.get(l);if(c){let u=o(c);r[l]=u.provider}}),r},getWalletInfo(r){let l=s.get(r);if(!l)throw new Error(`You should add ${r} to provider first.`);return l.actions.getWalletInfo(e.allBlockChains||[])},getSigners(r){let l=s.get(r);if(!l)throw new Error(`You should add ${r} to provider first.`);let c=o(l),u=c.getWalletInfo(e.allBlockChains||[]).supportedChains,f=x(u,c.provider,r);return c.getSigners(f)}};return k(()=>{s.forEach(r=>{let l=o(r),c=i(()=>{l.onInit&&l.onInit()},"runOnInit"),u=i(f=>{f.target&&f.target.readyState==="complete"&&(c(),document.removeEventListener("readystatechange",u))},"initWhenPageIsReady");c(),document.addEventListener("readystatechange",u)})},[]),k(()=>{e.allBlockChains&&s.forEach(l=>{let c=o(l),u=c.getWalletInfo(e.allBlockChains||[]).supportedChains;c.setMeta(u)})},[e.allBlockChains]),k(()=>{s.forEach(r=>{o(r).setHandler(M(n,e.onUpdateState))})},[e.onUpdateState]),k(()=>{e.allBlockChains&&e.allBlockChains.length&&e.autoConnect&&(async()=>await b(s,o))()},[e.autoConnect,e.allBlockChains]),Y.createElement(H.Provider,{value:d},e.children)}i(Q,"Provider");function V(){let e=q(H);if(!e)throw Error("useWallet can only be used within the Provider component");return e}i(V,"useWallets");var X=Q;export{B as Events,X as Provider,g as accountAddressesWithNetwork,b as autoConnect,T as availableWallets,P as checkWalletProviders,ut as choose,A as clearPersistStorage,N as connectedWallets,v as defaultWalletState,F as formatAddressWithNetwork,x as getComptaibleProvider,ft as isAsync,$ as isWalletDerivedFromWalletConnect,W as needsCheckInstallation,E as persistWallet,pt as readAccountAddress,C as removeWalletFromPersist,S as state_reducer,V as useWallets};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/helpers.ts", "../src/provider.tsx", "../src/wallet.ts", "../src/types.ts"],
|
|
4
|
-
"sourcesContent": ["import WalletConnectProvider from '@walletconnect/ethereum-provider';\nimport {\n convertEvmBlockchainMetaToEvmChainInfo,\n evmChainsToRpcMap,\n Network,\n WalletType,\n WalletTypes,\n} from '@rango-dev/wallets-shared';\nimport { State, WalletProvider, WalletProviders } from './types';\nimport { Options, State as WalletState } from './wallet';\nimport type { BlockchainMeta } from 'rango-types';\nimport { isEvmBlockchain } from 'rango-types';\n\nexport function choose(wallets: any[], type: WalletType): any | null {\n return wallets.find((wallet) => wallet.type === type) || null;\n}\n\nexport const defaultWalletState: WalletState = {\n connected: false,\n connecting: false,\n reachable: false,\n installed: false,\n accounts: null,\n network: null,\n};\n\nexport function state_reducer(state: State, action: any) {\n if (action.type === 'new_state') {\n // TODO fix problem and remove ts-ignore\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const target_wallet = state[action.wallet];\n if (!target_wallet) {\n return {\n ...state,\n [action.wallet]: {\n ...defaultWalletState,\n [action.name]: action.value,\n },\n };\n }\n\n return {\n ...state,\n [action.wallet]: {\n ...target_wallet,\n [action.name]: action.value,\n },\n };\n }\n\n return state;\n}\n\nexport function formatAddressWithNetwork(\n address: string,\n network?: Network | null\n) {\n return `${network || ''}:${address}`;\n}\n\nexport function accountAddressesWithNetwork(\n addresses: string[] | null,\n network?: Network | null\n) {\n if (!addresses) return [];\n\n return addresses.map((address) => {\n return formatAddressWithNetwork(address, network);\n });\n}\n\nexport function readAccountAddress(addressWithNetwork: string): {\n address: string;\n network: Network;\n} {\n const [network, address] = addressWithNetwork.split(':');\n\n return {\n network: network,\n address,\n };\n}\n\nexport function connectedWallets(providersState: State): WalletType[] {\n return Object.entries(providersState)\n .filter(([, wallet_state]) => {\n return wallet_state?.connected;\n })\n .map(([type]) => {\n return type;\n });\n}\n\nexport function availableWallets(providersState: State): WalletType[] {\n return Object.entries(providersState).map(([type]) => {\n return type;\n });\n}\n\nexport function checkWalletProviders(list: WalletProvider[]): WalletProviders {\n const wallets: WalletProviders = new Map();\n\n list.forEach((provider) => {\n const { config, ...actions } = provider;\n wallets.set(config.type, {\n actions,\n config,\n });\n });\n\n return wallets;\n}\n\n/* eslint-disable @typescript-eslint/ban-types */\nexport function isAsync(fn: Function) {\n return fn?.constructor?.name === 'AsyncFunction';\n}\n\nexport function needsCheckInstallation(options: Options) {\n const { checkInstallation = true } = options.config;\n return checkInstallation;\n}\n\n/*\n WalletConnect instance is not compatible with ethers.providers.Web3Provider,\n Here we are returning a comptable instance, instead of the original one. \n*/\n\nexport function isWalletDerivedFromWalletConnect(wallet_type: WalletType) {\n return wallet_type === WalletTypes.WALLET_CONNECT;\n}\n\nexport function getComptaibleProvider(\n supportedChains: BlockchainMeta[],\n provider: any,\n type: WalletType\n) {\n if (isWalletDerivedFromWalletConnect(type)) {\n const evmBlockchains = supportedChains.filter(isEvmBlockchain);\n const rpcUrls = evmChainsToRpcMap(\n convertEvmBlockchainMetaToEvmChainInfo(evmBlockchains)\n );\n return new WalletConnectProvider({\n qrcode: false,\n rpc: rpcUrls,\n connector: provider,\n chainId: provider.chainId,\n });\n }\n return provider;\n}\n", "import React, {\n createContext,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react';\n\nimport {\n availableWallets,\n checkWalletProviders,\n connectedWallets,\n defaultWalletState,\n getComptaibleProvider,\n state_reducer,\n} from './helpers';\nimport {\n ProviderProps,\n ProviderContext,\n WalletActions,\n WalletConfig,\n} from './types';\nimport { WalletType } from '@rango-dev/wallets-shared';\n\nimport Wallet, { EventHandler as WalletEventHandler } from './wallet';\n\n// TODO fix lint problem\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst WalletContext = createContext<ProviderContext>({});\n\n/*\n Our event handler includes an internal state updater, and a notifier\n for the outside listener.\n On creating first wallet refrence, and on chaning `props.onUpdateState`\n we are using this function.\n*/\nfunction makeEventHandler(dispatcher: any, onUpdateState?: WalletEventHandler) {\n const handler: WalletEventHandler = (\n type,\n name,\n value,\n coreState,\n supportedChains\n ) => {\n const action = { type: 'new_state', wallet: type, name, value };\n // Update state\n dispatcher(action);\n\n // Giving the event to the outside listener\n if (onUpdateState) {\n onUpdateState(type, name, value, coreState, supportedChains);\n }\n };\n\n return handler;\n}\n\nfunction useInitializers(onChangeState: WalletEventHandler) {\n const availableWallets = useRef<{\n [key: string]: Wallet | undefined;\n }>({});\n\n function updater(wallet: {\n actions: WalletActions;\n config: WalletConfig;\n }): Wallet {\n const type = wallet.config.type;\n // We only update, if there is no instance available.\n if (typeof availableWallets.current[type] === 'undefined') {\n availableWallets.current[type] = new Wallet(\n {\n config: wallet.config,\n handler: onChangeState,\n },\n wallet.actions\n );\n }\n\n return availableWallets.current[type]!;\n }\n\n return updater;\n}\n\nfunction Provider(props: ProviderProps) {\n const [providersState, dispatch] = useReducer(state_reducer, {});\n\n const addWalletRef = useInitializers(\n makeEventHandler(dispatch, props.onUpdateState)\n );\n // const providersRef = useRef<{ [type in WalletType]?: any }>({});\n\n const listOfProviders = props.providers;\n const wallets = checkWalletProviders(listOfProviders);\n const api: ProviderContext = {\n // TODO: Fix type error\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n async connect(type, network) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n const ref = addWalletRef(wallet);\n const result = await ref.connect(network);\n\n return result;\n },\n async disconnect(type) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n const ref = addWalletRef(wallet);\n await ref.disconnect();\n },\n async disconnectAll() {\n const disconnect_promises: Promise<any>[] = [];\n\n // When a wallet is initializing, a record will be added to `providersState`\n // So we use them to know what wallet has been initialized then we need to\n // filter connected wallets only.\n connectedWallets(providersState).forEach((type) => {\n const wallet = wallets.get(type);\n\n if (wallet) {\n const ref = addWalletRef(wallet);\n disconnect_promises.push(ref.disconnect());\n }\n });\n\n return await Promise.allSettled(disconnect_promises);\n },\n state(type) {\n return providersState[type] || defaultWalletState;\n },\n canSwitchNetworkTo(type, network) {\n const wallet = wallets.get(type);\n if (!wallet) {\n return false;\n }\n\n const ref = addWalletRef(wallet);\n return ref.canSwitchNetworkTo\n ? ref.canSwitchNetworkTo(network, ref.provider)\n : false;\n },\n providers() {\n const providers: { [type in WalletType]?: any } = {};\n availableWallets(providersState).forEach((type) => {\n const wallet = wallets.get(type);\n if (wallet) {\n const ref = addWalletRef(wallet);\n providers[type] = ref.provider;\n }\n });\n\n return providers;\n },\n getWalletInfo(type) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n // Get wallet info could be used in render methods to show wallets data\n // So, addWalletRef method shouldn't be called in this method\n\n return wallet.actions.getWalletInfo(props.allBlockChains || []);\n },\n getSigners(type) {\n const wallet = wallets.get(type);\n\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n const ref = addWalletRef(wallet);\n const supportedChains = ref.getWalletInfo(\n props.allBlockChains || []\n ).supportedChains;\n const provider = getComptaibleProvider(\n supportedChains,\n ref.provider,\n type\n );\n const result = ref.getSigners(provider);\n\n return result;\n },\n };\n\n useEffect(() => {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n const runOnInit = () => {\n if (ref.onInit) {\n ref.onInit();\n }\n };\n\n const initWhenPageIsReady = (event: Event) => {\n if (\n event.target &&\n (event.target as Document).readyState === 'complete'\n ) {\n runOnInit();\n\n document.removeEventListener('readystatechange', initWhenPageIsReady);\n }\n };\n\n // Try to run, maybe it's ready.\n runOnInit();\n\n // Try again when the page has been completely loaded.\n // Some of wallets, take some time to be fully injected and loaded.\n document.addEventListener('readystatechange', initWhenPageIsReady);\n });\n }, []);\n\n useEffect(() => {\n const allBlockChains = props.allBlockChains;\n if (allBlockChains) {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n const supportedChains = ref.getWalletInfo(\n props.allBlockChains || []\n ).supportedChains;\n ref.setMeta(supportedChains);\n });\n }\n }, [props.allBlockChains]);\n\n useEffect(() => {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n ref.setHandler(makeEventHandler(dispatch, props.onUpdateState));\n });\n }, [props.onUpdateState]);\n\n return (\n <WalletContext.Provider value={api}>\n {props.children}\n </WalletContext.Provider>\n );\n}\n\nexport function useWallets(): ProviderContext {\n const context = useContext(WalletContext);\n if (!context)\n throw Error('useWallet can only be used within the Provider component');\n return context;\n}\n\nexport default Provider;\n", "import {\n getBlockChainNameFromId,\n Network,\n Networks,\n WalletType,\n} from '@rango-dev/wallets-shared';\nimport { accountAddressesWithNetwork, needsCheckInstallation } from './helpers';\nimport {\n Events,\n GetInstanceOptions,\n WalletActions,\n WalletConfig,\n} from './types';\nimport { BlockchainMeta } from 'rango-types';\n\nexport type EventHandler = (\n type: WalletType,\n event: Events,\n value: any,\n coreState: State,\n supportedChains: BlockchainMeta[]\n) => void;\n\nexport interface State {\n connected: boolean;\n connecting: boolean;\n reachable: boolean;\n installed: boolean;\n accounts: string[] | null;\n network: Network | null;\n}\n\nexport interface Options {\n config: WalletConfig;\n handler: EventHandler;\n}\n\nclass Wallet<InstanceType = any> {\n private actions: WalletActions;\n private state: State;\n private options: Options;\n private meta: BlockchainMeta[];\n public provider: InstanceType | null;\n\n constructor(options: Options, actions: WalletActions) {\n this.actions = actions;\n this.options = options;\n this.provider = null;\n this.meta = [];\n this.state = {\n connected: false,\n connecting: false,\n // TODO: Remove\n reachable: false,\n installed: false,\n accounts: null,\n network: null,\n };\n\n if (!needsCheckInstallation(options)) {\n this.setInstalledAs(true);\n }\n }\n\n async eagerConnection() {\n // Already connected, so we return provider that we have in memory.\n\n // For switching network on Trust Wallet (WalletConnect),\n // We only kill the session (and not restting the whole state)\n // So we are relying on this.provider for achieving this functionality.\n if (this.state.connected && !!this.provider) {\n return {\n accounts: this.state.accounts,\n network: this.state.network,\n provider: this.provider,\n };\n }\n\n // TODO: call actions.eagerConnection\n return null;\n }\n async connect(network?: Network) {\n // If it's connecting, nothing do.\n if (this.state.connecting) {\n throw new Error('Connecting...');\n }\n\n const eagerConnection = await this.eagerConnection();\n const currentNetwork = this.state.network;\n // If a network hasn't been provided and also we have `lastNetwork`\n // We will use lastNetwork to make sure we will not\n // Ask the user to switch his network wrongly.\n const requestedNetwork =\n network || currentNetwork || this.options.config.defaultNetwork;\n\n if (eagerConnection) {\n const networkChanged =\n currentNetwork !== requestedNetwork && !!requestedNetwork;\n\n // Reuse current connection if nothing has changed and we already have the connection in memory.\n if (currentNetwork === requestedNetwork) {\n return eagerConnection;\n }\n if (networkChanged && !!this.actions.switchNetwork) {\n await this.actions.switchNetwork({\n instance: this.provider,\n meta: this.meta,\n // TODO: Fix type error\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n network: requestedNetwork,\n newInstance: this.tryGetInstance.bind(this),\n });\n\n return {\n // Only network has been changed, so we reuse accounts from what we have already.\n accounts: eagerConnection.accounts,\n network: requestedNetwork,\n provider: this.provider,\n };\n }\n\n // If none of the above conditions didn't match, continute to connect.\n }\n\n // We are connecting to wallet for the first time\n\n // Trying to get wallet's instance, if it's not available, raise an error.\n const instance = await this.tryGetInstance({ network });\n\n // Instance exists, trying to connect\n this.updateState({\n connecting: true,\n });\n this.setInstalledAs(true);\n\n try {\n // eslint-disable-next-line no-var\n var connectResult = await this.actions.connect({\n instance,\n network: requestedNetwork || undefined,\n meta: this.meta || [],\n });\n } catch (e) {\n this.resetState();\n throw e;\n }\n\n this.updateState({\n connected: true,\n reachable: true,\n connecting: false,\n });\n\n // TODO: Handle accounts.length > 0\n\n // Inserting accounts into our state.\n let nextAccounts: string[] = [];\n let nextNetwork: Network | null | undefined = null;\n if (Array.isArray(connectResult)) {\n const accounts = connectResult.flatMap((blockchain) => {\n const chainId = blockchain.chainId || Networks.Unknown;\n // Try to map chainId with a Network, if not found, we use chainId directly.\n const network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n // TODO: second parameter should be `string` when we decided to open source the package.\n return accountAddressesWithNetwork(blockchain.accounts, network);\n });\n // Typescript can not detect we are filtering out null values:(\n nextAccounts = accounts.filter(Boolean) as string[];\n nextNetwork = requestedNetwork || this.options.config.defaultNetwork;\n } else {\n const chainId = connectResult.chainId || Networks.Unknown;\n const network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n // We fallback to current active network if `chainId` not provided.\n nextAccounts = accountAddressesWithNetwork(\n connectResult.accounts,\n network\n );\n nextNetwork = network;\n }\n\n if (nextAccounts.length > 0) {\n this.updateState({\n accounts: nextAccounts,\n network: nextNetwork,\n });\n }\n\n return {\n accounts: this.state.accounts,\n network: this.state.network,\n provider: this.provider,\n };\n }\n\n async disconnect() {\n this.resetState();\n\n if (this.actions.disconnect) {\n this.actions.disconnect({\n instance: this.provider,\n // On wallet connect, we need to destory the instance and get a whole new instance when we are going to connect\n destroyInstance: () => {\n this.setProvider(null);\n },\n });\n }\n }\n\n getSigners(provider: any) {\n return this.actions.getSigners(provider);\n }\n getWalletInfo(allBlockChains: BlockchainMeta[]) {\n return this.actions.getWalletInfo(allBlockChains);\n }\n canSwitchNetworkTo(network: Network, provider: any) {\n const switchTo = this.actions.canSwitchNetworkTo;\n if (!switchTo) return false;\n\n return switchTo({\n network,\n meta: this.meta,\n provider,\n });\n }\n\n onInit() {\n if (!this.options.config.isAsyncInstance) {\n const instance = this.actions.getInstance();\n if (!!instance && !this.state.installed) {\n this.setInstalledAs(true);\n }\n }\n }\n\n setProvider(value: any) {\n this.provider = value;\n if (!!value && !!this.actions.subscribe) {\n this.actions.subscribe({\n instance: value,\n state: this.state,\n meta: this.meta,\n connect: this.connect.bind(this),\n disconnect: this.disconnect.bind(this),\n updateAccounts: (accounts, chainId) => {\n let network = this.state.network;\n if (chainId) {\n network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n }\n\n const nextAccounts = accountAddressesWithNetwork(accounts, network);\n if (nextAccounts.length > 0) {\n this.updateState({\n accounts: nextAccounts,\n });\n }\n },\n updateChainId: (chainId) => {\n const network = chainId\n ? getBlockChainNameFromId(chainId, this.meta)\n : Networks.Unknown;\n this.updateState({\n network,\n });\n },\n });\n }\n }\n\n setMeta(value: BlockchainMeta[]) {\n this.meta = value;\n }\n\n setHandler(handler: EventHandler) {\n this.options.handler = handler;\n }\n\n getState(): State {\n return this.state;\n }\n updateState(states: Partial<State>) {\n // We will notify handler after updating all the states.\n // Because when we call `handler` it will has latest states.\n const updates: [Events, any][] = [];\n\n if (typeof states.connected !== 'undefined') {\n this.state.connected = states.connected;\n updates.push([Events.CONNECTED, states.connected]);\n }\n if (typeof states.connecting !== 'undefined') {\n this.state.connecting = states.connecting;\n updates.push([Events.CONNECTING, states.connecting]);\n }\n if (typeof states.reachable !== 'undefined') {\n this.state.reachable = states.reachable;\n updates.push([Events.REACHABLE, states.reachable]);\n }\n if (typeof states.installed !== 'undefined') {\n this.state.installed = states.installed;\n updates.push([Events.INSTALLED, states.installed]);\n }\n if (typeof states.accounts !== 'undefined') {\n this.state.accounts = states.accounts;\n updates.push([Events.ACCOUNTS, states.accounts]);\n }\n if (typeof states.network !== 'undefined') {\n this.state.network = states.network;\n updates.push([Events.NETWORK, states.network]);\n }\n\n const state = this.getState();\n updates.forEach(([name, value]) => {\n this.options.handler(\n this.options.config.type,\n name,\n value,\n state,\n this.meta\n );\n });\n }\n\n resetState() {\n this.updateState({\n connected: false,\n connecting: false,\n reachable: false,\n accounts: null,\n network: null,\n });\n }\n\n private setInstalledAs(value: boolean) {\n if (!needsCheckInstallation(this.options) && value === false) return;\n\n this.updateState({\n installed: value,\n });\n }\n private async tryGetInstance({\n network,\n force,\n }: {\n network?: Network;\n force?: boolean;\n }) {\n let instance = null;\n // For switching network on Trust Wallet (WalletConnect),\n // We only kill the session (and not restting the whole state)\n // So we are relying on this.provider for achieving this functionality.\n this.setProvider(null);\n if (this.options.config.isAsyncInstance) {\n // Trying to connect\n const instanceOptions: GetInstanceOptions = {\n currentProvider: this.provider,\n meta: this.meta,\n force: force || false,\n updateChainId: (chainId) => {\n const network = chainId\n ? getBlockChainNameFromId(chainId, this.meta)\n : Networks.Unknown;\n this.updateState({\n network,\n });\n },\n };\n\n if (network) {\n instanceOptions.network = network;\n }\n instance = await this.actions.getInstance(instanceOptions);\n } else {\n instance = this.actions.getInstance();\n }\n\n if (!instance) {\n this.setInstalledAs(false);\n this.resetState();\n\n const error_message = `It seems your selected wallet (${this.options.config.type}) isn't installed.`;\n throw new Error(error_message);\n }\n\n this.setProvider(instance);\n return instance;\n }\n}\n\nexport default Wallet;\n", "import { PropsWithChildren } from 'react';\nimport { Network, WalletType, WalletInfo } from '@rango-dev/wallets-shared';\nimport {\n EventHandler as WalletEventHandler,\n State as WalletState,\n} from './wallet';\nimport { SignerFactory, BlockchainMeta } from 'rango-types';\n\nexport type State = {\n [key: string]: WalletState | undefined;\n};\n\nexport type ConnectResult = {\n accounts: string[] | null;\n network: Network | null;\n provider: any;\n};\n\nexport type Providers = { [type in WalletType]?: any };\n\nexport type ProviderContext = {\n connect(type: WalletType, network?: Network): Promise<ConnectResult>;\n disconnect(type: WalletType): Promise<void>;\n disconnectAll(): Promise<PromiseSettledResult<any>[]>;\n state(type: WalletType): WalletState;\n canSwitchNetworkTo(type: WalletType, network: Network): boolean;\n providers(): Providers;\n getSigners(type: WalletType): SignerFactory;\n getWalletInfo(type: WalletType): WalletInfo;\n};\n\nexport type ProviderProps = PropsWithChildren<{\n onUpdateState?: WalletEventHandler;\n allBlockChains?: BlockchainMeta[];\n providers: WalletProvider[];\n}>;\n\nexport enum Events {\n CONNECTED = 'connected',\n CONNECTING = 'connecting',\n REACHABLE = 'reachable',\n INSTALLED = 'installed',\n ACCOUNTS = 'accounts',\n NETWORK = 'network',\n}\n\nexport type ProviderConnectResult = {\n accounts: string[];\n chainId: string;\n};\n\nexport type GetInstanceOptions = {\n network?: Network;\n currentProvider: any;\n meta: BlockchainMeta[];\n force?: boolean;\n updateChainId: (chainId: number | string) => void;\n};\n\nexport type GetInstance =\n | (() => any)\n | ((options: GetInstanceOptions) => Promise<any>);\nexport type TryGetInstance =\n | (() => any)\n | ((options: Pick<GetInstanceOptions, 'force' | 'network'>) => Promise<any>);\nexport type Connect = (options: {\n instance: any;\n network?: Network;\n meta: BlockchainMeta[];\n}) => Promise<ProviderConnectResult | ProviderConnectResult[]>;\n\nexport type Disconnect = (options: {\n instance: any;\n destroyInstance: () => void;\n}) => Promise<void>;\nexport type Subscribe = (options: {\n instance: any;\n state: WalletState;\n meta: BlockchainMeta[];\n updateChainId: (chainId: string) => void;\n updateAccounts: (accounts: string[], chainId?: string) => void;\n connect: (network?: Network) => void;\n disconnect: () => void;\n}) => void;\n\nexport type SwitchNetwork = (options: {\n instance: any;\n network: Network;\n meta: BlockchainMeta[];\n newInstance?: TryGetInstance;\n}) => Promise<void>;\n\nexport type CanSwitchNetwork = (options: {\n network: Network;\n meta: BlockchainMeta[];\n provider: any;\n}) => boolean;\n\nexport interface WalletActions {\n connect: Connect;\n getInstance: any;\n disconnect?: Disconnect;\n subscribe?: Subscribe;\n // eagerConnect, // optional?\n // unsubscribe, // coupled to subscribe.\n\n // Optional, but should be provided at the same time.\n switchNetwork?: SwitchNetwork;\n getSigners: (provider: any) => SignerFactory;\n canSwitchNetworkTo?: CanSwitchNetwork;\n getWalletInfo(allBlockChains: BlockchainMeta[]): WalletInfo;\n}\n\nexport interface WalletConfig {\n type: WalletType;\n defaultNetwork?: Network;\n checkInstallation?: boolean;\n isAsyncInstance?: boolean;\n}\n\nexport type WalletProviders = Map<\n WalletType,\n {\n actions: WalletActions;\n config: WalletConfig;\n }\n>;\n\nexport type WalletProvider = { config: WalletConfig } & WalletActions;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["WalletConnectProvider", "convertEvmBlockchainMetaToEvmChainInfo", "evmChainsToRpcMap", "WalletTypes", "isEvmBlockchain", "choose", "wallets", "type", "wallet", "__name", "defaultWalletState", "state_reducer", "state", "action", "target_wallet", "formatAddressWithNetwork", "address", "network", "accountAddressesWithNetwork", "addresses", "readAccountAddress", "addressWithNetwork", "connectedWallets", "providersState", "wallet_state", "availableWallets", "checkWalletProviders", "list", "provider", "config", "actions", "isAsync", "fn", "needsCheckInstallation", "options", "checkInstallation", "isWalletDerivedFromWalletConnect", "wallet_type", "WalletTypes", "getComptaibleProvider", "supportedChains", "evmBlockchains", "isEvmBlockchain", "rpcUrls", "evmChainsToRpcMap", "convertEvmBlockchainMetaToEvmChainInfo", "WalletConnectProvider", "React", "createContext", "useContext", "useEffect", "useReducer", "useRef", "getBlockChainNameFromId", "Networks", "Events", "Wallet", "options", "actions", "needsCheckInstallation", "network", "eagerConnection", "currentNetwork", "requestedNetwork", "networkChanged", "instance", "connectResult", "e", "nextAccounts", "nextNetwork", "blockchain", "chainId", "Networks", "getBlockChainNameFromId", "accountAddressesWithNetwork", "provider", "allBlockChains", "switchTo", "value", "accounts", "handler", "states", "updates", "state", "name", "force", "instanceOptions", "error_message", "__name", "wallet_default", "WalletContext", "createContext", "makeEventHandler", "dispatcher", "onUpdateState", "__name", "type", "name", "value", "coreState", "supportedChains", "useInitializers", "onChangeState", "availableWallets", "useRef", "updater", "wallet", "wallet_default", "Provider", "props", "providersState", "dispatch", "useReducer", "state_reducer", "addWalletRef", "listOfProviders", "wallets", "checkWalletProviders", "api", "network", "disconnect_promises", "connectedWallets", "ref", "defaultWalletState", "providers", "provider", "getComptaibleProvider", "useEffect", "runOnInit", "initWhenPageIsReady", "event", "React", "useWallets", "context", "useContext", "provider_default"]
|
|
3
|
+
"sources": ["../src/helpers.ts", "../src/persistor.ts", "../src/constants.ts", "../src/provider.tsx", "../src/wallet.ts", "../src/types.ts"],
|
|
4
|
+
"sourcesContent": ["import WalletConnectProvider from '@walletconnect/ethereum-provider';\nimport {\n convertEvmBlockchainMetaToEvmChainInfo,\n evmChainsToRpcMap,\n Network,\n WalletConfig,\n WalletType,\n WalletTypes,\n} from '@rango-dev/wallets-shared';\nimport { State, WalletActions, WalletProvider, WalletProviders } from './types';\nimport Wallet, { Options, State as WalletState } from './wallet';\nimport type { BlockchainMeta } from 'rango-types';\nimport { isEvmBlockchain } from 'rango-types';\nimport { Persistor } from './persistor';\nimport { LASTE_CONNECTED_WALLETS } from './constants';\n\nexport function choose(wallets: any[], type: WalletType): any | null {\n return wallets.find((wallet) => wallet.type === type) || null;\n}\n\nexport const defaultWalletState: WalletState = {\n connected: false,\n connecting: false,\n reachable: false,\n installed: false,\n accounts: null,\n network: null,\n};\n\nexport function state_reducer(state: State, action: any) {\n if (action.type === 'new_state') {\n // TODO fix problem and remove ts-ignore\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const target_wallet = state[action.wallet];\n if (!target_wallet) {\n return {\n ...state,\n [action.wallet]: {\n ...defaultWalletState,\n [action.name]: action.value,\n },\n };\n }\n\n return {\n ...state,\n [action.wallet]: {\n ...target_wallet,\n [action.name]: action.value,\n },\n };\n }\n\n return state;\n}\n\nexport function formatAddressWithNetwork(\n address: string,\n network?: Network | null\n) {\n return `${network || ''}:${address}`;\n}\n\nexport function accountAddressesWithNetwork(\n addresses: string[] | null,\n network?: Network | null\n) {\n if (!addresses) return [];\n\n return addresses.map((address) => {\n return formatAddressWithNetwork(address, network);\n });\n}\n\nexport function readAccountAddress(addressWithNetwork: string): {\n address: string;\n network: Network;\n} {\n const [network, address] = addressWithNetwork.split(':');\n\n return {\n network: network,\n address,\n };\n}\n\nexport function connectedWallets(providersState: State): WalletType[] {\n return Object.entries(providersState)\n .filter(([, wallet_state]) => {\n return wallet_state?.connected;\n })\n .map(([type]) => {\n return type;\n });\n}\n\nexport function availableWallets(providersState: State): WalletType[] {\n return Object.entries(providersState).map(([type]) => {\n return type;\n });\n}\n\nexport function checkWalletProviders(list: WalletProvider[]): WalletProviders {\n const wallets: WalletProviders = new Map();\n\n list.forEach((provider) => {\n const { config, ...actions } = provider;\n wallets.set(config.type, {\n actions,\n config,\n });\n });\n\n return wallets;\n}\n\n/* eslint-disable @typescript-eslint/ban-types */\nexport function isAsync(fn: Function) {\n return fn?.constructor?.name === 'AsyncFunction';\n}\n\nexport function needsCheckInstallation(options: Options) {\n const { checkInstallation = true } = options.config;\n return checkInstallation;\n}\n\n/*\n WalletConnect instance is not compatible with ethers.providers.Web3Provider,\n Here we are returning a comptable instance, instead of the original one. \n*/\n\nexport function isWalletDerivedFromWalletConnect(wallet_type: WalletType) {\n return wallet_type === WalletTypes.WALLET_CONNECT;\n}\n\nexport function getComptaibleProvider(\n supportedChains: BlockchainMeta[],\n provider: any,\n type: WalletType\n) {\n if (isWalletDerivedFromWalletConnect(type)) {\n const evmBlockchains = supportedChains.filter(isEvmBlockchain);\n const rpcUrls = evmChainsToRpcMap(\n convertEvmBlockchainMetaToEvmChainInfo(evmBlockchains)\n );\n return new WalletConnectProvider({\n qrcode: false,\n rpc: rpcUrls,\n connector: provider,\n chainId: provider.chainId,\n });\n }\n return provider;\n}\n\nexport async function persistWallet(type: WalletType) {\n const persistor = new Persistor<string[]>();\n const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);\n const walletAlreadyPersisted = !!wallets?.find((wallet) => wallet === type);\n if (wallets && !walletAlreadyPersisted)\n persistor.setItem(LASTE_CONNECTED_WALLETS, wallets.concat(type));\n else persistor.setItem(LASTE_CONNECTED_WALLETS, [type]);\n}\n\nexport function removeWalletFromPersist(type: WalletType) {\n const persistor = new Persistor<string[]>();\n const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);\n if (wallets)\n persistor.setItem(\n LASTE_CONNECTED_WALLETS,\n wallets.filter((wallet) => wallet !== type)\n );\n}\n\nexport function clearPersistStorage() {\n const persistor = new Persistor<string[]>();\n const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);\n if (wallets) persistor.removeItem(LASTE_CONNECTED_WALLETS);\n}\n\nexport async function autoConnect(\n wallets: WalletProviders,\n addWalletRef: (wallet: {\n actions: WalletActions;\n config: WalletConfig;\n }) => Wallet<any>\n) {\n const persistor = new Persistor<string[]>();\n const lastConnectedWallets = persistor.getItem(LASTE_CONNECTED_WALLETS);\n if (lastConnectedWallets && lastConnectedWallets.length) {\n const connect_promises: {\n walletType: WalletType;\n connect: () => Promise<any>;\n }[] = [];\n lastConnectedWallets.forEach((walletType) => {\n const wallet = wallets.get(walletType);\n\n if (!!wallet) {\n const ref = addWalletRef(wallet);\n connect_promises.push({ walletType, connect: ref.connect.bind(ref) });\n }\n });\n\n for (const { connect, walletType } of connect_promises) {\n try {\n await connect();\n } catch (error) {\n removeWalletFromPersist(walletType);\n }\n }\n }\n}\n", "export interface PersistStorage<T> {\n getItem: (name: string) => T | null;\n setItem: (name: string, value: T) => void;\n removeItem: (name: string) => void;\n}\n\nexport class Persistor<T> implements PersistStorage<T> {\n getItem(name: string) {\n const item = localStorage.getItem(name);\n const parsedItem = item ? (JSON.parse(item) as T) : null;\n return parsedItem;\n }\n setItem(name: string, value: T) {\n localStorage.setItem(name, JSON.stringify(value));\n }\n removeItem(name: string) {\n localStorage.removeItem(name);\n }\n}\n", "export const LASTE_CONNECTED_WALLETS = 'last-connected-wallets';\n", "import React, {\n createContext,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react';\n\nimport {\n autoConnect,\n availableWallets,\n checkWalletProviders,\n clearPersistStorage,\n connectedWallets,\n defaultWalletState,\n getComptaibleProvider,\n persistWallet,\n removeWalletFromPersist,\n state_reducer,\n} from './helpers';\nimport {\n ProviderProps,\n ProviderContext,\n WalletActions,\n WalletConfig,\n} from './types';\nimport { WalletType } from '@rango-dev/wallets-shared';\n\nimport Wallet, { EventHandler as WalletEventHandler } from './wallet';\n\n// TODO fix lint problem\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst WalletContext = createContext<ProviderContext>({});\n\n/*\n Our event handler includes an internal state updater, and a notifier\n for the outside listener.\n On creating first wallet refrence, and on chaning `props.onUpdateState`\n we are using this function.\n*/\nfunction makeEventHandler(dispatcher: any, onUpdateState?: WalletEventHandler) {\n const handler: WalletEventHandler = (\n type,\n name,\n value,\n coreState,\n supportedChains\n ) => {\n const action = { type: 'new_state', wallet: type, name, value };\n // Update state\n dispatcher(action);\n\n // Giving the event to the outside listener\n if (onUpdateState) {\n onUpdateState(type, name, value, coreState, supportedChains);\n }\n };\n\n return handler;\n}\n\nfunction useInitializers(onChangeState: WalletEventHandler) {\n const availableWallets = useRef<{\n [key: string]: Wallet | undefined;\n }>({});\n\n function updater(wallet: {\n actions: WalletActions;\n config: WalletConfig;\n }): Wallet {\n const type = wallet.config.type;\n // We only update, if there is no instance available.\n if (typeof availableWallets.current[type] === 'undefined') {\n availableWallets.current[type] = new Wallet(\n {\n config: wallet.config,\n handler: onChangeState,\n },\n wallet.actions\n );\n }\n\n return availableWallets.current[type]!;\n }\n\n return updater;\n}\n\nfunction Provider(props: ProviderProps) {\n const [providersState, dispatch] = useReducer(state_reducer, {});\n\n const addWalletRef = useInitializers(\n makeEventHandler(dispatch, props.onUpdateState)\n );\n // const providersRef = useRef<{ [type in WalletType]?: any }>({});\n\n const listOfProviders = props.providers;\n const wallets = checkWalletProviders(listOfProviders);\n const api: ProviderContext = {\n // TODO: Fix type error\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n async connect(type, network) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n const ref = addWalletRef(wallet);\n const result = await ref.connect(network);\n if (props.autoConnect) persistWallet(type);\n\n return result;\n },\n async disconnect(type) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n const ref = addWalletRef(wallet);\n await ref.disconnect();\n if (props.autoConnect) removeWalletFromPersist(type);\n },\n async disconnectAll() {\n const disconnect_promises: Promise<any>[] = [];\n\n // When a wallet is initializing, a record will be added to `providersState`\n // So we use them to know what wallet has been initialized then we need to\n // filter connected wallets only.\n connectedWallets(providersState).forEach((type) => {\n const wallet = wallets.get(type);\n\n if (wallet) {\n const ref = addWalletRef(wallet);\n disconnect_promises.push(ref.disconnect());\n }\n });\n\n if (props.autoConnect) clearPersistStorage();\n return await Promise.allSettled(disconnect_promises);\n },\n state(type) {\n return providersState[type] || defaultWalletState;\n },\n canSwitchNetworkTo(type, network) {\n const wallet = wallets.get(type);\n if (!wallet) {\n return false;\n }\n\n const ref = addWalletRef(wallet);\n return ref.canSwitchNetworkTo\n ? ref.canSwitchNetworkTo(network, ref.provider)\n : false;\n },\n providers() {\n const providers: { [type in WalletType]?: any } = {};\n availableWallets(providersState).forEach((type) => {\n const wallet = wallets.get(type);\n if (wallet) {\n const ref = addWalletRef(wallet);\n providers[type] = ref.provider;\n }\n });\n\n return providers;\n },\n getWalletInfo(type) {\n const wallet = wallets.get(type);\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n\n // Get wallet info could be used in render methods to show wallets data\n // So, addWalletRef method shouldn't be called in this method\n\n return wallet.actions.getWalletInfo(props.allBlockChains || []);\n },\n getSigners(type) {\n const wallet = wallets.get(type);\n\n if (!wallet) {\n throw new Error(`You should add ${type} to provider first.`);\n }\n const ref = addWalletRef(wallet);\n const supportedChains = ref.getWalletInfo(\n props.allBlockChains || []\n ).supportedChains;\n const provider = getComptaibleProvider(\n supportedChains,\n ref.provider,\n type\n );\n const result = ref.getSigners(provider);\n\n return result;\n },\n };\n\n useEffect(() => {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n const runOnInit = () => {\n if (ref.onInit) {\n ref.onInit();\n }\n };\n\n const initWhenPageIsReady = (event: Event) => {\n if (\n event.target &&\n (event.target as Document).readyState === 'complete'\n ) {\n runOnInit();\n\n document.removeEventListener('readystatechange', initWhenPageIsReady);\n }\n };\n\n // Try to run, maybe it's ready.\n runOnInit();\n\n // Try again when the page has been completely loaded.\n // Some of wallets, take some time to be fully injected and loaded.\n document.addEventListener('readystatechange', initWhenPageIsReady);\n });\n }, []);\n\n useEffect(() => {\n const allBlockChains = props.allBlockChains;\n if (allBlockChains) {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n const supportedChains = ref.getWalletInfo(\n props.allBlockChains || []\n ).supportedChains;\n ref.setMeta(supportedChains);\n });\n }\n }, [props.allBlockChains]);\n\n useEffect(() => {\n wallets.forEach((wallet) => {\n const ref = addWalletRef(wallet);\n ref.setHandler(makeEventHandler(dispatch, props.onUpdateState));\n });\n }, [props.onUpdateState]);\n\n useEffect(() => {\n const shouldTryAutoConnect =\n props.allBlockChains && props.allBlockChains.length && props.autoConnect;\n if (shouldTryAutoConnect) {\n (async () => {\n await autoConnect(wallets, addWalletRef);\n })();\n }\n }, [props.autoConnect, props.allBlockChains]);\n\n return (\n <WalletContext.Provider value={api}>\n {props.children}\n </WalletContext.Provider>\n );\n}\n\nexport function useWallets(): ProviderContext {\n const context = useContext(WalletContext);\n if (!context)\n throw Error('useWallet can only be used within the Provider component');\n return context;\n}\n\nexport default Provider;\n", "import {\n getBlockChainNameFromId,\n Network,\n Networks,\n WalletType,\n} from '@rango-dev/wallets-shared';\nimport { accountAddressesWithNetwork, needsCheckInstallation } from './helpers';\nimport {\n Events,\n GetInstanceOptions,\n WalletActions,\n WalletConfig,\n} from './types';\nimport { BlockchainMeta } from 'rango-types';\n\nexport type EventHandler = (\n type: WalletType,\n event: Events,\n value: any,\n coreState: State,\n supportedChains: BlockchainMeta[]\n) => void;\n\nexport interface State {\n connected: boolean;\n connecting: boolean;\n reachable: boolean;\n installed: boolean;\n accounts: string[] | null;\n network: Network | null;\n}\n\nexport interface Options {\n config: WalletConfig;\n handler: EventHandler;\n}\n\nclass Wallet<InstanceType = any> {\n private actions: WalletActions;\n private state: State;\n private options: Options;\n private meta: BlockchainMeta[];\n public provider: InstanceType | null;\n\n constructor(options: Options, actions: WalletActions) {\n this.actions = actions;\n this.options = options;\n this.provider = null;\n this.meta = [];\n this.state = {\n connected: false,\n connecting: false,\n // TODO: Remove\n reachable: false,\n installed: false,\n accounts: null,\n network: null,\n };\n\n if (!needsCheckInstallation(options)) {\n this.setInstalledAs(true);\n }\n }\n\n async eagerConnection() {\n // Already connected, so we return provider that we have in memory.\n\n // For switching network on Trust Wallet (WalletConnect),\n // We only kill the session (and not restting the whole state)\n // So we are relying on this.provider for achieving this functionality.\n if (this.state.connected && !!this.provider) {\n return {\n accounts: this.state.accounts,\n network: this.state.network,\n provider: this.provider,\n };\n }\n\n // TODO: call actions.eagerConnection\n return null;\n }\n async connect(network?: Network) {\n // If it's connecting, nothing do.\n if (this.state.connecting) {\n throw new Error('Connecting...');\n }\n\n const eagerConnection = await this.eagerConnection();\n const currentNetwork = this.state.network;\n // If a network hasn't been provided and also we have `lastNetwork`\n // We will use lastNetwork to make sure we will not\n // Ask the user to switch his network wrongly.\n const requestedNetwork =\n network || currentNetwork || this.options.config.defaultNetwork;\n\n if (eagerConnection) {\n const networkChanged =\n currentNetwork !== requestedNetwork && !!requestedNetwork;\n\n // Reuse current connection if nothing has changed and we already have the connection in memory.\n if (currentNetwork === requestedNetwork) {\n return eagerConnection;\n }\n if (networkChanged && !!this.actions.switchNetwork) {\n await this.actions.switchNetwork({\n instance: this.provider,\n meta: this.meta,\n // TODO: Fix type error\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n network: requestedNetwork,\n newInstance: this.tryGetInstance.bind(this),\n });\n\n return {\n // Only network has been changed, so we reuse accounts from what we have already.\n accounts: eagerConnection.accounts,\n network: requestedNetwork,\n provider: this.provider,\n };\n }\n\n // If none of the above conditions didn't match, continute to connect.\n }\n\n // We are connecting to wallet for the first time\n\n // Trying to get wallet's instance, if it's not available, raise an error.\n const instance = await this.tryGetInstance({ network });\n\n // Instance exists, trying to connect\n this.updateState({\n connecting: true,\n });\n this.setInstalledAs(true);\n\n try {\n // eslint-disable-next-line no-var\n var connectResult = await this.actions.connect({\n instance,\n network: requestedNetwork || undefined,\n meta: this.meta || [],\n });\n } catch (e) {\n this.resetState();\n throw e;\n }\n\n this.updateState({\n connected: true,\n reachable: true,\n connecting: false,\n });\n\n // TODO: Handle accounts.length > 0\n\n // Inserting accounts into our state.\n let nextAccounts: string[] = [];\n let nextNetwork: Network | null | undefined = null;\n if (Array.isArray(connectResult)) {\n const accounts = connectResult.flatMap((blockchain) => {\n const chainId = blockchain.chainId || Networks.Unknown;\n // Try to map chainId with a Network, if not found, we use chainId directly.\n const network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n // TODO: second parameter should be `string` when we decided to open source the package.\n return accountAddressesWithNetwork(blockchain.accounts, network);\n });\n // Typescript can not detect we are filtering out null values:(\n nextAccounts = accounts.filter(Boolean) as string[];\n nextNetwork = requestedNetwork || this.options.config.defaultNetwork;\n } else {\n const chainId = connectResult.chainId || Networks.Unknown;\n const network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n // We fallback to current active network if `chainId` not provided.\n nextAccounts = accountAddressesWithNetwork(\n connectResult.accounts,\n network\n );\n nextNetwork = network;\n }\n\n if (nextAccounts.length > 0) {\n this.updateState({\n accounts: nextAccounts,\n network: nextNetwork,\n });\n }\n\n return {\n accounts: this.state.accounts,\n network: this.state.network,\n provider: this.provider,\n };\n }\n\n async disconnect() {\n this.resetState();\n\n if (this.actions.disconnect) {\n this.actions.disconnect({\n instance: this.provider,\n // On wallet connect, we need to destory the instance and get a whole new instance when we are going to connect\n destroyInstance: () => {\n this.setProvider(null);\n },\n });\n }\n }\n\n getSigners(provider: any) {\n return this.actions.getSigners(provider);\n }\n getWalletInfo(allBlockChains: BlockchainMeta[]) {\n return this.actions.getWalletInfo(allBlockChains);\n }\n canSwitchNetworkTo(network: Network, provider: any) {\n const switchTo = this.actions.canSwitchNetworkTo;\n if (!switchTo) return false;\n\n return switchTo({\n network,\n meta: this.meta,\n provider,\n });\n }\n\n onInit() {\n if (!this.options.config.isAsyncInstance) {\n const instance = this.actions.getInstance();\n if (!!instance && !this.state.installed) {\n this.setInstalledAs(true);\n }\n }\n }\n\n setProvider(value: any) {\n this.provider = value;\n if (!!value && !!this.actions.subscribe) {\n this.actions.subscribe({\n instance: value,\n state: this.state,\n meta: this.meta,\n connect: this.connect.bind(this),\n disconnect: this.disconnect.bind(this),\n updateAccounts: (accounts, chainId) => {\n let network = this.state.network;\n if (chainId) {\n network =\n getBlockChainNameFromId(chainId, this.meta) || Networks.Unknown;\n }\n\n const nextAccounts = accountAddressesWithNetwork(accounts, network);\n if (nextAccounts.length > 0) {\n this.updateState({\n accounts: nextAccounts,\n });\n }\n },\n updateChainId: (chainId) => {\n const network = chainId\n ? getBlockChainNameFromId(chainId, this.meta)\n : Networks.Unknown;\n this.updateState({\n network,\n });\n },\n });\n }\n }\n\n setMeta(value: BlockchainMeta[]) {\n this.meta = value;\n }\n\n setHandler(handler: EventHandler) {\n this.options.handler = handler;\n }\n\n getState(): State {\n return this.state;\n }\n updateState(states: Partial<State>) {\n // We will notify handler after updating all the states.\n // Because when we call `handler` it will has latest states.\n const updates: [Events, any][] = [];\n\n if (typeof states.connected !== 'undefined') {\n this.state.connected = states.connected;\n updates.push([Events.CONNECTED, states.connected]);\n }\n if (typeof states.connecting !== 'undefined') {\n this.state.connecting = states.connecting;\n updates.push([Events.CONNECTING, states.connecting]);\n }\n if (typeof states.reachable !== 'undefined') {\n this.state.reachable = states.reachable;\n updates.push([Events.REACHABLE, states.reachable]);\n }\n if (typeof states.installed !== 'undefined') {\n this.state.installed = states.installed;\n updates.push([Events.INSTALLED, states.installed]);\n }\n if (typeof states.accounts !== 'undefined') {\n this.state.accounts = states.accounts;\n updates.push([Events.ACCOUNTS, states.accounts]);\n }\n if (typeof states.network !== 'undefined') {\n this.state.network = states.network;\n updates.push([Events.NETWORK, states.network]);\n }\n\n const state = this.getState();\n updates.forEach(([name, value]) => {\n this.options.handler(\n this.options.config.type,\n name,\n value,\n state,\n this.meta\n );\n });\n }\n\n resetState() {\n this.updateState({\n connected: false,\n connecting: false,\n reachable: false,\n accounts: null,\n network: null,\n });\n }\n\n private setInstalledAs(value: boolean) {\n if (!needsCheckInstallation(this.options) && value === false) return;\n\n this.updateState({\n installed: value,\n });\n }\n private async tryGetInstance({\n network,\n force,\n }: {\n network?: Network;\n force?: boolean;\n }) {\n let instance = null;\n // For switching network on Trust Wallet (WalletConnect),\n // We only kill the session (and not restting the whole state)\n // So we are relying on this.provider for achieving this functionality.\n this.setProvider(null);\n if (this.options.config.isAsyncInstance) {\n // Trying to connect\n const instanceOptions: GetInstanceOptions = {\n currentProvider: this.provider,\n meta: this.meta,\n force: force || false,\n updateChainId: (chainId) => {\n const network = chainId\n ? getBlockChainNameFromId(chainId, this.meta)\n : Networks.Unknown;\n this.updateState({\n network,\n });\n },\n };\n\n if (network) {\n instanceOptions.network = network;\n }\n instance = await this.actions.getInstance(instanceOptions);\n } else {\n instance = this.actions.getInstance();\n }\n\n if (!instance) {\n this.setInstalledAs(false);\n this.resetState();\n\n const error_message = `It seems your selected wallet (${this.options.config.type}) isn't installed.`;\n throw new Error(error_message);\n }\n\n this.setProvider(instance);\n return instance;\n }\n}\n\nexport default Wallet;\n", "import { PropsWithChildren } from 'react';\nimport { Network, WalletType, WalletInfo } from '@rango-dev/wallets-shared';\nimport {\n EventHandler as WalletEventHandler,\n State as WalletState,\n} from './wallet';\nimport { SignerFactory, BlockchainMeta } from 'rango-types';\n\nexport type State = {\n [key: string]: WalletState | undefined;\n};\n\nexport type ConnectResult = {\n accounts: string[] | null;\n network: Network | null;\n provider: any;\n};\n\nexport type Providers = { [type in WalletType]?: any };\n\nexport type ProviderContext = {\n connect(type: WalletType, network?: Network): Promise<ConnectResult>;\n disconnect(type: WalletType): Promise<void>;\n disconnectAll(): Promise<PromiseSettledResult<any>[]>;\n state(type: WalletType): WalletState;\n canSwitchNetworkTo(type: WalletType, network: Network): boolean;\n providers(): Providers;\n getSigners(type: WalletType): SignerFactory;\n getWalletInfo(type: WalletType): WalletInfo;\n};\n\nexport type ProviderProps = PropsWithChildren<{\n onUpdateState?: WalletEventHandler;\n allBlockChains?: BlockchainMeta[];\n providers: WalletProvider[];\n autoConnect?: boolean;\n}>;\n\nexport enum Events {\n CONNECTED = 'connected',\n CONNECTING = 'connecting',\n REACHABLE = 'reachable',\n INSTALLED = 'installed',\n ACCOUNTS = 'accounts',\n NETWORK = 'network',\n}\n\nexport type ProviderConnectResult = {\n accounts: string[];\n chainId: string;\n};\n\nexport type GetInstanceOptions = {\n network?: Network;\n currentProvider: any;\n meta: BlockchainMeta[];\n force?: boolean;\n updateChainId: (chainId: number | string) => void;\n};\n\nexport type GetInstance =\n | (() => any)\n | ((options: GetInstanceOptions) => Promise<any>);\nexport type TryGetInstance =\n | (() => any)\n | ((options: Pick<GetInstanceOptions, 'force' | 'network'>) => Promise<any>);\nexport type Connect = (options: {\n instance: any;\n network?: Network;\n meta: BlockchainMeta[];\n}) => Promise<ProviderConnectResult | ProviderConnectResult[]>;\n\nexport type Disconnect = (options: {\n instance: any;\n destroyInstance: () => void;\n}) => Promise<void>;\nexport type Subscribe = (options: {\n instance: any;\n state: WalletState;\n meta: BlockchainMeta[];\n updateChainId: (chainId: string) => void;\n updateAccounts: (accounts: string[], chainId?: string) => void;\n connect: (network?: Network) => void;\n disconnect: () => void;\n}) => void;\n\nexport type SwitchNetwork = (options: {\n instance: any;\n network: Network;\n meta: BlockchainMeta[];\n newInstance?: TryGetInstance;\n}) => Promise<void>;\n\nexport type CanSwitchNetwork = (options: {\n network: Network;\n meta: BlockchainMeta[];\n provider: any;\n}) => boolean;\n\nexport interface WalletActions {\n connect: Connect;\n getInstance: any;\n disconnect?: Disconnect;\n subscribe?: Subscribe;\n // eagerConnect, // optional?\n // unsubscribe, // coupled to subscribe.\n\n // Optional, but should be provided at the same time.\n switchNetwork?: SwitchNetwork;\n getSigners: (provider: any) => SignerFactory;\n canSwitchNetworkTo?: CanSwitchNetwork;\n getWalletInfo(allBlockChains: BlockchainMeta[]): WalletInfo;\n}\n\nexport interface WalletConfig {\n type: WalletType;\n defaultNetwork?: Network;\n checkInstallation?: boolean;\n isAsyncInstance?: boolean;\n}\n\nexport type WalletProviders = Map<\n WalletType,\n {\n actions: WalletActions;\n config: WalletConfig;\n }\n>;\n\nexport type WalletProvider = { config: WalletConfig } & WalletActions;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["WalletConnectProvider", "convertEvmBlockchainMetaToEvmChainInfo", "evmChainsToRpcMap", "WalletTypes", "isEvmBlockchain", "Persistor", "name", "item", "value", "__name", "LASTE_CONNECTED_WALLETS", "choose", "wallets", "type", "wallet", "__name", "defaultWalletState", "state_reducer", "state", "action", "target_wallet", "formatAddressWithNetwork", "address", "network", "accountAddressesWithNetwork", "addresses", "readAccountAddress", "addressWithNetwork", "connectedWallets", "providersState", "wallet_state", "availableWallets", "checkWalletProviders", "list", "provider", "config", "actions", "isAsync", "fn", "needsCheckInstallation", "options", "checkInstallation", "isWalletDerivedFromWalletConnect", "wallet_type", "WalletTypes", "getComptaibleProvider", "supportedChains", "evmBlockchains", "isEvmBlockchain", "rpcUrls", "evmChainsToRpcMap", "convertEvmBlockchainMetaToEvmChainInfo", "WalletConnectProvider", "persistWallet", "persistor", "Persistor", "LASTE_CONNECTED_WALLETS", "walletAlreadyPersisted", "removeWalletFromPersist", "clearPersistStorage", "autoConnect", "addWalletRef", "lastConnectedWallets", "connect_promises", "walletType", "ref", "connect", "React", "createContext", "useContext", "useEffect", "useReducer", "useRef", "getBlockChainNameFromId", "Networks", "Events", "Wallet", "options", "actions", "needsCheckInstallation", "network", "eagerConnection", "currentNetwork", "requestedNetwork", "networkChanged", "instance", "connectResult", "e", "nextAccounts", "nextNetwork", "blockchain", "chainId", "Networks", "getBlockChainNameFromId", "accountAddressesWithNetwork", "provider", "allBlockChains", "switchTo", "value", "accounts", "handler", "states", "updates", "state", "name", "force", "instanceOptions", "error_message", "__name", "wallet_default", "WalletContext", "createContext", "makeEventHandler", "dispatcher", "onUpdateState", "__name", "type", "name", "value", "coreState", "supportedChains", "useInitializers", "onChangeState", "availableWallets", "useRef", "updater", "wallet", "wallet_default", "Provider", "props", "providersState", "dispatch", "useReducer", "state_reducer", "addWalletRef", "listOfProviders", "wallets", "checkWalletProviders", "api", "network", "result", "persistWallet", "removeWalletFromPersist", "disconnect_promises", "connectedWallets", "ref", "clearPersistStorage", "defaultWalletState", "providers", "provider", "getComptaibleProvider", "useEffect", "runOnInit", "initWhenPageIsReady", "event", "autoConnect", "React", "useWallets", "context", "useContext", "provider_default"]
|
|
7
7
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface PersistStorage<T> {
|
|
2
|
+
getItem: (name: string) => T | null;
|
|
3
|
+
setItem: (name: string, value: T) => void;
|
|
4
|
+
removeItem: (name: string) => void;
|
|
5
|
+
}
|
|
6
|
+
export declare class Persistor<T> implements PersistStorage<T> {
|
|
7
|
+
getItem(name: string): T | null;
|
|
8
|
+
setItem(name: string, value: T): void;
|
|
9
|
+
removeItem(name: string): void;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=persistor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistor.d.ts","sourceRoot":"","sources":["../src/persistor.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc,CAAC,CAAC;IAC/B,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC;IACpC,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;IAC1C,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC;AAED,qBAAa,SAAS,CAAC,CAAC,CAAE,YAAW,cAAc,CAAC,CAAC,CAAC;IACpD,OAAO,CAAC,IAAI,EAAE,MAAM;IAKpB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAG9B,UAAU,CAAC,IAAI,EAAE,MAAM;CAGxB"}
|
package/dist/provider.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.tsx"],"names":[],"mappings":";AAoBA,OAAO,EACL,aAAa,EACb,eAAe,EAGhB,MAAM,SAAS,CAAC;AAgEjB,iBAAS,QAAQ,CAAC,KAAK,EAAE,aAAa,eAgLrC;AAED,wBAAgB,UAAU,IAAI,eAAe,CAK5C;AAED,eAAe,QAAQ,CAAC"}
|
package/dist/types.d.ts
CHANGED
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAC5E,OAAO,EACL,YAAY,IAAI,kBAAkB,EAClC,KAAK,IAAI,WAAW,EACrB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE5D,MAAM,MAAM,KAAK,GAAG;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAC1B,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,QAAQ,EAAE,GAAG,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;KAAG,IAAI,IAAI,UAAU,CAAC,CAAC,EAAE,GAAG;CAAE,CAAC;AAEvD,MAAM,MAAM,eAAe,GAAG;IAC5B,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IACrE,UAAU,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,aAAa,IAAI,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACtD,KAAK,CAAC,IAAI,EAAE,UAAU,GAAG,WAAW,CAAC;IACrC,kBAAkB,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC;IAChE,SAAS,IAAI,SAAS,CAAC;IACvB,UAAU,CAAC,IAAI,EAAE,UAAU,GAAG,aAAa,CAAC;IAC5C,aAAa,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,CAAC;CAC7C,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,iBAAiB,CAAC;IAC5C,aAAa,CAAC,EAAE,kBAAkB,CAAC;IACnC,cAAc,CAAC,EAAE,cAAc,EAAE,CAAC;IAClC,SAAS,EAAE,cAAc,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rango-dev/wallets-core",
|
|
3
|
-
"version": "0.5.1-next.
|
|
3
|
+
"version": "0.5.1-next.4",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"module": "./dist/index.js",
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
"react-dom": "^17.0.0 || ^18.0.0"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"@rango-dev/wallets-shared": "^0.5.1-next.
|
|
28
|
+
"@rango-dev/wallets-shared": "^0.5.1-next.10",
|
|
29
29
|
"@walletconnect/ethereum-provider": "1.8.0",
|
|
30
30
|
"rango-types": "^0.1.39"
|
|
31
31
|
},
|
package/src/constants.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const LASTE_CONNECTED_WALLETS = 'last-connected-wallets';
|
package/src/helpers.ts
CHANGED
|
@@ -3,13 +3,16 @@ import {
|
|
|
3
3
|
convertEvmBlockchainMetaToEvmChainInfo,
|
|
4
4
|
evmChainsToRpcMap,
|
|
5
5
|
Network,
|
|
6
|
+
WalletConfig,
|
|
6
7
|
WalletType,
|
|
7
8
|
WalletTypes,
|
|
8
9
|
} from '@rango-dev/wallets-shared';
|
|
9
|
-
import { State, WalletProvider, WalletProviders } from './types';
|
|
10
|
-
import { Options, State as WalletState } from './wallet';
|
|
10
|
+
import { State, WalletActions, WalletProvider, WalletProviders } from './types';
|
|
11
|
+
import Wallet, { Options, State as WalletState } from './wallet';
|
|
11
12
|
import type { BlockchainMeta } from 'rango-types';
|
|
12
13
|
import { isEvmBlockchain } from 'rango-types';
|
|
14
|
+
import { Persistor } from './persistor';
|
|
15
|
+
import { LASTE_CONNECTED_WALLETS } from './constants';
|
|
13
16
|
|
|
14
17
|
export function choose(wallets: any[], type: WalletType): any | null {
|
|
15
18
|
return wallets.find((wallet) => wallet.type === type) || null;
|
|
@@ -150,3 +153,61 @@ export function getComptaibleProvider(
|
|
|
150
153
|
}
|
|
151
154
|
return provider;
|
|
152
155
|
}
|
|
156
|
+
|
|
157
|
+
export async function persistWallet(type: WalletType) {
|
|
158
|
+
const persistor = new Persistor<string[]>();
|
|
159
|
+
const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);
|
|
160
|
+
const walletAlreadyPersisted = !!wallets?.find((wallet) => wallet === type);
|
|
161
|
+
if (wallets && !walletAlreadyPersisted)
|
|
162
|
+
persistor.setItem(LASTE_CONNECTED_WALLETS, wallets.concat(type));
|
|
163
|
+
else persistor.setItem(LASTE_CONNECTED_WALLETS, [type]);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
export function removeWalletFromPersist(type: WalletType) {
|
|
167
|
+
const persistor = new Persistor<string[]>();
|
|
168
|
+
const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);
|
|
169
|
+
if (wallets)
|
|
170
|
+
persistor.setItem(
|
|
171
|
+
LASTE_CONNECTED_WALLETS,
|
|
172
|
+
wallets.filter((wallet) => wallet !== type)
|
|
173
|
+
);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
export function clearPersistStorage() {
|
|
177
|
+
const persistor = new Persistor<string[]>();
|
|
178
|
+
const wallets = persistor.getItem(LASTE_CONNECTED_WALLETS);
|
|
179
|
+
if (wallets) persistor.removeItem(LASTE_CONNECTED_WALLETS);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
export async function autoConnect(
|
|
183
|
+
wallets: WalletProviders,
|
|
184
|
+
addWalletRef: (wallet: {
|
|
185
|
+
actions: WalletActions;
|
|
186
|
+
config: WalletConfig;
|
|
187
|
+
}) => Wallet<any>
|
|
188
|
+
) {
|
|
189
|
+
const persistor = new Persistor<string[]>();
|
|
190
|
+
const lastConnectedWallets = persistor.getItem(LASTE_CONNECTED_WALLETS);
|
|
191
|
+
if (lastConnectedWallets && lastConnectedWallets.length) {
|
|
192
|
+
const connect_promises: {
|
|
193
|
+
walletType: WalletType;
|
|
194
|
+
connect: () => Promise<any>;
|
|
195
|
+
}[] = [];
|
|
196
|
+
lastConnectedWallets.forEach((walletType) => {
|
|
197
|
+
const wallet = wallets.get(walletType);
|
|
198
|
+
|
|
199
|
+
if (!!wallet) {
|
|
200
|
+
const ref = addWalletRef(wallet);
|
|
201
|
+
connect_promises.push({ walletType, connect: ref.connect.bind(ref) });
|
|
202
|
+
}
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
for (const { connect, walletType } of connect_promises) {
|
|
206
|
+
try {
|
|
207
|
+
await connect();
|
|
208
|
+
} catch (error) {
|
|
209
|
+
removeWalletFromPersist(walletType);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
package/src/persistor.ts
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export interface PersistStorage<T> {
|
|
2
|
+
getItem: (name: string) => T | null;
|
|
3
|
+
setItem: (name: string, value: T) => void;
|
|
4
|
+
removeItem: (name: string) => void;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export class Persistor<T> implements PersistStorage<T> {
|
|
8
|
+
getItem(name: string) {
|
|
9
|
+
const item = localStorage.getItem(name);
|
|
10
|
+
const parsedItem = item ? (JSON.parse(item) as T) : null;
|
|
11
|
+
return parsedItem;
|
|
12
|
+
}
|
|
13
|
+
setItem(name: string, value: T) {
|
|
14
|
+
localStorage.setItem(name, JSON.stringify(value));
|
|
15
|
+
}
|
|
16
|
+
removeItem(name: string) {
|
|
17
|
+
localStorage.removeItem(name);
|
|
18
|
+
}
|
|
19
|
+
}
|
package/src/provider.tsx
CHANGED
|
@@ -7,11 +7,15 @@ import React, {
|
|
|
7
7
|
} from 'react';
|
|
8
8
|
|
|
9
9
|
import {
|
|
10
|
+
autoConnect,
|
|
10
11
|
availableWallets,
|
|
11
12
|
checkWalletProviders,
|
|
13
|
+
clearPersistStorage,
|
|
12
14
|
connectedWallets,
|
|
13
15
|
defaultWalletState,
|
|
14
16
|
getComptaibleProvider,
|
|
17
|
+
persistWallet,
|
|
18
|
+
removeWalletFromPersist,
|
|
15
19
|
state_reducer,
|
|
16
20
|
} from './helpers';
|
|
17
21
|
import {
|
|
@@ -105,6 +109,7 @@ function Provider(props: ProviderProps) {
|
|
|
105
109
|
|
|
106
110
|
const ref = addWalletRef(wallet);
|
|
107
111
|
const result = await ref.connect(network);
|
|
112
|
+
if (props.autoConnect) persistWallet(type);
|
|
108
113
|
|
|
109
114
|
return result;
|
|
110
115
|
},
|
|
@@ -116,6 +121,7 @@ function Provider(props: ProviderProps) {
|
|
|
116
121
|
|
|
117
122
|
const ref = addWalletRef(wallet);
|
|
118
123
|
await ref.disconnect();
|
|
124
|
+
if (props.autoConnect) removeWalletFromPersist(type);
|
|
119
125
|
},
|
|
120
126
|
async disconnectAll() {
|
|
121
127
|
const disconnect_promises: Promise<any>[] = [];
|
|
@@ -132,6 +138,7 @@ function Provider(props: ProviderProps) {
|
|
|
132
138
|
}
|
|
133
139
|
});
|
|
134
140
|
|
|
141
|
+
if (props.autoConnect) clearPersistStorage();
|
|
135
142
|
return await Promise.allSettled(disconnect_promises);
|
|
136
143
|
},
|
|
137
144
|
state(type) {
|
|
@@ -241,6 +248,16 @@ function Provider(props: ProviderProps) {
|
|
|
241
248
|
});
|
|
242
249
|
}, [props.onUpdateState]);
|
|
243
250
|
|
|
251
|
+
useEffect(() => {
|
|
252
|
+
const shouldTryAutoConnect =
|
|
253
|
+
props.allBlockChains && props.allBlockChains.length && props.autoConnect;
|
|
254
|
+
if (shouldTryAutoConnect) {
|
|
255
|
+
(async () => {
|
|
256
|
+
await autoConnect(wallets, addWalletRef);
|
|
257
|
+
})();
|
|
258
|
+
}
|
|
259
|
+
}, [props.autoConnect, props.allBlockChains]);
|
|
260
|
+
|
|
244
261
|
return (
|
|
245
262
|
<WalletContext.Provider value={api}>
|
|
246
263
|
{props.children}
|