UNPKG

@tronweb3/tronwallet-adapter-gatewallet

Version:

Wallet adapter for Gate Wallet app and extension.

1,067 lines (995 loc) 79.2 kB
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : typeof define === 'function' && define.amd ? define(factory) : (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global["@tronweb3/tronwallet-adapter-gatewallet"] = factory()); })(this, (function () { 'use strict'; var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; function getDefaultExportFromCjs (x) { return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x; } var cjs$2 = {}; var adapter$2 = {}; var cjs$1 = {}; var adapter$1 = {}; var eventemitter3 = {exports: {}}; (function (module) { var has = Object.prototype.hasOwnProperty , prefix = '~'; /** * Constructor to create a storage for our `EE` objects. * An `Events` instance is a plain object whose properties are event names. * * @constructor * @private */ function Events() {} // // We try to not inherit from `Object.prototype`. In some engines creating an // instance in this way is faster than calling `Object.create(null)` directly. // If `Object.create(null)` is not supported we prefix the event names with a // character to make sure that the built-in object properties are not // overridden or used as an attack vector. // if (Object.create) { Events.prototype = Object.create(null); // // This hack is needed because the `__proto__` property is still inherited in // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5. // if (!new Events().__proto__) prefix = false; } /** * Representation of a single event listener. * * @param {Function} fn The listener function. * @param {*} context The context to invoke the listener with. * @param {Boolean} [once=false] Specify if the listener is a one-time listener. * @constructor * @private */ function EE(fn, context, once) { this.fn = fn; this.context = context; this.once = once || false; } /** * Add a listener for a given event. * * @param {EventEmitter} emitter Reference to the `EventEmitter` instance. * @param {(String|Symbol)} event The event name. * @param {Function} fn The listener function. * @param {*} context The context to invoke the listener with. * @param {Boolean} once Specify if the listener is a one-time listener. * @returns {EventEmitter} * @private */ function addListener(emitter, event, fn, context, once) { if (typeof fn !== 'function') { throw new TypeError('The listener must be a function'); } var listener = new EE(fn, context || emitter, once) , evt = prefix ? prefix + event : event; if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++; else if (!emitter._events[evt].fn) emitter._events[evt].push(listener); else emitter._events[evt] = [emitter._events[evt], listener]; return emitter; } /** * Clear event by name. * * @param {EventEmitter} emitter Reference to the `EventEmitter` instance. * @param {(String|Symbol)} evt The Event name. * @private */ function clearEvent(emitter, evt) { if (--emitter._eventsCount === 0) emitter._events = new Events(); else delete emitter._events[evt]; } /** * Minimal `EventEmitter` interface that is molded against the Node.js * `EventEmitter` interface. * * @constructor * @public */ function EventEmitter() { this._events = new Events(); this._eventsCount = 0; } /** * Return an array listing the events for which the emitter has registered * listeners. * * @returns {Array} * @public */ EventEmitter.prototype.eventNames = function eventNames() { var names = [] , events , name; if (this._eventsCount === 0) return names; for (name in (events = this._events)) { if (has.call(events, name)) names.push(prefix ? name.slice(1) : name); } if (Object.getOwnPropertySymbols) { return names.concat(Object.getOwnPropertySymbols(events)); } return names; }; /** * Return the listeners registered for a given event. * * @param {(String|Symbol)} event The event name. * @returns {Array} The registered listeners. * @public */ EventEmitter.prototype.listeners = function listeners(event) { var evt = prefix ? prefix + event : event , handlers = this._events[evt]; if (!handlers) return []; if (handlers.fn) return [handlers.fn]; for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) { ee[i] = handlers[i].fn; } return ee; }; /** * Return the number of listeners listening to a given event. * * @param {(String|Symbol)} event The event name. * @returns {Number} The number of listeners. * @public */ EventEmitter.prototype.listenerCount = function listenerCount(event) { var evt = prefix ? prefix + event : event , listeners = this._events[evt]; if (!listeners) return 0; if (listeners.fn) return 1; return listeners.length; }; /** * Calls each of the listeners registered for a given event. * * @param {(String|Symbol)} event The event name. * @returns {Boolean} `true` if the event had listeners, else `false`. * @public */ EventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) { var evt = prefix ? prefix + event : event; if (!this._events[evt]) return false; var listeners = this._events[evt] , len = arguments.length , args , i; if (listeners.fn) { if (listeners.once) this.removeListener(event, listeners.fn, undefined, true); switch (len) { case 1: return listeners.fn.call(listeners.context), true; case 2: return listeners.fn.call(listeners.context, a1), true; case 3: return listeners.fn.call(listeners.context, a1, a2), true; case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true; case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true; case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true; } for (i = 1, args = new Array(len -1); i < len; i++) { args[i - 1] = arguments[i]; } listeners.fn.apply(listeners.context, args); } else { var length = listeners.length , j; for (i = 0; i < length; i++) { if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true); switch (len) { case 1: listeners[i].fn.call(listeners[i].context); break; case 2: listeners[i].fn.call(listeners[i].context, a1); break; case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break; case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break; default: if (!args) for (j = 1, args = new Array(len -1); j < len; j++) { args[j - 1] = arguments[j]; } listeners[i].fn.apply(listeners[i].context, args); } } } return true; }; /** * Add a listener for a given event. * * @param {(String|Symbol)} event The event name. * @param {Function} fn The listener function. * @param {*} [context=this] The context to invoke the listener with. * @returns {EventEmitter} `this`. * @public */ EventEmitter.prototype.on = function on(event, fn, context) { return addListener(this, event, fn, context, false); }; /** * Add a one-time listener for a given event. * * @param {(String|Symbol)} event The event name. * @param {Function} fn The listener function. * @param {*} [context=this] The context to invoke the listener with. * @returns {EventEmitter} `this`. * @public */ EventEmitter.prototype.once = function once(event, fn, context) { return addListener(this, event, fn, context, true); }; /** * Remove the listeners of a given event. * * @param {(String|Symbol)} event The event name. * @param {Function} fn Only remove the listeners that match this function. * @param {*} context Only remove the listeners that have this context. * @param {Boolean} once Only remove one-time listeners. * @returns {EventEmitter} `this`. * @public */ EventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) { var evt = prefix ? prefix + event : event; if (!this._events[evt]) return this; if (!fn) { clearEvent(this, evt); return this; } var listeners = this._events[evt]; if (listeners.fn) { if ( listeners.fn === fn && (!once || listeners.once) && (!context || listeners.context === context) ) { clearEvent(this, evt); } } else { for (var i = 0, events = [], length = listeners.length; i < length; i++) { if ( listeners[i].fn !== fn || (once && !listeners[i].once) || (context && listeners[i].context !== context) ) { events.push(listeners[i]); } } // // Reset the array, or remove it completely if we have no more listeners. // if (events.length) this._events[evt] = events.length === 1 ? events[0] : events; else clearEvent(this, evt); } return this; }; /** * Remove all listeners, or those of the specified event. * * @param {(String|Symbol)} [event] The event name. * @returns {EventEmitter} `this`. * @public */ EventEmitter.prototype.removeAllListeners = function removeAllListeners(event) { var evt; if (event) { evt = prefix ? prefix + event : event; if (this._events[evt]) clearEvent(this, evt); } else { this._events = new Events(); this._eventsCount = 0; } return this; }; // // Alias methods names because people roll like that. // EventEmitter.prototype.off = EventEmitter.prototype.removeListener; EventEmitter.prototype.addListener = EventEmitter.prototype.on; // // Expose the prefix. // EventEmitter.prefixed = prefix; // // Allow `EventEmitter` to be imported as module namespace. // EventEmitter.EventEmitter = EventEmitter; // // Expose the module. // { module.exports = EventEmitter; } } (eventemitter3)); var eventemitter3Exports = eventemitter3.exports; var __importDefault = (commonjsGlobal && commonjsGlobal.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(adapter$1, "__esModule", { value: true }); adapter$1.Adapter = adapter$1.AdapterState = adapter$1.WalletReadyState = adapter$1.EventEmitter = void 0; const eventemitter3_1 = __importDefault(eventemitter3Exports); adapter$1.EventEmitter = eventemitter3_1.default; /** * Wallet ready state. */ var WalletReadyState; (function (WalletReadyState) { /** * Adapter will start to check if wallet exists after adapter instance is created. */ WalletReadyState["Loading"] = "Loading"; /** * When checking ends and wallet is not found, readyState will be NotFound. */ WalletReadyState["NotFound"] = "NotFound"; /** * When checking ends and wallet is found, readyState will be Found. */ WalletReadyState["Found"] = "Found"; })(WalletReadyState || (adapter$1.WalletReadyState = WalletReadyState = {})); /** * Adapter state */ var AdapterState; (function (AdapterState) { /** * If adapter is checking the wallet, the state is Loading. */ AdapterState["Loading"] = "Loading"; /** * If wallet is not installed, the state is NotFound. */ AdapterState["NotFound"] = "NotFound"; /** * If wallet is installed but is not connected to current Dapp, the state is Disconnected. */ AdapterState["Disconnect"] = "Disconnected"; /** * Wallet is connected to current Dapp. */ AdapterState["Connected"] = "Connected"; })(AdapterState || (adapter$1.AdapterState = AdapterState = {})); class Adapter extends eventemitter3_1.default { get connected() { return this.state === AdapterState.Connected; } /** * Some wallets such as TronLink don't support disconnect() method. */ disconnect() { console.info("The current adapter doesn't support disconnect by DApp."); return Promise.resolve(); } // eslint-disable-next-line @typescript-eslint/no-unused-vars multiSign(...args) { return Promise.reject("The current wallet doesn't support multiSign."); } // eslint-disable-next-line @typescript-eslint/no-unused-vars switchChain(_chainId) { return Promise.reject("The current wallet doesn't support switch chain."); } } adapter$1.Adapter = Adapter; var errors = {}; Object.defineProperty(errors, "__esModule", { value: true }); errors.WalletGetNetworkError = errors.WalletSwitchChainError = errors.WalletWindowClosedError = errors.WalletWalletLoadError = errors.WalletSignTransactionError = errors.WalletSignMessageError = errors.WalletDisconnectionError = errors.WalletConnectionError = errors.WalletDisconnectedError = errors.WalletNotSelectedError = errors.WalletNotFoundError = errors.WalletError = void 0; class WalletError extends Error { constructor(message, error) { super(message); this.error = error; } } errors.WalletError = WalletError; /** * Occurs when wallet is not installed. */ class WalletNotFoundError extends WalletError { constructor() { super(...arguments); this.name = 'WalletNotFoundError'; this.message = 'The wallet is not found.'; } } errors.WalletNotFoundError = WalletNotFoundError; /** * Occurs when connect to a wallet but there is no wallet selected. */ class WalletNotSelectedError extends WalletError { constructor() { super(...arguments); this.name = 'WalletNotSelectedError'; this.message = 'No wallet is selected. Please select a wallet.'; } } errors.WalletNotSelectedError = WalletNotSelectedError; /** * Occurs when wallet is disconnected. * Used by some wallets which won't connect automatically when call `signMessage()` or `signTransaction()`. */ class WalletDisconnectedError extends WalletError { constructor() { super(...arguments); this.name = 'WalletDisconnectedError'; this.message = 'The wallet is disconnected. Please connect first.'; } } errors.WalletDisconnectedError = WalletDisconnectedError; /** * Occurs when try to connect a wallet. */ class WalletConnectionError extends WalletError { constructor() { super(...arguments); this.name = 'WalletConnectionError'; } } errors.WalletConnectionError = WalletConnectionError; /** * Occurs when try to disconnect a wallet. */ class WalletDisconnectionError extends WalletError { constructor() { super(...arguments); this.name = 'WalletDisconnectionError'; } } errors.WalletDisconnectionError = WalletDisconnectionError; /** * Occurs when call `signMessage()`. */ class WalletSignMessageError extends WalletError { constructor() { super(...arguments); this.name = 'WalletSignMessageError'; } } errors.WalletSignMessageError = WalletSignMessageError; /** * Occurs when call `signTransaction()`. */ class WalletSignTransactionError extends WalletError { constructor() { super(...arguments); this.name = 'WalletSignTransactionError'; } } errors.WalletSignTransactionError = WalletSignTransactionError; /** * Occurs when load wallet */ class WalletWalletLoadError extends WalletError { constructor() { super(...arguments); this.name = 'WalletWalletLoadError'; } } errors.WalletWalletLoadError = WalletWalletLoadError; /** * Occurs when walletconnect QR window is closed. */ class WalletWindowClosedError extends WalletError { constructor() { super(...arguments); this.name = 'WalletWindowClosedError'; this.message = 'The QR window is closed.'; } } errors.WalletWindowClosedError = WalletWindowClosedError; /** * Occurs when request wallet to switch chain. */ class WalletSwitchChainError extends WalletError { constructor() { super(...arguments); this.name = 'WalletSwitchChainError'; } } errors.WalletSwitchChainError = WalletSwitchChainError; /** * Occurs when get network infomation. */ class WalletGetNetworkError extends WalletError { constructor() { super(...arguments); this.name = 'WalletGetNetworkError'; } } errors.WalletGetNetworkError = WalletGetNetworkError; var types$1 = {}; Object.defineProperty(types$1, "__esModule", { value: true }); types$1.ChainNetwork = types$1.NetworkType = void 0; var NetworkType; (function (NetworkType) { NetworkType["Mainnet"] = "Mainnet"; NetworkType["Shasta"] = "Shasta"; NetworkType["Nile"] = "Nile"; /** * When use custom node */ NetworkType["Unknown"] = "Unknown"; })(NetworkType || (types$1.NetworkType = NetworkType = {})); var ChainNetwork; (function (ChainNetwork) { ChainNetwork["Mainnet"] = "Mainnet"; ChainNetwork["Shasta"] = "Shasta"; ChainNetwork["Nile"] = "Nile"; })(ChainNetwork || (types$1.ChainNetwork = ChainNetwork = {})); var utils$2 = {}; Object.defineProperty(utils$2, "__esModule", { value: true }); utils$2.isInBrowser = isInBrowser; utils$2.checkAdapterState = checkAdapterState; utils$2.isInMobileBrowser = isInMobileBrowser; /** * check simply if current environment is browser or not * @returns boolean */ function isInBrowser() { return typeof window !== 'undefined' && typeof document !== 'undefined' && typeof navigator !== 'undefined'; } /** * * @param {Function} check funcion to check if wallet is installed. return true if wallet is detected. * @returns */ function checkAdapterState(check) { if (!isInBrowser()) return; const disposers = []; function dispose() { for (const dispose of disposers) { dispose(); } } function checkAndDispose() { if (check()) { dispose(); } } const interval = setInterval(checkAndDispose, 500); disposers.push(() => clearInterval(interval)); if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', checkAndDispose, { once: true }); disposers.push(() => document.removeEventListener('DOMContentLoaded', checkAndDispose)); } if (document.readyState !== 'complete') { window.addEventListener('load', checkAndDispose, { once: true }); disposers.push(() => window.removeEventListener('load', checkAndDispose)); } checkAndDispose(); // stop all task after 1min setTimeout(dispose, 60 * 1000); } /** * Simplily detect mobile device */ function isInMobileBrowser() { return (typeof navigator !== 'undefined' && navigator.userAgent.match(/Android|webOS|iPhone|iPad|iPod|BlackBerry|Windows Phone/i)); } (function (exports) { var __createBinding = (commonjsGlobal && commonjsGlobal.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __exportStar = (commonjsGlobal && commonjsGlobal.__exportStar) || function(m, exports) { for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); }; Object.defineProperty(exports, "__esModule", { value: true }); __exportStar(adapter$1, exports); __exportStar(errors, exports); __exportStar(types$1, exports); __exportStar(utils$2, exports); } (cjs$1)); var cjs = {}; var adapter = {}; var utils$1 = {}; var __awaiter = (commonjsGlobal && commonjsGlobal.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(utils$1, "__esModule", { value: true }); utils$1.supportTron = supportTron; utils$1.supportTronLink = supportTronLink; utils$1.isInTronLinkApp = isInTronLinkApp; utils$1.openTronLink = openTronLink; utils$1.waitTronwebReady = waitTronwebReady; const tronwallet_abstract_adapter_1$1 = cjs$1; function supportTron() { return !!(window.tron && window.tron.isTronLink); } function supportTronLink() { return !!(supportTron() || window.tronLink || window.tronWeb); } /** * Detect if in TronLinkApp * Tron DApp running in the DApp Explorer injects iTron objects automatically to offer customized App service. * See [here](https://docs.tronlink.org/tronlink-app/dapp-support/dapp-explorer) */ function isInTronLinkApp() { return (0, tronwallet_abstract_adapter_1$1.isInBrowser)() && typeof window.iTron !== 'undefined'; } function openTronLink({ dappIcon, dappName } = { dappIcon: '', dappName: '' }) { if (!supportTronLink() && (0, tronwallet_abstract_adapter_1$1.isInMobileBrowser)() && !isInTronLinkApp()) { let defaultDappName = '', defaultDappIcon = ''; try { defaultDappName = document.title; const link = document.querySelector('link[rel*="icon"]'); if (link) { defaultDappIcon = new URL(link.getAttribute('href') || '', location.href).toString(); } } catch (e) { // console.error(e); } const { origin, pathname, search, hash } = window.location; const url = origin + pathname + search + (hash.includes('?') ? hash : `${hash}?_=1`); const params = { action: 'open', actionId: Date.now() + '', callbackUrl: 'http://someurl.com', // no need callback dappIcon: dappIcon || defaultDappIcon, dappName: dappName || defaultDappName, url, protocol: 'TronLink', version: '1.0', chainId: '0x2b6653dc', }; window.location.href = `tronlinkoutside://pull.activity?param=${encodeURIComponent(JSON.stringify(params))}`; return true; } return false; } function waitTronwebReady(tronObj) { return __awaiter(this, void 0, void 0, function* () { return new Promise((resolve, reject) => { const interval = setInterval(() => { if (tronObj.tronWeb) { clearInterval(interval); clearTimeout(timeout); resolve(); } }, 50); const timeout = setTimeout(() => { clearInterval(interval); reject('`window.tron.tronweb` is not ready.'); }, 2000); }); }); } (function (exports) { var __awaiter = (commonjsGlobal && commonjsGlobal.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.TronLinkAdapter = exports.TronLinkAdapterName = exports.chainIdNetworkMap = void 0; exports.getNetworkInfoByTronWeb = getNetworkInfoByTronWeb; const tronwallet_abstract_adapter_1 = cjs$1; const utils_js_1 = utils$1; exports.chainIdNetworkMap = { '0x2b6653dc': tronwallet_abstract_adapter_1.NetworkType.Mainnet, '0x94a9059e': tronwallet_abstract_adapter_1.NetworkType.Shasta, '0xcd8690dc': tronwallet_abstract_adapter_1.NetworkType.Nile, }; function getNetworkInfoByTronWeb(tronWeb) { return __awaiter(this, void 0, void 0, function* () { var _a, _b, _c; const { blockID = '' } = yield tronWeb.trx.getBlockByNumber(0); const chainId = `0x${blockID.slice(-8)}`; return { networkType: exports.chainIdNetworkMap[chainId] || tronwallet_abstract_adapter_1.NetworkType.Unknown, chainId, fullNode: ((_a = tronWeb.fullNode) === null || _a === void 0 ? void 0 : _a.host) || '', solidityNode: ((_b = tronWeb.solidityNode) === null || _b === void 0 ? void 0 : _b.host) || '', eventServer: ((_c = tronWeb.eventServer) === null || _c === void 0 ? void 0 : _c.host) || '', }; }); } exports.TronLinkAdapterName = 'TronLink'; class TronLinkAdapter extends tronwallet_abstract_adapter_1.Adapter { // record if first connect event has emitted or not constructor(config = {}) { super(); this.name = exports.TronLinkAdapterName; this.url = 'https://www.tronlink.org/'; this.icon = ''; this._readyState = (0, tronwallet_abstract_adapter_1.isInBrowser)() ? tronwallet_abstract_adapter_1.WalletReadyState.Loading : tronwallet_abstract_adapter_1.WalletReadyState.NotFound; this._state = tronwallet_abstract_adapter_1.AdapterState.Loading; // https://github.com/tronprotocol/tips/blob/master/tip-1193.md this._supportNewTronProtocol = false; this._tronLinkMessageHandler = (e) => { var _a, _b, _c, _d, _e; const message = (_a = e.data) === null || _a === void 0 ? void 0 : _a.message; if (!message) { return; } if (message.action === 'accountsChanged') { setTimeout(() => { var _a; const preAddr = this.address || ''; if ((_a = this._wallet) === null || _a === void 0 ? void 0 : _a.ready) { const address = message.data.address; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); } else { this.setAddress(null); this.setState(tronwallet_abstract_adapter_1.AdapterState.Disconnect); } this.emit('accountsChanged', this.address || '', preAddr); if (!preAddr && this.address) { this.emit('connect', this.address); } else if (preAddr && !this.address) { this.emit('disconnect'); } }, 200); } else if (message.action === 'setNode') { this.emit('chainChanged', { chainId: ((_c = (_b = message.data) === null || _b === void 0 ? void 0 : _b.node) === null || _c === void 0 ? void 0 : _c.chainId) || '' }); } else if (message.action === 'connect') { const address = ((_e = (_d = this._wallet.tronWeb) === null || _d === void 0 ? void 0 : _d.defaultAddress) === null || _e === void 0 ? void 0 : _e.base58) || ''; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); this.emit('connect', address); } else if (message.action === 'disconnect') { this.setAddress(null); this.setState(tronwallet_abstract_adapter_1.AdapterState.Disconnect); this.emit('disconnect'); } }; this._onChainChanged = (data) => { this.emit('chainChanged', data); }; this._onAccountsChanged = () => { var _a, _b, _c; const preAddr = this.address || ''; const curAddr = (((_a = this._wallet) === null || _a === void 0 ? void 0 : _a.tronWeb) && ((_c = (_b = this._wallet) === null || _b === void 0 ? void 0 : _b.tronWeb.defaultAddress) === null || _c === void 0 ? void 0 : _c.base58)) || ''; if (!curAddr) { // change to a new address and if it's disconnected, data will be empty // tronlink will emit accountsChanged many times, only process when connected this.setAddress(null); this.setState(tronwallet_abstract_adapter_1.AdapterState.Disconnect); } else { const address = curAddr; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); } this.emit('accountsChanged', this.address || '', preAddr); if (!preAddr && this.address) { this.emit('connect', this.address); } else if (preAddr && !this.address) { this.emit('disconnect'); } }; this._checkPromise = null; this._updateWallet = () => { var _a, _b, _c, _d, _e, _f, _g, _h; let state = this.state; let address = this.address; if ((0, tronwallet_abstract_adapter_1.isInMobileBrowser)()) { if (window.tronLink) { this._wallet = window.tronLink; } else { this._wallet = { ready: !!((_a = window.tronWeb) === null || _a === void 0 ? void 0 : _a.defaultAddress), tronWeb: window.tronWeb, request: () => Promise.resolve(true), }; } address = ((_c = (_b = this._wallet.tronWeb) === null || _b === void 0 ? void 0 : _b.defaultAddress) === null || _c === void 0 ? void 0 : _c.base58) || null; state = address ? tronwallet_abstract_adapter_1.AdapterState.Connected : tronwallet_abstract_adapter_1.AdapterState.Disconnect; } else if (window.tron && window.tron.isTronLink) { this._supportNewTronProtocol = true; this._wallet = window.tron; this._listenTronEvent(); address = (this._wallet.tronWeb && ((_e = (_d = this._wallet.tronWeb) === null || _d === void 0 ? void 0 : _d.defaultAddress) === null || _e === void 0 ? void 0 : _e.base58)) || null; state = address ? tronwallet_abstract_adapter_1.AdapterState.Connected : tronwallet_abstract_adapter_1.AdapterState.Disconnect; } else if (window.tronLink) { this._wallet = window.tronLink; this._listenTronLinkEvent(); address = ((_g = (_f = this._wallet.tronWeb) === null || _f === void 0 ? void 0 : _f.defaultAddress) === null || _g === void 0 ? void 0 : _g.base58) || null; state = this._wallet.ready ? tronwallet_abstract_adapter_1.AdapterState.Connected : tronwallet_abstract_adapter_1.AdapterState.Disconnect; } else if (window.tronWeb) { // fake tronLink this._wallet = { ready: window.tronWeb.ready, tronWeb: window.tronWeb, request: () => Promise.resolve(true), }; address = ((_h = this._wallet.tronWeb.defaultAddress) === null || _h === void 0 ? void 0 : _h.base58) || null; state = this._wallet.ready ? tronwallet_abstract_adapter_1.AdapterState.Connected : tronwallet_abstract_adapter_1.AdapterState.Disconnect; } else { // no tronlink support this._wallet = null; address = null; state = tronwallet_abstract_adapter_1.AdapterState.NotFound; } // In TronLink App, account should be connected if ((0, tronwallet_abstract_adapter_1.isInMobileBrowser)() && state === tronwallet_abstract_adapter_1.AdapterState.Disconnect) { this.checkForWalletReadyForApp(); } this.setAddress(address); this.setState(state); }; this.checkReadyInterval = null; const { checkTimeout = 30 * 1000, dappIcon = '', dappName = '', openUrlWhenWalletNotFound = true, openTronLinkAppOnMobile = true, } = config; if (typeof checkTimeout !== 'number') { throw new Error('[TronLinkAdapter] config.checkTimeout should be a number'); } this.config = { checkTimeout, openTronLinkAppOnMobile, openUrlWhenWalletNotFound, dappIcon, dappName, }; this._connecting = false; this._wallet = null; this._address = null; if (!(0, tronwallet_abstract_adapter_1.isInBrowser)()) { this._readyState = tronwallet_abstract_adapter_1.WalletReadyState.NotFound; this.setState(tronwallet_abstract_adapter_1.AdapterState.NotFound); return; } if ((0, utils_js_1.supportTron)() || ((0, tronwallet_abstract_adapter_1.isInMobileBrowser)() && (window.tronLink || window.tronWeb))) { this._readyState = tronwallet_abstract_adapter_1.WalletReadyState.Found; this._updateWallet(); } else { this._checkWallet().then(() => { if (this.connected) { this.emit('connect', this.address || ''); } }); } } get address() { return this._address; } get state() { return this._state; } get readyState() { return this._readyState; } get connecting() { return this._connecting; } /** * Get network information used by TronLink. * @returns {Network} Current network information. */ network() { return __awaiter(this, void 0, void 0, function* () { var _a; try { yield this._checkWallet(); if (this.state !== tronwallet_abstract_adapter_1.AdapterState.Connected) throw new tronwallet_abstract_adapter_1.WalletDisconnectedError(); const tronWeb = ((_a = this._wallet) === null || _a === void 0 ? void 0 : _a.tronWeb) || window.tronWeb; if (!tronWeb) throw new tronwallet_abstract_adapter_1.WalletDisconnectedError(); try { return yield getNetworkInfoByTronWeb(tronWeb); } catch (e) { throw new tronwallet_abstract_adapter_1.WalletGetNetworkError(e === null || e === void 0 ? void 0 : e.message, e); } } catch (e) { this.emit('error', e); throw e; } }); } connect() { return __awaiter(this, void 0, void 0, function* () { var _a, _b; try { this.checkIfOpenTronLink(); if (this.connected || this.connecting) return; yield this._checkWallet(); if (this.state === tronwallet_abstract_adapter_1.AdapterState.NotFound) { if (this.config.openUrlWhenWalletNotFound !== false && (0, tronwallet_abstract_adapter_1.isInBrowser)()) { window.open(this.url, '_blank'); } throw new tronwallet_abstract_adapter_1.WalletNotFoundError(); } // lower version only support window.tronWeb, no window.tronLink if (!this._wallet) return; this._connecting = true; if (this._supportNewTronProtocol) { const wallet = this._wallet; try { const res = yield wallet.request({ method: 'eth_requestAccounts' }); const address = res[0]; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); this._listenTronEvent(); if (!this._wallet.tronWeb) { yield (0, utils_js_1.waitTronwebReady)(this._wallet); } } catch (error) { let message = (error === null || error === void 0 ? void 0 : error.message) || error || 'Connect TronLink wallet failed.'; if (error.code === -32002) { message = 'The same DApp has already initiated a request to connect to TronLink wallet, and the pop-up window has not been closed.'; } if (error.code === 4001) { message = 'The user rejected connection.'; } throw new tronwallet_abstract_adapter_1.WalletConnectionError(message, error); } } else if (window.tronLink) { const wallet = this._wallet; try { const res = yield wallet.request({ method: 'tron_requestAccounts' }); if (!res) { // 1. wallet is locked // 2. tronlink is first installed and there is no wallet account throw new tronwallet_abstract_adapter_1.WalletConnectionError('TronLink wallet is locked or no wallet account is avaliable.'); } if (res.code === 4000) { throw new tronwallet_abstract_adapter_1.WalletConnectionError('The same DApp has already initiated a request to connect to TronLink wallet, and the pop-up window has not been closed.'); } if (res.code === 4001) { throw new tronwallet_abstract_adapter_1.WalletConnectionError('The user rejected connection.'); } } catch (error) { throw new tronwallet_abstract_adapter_1.WalletConnectionError(error === null || error === void 0 ? void 0 : error.message, error); } const address = ((_a = wallet.tronWeb.defaultAddress) === null || _a === void 0 ? void 0 : _a.base58) || ''; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); this._listenTronLinkEvent(); } else if (window.tronWeb) { const wallet = this._wallet; const address = ((_b = wallet.tronWeb.defaultAddress) === null || _b === void 0 ? void 0 : _b.base58) || ''; this.setAddress(address); this.setState(tronwallet_abstract_adapter_1.AdapterState.Connected); } else { throw new tronwallet_abstract_adapter_1.WalletConnectionError('Cannot connect wallet.'); } this.connected && this.emit('connect', this.address || ''); } catch (error) { this.emit('error', error); throw error; } finally { this._connecting = false; }