@aptos-labs/wallet-adapter-core 7.10.1 → 8.0.0-xchaininit.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AIP62StandardWallets/WalletStandard.d.ts +44 -0
- package/dist/AIP62StandardWallets/WalletStandard.d.ts.map +1 -0
- package/dist/AIP62StandardWallets/index.d.ts +3 -0
- package/dist/AIP62StandardWallets/index.d.ts.map +1 -0
- package/dist/AIP62StandardWallets/registry.d.ts +17 -0
- package/dist/AIP62StandardWallets/registry.d.ts.map +1 -0
- package/dist/AIP62StandardWallets/sdkWallets.d.ts +4 -0
- package/dist/AIP62StandardWallets/sdkWallets.d.ts.map +1 -0
- package/dist/AIP62StandardWallets/types.d.ts +12 -0
- package/dist/AIP62StandardWallets/types.d.ts.map +1 -0
- package/dist/CrossChainCore.d.ts +28 -0
- package/dist/CrossChainCore.d.ts.map +1 -0
- package/dist/LegacyWalletPlugins/WalletCoreV1.d.ts +50 -0
- package/dist/LegacyWalletPlugins/WalletCoreV1.d.ts.map +1 -0
- package/dist/LegacyWalletPlugins/conversion.d.ts +21 -0
- package/dist/LegacyWalletPlugins/conversion.d.ts.map +1 -0
- package/dist/LegacyWalletPlugins/index.d.ts +4 -0
- package/dist/LegacyWalletPlugins/index.d.ts.map +1 -0
- package/dist/LegacyWalletPlugins/types.d.ts +116 -0
- package/dist/LegacyWalletPlugins/types.d.ts.map +1 -0
- package/dist/WalletCore.d.ts +9 -1
- package/dist/WalletCore.d.ts.map +1 -1
- package/dist/WalletCoreNew.d.ts +194 -0
- package/dist/WalletCoreNew.d.ts.map +1 -0
- package/dist/__tests__/WalletCore.test.d.ts +2 -0
- package/dist/__tests__/WalletCore.test.d.ts.map +1 -0
- package/dist/index.cjs +2376 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.mts +12 -4
- package/dist/index.js +40 -26
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +34 -24
- package/dist/index.mjs.map +1 -1
- package/dist/registry.d.ts +2 -1
- package/dist/registry.d.ts.map +1 -1
- package/dist/utils/aptosConnect.d.ts +18 -0
- package/dist/utils/aptosConnect.d.ts.map +1 -0
- package/dist/utils/crossChain/chains/mainnet/index.d.ts +45 -0
- package/dist/utils/crossChain/chains/mainnet/index.d.ts.map +1 -0
- package/dist/utils/crossChain/chains/testnet/index.d.ts +50 -0
- package/dist/utils/crossChain/chains/testnet/index.d.ts.map +1 -0
- package/dist/utils/crossChain/tokens/mainnet.d.ts +15 -0
- package/dist/utils/crossChain/tokens/mainnet.d.ts.map +1 -0
- package/dist/utils/crossChain/tokens/testnet.d.ts +11 -0
- package/dist/utils/crossChain/tokens/testnet.d.ts.map +1 -0
- package/dist/utils/logger.d.ts +6 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/scopePollingDetectionStrategy.d.ts +2 -0
- package/dist/utils/scopePollingDetectionStrategy.d.ts.map +1 -0
- package/dist/version.d.ts +1 -1
- package/package.json +2 -2
- package/src/WalletCore.ts +45 -35
- package/src/registry.ts +24 -18
- package/src/version.ts +1 -1
package/dist/index.js
CHANGED
|
@@ -410,8 +410,8 @@ __export(index_exports, {
|
|
|
410
410
|
convertNetwork: function() {
|
|
411
411
|
return convertNetwork;
|
|
412
412
|
},
|
|
413
|
-
|
|
414
|
-
return
|
|
413
|
+
evmStandardSupportedWalletList: function() {
|
|
414
|
+
return evmStandardSupportedWalletList;
|
|
415
415
|
},
|
|
416
416
|
fetchDevnetChainId: function() {
|
|
417
417
|
return fetchDevnetChainId;
|
|
@@ -476,13 +476,16 @@ __export(index_exports, {
|
|
|
476
476
|
setLocalStorage: function() {
|
|
477
477
|
return setLocalStorage;
|
|
478
478
|
},
|
|
479
|
+
solanaStandardSupportedWalletList: function() {
|
|
480
|
+
return solanaStandardSupportedWalletList;
|
|
481
|
+
},
|
|
479
482
|
truncateAddress: function() {
|
|
480
483
|
return truncateAddress;
|
|
481
484
|
}
|
|
482
485
|
});
|
|
483
486
|
module.exports = __toCommonJS(index_exports);
|
|
484
487
|
// src/version.ts
|
|
485
|
-
var WALLET_ADAPTER_CORE_VERSION = "7.10.
|
|
488
|
+
var WALLET_ADAPTER_CORE_VERSION = "7.10.2";
|
|
486
489
|
// src/WalletCore.ts
|
|
487
490
|
var import_eventemitter3 = __toESM(require("eventemitter3"));
|
|
488
491
|
var import_ts_sdk2 = require("@aptos-labs/ts-sdk");
|
|
@@ -491,7 +494,7 @@ var import_wallet_standard = require("@aptos-labs/wallet-standard");
|
|
|
491
494
|
var GA4 = /*#__PURE__*/ function() {
|
|
492
495
|
function GA4() {
|
|
493
496
|
_class_call_check(this, GA4);
|
|
494
|
-
this.aptosGAID =
|
|
497
|
+
this.aptosGAID = "G-GNVVWBL3J9";
|
|
495
498
|
this.injectGA(this.aptosGAID);
|
|
496
499
|
}
|
|
497
500
|
_create_class(GA4, [
|
|
@@ -1030,7 +1033,7 @@ var aptosStandardSupportedWalletList = [
|
|
|
1030
1033
|
isAIP62Standard: true
|
|
1031
1034
|
}
|
|
1032
1035
|
];
|
|
1033
|
-
var
|
|
1036
|
+
var solanaStandardSupportedWalletList = [
|
|
1034
1037
|
{
|
|
1035
1038
|
name: "Phantom (Solana)",
|
|
1036
1039
|
url: "https://phantom.com/",
|
|
@@ -1039,14 +1042,6 @@ var crossChainStandardSupportedWalletList = [
|
|
|
1039
1042
|
isAIP62Standard: true,
|
|
1040
1043
|
deeplinkProvider: "https://phantom.app/ul/browse/"
|
|
1041
1044
|
},
|
|
1042
|
-
{
|
|
1043
|
-
name: "Phantom (Ethereum)",
|
|
1044
|
-
url: "https://phantom.com/",
|
|
1045
|
-
icon: "",
|
|
1046
|
-
readyState: "NotDetected" /* NotDetected */ ,
|
|
1047
|
-
isAIP62Standard: true,
|
|
1048
|
-
deeplinkProvider: "https://phantom.app/ul/browse/"
|
|
1049
|
-
},
|
|
1050
1045
|
{
|
|
1051
1046
|
name: "Nightly (Solana)",
|
|
1052
1047
|
url: "https://nightly.app/",
|
|
@@ -1056,23 +1051,33 @@ var crossChainStandardSupportedWalletList = [
|
|
|
1056
1051
|
deeplinkProvider: "nightly://v1?network=aptos&url="
|
|
1057
1052
|
},
|
|
1058
1053
|
{
|
|
1059
|
-
name: "
|
|
1060
|
-
url: "https://
|
|
1061
|
-
icon: "data:image/svg+xml;base64,
|
|
1054
|
+
name: "MetaMask (Solana)",
|
|
1055
|
+
url: "https://metamask.io/",
|
|
1056
|
+
icon: "",
|
|
1062
1057
|
readyState: "NotDetected" /* NotDetected */ ,
|
|
1063
1058
|
isAIP62Standard: true,
|
|
1064
|
-
deeplinkProvider: "
|
|
1059
|
+
deeplinkProvider: "https://link.metamask.io/dapp/"
|
|
1060
|
+
}
|
|
1061
|
+
];
|
|
1062
|
+
var evmStandardSupportedWalletList = [
|
|
1063
|
+
{
|
|
1064
|
+
name: "Phantom (Ethereum)",
|
|
1065
|
+
url: "https://phantom.com/",
|
|
1066
|
+
icon: "",
|
|
1067
|
+
readyState: "NotDetected" /* NotDetected */ ,
|
|
1068
|
+
isAIP62Standard: true,
|
|
1069
|
+
deeplinkProvider: "https://phantom.app/ul/browse/"
|
|
1065
1070
|
},
|
|
1066
1071
|
{
|
|
1067
|
-
name: "
|
|
1068
|
-
url: "https://
|
|
1069
|
-
icon: "data:image/svg+xml;base64,
|
|
1072
|
+
name: "Nightly (Ethereum)",
|
|
1073
|
+
url: "https://nightly.app/",
|
|
1074
|
+
icon: "",
|
|
1070
1075
|
readyState: "NotDetected" /* NotDetected */ ,
|
|
1071
1076
|
isAIP62Standard: true,
|
|
1072
|
-
deeplinkProvider: "
|
|
1077
|
+
deeplinkProvider: "nightly://v1?network=aptos&url="
|
|
1073
1078
|
},
|
|
1074
1079
|
{
|
|
1075
|
-
name: "
|
|
1080
|
+
name: "MetaMask (Ethereum)",
|
|
1076
1081
|
url: "https://metamask.io/",
|
|
1077
1082
|
icon: "",
|
|
1078
1083
|
readyState: "NotDetected" /* NotDetected */ ,
|
|
@@ -1224,8 +1229,16 @@ var WalletCore = /*#__PURE__*/ function(_import_eventemitter3_default) {
|
|
|
1224
1229
|
key: "appendNotDetectedStandardSupportedWallets",
|
|
1225
1230
|
value: function appendNotDetectedStandardSupportedWallets() {
|
|
1226
1231
|
var _this = this;
|
|
1227
|
-
var _this__dappConfig;
|
|
1228
|
-
var walletRegistry =
|
|
1232
|
+
var _this__dappConfig_crossChainWallets, _this__dappConfig, _this__dappConfig_crossChainWallets1, _this__dappConfig1;
|
|
1233
|
+
var walletRegistry = _to_consumable_array(aptosStandardSupportedWalletList);
|
|
1234
|
+
if ((_this__dappConfig = this._dappConfig) === null || _this__dappConfig === void 0 ? void 0 : (_this__dappConfig_crossChainWallets = _this__dappConfig.crossChainWallets) === null || _this__dappConfig_crossChainWallets === void 0 ? void 0 : _this__dappConfig_crossChainWallets.solana) {
|
|
1235
|
+
var _walletRegistry;
|
|
1236
|
+
(_walletRegistry = walletRegistry).push.apply(_walletRegistry, _to_consumable_array(solanaStandardSupportedWalletList));
|
|
1237
|
+
}
|
|
1238
|
+
if ((_this__dappConfig1 = this._dappConfig) === null || _this__dappConfig1 === void 0 ? void 0 : (_this__dappConfig_crossChainWallets1 = _this__dappConfig1.crossChainWallets) === null || _this__dappConfig_crossChainWallets1 === void 0 ? void 0 : _this__dappConfig_crossChainWallets1.evm) {
|
|
1239
|
+
var _walletRegistry1;
|
|
1240
|
+
(_walletRegistry1 = walletRegistry).push.apply(_walletRegistry1, _to_consumable_array(evmStandardSupportedWalletList));
|
|
1241
|
+
}
|
|
1229
1242
|
walletRegistry.map(function(supportedWallet) {
|
|
1230
1243
|
var existingStandardWallet = _this._standard_wallets.find(function(wallet) {
|
|
1231
1244
|
return wallet.name == supportedWallet.name;
|
|
@@ -1267,7 +1280,7 @@ var WalletCore = /*#__PURE__*/ function(_import_eventemitter3_default) {
|
|
|
1267
1280
|
network: (_this__network = this._network) === null || _this__network === void 0 ? void 0 : _this__network.name,
|
|
1268
1281
|
network_url: (_this__network1 = this._network) === null || _this__network1 === void 0 ? void 0 : _this__network1.url,
|
|
1269
1282
|
adapter_core_version: WALLET_ADAPTER_CORE_VERSION,
|
|
1270
|
-
send_to:
|
|
1283
|
+
send_to: "G-GNVVWBL3J9"
|
|
1271
1284
|
}, additionalInfo));
|
|
1272
1285
|
}
|
|
1273
1286
|
},
|
|
@@ -2422,7 +2435,7 @@ if (typeof window !== "undefined") {
|
|
|
2422
2435
|
WalletReadyState: WalletReadyState,
|
|
2423
2436
|
aptosStandardSupportedWalletList: aptosStandardSupportedWalletList,
|
|
2424
2437
|
convertNetwork: convertNetwork,
|
|
2425
|
-
|
|
2438
|
+
evmStandardSupportedWalletList: evmStandardSupportedWalletList,
|
|
2426
2439
|
fetchDevnetChainId: fetchDevnetChainId,
|
|
2427
2440
|
generalizedErrorMessage: generalizedErrorMessage,
|
|
2428
2441
|
getAptosConfig: getAptosConfig,
|
|
@@ -2444,6 +2457,7 @@ if (typeof window !== "undefined") {
|
|
|
2444
2457
|
partitionWallets: partitionWallets,
|
|
2445
2458
|
removeLocalStorage: removeLocalStorage,
|
|
2446
2459
|
setLocalStorage: setLocalStorage,
|
|
2460
|
+
solanaStandardSupportedWalletList: solanaStandardSupportedWalletList,
|
|
2447
2461
|
truncateAddress: truncateAddress
|
|
2448
2462
|
});
|
|
2449
2463
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/maykon/Projects/@aptos-labs/aptos-wallet-adapter/packages/wallet-adapter-core/dist/index.js"],"names":[],"mappings":"AAAA","sourcesContent":["\"use strict\";\nvar __create = Object.create;\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __getProtoOf = Object.getPrototypeOf;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(\n // If the importer is in node compatibility mode or this is not an ESM\n // file that has been converted to a CommonJS file using a Babel-\n // compatible transform (i.e. \"__esModule\" has not been set), then set\n // \"default\" to the CommonJS \"module.exports\" for node compatibility.\n isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", { value: mod, enumerable: true }) : target,\n mod\n));\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar index_exports = {};\n__export(index_exports, {\n APTOS_CONNECT_ACCOUNT_URL: () => APTOS_CONNECT_ACCOUNT_URL,\n APTOS_CONNECT_BASE_URL: () => APTOS_CONNECT_BASE_URL,\n ChainIdToAnsSupportedNetworkMap: () => ChainIdToAnsSupportedNetworkMap,\n NetworkName: () => NetworkName,\n WalletCore: () => WalletCore,\n WalletReadyState: () => WalletReadyState,\n aptosStandardSupportedWalletList: () => aptosStandardSupportedWalletList,\n convertNetwork: () => convertNetwork,\n crossChainStandardSupportedWalletList: () => crossChainStandardSupportedWalletList,\n fetchDevnetChainId: () => fetchDevnetChainId,\n generalizedErrorMessage: () => generalizedErrorMessage,\n getAptosConfig: () => getAptosConfig,\n getAptosConnectWallets: () => getAptosConnectWallets,\n getLocalStorage: () => getLocalStorage,\n getSDKWallets: () => getSDKWallets,\n groupAndSortWallets: () => groupAndSortWallets,\n handlePublishPackageTransaction: () => handlePublishPackageTransaction,\n isAptosConnectWallet: () => isAptosConnectWallet,\n isAptosLiveNetwork: () => isAptosLiveNetwork,\n isAptosNetwork: () => isAptosNetwork,\n isInAppBrowser: () => isInAppBrowser,\n isInstallRequired: () => isInstallRequired,\n isInstalledOrLoadable: () => isInstalledOrLoadable,\n isMobile: () => isMobile,\n isRedirectable: () => isRedirectable,\n partitionWallets: () => partitionWallets,\n removeLocalStorage: () => removeLocalStorage,\n setLocalStorage: () => setLocalStorage,\n truncateAddress: () => truncateAddress\n});\nmodule.exports = __toCommonJS(index_exports);\n\n// src/version.ts\nvar WALLET_ADAPTER_CORE_VERSION = \"7.6.0\";\n\n// src/WalletCore.ts\nvar import_eventemitter3 = __toESM(require(\"eventemitter3\"));\nvar import_ts_sdk2 = require(\"@aptos-labs/ts-sdk\");\nvar import_wallet_standard = require(\"@aptos-labs/wallet-standard\");\n\n// src/ga/index.ts\nvar GA4 = class {\n constructor() {\n this.aptosGAID = true;\n this.injectGA(this.aptosGAID);\n }\n gtag(a, b, c) {\n let dataLayer = window.dataLayer || [];\n dataLayer.push(arguments);\n }\n injectGA(gaID) {\n if (typeof window === \"undefined\") return;\n if (!gaID) return;\n const head = document.getElementsByTagName(\"head\")[0];\n var myScript = document.createElement(\"script\");\n myScript.setAttribute(\n \"src\",\n `https://www.googletagmanager.com/gtag/js?id=${gaID}`\n );\n const that = this;\n myScript.onload = function() {\n that.gtag(\"js\", /* @__PURE__ */ new Date());\n that.gtag(\"config\", `${gaID}`, {\n send_page_view: false\n });\n };\n head.insertBefore(myScript, head.children[1]);\n }\n};\n\n// src/error/index.ts\nvar WalletError = class extends Error {\n constructor(message, error) {\n super(message);\n this.error = error;\n }\n};\nvar WalletNotSelectedError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNotSelectedError\";\n }\n};\nvar WalletNotReadyError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNotReadyError\";\n }\n};\nvar WalletConnectionError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletConnectionError\";\n }\n};\nvar WalletDisconnectionError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletDisconnectionError\";\n }\n};\nvar WalletAccountError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletAccountError\";\n }\n};\nvar WalletGetNetworkError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletGetNetworkError\";\n }\n};\nvar WalletAccountChangeError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletAccountChangeError\";\n }\n};\nvar WalletNetworkChangeError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNetworkChangeError\";\n }\n};\nvar WalletNotConnectedError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNotConnectedError\";\n }\n};\nvar WalletSignMessageError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletSignMessageError\";\n }\n};\nvar WalletSignMessageAndVerifyError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletSignMessageAndVerifyError\";\n }\n};\nvar WalletSignAndSubmitMessageError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletSignAndSubmitMessageError\";\n }\n};\nvar WalletSignTransactionError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletSignTransactionError\";\n }\n};\nvar WalletNotSupportedMethod = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNotSupportedMethod\";\n }\n};\nvar WalletChangeNetworkError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletChangeNetworkError\";\n }\n};\nvar WalletSubmitTransactionError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletSubmitTransactionError\";\n }\n};\nvar WalletNotFoundError = class extends WalletError {\n constructor() {\n super(...arguments);\n this.name = \"WalletNotFoundError\";\n }\n};\n\n// src/constants.ts\nvar WalletReadyState = /* @__PURE__ */ ((WalletReadyState2) => {\n WalletReadyState2[\"Installed\"] = \"Installed\";\n WalletReadyState2[\"NotDetected\"] = \"NotDetected\";\n return WalletReadyState2;\n})(WalletReadyState || {});\nvar NetworkName = /* @__PURE__ */ ((NetworkName2) => {\n NetworkName2[\"Mainnet\"] = \"mainnet\";\n NetworkName2[\"Testnet\"] = \"testnet\";\n NetworkName2[\"Devnet\"] = \"devnet\";\n return NetworkName2;\n})(NetworkName || {});\nvar ChainIdToAnsSupportedNetworkMap = {\n \"1\": \"mainnet\",\n // mainnet\n \"2\": \"testnet\"\n // testnet\n};\nvar APTOS_CONNECT_BASE_URL = \"https://aptosconnect.app\";\nvar APTOS_CONNECT_ACCOUNT_URL = \"https://aptosconnect.app/dashboard/main-account\";\n\n// src/utils/helpers.ts\nvar import_ts_sdk = require(\"@aptos-labs/ts-sdk\");\nfunction isMobile() {\n return /Mobile|iP(hone|od|ad)|Android|BlackBerry|IEMobile|Kindle|NetFront|Silk-Accelerated|(hpw|web)OS|Fennec|Minimo|Opera M(obi|ini)|Blazer|Dolfin|Dolphin|Skyfire|Zune/i.test(\n navigator.userAgent\n );\n}\nfunction isInAppBrowser() {\n const isIphone = /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(\n navigator.userAgent\n );\n const isAndroid = /(Android).*Version\\/[\\d.]+.*Chrome\\/[^\\s]+ Mobile/i.test(\n navigator.userAgent\n );\n return isIphone || isAndroid;\n}\nfunction isRedirectable() {\n if (typeof navigator === \"undefined\" || !navigator) return false;\n return isMobile() && !isInAppBrowser();\n}\nfunction generalizedErrorMessage(error) {\n return typeof error === \"object\" && \"message\" in error ? error.message : error;\n}\nvar getAptosConfig = (networkInfo, dappConfig) => {\n if (!networkInfo) {\n throw new Error(\"Undefined network\");\n }\n const pluginSettings = {\n TRANSACTION_SUBMITTER: dappConfig?.transactionSubmitter\n };\n if (isAptosNetwork(networkInfo)) {\n const currentNetwork = convertNetwork(networkInfo);\n if (isAptosLiveNetwork(currentNetwork)) {\n const apiKey = dappConfig?.aptosApiKeys;\n return new import_ts_sdk.AptosConfig({\n network: currentNetwork,\n clientConfig: { API_KEY: apiKey ? apiKey[currentNetwork] : void 0 },\n pluginSettings\n });\n }\n return new import_ts_sdk.AptosConfig({\n network: currentNetwork,\n pluginSettings\n });\n }\n const knownNetworks = {\n okx: \"https://wallet.okx.com/fullnode/aptos/discover/rpc\"\n };\n if (networkInfo.url) {\n const isKnownNetwork = Object.values(knownNetworks).includes(\n networkInfo.url\n );\n if (isKnownNetwork) {\n return new import_ts_sdk.AptosConfig({\n network: import_ts_sdk.Network.CUSTOM,\n fullnode: networkInfo.url,\n pluginSettings\n });\n }\n }\n throw new Error(\n `Invalid network, network ${networkInfo.name} not supported with Aptos wallet adapter to prevent user from using an unexpected network.`\n );\n};\nvar isAptosNetwork = (networkInfo) => {\n if (!networkInfo) {\n throw new Error(\"Undefined network\");\n }\n return import_ts_sdk.NetworkToNodeAPI[networkInfo.name] !== void 0;\n};\nvar isAptosLiveNetwork = (networkInfo) => {\n return networkInfo === \"devnet\" || networkInfo === \"testnet\" || networkInfo === \"mainnet\";\n};\nvar fetchDevnetChainId = async () => {\n const aptos = new import_ts_sdk.Aptos();\n return await aptos.getChainId();\n};\nvar handlePublishPackageTransaction = (transactionInput) => {\n let metadataBytes = transactionInput.data.functionArguments[0];\n if (typeof metadataBytes === \"string\") {\n metadataBytes = import_ts_sdk.Hex.fromHexInput(metadataBytes).toUint8Array();\n }\n let byteCode = transactionInput.data.functionArguments[1];\n if (Array.isArray(byteCode)) {\n byteCode = byteCode.map((byte) => {\n if (typeof byte === \"string\") {\n return import_ts_sdk.Hex.fromHexInput(byte).toUint8Array();\n }\n return byte;\n });\n } else {\n throw new WalletSignAndSubmitMessageError(\n \"The bytecode argument must be an array.\"\n ).message;\n }\n return { metadataBytes, byteCode };\n};\nfunction convertNetwork(networkInfo) {\n switch (networkInfo?.name) {\n case \"mainnet\":\n return import_ts_sdk.Network.MAINNET;\n case \"testnet\":\n return import_ts_sdk.Network.TESTNET;\n case \"devnet\":\n return import_ts_sdk.Network.DEVNET;\n case \"local\":\n return import_ts_sdk.Network.LOCAL;\n default:\n throw new Error(\"Invalid Aptos network name\");\n }\n}\n\n// src/utils/localStorage.ts\nvar LOCAL_STORAGE_ITEM_KEY = \"AptosWalletName\";\nfunction setLocalStorage(walletName) {\n localStorage.setItem(LOCAL_STORAGE_ITEM_KEY, walletName);\n}\nfunction removeLocalStorage() {\n localStorage.removeItem(LOCAL_STORAGE_ITEM_KEY);\n}\nfunction getLocalStorage() {\n localStorage.getItem(LOCAL_STORAGE_ITEM_KEY);\n}\n\n// src/utils/walletSelector.ts\nfunction partitionWallets(wallets, partitionFunction = isInstalledOrLoadable) {\n const defaultWallets = [];\n const moreWallets = [];\n for (const wallet of wallets) {\n if (partitionFunction(wallet)) defaultWallets.push(wallet);\n else moreWallets.push(wallet);\n }\n return { defaultWallets, moreWallets };\n}\nfunction isInstalledOrLoadable(wallet) {\n return wallet.readyState === \"Installed\" /* Installed */;\n}\nfunction isInstallRequired(wallet) {\n const isWalletReady = isInstalledOrLoadable(wallet);\n const isMobile2 = !isWalletReady && isRedirectable();\n return !isMobile2 && !isWalletReady;\n}\nfunction truncateAddress(address) {\n if (!address) return;\n return `${address.slice(0, 6)}...${address.slice(-5)}`;\n}\nfunction isAptosConnectWallet(wallet) {\n if (!wallet.url) return false;\n return wallet.url.startsWith(APTOS_CONNECT_BASE_URL);\n}\nfunction getAptosConnectWallets(wallets) {\n const { defaultWallets, moreWallets } = partitionWallets(\n wallets,\n isAptosConnectWallet\n );\n return { aptosConnectWallets: defaultWallets, otherWallets: moreWallets };\n}\nfunction groupAndSortWallets(wallets, options) {\n const { aptosConnectWallets, otherWallets } = getAptosConnectWallets(wallets);\n const { defaultWallets, moreWallets } = partitionWallets(otherWallets);\n if (options?.sortAptosConnectWallets) {\n aptosConnectWallets.sort(options.sortAptosConnectWallets);\n }\n if (options?.sortAvailableWallets) {\n defaultWallets.sort(options.sortAvailableWallets);\n }\n if (options?.sortInstallableWallets) {\n moreWallets.sort(options.sortInstallableWallets);\n }\n return {\n /** Wallets that use social login to create an account on the blockchain */\n aptosConnectWallets,\n /** Wallets that are currently installed or loadable. */\n availableWallets: defaultWallets,\n /** Wallets that are NOT currently installed or loadable. */\n installableWallets: moreWallets\n };\n}\n\n// src/registry.ts\nvar aptosStandardSupportedWalletList = [\n {\n name: \"OKX Wallet\",\n url: \"https://chromewebstore.google.com/detail/okx-wallet/mcohilncbfahbmgdjkbpemcciiolgcge\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true\n },\n {\n name: \"Petra\",\n url: \"https://chromewebstore.google.com/detail/petra-aptos-wallet/ejjladinnckdgjemekebdpeokbikhfci?hl=en\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: \"https://petra.app/explore?link=\"\n },\n {\n name: \"Nightly\",\n url: \"https://nightly.app/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: \"nightly://v1?network=aptos&url=\"\n },\n {\n name: \"Pontem Wallet\",\n url: \"https://pontem.network/pontem-wallet\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true\n },\n {\n name: \"Backpack\",\n url: \"https://chromewebstore.google.com/detail/backpack/aflkmfhebedbjioipglgcbcmnbpgliof\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: \"https://backpack.app/ul/v1?url=\"\n },\n {\n name: \"Bitget Wallet\",\n url: \"https://web3.bitget.com\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true\n },\n {\n name: \"Gate Wallet\",\n url: \"https://www.gate.com/zh/web3/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true\n }\n];\nvar crossChainStandardSupportedWalletList = [\n {\n name: \"Phantom (Solana)\",\n url: \"https://phantom.com/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: `https://phantom.app/ul/browse/`\n },\n {\n name: \"Phantom (Ethereum)\",\n url: \"https://phantom.com/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: `https://phantom.app/ul/browse/`\n },\n {\n name: \"Nightly (Solana)\",\n url: \"https://nightly.app/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: \"nightly://v1?network=aptos&url=\"\n },\n {\n name: \"Nightly (Ethereum)\",\n url: \"https://nightly.app/\",\n icon: \"\",\n readyState: \"NotDetected\" /* NotDetected */,\n isAIP62Standard: true,\n deeplinkProvider: \"nightly://v1?network=aptos&url=\"\n }\n];\n\n// src/sdkWallets.ts\nvar import_wallet_adapter_plugin = require(\"@aptos-connect/wallet-adapter-plugin\");\nfunction getSDKWallets(dappConfig) {\n const sdkWallets = [];\n if (typeof window !== \"undefined\") {\n sdkWallets.push(\n new import_wallet_adapter_plugin.AptosConnectGoogleWallet({\n network: dappConfig?.network,\n dappId: dappConfig?.aptosConnectDappId,\n ...dappConfig?.aptosConnect\n }),\n new import_wallet_adapter_plugin.AptosConnectAppleWallet({\n network: dappConfig?.network,\n dappId: dappConfig?.aptosConnectDappId,\n ...dappConfig?.aptosConnect\n })\n );\n }\n return sdkWallets;\n}\n\n// src/WalletCore.ts\nvar WalletCore = class extends import_eventemitter3.default {\n constructor(optInWallets, dappConfig, disableTelemetry) {\n super();\n // Local private variable to hold the wallet that is currently connected\n this._wallet = null;\n // Local private variable to hold SDK wallets in the adapter\n this._sdkWallets = [];\n // Local array that holds all the wallets that are AIP-62 standard compatible\n this._standard_wallets = [];\n // Local array that holds all the wallets that are AIP-62 standard compatible but are not installed on the user machine\n this._standard_not_detected_wallets = [];\n // Local private variable to hold the network that is currently connected\n this._network = null;\n // Local private variable to hold the wallet connected state\n this._connected = false;\n // Local private variable to hold the connecting state\n this._connecting = false;\n // Local private variable to hold the account that is currently connected\n this._account = null;\n // Private array that holds all the Wallets a dapp decided to opt-in to\n this._optInWallets = [];\n // Local flag to disable the adapter telemetry tool\n this._disableTelemetry = false;\n // Google Analytics 4 module\n this.ga4 = null;\n this._optInWallets = optInWallets || [];\n this._dappConfig = dappConfig;\n this._disableTelemetry = disableTelemetry ?? false;\n this._sdkWallets = getSDKWallets(this._dappConfig);\n if (!this._disableTelemetry) {\n this.ga4 = new GA4();\n }\n this.fetchExtensionAIP62AptosWallets();\n this.fetchSDKAIP62AptosWallets();\n this.appendNotDetectedStandardSupportedWallets();\n }\n fetchExtensionAIP62AptosWallets() {\n let { aptosWallets, on } = (0, import_wallet_standard.getAptosWallets)();\n this.setExtensionAIP62Wallets(aptosWallets);\n if (typeof window === \"undefined\") return;\n const that = this;\n const removeRegisterListener = on(\"register\", function() {\n let { aptosWallets: aptosWallets2 } = (0, import_wallet_standard.getAptosWallets)();\n that.setExtensionAIP62Wallets(aptosWallets2);\n });\n const removeUnregisterListener = on(\"unregister\", function() {\n let { aptosWallets: aptosWallets2 } = (0, import_wallet_standard.getAptosWallets)();\n that.setExtensionAIP62Wallets(aptosWallets2);\n });\n }\n /**\n * Set AIP-62 extension wallets\n *\n * @param extensionwWallets\n */\n setExtensionAIP62Wallets(extensionwWallets) {\n extensionwWallets.map((wallet) => {\n if (this.excludeWallet(wallet)) {\n return;\n }\n if (wallet.name === \"Rimosafe\") {\n return;\n }\n const isValid = (0, import_wallet_standard.isWalletWithRequiredFeatureSet)(wallet);\n if (isValid) {\n const index = this._standard_not_detected_wallets.findIndex(\n (notDetctedWallet) => notDetctedWallet.name == wallet.name\n );\n if (index !== -1) {\n this._standard_not_detected_wallets.splice(index, 1);\n }\n const alreadyExists = this._standard_wallets.some(\n (w) => w.name === wallet.name\n );\n if (!alreadyExists) {\n wallet.readyState = \"Installed\" /* Installed */;\n wallet.isAptosNativeWallet = this.isAptosNativeWallet(wallet);\n this._standard_wallets.push(wallet);\n this.emit(\"standardWalletsAdded\", wallet);\n }\n }\n });\n }\n /**\n * Set AIP-62 SDK wallets\n */\n fetchSDKAIP62AptosWallets() {\n this._sdkWallets.map((wallet) => {\n if (this.excludeWallet(wallet)) {\n return;\n }\n const isValid = (0, import_wallet_standard.isWalletWithRequiredFeatureSet)(wallet);\n if (isValid) {\n wallet.readyState = \"Installed\" /* Installed */;\n wallet.isAptosNativeWallet = this.isAptosNativeWallet(wallet);\n this._standard_wallets.push(wallet);\n }\n });\n }\n // Aptos native wallets do not have an authenticationFunction property\n isAptosNativeWallet(wallet) {\n return !(\"authenticationFunction\" in wallet);\n }\n // Since we can't discover AIP-62 wallets that are not installed on the user machine,\n // we hold a AIP-62 wallets registry to show on the wallet selector modal for the users.\n // Append wallets from wallet standard support registry to the `_standard_not_detected_wallets` array\n // when wallet is not installed on the user machine\n appendNotDetectedStandardSupportedWallets() {\n const walletRegistry = this._dappConfig?.crossChainWallets ? [\n ...aptosStandardSupportedWalletList,\n ...crossChainStandardSupportedWalletList\n ] : aptosStandardSupportedWalletList;\n walletRegistry.map((supportedWallet) => {\n const existingStandardWallet = this._standard_wallets.find(\n (wallet) => wallet.name == supportedWallet.name\n );\n if (existingStandardWallet) {\n return;\n }\n if (this.excludeWallet(supportedWallet)) {\n return;\n }\n if (!existingStandardWallet) {\n supportedWallet.isAptosNativeWallet = !(\"authenticationFunction\" in supportedWallet);\n this._standard_not_detected_wallets.push(supportedWallet);\n this.emit(\"standardNotDetectedWalletAdded\", supportedWallet);\n }\n });\n }\n /**\n * A function that excludes an AIP-62 compatible wallet the dapp doesnt want to include\n *\n * @param wallet AdapterWallet | AdapterNotDetectedWallet\n * @returns boolean\n */\n excludeWallet(wallet) {\n if (this._optInWallets.length > 0 && !this._optInWallets.includes(wallet.name)) {\n return true;\n }\n return false;\n }\n recordEvent(eventName, additionalInfo) {\n this.ga4?.gtag(\"event\", `wallet_adapter_${eventName}`, {\n wallet: this._wallet?.name,\n network: this._network?.name,\n network_url: this._network?.url,\n adapter_core_version: WALLET_ADAPTER_CORE_VERSION,\n send_to: true,\n ...additionalInfo\n });\n }\n /**\n * Helper function to ensure wallet exists\n *\n * @param wallet A wallet\n */\n ensureWalletExists(wallet) {\n if (!wallet) {\n throw new WalletNotConnectedError().name;\n }\n if (!(wallet.readyState === \"Installed\" /* Installed */))\n throw new WalletNotReadyError(\"Wallet is not set\").name;\n }\n /**\n * Helper function to ensure account exists\n *\n * @param account An account\n */\n ensureAccountExists(account) {\n if (!account) {\n throw new WalletAccountError(\"Account is not set\").name;\n }\n }\n /**\n * Queries and sets ANS name for the current connected wallet account\n */\n async setAnsName() {\n if (this._network?.chainId && this._account) {\n if (this._account.ansName) return;\n if (!ChainIdToAnsSupportedNetworkMap[this._network.chainId] || !isAptosNetwork(this._network)) {\n this._account.ansName = void 0;\n return;\n }\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new import_ts_sdk2.Aptos(aptosConfig);\n try {\n const name = await aptos.ans.getPrimaryName({\n address: this._account.address.toString()\n });\n this._account.ansName = name;\n } catch (error) {\n console.log(`Error setting ANS name ${error}`);\n }\n }\n }\n /**\n * Function to cleat wallet adapter data.\n *\n * - Removes current connected wallet state\n * - Removes current connected account state\n * - Removes current connected network state\n * - Removes autoconnect local storage value\n */\n clearData() {\n this._connected = false;\n this.setWallet(null);\n this.setAccount(null);\n this.setNetwork(null);\n removeLocalStorage();\n }\n /**\n * Sets the connected wallet\n *\n * @param wallet A wallet\n */\n setWallet(wallet) {\n this._wallet = wallet;\n }\n /**\n * Sets the connected account\n *\n * @param account An account\n */\n setAccount(account) {\n this._account = account;\n }\n /**\n * Sets the connected network\n *\n * @param network A network\n */\n setNetwork(network) {\n this._network = network;\n }\n /**\n * Helper function to detect whether a wallet is connected\n *\n * @returns boolean\n */\n isConnected() {\n return this._connected;\n }\n /**\n * Getter to fetch all detected wallets\n */\n get wallets() {\n return this._standard_wallets;\n }\n get notDetectedWallets() {\n return this._standard_not_detected_wallets;\n }\n /**\n * Getter for the current connected wallet\n *\n * @return wallet info\n * @throws WalletNotSelectedError\n */\n get wallet() {\n try {\n if (!this._wallet) return null;\n return this._wallet;\n } catch (error) {\n throw new WalletNotSelectedError(error).message;\n }\n }\n /**\n * Getter for the current connected account\n *\n * @return account info\n * @throws WalletAccountError\n */\n get account() {\n try {\n return this._account;\n } catch (error) {\n throw new WalletAccountError(error).message;\n }\n }\n /**\n * Getter for the current wallet network\n *\n * @return network info\n * @throws WalletGetNetworkError\n */\n get network() {\n try {\n return this._network;\n } catch (error) {\n throw new WalletGetNetworkError(error).message;\n }\n }\n /**\n * Helper function to run some checks before we connect with a wallet.\n *\n * @param walletName. The wallet name we want to connect with.\n */\n async connect(walletName) {\n if (isRedirectable()) {\n const selectedWallet2 = this._standard_not_detected_wallets.find(\n (wallet) => wallet.name === walletName\n );\n if (selectedWallet2) {\n const uninstalledWallet = selectedWallet2;\n if (uninstalledWallet.deeplinkProvider) {\n let parameter = \"\";\n if (uninstalledWallet.name.includes(\"Phantom\")) {\n let url = encodeURIComponent(window.location.href);\n let ref = encodeURIComponent(window.location.origin);\n parameter = `${url}?ref=${ref}`;\n } else {\n parameter = encodeURIComponent(window.location.href);\n }\n const location = uninstalledWallet.deeplinkProvider.concat(parameter);\n window.location.href = location;\n return;\n }\n }\n }\n const allDetectedWallets = this._standard_wallets;\n const selectedWallet = allDetectedWallets.find(\n (wallet) => wallet.name === walletName\n );\n if (!selectedWallet) return;\n if (this._connected && this._account) {\n if (this._wallet?.name === walletName)\n throw new WalletConnectionError(\n `${walletName} wallet is already connected`\n ).message;\n }\n await this.connectWallet(selectedWallet, async () => {\n const response = await selectedWallet.features[\"aptos:connect\"].connect();\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return { account: response.args, output: void 0 };\n });\n }\n /**\n * Signs into the wallet by connecting and signing an authentication messages.\n *\n * For more information, visit: https://siwa.aptos.dev\n *\n * @param args\n * @param args.input The AptosSignInInput which defines how the SIWA Message should be constructed\n * @param args.walletName The name of the wallet to sign into\n * @returns The AptosSignInOutput which contains the account and signature information\n */\n async signIn(args) {\n const { input, walletName } = args;\n const allDetectedWallets = this._standard_wallets;\n const selectedWallet = allDetectedWallets.find(\n (wallet) => wallet.name === walletName\n );\n if (!selectedWallet) {\n throw new WalletNotFoundError(`Wallet ${walletName} not found`).message;\n }\n if (!selectedWallet.features[\"aptos:signIn\"]) {\n throw new WalletNotSupportedMethod(\n `aptos:signIn is not supported by ${walletName}`\n ).message;\n }\n return await this.connectWallet(selectedWallet, async () => {\n if (!selectedWallet.features[\"aptos:signIn\"]) {\n throw new WalletNotSupportedMethod(\n `aptos:signIn is not supported by ${selectedWallet.name}`\n ).message;\n }\n const response = await selectedWallet.features[\"aptos:signIn\"].signIn(input);\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return { account: response.args.account, output: response.args };\n });\n }\n /**\n * Connects a wallet to the dapp.\n * On connect success, we set the current account and the network, and keeping the selected wallet\n * name in LocalStorage to support autoConnect function.\n *\n * @param selectedWallet. The wallet we want to connect.\n * @emit emits \"connect\" event\n * @throws WalletConnectionError\n */\n async connectWallet(selectedWallet, onConnect) {\n try {\n this._connecting = true;\n this.setWallet(selectedWallet);\n const { account, output } = await onConnect();\n this.setAccount(account);\n const network = await selectedWallet.features[\"aptos:network\"].network();\n this.setNetwork(network);\n await this.setAnsName();\n setLocalStorage(selectedWallet.name);\n this._connected = true;\n this.recordEvent(\"wallet_connect\");\n this.emit(\"connect\", account);\n return output;\n } catch (error) {\n this.clearData();\n const errMsg = generalizedErrorMessage(error);\n throw new WalletConnectionError(errMsg).message;\n } finally {\n this._connecting = false;\n }\n }\n /**\n * Disconnect the current connected wallet. On success, we clear the\n * current account, current network and LocalStorage data.\n *\n * @emit emits \"disconnect\" event\n * @throws WalletDisconnectionError\n */\n async disconnect() {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:disconnect\"].disconnect();\n this.clearData();\n this.recordEvent(\"wallet_disconnect\");\n this.emit(\"disconnect\");\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletDisconnectionError(errMsg).message;\n }\n }\n /**\n * Signs and submits a transaction to chain\n *\n * @param transactionInput InputTransactionData\n * @returns AptosSignAndSubmitTransactionOutput\n */\n async signAndSubmitTransaction(transactionInput) {\n try {\n if (\"function\" in transactionInput.data) {\n if (transactionInput.data.function === \"0x1::account::rotate_authentication_key_call\") {\n throw new WalletSignAndSubmitMessageError(\"SCAM SITE DETECTED\").message;\n }\n if (transactionInput.data.function === \"0x1::code::publish_package_txn\") {\n ({\n metadataBytes: transactionInput.data.functionArguments[0],\n byteCode: transactionInput.data.functionArguments[1]\n } = handlePublishPackageTransaction(transactionInput));\n }\n }\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_and_submit_transaction\");\n const shouldUseTxnSubmitter = !!(this._dappConfig?.transactionSubmitter || transactionInput.transactionSubmitter);\n if (this._wallet.features[\"aptos:signAndSubmitTransaction\"] && !shouldUseTxnSubmitter) {\n if (this._wallet.features[\"aptos:signAndSubmitTransaction\"].version !== \"1.1.0\") {\n const aptosConfig2 = getAptosConfig(this._network, this._dappConfig);\n const aptos2 = new import_ts_sdk2.Aptos(aptosConfig2);\n const transaction2 = await aptos2.transaction.build.simple({\n sender: this._account.address.toString(),\n data: transactionInput.data,\n options: transactionInput.options\n });\n const signAndSubmitTransactionMethod = this._wallet.features[\"aptos:signAndSubmitTransaction\"].signAndSubmitTransaction;\n const response3 = await signAndSubmitTransactionMethod(\n transaction2\n );\n if (response3.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return response3.args;\n }\n const response2 = await this._wallet.features[\"aptos:signAndSubmitTransaction\"].signAndSubmitTransaction({\n payload: transactionInput.data,\n gasUnitPrice: transactionInput.options?.gasUnitPrice,\n maxGasAmount: transactionInput.options?.maxGasAmount\n });\n if (response2.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return response2.args;\n }\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new import_ts_sdk2.Aptos(aptosConfig);\n const transaction = await aptos.transaction.build.simple({\n sender: this._account.address.toString(),\n data: transactionInput.data,\n options: transactionInput.options,\n withFeePayer: shouldUseTxnSubmitter\n });\n const signTransactionResponse = await this.signTransaction({\n transactionOrPayload: transaction\n });\n const response = await this.submitTransaction({\n transaction,\n senderAuthenticator: signTransactionResponse.authenticator,\n transactionSubmitter: transactionInput.transactionSubmitter,\n pluginParams: transactionInput.pluginParams\n });\n return { hash: response.hash };\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignAndSubmitMessageError(errMsg).message;\n }\n }\n /**\n * Signs a transaction\n *\n * This method supports 2 input types -\n * 1. A raw transaction that was already built by the dapp,\n * 2. A transaction data input as JSON. This is for the wallet to be able to simulate before signing\n *\n * @param transactionOrPayload AnyRawTransaction | InputTransactionData\n * @param asFeePayer optional. A flag indicates to sign the transaction as the fee payer\n * @param options optional. Transaction options\n *\n * @returns AccountAuthenticator\n */\n async signTransaction(args) {\n const { transactionOrPayload, asFeePayer } = args;\n try {\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_transaction\");\n if (\"rawTransaction\" in transactionOrPayload) {\n const response = await this._wallet?.features[\"aptos:signTransaction\"].signTransaction(\n transactionOrPayload,\n asFeePayer\n );\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return {\n authenticator: response.args,\n rawTransaction: transactionOrPayload.rawTransaction.bcsToBytes()\n };\n } else if (this._wallet.features[\"aptos:signTransaction\"]?.version === \"1.1.0\") {\n const signTransactionV1_1StandardInput = {\n payload: transactionOrPayload.data,\n expirationTimestamp: transactionOrPayload.options?.expirationTimestamp,\n expirationSecondsFromNow: transactionOrPayload.options?.expirationSecondsFromNow,\n gasUnitPrice: transactionOrPayload.options?.gasUnitPrice,\n maxGasAmount: transactionOrPayload.options?.maxGasAmount,\n sequenceNumber: transactionOrPayload.options?.accountSequenceNumber,\n sender: transactionOrPayload.sender ? { address: import_ts_sdk2.AccountAddress.from(transactionOrPayload.sender) } : void 0\n };\n const walletSignTransactionMethod = this._wallet?.features[\"aptos:signTransaction\"].signTransaction;\n const response = await walletSignTransactionMethod(\n signTransactionV1_1StandardInput\n );\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return {\n authenticator: response.args.authenticator,\n rawTransaction: response.args.rawTransaction.bcsToBytes()\n };\n } else {\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new import_ts_sdk2.Aptos(aptosConfig);\n const transaction = await aptos.transaction.build.simple({\n sender: this._account.address,\n data: transactionOrPayload.data,\n options: transactionOrPayload.options,\n withFeePayer: transactionOrPayload.withFeePayer\n });\n const response = await this._wallet?.features[\"aptos:signTransaction\"].signTransaction(\n transaction,\n asFeePayer\n );\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return {\n authenticator: response.args,\n rawTransaction: transaction.bcsToBytes()\n };\n }\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignTransactionError(errMsg).message;\n }\n }\n /**\n * Sign a message (doesnt submit to chain).\n *\n * @param message - AptosSignMessageInput\n *\n * @return response from the wallet's signMessage function\n * @throws WalletSignMessageError\n */\n async signMessage(message) {\n try {\n this.ensureWalletExists(this._wallet);\n this.recordEvent(\"sign_message\");\n const response = await this._wallet?.features[\"aptos:signMessage\"]?.signMessage(message);\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return response.args;\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignMessageError(errMsg).message;\n }\n }\n /**\n * Submits transaction to chain\n *\n * @param transaction - InputSubmitTransactionData\n * @returns PendingTransactionResponse\n */\n async submitTransaction(transaction) {\n try {\n this.ensureWalletExists(this._wallet);\n const { additionalSignersAuthenticators } = transaction;\n const transactionType = additionalSignersAuthenticators !== void 0 ? \"multi-agent\" : \"simple\";\n this.recordEvent(\"submit_transaction\", {\n transaction_type: transactionType\n });\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new import_ts_sdk2.Aptos(aptosConfig);\n if (additionalSignersAuthenticators !== void 0) {\n const multiAgentTxn = {\n ...transaction,\n additionalSignersAuthenticators\n };\n return aptos.transaction.submit.multiAgent(multiAgentTxn);\n } else {\n return aptos.transaction.submit.simple(transaction);\n }\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSubmitTransactionError(errMsg).message;\n }\n }\n /**\n Event for when account has changed on the wallet\n @return the new account info\n @throws WalletAccountChangeError\n */\n async onAccountChange() {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:onAccountChange\"]?.onAccountChange(\n async (data) => {\n this.setAccount(data);\n await this.setAnsName();\n this.recordEvent(\"account_change\");\n this.emit(\"accountChange\", this._account);\n }\n );\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletAccountChangeError(errMsg).message;\n }\n }\n /**\n Event for when network has changed on the wallet\n @return the new network info\n @throws WalletNetworkChangeError\n */\n async onNetworkChange() {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:onNetworkChange\"]?.onNetworkChange(\n async (data) => {\n this.setNetwork(data);\n await this.setAnsName();\n this.emit(\"networkChange\", this._network);\n }\n );\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletNetworkChangeError(errMsg).message;\n }\n }\n /**\n * Sends a change network request to the wallet to change the connected network\n *\n * @param network - Network\n * @returns AptosChangeNetworkOutput\n */\n async changeNetwork(network) {\n try {\n this.ensureWalletExists(this._wallet);\n this.recordEvent(\"change_network_request\", {\n from: this._network?.name,\n to: network\n });\n const chainId = network === import_ts_sdk2.Network.DEVNET ? await fetchDevnetChainId() : import_ts_sdk2.NetworkToChainId[network];\n const networkInfo = {\n name: network,\n chainId\n };\n if (this._wallet.features[\"aptos:changeNetwork\"]) {\n const response = await this._wallet.features[\"aptos:changeNetwork\"].changeNetwork(\n networkInfo\n );\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\").message;\n }\n return response.args;\n }\n throw new WalletChangeNetworkError(\n `${this._wallet.name} does not support changing network request`\n ).message;\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletChangeNetworkError(errMsg).message;\n }\n }\n /**\n * Signs a message and verifies the signer\n * @param message - AptosSignMessageInput\n * @returns boolean\n */\n async signMessageAndVerify(message) {\n try {\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_message_and_verify\");\n const response = await this._wallet.features[\"aptos:signMessage\"].signMessage(message);\n if (response.status === import_wallet_standard.UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"Failed to sign a message\").message;\n }\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const signingMessage = new TextEncoder().encode(\n response.args.fullMessage\n );\n if (\"verifySignatureAsync\" in this._account.publicKey) {\n return await this._account.publicKey.verifySignatureAsync({\n aptosConfig,\n message: signingMessage,\n signature: response.args.signature,\n options: { throwErrorWithReason: true }\n });\n }\n return this._account.publicKey.verifySignature({\n message: signingMessage,\n signature: response.args.signature\n });\n } catch (error) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignMessageAndVerifyError(errMsg).message;\n }\n }\n};\n\n// src/index.ts\nif (typeof window !== \"undefined\") {\n window.WALLET_ADAPTER_CORE_VERSION = WALLET_ADAPTER_CORE_VERSION;\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n APTOS_CONNECT_ACCOUNT_URL,\n APTOS_CONNECT_BASE_URL,\n ChainIdToAnsSupportedNetworkMap,\n NetworkName,\n WalletCore,\n WalletReadyState,\n aptosStandardSupportedWalletList,\n convertNetwork,\n crossChainStandardSupportedWalletList,\n fetchDevnetChainId,\n generalizedErrorMessage,\n getAptosConfig,\n getAptosConnectWallets,\n getLocalStorage,\n getSDKWallets,\n groupAndSortWallets,\n handlePublishPackageTransaction,\n isAptosConnectWallet,\n isAptosLiveNetwork,\n isAptosNetwork,\n isInAppBrowser,\n isInstallRequired,\n isInstalledOrLoadable,\n isMobile,\n isRedirectable,\n partitionWallets,\n removeLocalStorage,\n setLocalStorage,\n truncateAddress\n});\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/WalletCore.ts","../src/ga/index.ts","../src/version.ts","../src/error/index.ts"],"names":[],"mappings":"","sourcesContent":["import { AptosSignInBoundFields } from \"@aptos-labs/wallet-standard\";\nimport { WALLET_ADAPTER_CORE_VERSION } from \"./version\";\n\nexport type {\n AptosSignInOutput,\n AptosSignInInput,\n AptosSignInBoundFields,\n} from \"@aptos-labs/wallet-standard\";\n/**\n * @deprecated Use `AptosSignInBoundFields` instead. This will be removed in future versions.\n */\nexport type AptosSignInRequiredFields = AptosSignInBoundFields;\n\nexport * from \"./WalletCore\";\nexport * from \"./constants\";\nexport * from \"./utils\";\nexport * from \"./sdkWallets\";\nexport * from \"./registry\";\n\n// inject adapter core version to the window\nif (typeof window !== \"undefined\") {\n (window as any).WALLET_ADAPTER_CORE_VERSION = WALLET_ADAPTER_CORE_VERSION;\n}\n","import EventEmitter from \"eventemitter3\";\nimport {\n AccountAddress,\n AccountAuthenticator,\n AnyRawTransaction,\n Aptos,\n InputSubmitTransactionData,\n Network,\n NetworkToChainId,\n PendingTransactionResponse,\n TransactionSubmitter,\n} from \"@aptos-labs/ts-sdk\";\nimport {\n AptosWallet,\n getAptosWallets,\n isWalletWithRequiredFeatureSet,\n UserResponseStatus,\n AptosSignAndSubmitTransactionOutput,\n UserResponse,\n AptosSignTransactionOutputV1_1,\n AptosSignTransactionInputV1_1,\n AptosSignTransactionMethod,\n AptosSignTransactionMethodV1_1,\n NetworkInfo,\n AccountInfo,\n AptosSignMessageInput,\n AptosSignMessageOutput,\n AptosChangeNetworkOutput,\n AptosSignInInput,\n AptosSignInOutput,\n} from \"@aptos-labs/wallet-standard\";\nimport { AptosConnectWalletConfig } from \"@aptos-connect/wallet-adapter-plugin\";\n\nexport type {\n NetworkInfo,\n AccountInfo,\n AptosSignAndSubmitTransactionOutput,\n AptosSignTransactionOutputV1_1,\n AptosSignMessageInput,\n AptosSignMessageOutput,\n AptosChangeNetworkOutput,\n} from \"@aptos-labs/wallet-standard\";\nexport type {\n AccountAuthenticator,\n AnyRawTransaction,\n InputGenerateTransactionOptions,\n PendingTransactionResponse,\n InputSubmitTransactionData,\n Network,\n AnyPublicKey,\n AccountAddress,\n TransactionSubmitter,\n} from \"@aptos-labs/ts-sdk\";\n\nimport { GA4 } from \"./ga\";\nimport {\n WalletChangeNetworkError,\n WalletAccountChangeError,\n WalletAccountError,\n WalletConnectionError,\n WalletGetNetworkError,\n WalletNetworkChangeError,\n WalletNotConnectedError,\n WalletNotReadyError,\n WalletNotSelectedError,\n WalletSignAndSubmitMessageError,\n WalletSignMessageError,\n WalletSignTransactionError,\n WalletSignMessageAndVerifyError,\n WalletDisconnectionError,\n WalletSubmitTransactionError,\n WalletNotSupportedMethod,\n WalletNotFoundError,\n} from \"./error\";\nimport { ChainIdToAnsSupportedNetworkMap, WalletReadyState } from \"./constants\";\nimport { WALLET_ADAPTER_CORE_VERSION } from \"./version\";\nimport {\n fetchDevnetChainId,\n generalizedErrorMessage,\n getAptosConfig,\n handlePublishPackageTransaction,\n isAptosNetwork,\n isRedirectable,\n removeLocalStorage,\n setLocalStorage,\n} from \"./utils\";\nimport {\n aptosStandardSupportedWalletList,\n evmStandardSupportedWalletList,\n solanaStandardSupportedWalletList,\n} from \"./registry\";\nimport { getSDKWallets } from \"./sdkWallets\";\nimport {\n AvailableWallets,\n AptosStandardSupportedWallet,\n InputTransactionData,\n} from \"./utils/types\";\n\n// An adapter wallet types is a wallet that is compatible with the wallet standard and the wallet adapter properties\nexport type AdapterWallet = AptosWallet & {\n readyState?: WalletReadyState;\n isAptosNativeWallet?: boolean;\n};\n\n// An adapter not detected wallet types is a wallet that is compatible with the wallet standard but not detected\nexport type AdapterNotDetectedWallet = Omit<\n AdapterWallet,\n \"features\" | \"version\" | \"chains\" | \"accounts\"\n> & {\n readyState: WalletReadyState.NotDetected;\n};\n\nexport interface DappConfig {\n network: Network;\n /**\n * If provided, the wallet adapter will submit transactions using the provided\n * transaction submitter rather than via the wallet.\n */\n transactionSubmitter?: TransactionSubmitter;\n aptosApiKeys?: Partial<Record<Network, string>>;\n aptosConnectDappId?: string;\n aptosConnect?: Omit<AptosConnectWalletConfig, \"network\">;\n /**\n * @deprecated will be removed in a future version\n */\n mizuwallet?: {\n manifestURL: string;\n appId?: string;\n };\n /**\n * @deprecated will be removed in a future version\n */\n msafeWalletConfig?: {\n appId?: string;\n appUrl?: string;\n };\n /**\n * A flag to indicate that the dapp supports cross-chain transactions.\n * If enabled, the adapter will show cross-chain wallets in the wallet selector modal.\n * @default false\n */\n crossChainWallets?: {\n solana?: boolean;\n evm?: boolean;\n };\n}\n\nexport declare interface WalletCoreEvents {\n connect(account: AccountInfo | null): void;\n disconnect(): void;\n standardWalletsAdded(wallets: AdapterWallet): void;\n standardNotDetectedWalletAdded(wallets: AdapterNotDetectedWallet): void;\n networkChange(network: NetworkInfo | null): void;\n accountChange(account: AccountInfo | null): void;\n}\n\nexport type AdapterAccountInfo = Omit<AccountInfo, \"ansName\"> & {\n // ansName is a read-only property on the standard AccountInfo type\n ansName?: string;\n};\n\nexport class WalletCore extends EventEmitter<WalletCoreEvents> {\n // Local private variable to hold the wallet that is currently connected\n private _wallet: AdapterWallet | null = null;\n\n // Local private variable to hold SDK wallets in the adapter\n private readonly _sdkWallets: AdapterWallet[] = [];\n\n // Local array that holds all the wallets that are AIP-62 standard compatible\n private _standard_wallets: AdapterWallet[] = [];\n\n // Local array that holds all the wallets that are AIP-62 standard compatible but are not installed on the user machine\n private _standard_not_detected_wallets: AdapterNotDetectedWallet[] = [];\n\n // Local private variable to hold the network that is currently connected\n private _network: NetworkInfo | null = null;\n\n // Local private variable to hold the wallet connected state\n private _connected: boolean = false;\n\n // Local private variable to hold the connecting state\n private _connecting: boolean = false;\n\n // Local private variable to hold the account that is currently connected\n private _account: AdapterAccountInfo | null = null;\n\n // JSON configuration for AptosConnect\n private _dappConfig: DappConfig | undefined;\n\n // Private array that holds all the Wallets a dapp decided to opt-in to\n private _optInWallets: ReadonlyArray<AvailableWallets> = [];\n\n // Local flag to disable the adapter telemetry tool\n private _disableTelemetry: boolean = false;\n\n // Google Analytics 4 module\n private readonly ga4: GA4 | null = null;\n\n constructor(\n optInWallets?: ReadonlyArray<AvailableWallets>,\n dappConfig?: DappConfig,\n disableTelemetry?: boolean\n ) {\n super();\n this._optInWallets = optInWallets || [];\n this._dappConfig = dappConfig;\n this._disableTelemetry = disableTelemetry ?? false;\n this._sdkWallets = getSDKWallets(this._dappConfig);\n\n // If disableTelemetry set to false (by default), start GA4\n if (!this._disableTelemetry) {\n this.ga4 = new GA4();\n }\n // Strategy to detect AIP-62 standard compatible extension wallets\n this.fetchExtensionAIP62AptosWallets();\n // Strategy to detect AIP-62 standard compatible SDK wallets.\n // We separate the extension and sdk detection process so we dont refetch sdk wallets everytime a new\n // extension wallet is detected\n this.fetchSDKAIP62AptosWallets();\n // Strategy to append not detected AIP-62 standard compatible extension wallets\n this.appendNotDetectedStandardSupportedWallets();\n }\n\n private fetchExtensionAIP62AptosWallets(): void {\n let { aptosWallets, on } = getAptosWallets();\n this.setExtensionAIP62Wallets(aptosWallets);\n\n if (typeof window === \"undefined\") return;\n // Adds an event listener for new wallets that get registered after the dapp has been loaded,\n // receiving an unsubscribe function, which it can later use to remove the listener\n const that = this;\n const removeRegisterListener = on(\"register\", function () {\n let { aptosWallets } = getAptosWallets();\n that.setExtensionAIP62Wallets(aptosWallets);\n });\n\n const removeUnregisterListener = on(\"unregister\", function () {\n let { aptosWallets } = getAptosWallets();\n that.setExtensionAIP62Wallets(aptosWallets);\n });\n }\n\n /**\n * Set AIP-62 extension wallets\n *\n * @param extensionwWallets\n */\n private setExtensionAIP62Wallets(\n extensionwWallets: readonly AptosWallet[]\n ): void {\n extensionwWallets.map((wallet: AdapterWallet) => {\n if (this.excludeWallet(wallet)) {\n return;\n }\n\n // Rimosafe is not supported anymore, so hiding it\n if (wallet.name === \"Rimosafe\") {\n return;\n }\n\n const isValid = isWalletWithRequiredFeatureSet(wallet);\n\n if (isValid) {\n // check if we already have this wallet as a not detected wallet\n const index = this._standard_not_detected_wallets.findIndex(\n (notDetctedWallet) => notDetctedWallet.name == wallet.name\n );\n // if we do, remove it from the not detected wallets array as it is now become detected\n if (index !== -1) {\n this._standard_not_detected_wallets.splice(index, 1);\n }\n\n // ✅ Check if wallet already exists in _standard_wallets\n const alreadyExists = this._standard_wallets.some(\n (w) => w.name === wallet.name\n );\n if (!alreadyExists) {\n wallet.readyState = WalletReadyState.Installed;\n wallet.isAptosNativeWallet = this.isAptosNativeWallet(wallet);\n this._standard_wallets.push(wallet);\n this.emit(\"standardWalletsAdded\", wallet);\n }\n }\n });\n }\n\n /**\n * Set AIP-62 SDK wallets\n */\n private fetchSDKAIP62AptosWallets(): void {\n this._sdkWallets.map((wallet: AdapterWallet) => {\n if (this.excludeWallet(wallet)) {\n return;\n }\n const isValid = isWalletWithRequiredFeatureSet(wallet);\n\n if (isValid) {\n wallet.readyState = WalletReadyState.Installed;\n wallet.isAptosNativeWallet = this.isAptosNativeWallet(wallet);\n this._standard_wallets.push(wallet);\n }\n });\n }\n\n // Aptos native wallets do not have an authenticationFunction property\n private isAptosNativeWallet(wallet: AptosWallet): boolean {\n return !(\"authenticationFunction\" in wallet);\n }\n\n // Since we can't discover AIP-62 wallets that are not installed on the user machine,\n // we hold a AIP-62 wallets registry to show on the wallet selector modal for the users.\n // Append wallets from wallet standard support registry to the `_standard_not_detected_wallets` array\n // when wallet is not installed on the user machine\n private appendNotDetectedStandardSupportedWallets(): void {\n const walletRegistry = [...aptosStandardSupportedWalletList];\n if (this._dappConfig?.crossChainWallets?.solana) {\n walletRegistry.push(...solanaStandardSupportedWalletList);\n }\n if (this._dappConfig?.crossChainWallets?.evm) {\n walletRegistry.push(...evmStandardSupportedWalletList);\n }\n // Loop over the registry map\n walletRegistry.map((supportedWallet: AptosStandardSupportedWallet) => {\n // Check if we already have this wallet as a detected AIP-62 wallet standard\n const existingStandardWallet = this._standard_wallets.find(\n (wallet) => wallet.name == supportedWallet.name\n );\n // If it is detected, it means the user has the wallet installed, so dont add it to the wallets array\n if (existingStandardWallet) {\n return;\n }\n // If AIP-62 wallet detected but it is excluded by the dapp, dont add it to the wallets array\n if (this.excludeWallet(supportedWallet)) {\n return;\n }\n // If AIP-62 wallet does not exist, append it to the wallet selector modal\n // as an undetected wallet\n if (!existingStandardWallet) {\n // Aptos native wallets do not have an authenticationFunction property\n supportedWallet.isAptosNativeWallet = !(\n \"authenticationFunction\" in supportedWallet\n );\n this._standard_not_detected_wallets.push(supportedWallet);\n this.emit(\"standardNotDetectedWalletAdded\", supportedWallet);\n }\n });\n }\n\n /**\n * A function that excludes an AIP-62 compatible wallet the dapp doesnt want to include\n *\n * @param wallet AdapterWallet | AdapterNotDetectedWallet\n * @returns boolean\n */\n excludeWallet(wallet: AdapterWallet | AdapterNotDetectedWallet): boolean {\n // If _optInWallets is not empty, and does not include the provided wallet,\n // return true to exclude the wallet, otherwise return false\n if (\n this._optInWallets.length > 0 &&\n !this._optInWallets.includes(wallet.name as AvailableWallets)\n ) {\n return true;\n }\n return false;\n }\n\n private recordEvent(eventName: string, additionalInfo?: object): void {\n this.ga4?.gtag(\"event\", `wallet_adapter_${eventName}`, {\n wallet: this._wallet?.name,\n network: this._network?.name,\n network_url: this._network?.url,\n adapter_core_version: WALLET_ADAPTER_CORE_VERSION,\n send_to: process.env.GAID,\n ...additionalInfo,\n });\n }\n\n /**\n * Helper function to ensure wallet exists\n *\n * @param wallet A wallet\n */\n private ensureWalletExists(\n wallet: AdapterWallet | null\n ): asserts wallet is AdapterWallet {\n if (!wallet) {\n throw new WalletNotConnectedError().name;\n }\n if (!(wallet.readyState === WalletReadyState.Installed))\n throw new WalletNotReadyError(\"Wallet is not set\").name;\n }\n\n /**\n * Helper function to ensure account exists\n *\n * @param account An account\n */\n private ensureAccountExists(\n account: AccountInfo | null\n ): asserts account is AccountInfo {\n if (!account) {\n throw new WalletAccountError(\"Account is not set\").name;\n }\n }\n\n /**\n * Queries and sets ANS name for the current connected wallet account\n */\n private async setAnsName(): Promise<void> {\n if (this._network?.chainId && this._account) {\n if (this._account.ansName) return;\n // ANS supports only MAINNET or TESTNET\n if (\n !ChainIdToAnsSupportedNetworkMap[this._network.chainId] ||\n !isAptosNetwork(this._network)\n ) {\n this._account.ansName = undefined;\n return;\n }\n\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new Aptos(aptosConfig);\n try {\n const name = await aptos.ans.getPrimaryName({\n address: this._account.address.toString(),\n });\n this._account.ansName = name;\n } catch (error: any) {\n console.log(`Error setting ANS name ${error}`);\n }\n }\n }\n\n /**\n * Function to cleat wallet adapter data.\n *\n * - Removes current connected wallet state\n * - Removes current connected account state\n * - Removes current connected network state\n * - Removes autoconnect local storage value\n */\n private clearData(): void {\n this._connected = false;\n this.setWallet(null);\n this.setAccount(null);\n this.setNetwork(null);\n removeLocalStorage();\n }\n\n /**\n * Sets the connected wallet\n *\n * @param wallet A wallet\n */\n setWallet(wallet: AptosWallet | null): void {\n this._wallet = wallet;\n }\n\n /**\n * Sets the connected account\n *\n * @param account An account\n */\n setAccount(account: AccountInfo | null): void {\n this._account = account;\n }\n\n /**\n * Sets the connected network\n *\n * @param network A network\n */\n setNetwork(network: NetworkInfo | null): void {\n this._network = network;\n }\n\n /**\n * Helper function to detect whether a wallet is connected\n *\n * @returns boolean\n */\n isConnected(): boolean {\n return this._connected;\n }\n\n /**\n * Getter to fetch all detected wallets\n */\n get wallets(): ReadonlyArray<AptosWallet> {\n return this._standard_wallets;\n }\n\n get notDetectedWallets(): ReadonlyArray<AdapterNotDetectedWallet> {\n return this._standard_not_detected_wallets;\n }\n\n /**\n * Getter for the current connected wallet\n *\n * @return wallet info\n * @throws WalletNotSelectedError\n */\n get wallet(): AptosWallet | null {\n try {\n if (!this._wallet) return null;\n return this._wallet;\n } catch (error: any) {\n throw new WalletNotSelectedError(error).message;\n }\n }\n\n /**\n * Getter for the current connected account\n *\n * @return account info\n * @throws WalletAccountError\n */\n get account(): AccountInfo | null {\n try {\n return this._account;\n } catch (error: any) {\n throw new WalletAccountError(error).message;\n }\n }\n\n /**\n * Getter for the current wallet network\n *\n * @return network info\n * @throws WalletGetNetworkError\n */\n get network(): NetworkInfo | null {\n try {\n return this._network;\n } catch (error: any) {\n throw new WalletGetNetworkError(error).message;\n }\n }\n\n /**\n * Helper function to run some checks before we connect with a wallet.\n *\n * @param walletName. The wallet name we want to connect with.\n */\n async connect(walletName: string): Promise<void | string> {\n // First, handle mobile case\n // Check if we are in a redirectable view (i.e on mobile AND not in an in-app browser)\n if (isRedirectable()) {\n const selectedWallet = this._standard_not_detected_wallets.find(\n (wallet: AdapterNotDetectedWallet) => wallet.name === walletName\n );\n\n if (selectedWallet) {\n // If wallet has a deeplinkProvider property, use it\n const uninstalledWallet =\n selectedWallet as unknown as AptosStandardSupportedWallet;\n if (uninstalledWallet.deeplinkProvider) {\n let parameter = \"\";\n if (uninstalledWallet.name.includes(\"Phantom\")) {\n // Phantom required parameters https://docs.phantom.com/phantom-deeplinks/other-methods/browse#parameters\n let url = encodeURIComponent(window.location.href);\n let ref = encodeURIComponent(window.location.origin);\n parameter = `${url}?ref=${ref}`;\n } else if (uninstalledWallet.name.includes(\"Metamask\")) {\n // Metamask expects the raw URL as a path parameter\n // Format: https://link.metamask.io/dapp/aptos-labs.github.io\n parameter = window.location.href;\n } else {\n parameter = encodeURIComponent(window.location.href);\n }\n const location = uninstalledWallet.deeplinkProvider.concat(parameter);\n window.location.href = location;\n return;\n }\n }\n }\n\n // Checks the wallet exists in the detected wallets array\n const allDetectedWallets = this._standard_wallets;\n\n const selectedWallet = allDetectedWallets.find(\n (wallet: AdapterWallet) => wallet.name === walletName\n );\n\n if (!selectedWallet) return;\n\n // Check if wallet is already connected\n if (this._connected && this._account) {\n // if the selected wallet is already connected, we don't need to connect again\n if (this._wallet?.name === walletName)\n throw new WalletConnectionError(\n `${walletName} wallet is already connected`\n ).message;\n }\n\n await this.connectWallet(selectedWallet, async () => {\n const response = await selectedWallet.features[\"aptos:connect\"].connect();\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n\n return { account: response.args, output: undefined };\n });\n }\n\n /**\n * Signs into the wallet by connecting and signing an authentication messages.\n *\n * For more information, visit: https://siwa.aptos.dev\n *\n * @param args\n * @param args.input The AptosSignInInput which defines how the SIWA Message should be constructed\n * @param args.walletName The name of the wallet to sign into\n * @returns The AptosSignInOutput which contains the account and signature information\n */\n async signIn(args: {\n input: AptosSignInInput;\n walletName: string;\n }): Promise<AptosSignInOutput> {\n const { input, walletName } = args;\n\n const allDetectedWallets = this._standard_wallets;\n const selectedWallet = allDetectedWallets.find(\n (wallet: AdapterWallet) => wallet.name === walletName\n );\n\n if (!selectedWallet) {\n throw new WalletNotFoundError(`Wallet ${walletName} not found`).message;\n }\n\n if (!selectedWallet.features[\"aptos:signIn\"]) {\n throw new WalletNotSupportedMethod(\n `aptos:signIn is not supported by ${walletName}`\n ).message;\n }\n\n return await this.connectWallet(selectedWallet, async () => {\n if (!selectedWallet.features[\"aptos:signIn\"]) {\n throw new WalletNotSupportedMethod(\n `aptos:signIn is not supported by ${selectedWallet.name}`\n ).message;\n }\n\n const response =\n await selectedWallet.features[\"aptos:signIn\"].signIn(input);\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n\n return { account: response.args.account, output: response.args };\n });\n }\n\n /**\n * Connects a wallet to the dapp.\n * On connect success, we set the current account and the network, and keeping the selected wallet\n * name in LocalStorage to support autoConnect function.\n *\n * @param selectedWallet. The wallet we want to connect.\n * @emit emits \"connect\" event\n * @throws WalletConnectionError\n */\n private async connectWallet<T>(\n selectedWallet: AdapterWallet,\n onConnect: () => Promise<{ account: AccountInfo; output: T }>\n ): Promise<T> {\n try {\n this._connecting = true;\n this.setWallet(selectedWallet);\n const { account, output } = await onConnect();\n this.setAccount(account);\n const network = await selectedWallet.features[\"aptos:network\"].network();\n this.setNetwork(network);\n await this.setAnsName();\n setLocalStorage(selectedWallet.name);\n this._connected = true;\n this.recordEvent(\"wallet_connect\");\n this.emit(\"connect\", account);\n return output;\n } catch (error: any) {\n this.clearData();\n const errMsg = generalizedErrorMessage(error);\n throw new WalletConnectionError(errMsg).message;\n } finally {\n this._connecting = false;\n }\n }\n\n /**\n * Disconnect the current connected wallet. On success, we clear the\n * current account, current network and LocalStorage data.\n *\n * @emit emits \"disconnect\" event\n * @throws WalletDisconnectionError\n */\n async disconnect(): Promise<void> {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:disconnect\"].disconnect();\n this.clearData();\n this.recordEvent(\"wallet_disconnect\");\n this.emit(\"disconnect\");\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletDisconnectionError(errMsg).message;\n }\n }\n\n /**\n * Signs and submits a transaction to chain\n *\n * @param transactionInput InputTransactionData\n * @returns AptosSignAndSubmitTransactionOutput\n */\n async signAndSubmitTransaction(\n transactionInput: InputTransactionData\n ): Promise<AptosSignAndSubmitTransactionOutput> {\n try {\n if (\"function\" in transactionInput.data) {\n if (\n transactionInput.data.function ===\n \"0x1::account::rotate_authentication_key_call\"\n ) {\n throw new WalletSignAndSubmitMessageError(\"SCAM SITE DETECTED\")\n .message;\n }\n\n if (\n transactionInput.data.function === \"0x1::code::publish_package_txn\"\n ) {\n ({\n metadataBytes: transactionInput.data.functionArguments[0],\n byteCode: transactionInput.data.functionArguments[1],\n } = handlePublishPackageTransaction(transactionInput));\n }\n }\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_and_submit_transaction\");\n\n // We'll submit ourselves if a custom transaction submitter has been provided.\n const shouldUseTxnSubmitter = !!(\n this._dappConfig?.transactionSubmitter ||\n transactionInput.transactionSubmitter\n );\n\n if (\n this._wallet.features[\"aptos:signAndSubmitTransaction\"] &&\n !shouldUseTxnSubmitter\n ) {\n // check for backward compatibility. before version 1.1.0 the standard expected\n // AnyRawTransaction input so the adapter built the transaction before sending it to the wallet\n if (\n this._wallet.features[\"aptos:signAndSubmitTransaction\"].version !==\n \"1.1.0\"\n ) {\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n\n const aptos = new Aptos(aptosConfig);\n const transaction = await aptos.transaction.build.simple({\n sender: this._account.address.toString(),\n data: transactionInput.data,\n options: transactionInput.options,\n });\n\n type AptosSignAndSubmitTransactionV1Method = (\n transaction: AnyRawTransaction\n ) => Promise<UserResponse<AptosSignAndSubmitTransactionOutput>>;\n\n const signAndSubmitTransactionMethod = this._wallet.features[\n \"aptos:signAndSubmitTransaction\"\n ]\n .signAndSubmitTransaction as unknown as AptosSignAndSubmitTransactionV1Method;\n\n const response = (await signAndSubmitTransactionMethod(\n transaction\n )) as UserResponse<AptosSignAndSubmitTransactionOutput>;\n\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n\n return response.args;\n }\n\n const response = await this._wallet.features[\n \"aptos:signAndSubmitTransaction\"\n ].signAndSubmitTransaction({\n payload: transactionInput.data,\n gasUnitPrice: transactionInput.options?.gasUnitPrice,\n maxGasAmount: transactionInput.options?.maxGasAmount,\n });\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n return response.args;\n }\n\n // If wallet does not support signAndSubmitTransaction or a transaction submitter\n // is provided, the adapter will sign and submit it for the dapp.\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new Aptos(aptosConfig);\n const transaction = await aptos.transaction.build.simple({\n sender: this._account.address.toString(),\n data: transactionInput.data,\n options: transactionInput.options,\n withFeePayer: shouldUseTxnSubmitter,\n });\n\n const signTransactionResponse = await this.signTransaction({\n transactionOrPayload: transaction,\n });\n const response = await this.submitTransaction({\n transaction,\n senderAuthenticator: signTransactionResponse.authenticator,\n transactionSubmitter: transactionInput.transactionSubmitter,\n pluginParams: transactionInput.pluginParams,\n });\n return { hash: response.hash };\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignAndSubmitMessageError(errMsg).message;\n }\n }\n\n /**\n * Signs a transaction\n *\n * This method supports 2 input types -\n * 1. A raw transaction that was already built by the dapp,\n * 2. A transaction data input as JSON. This is for the wallet to be able to simulate before signing\n *\n * @param transactionOrPayload AnyRawTransaction | InputTransactionData\n * @param asFeePayer optional. A flag indicates to sign the transaction as the fee payer\n * @param options optional. Transaction options\n *\n * @returns AccountAuthenticator\n */\n async signTransaction(args: {\n transactionOrPayload: AnyRawTransaction | InputTransactionData;\n asFeePayer?: boolean;\n }): Promise<{\n authenticator: AccountAuthenticator;\n rawTransaction: Uint8Array;\n }> {\n const { transactionOrPayload, asFeePayer } = args;\n /**\n * All standard compatible wallets should support AnyRawTransaction for signTransaction version 1.0.0\n * For standard signTransaction version 1.1.0, the standard expects a transaction input\n *\n * So, if the input is AnyRawTransaction, we can directly call the wallet's signTransaction method\n *\n *\n * If the input is InputTransactionData, we need to\n * 1. check if the wallet supports signTransaction version 1.1.0 - if so, we convert the input to the standard expected input\n * 2. if it does not support signTransaction version 1.1.0, we convert it to a rawTransaction input and call the wallet's signTransaction method\n */\n\n try {\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_transaction\");\n\n // dapp sends a generated transaction (i.e AnyRawTransaction), which is supported by the wallet standard at signTransaction version 1.0.0\n if (\"rawTransaction\" in transactionOrPayload) {\n const response = (await this._wallet?.features[\n \"aptos:signTransaction\"\n ].signTransaction(\n transactionOrPayload,\n asFeePayer\n )) as UserResponse<AccountAuthenticator>;\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n return {\n authenticator: response.args,\n rawTransaction: transactionOrPayload.rawTransaction.bcsToBytes(),\n };\n } // dapp sends a transaction data input (i.e InputTransactionData), which is supported by the wallet standard at signTransaction version 1.1.0\n else if (\n this._wallet.features[\"aptos:signTransaction\"]?.version === \"1.1.0\"\n ) {\n // convert input to standard expected input\n const signTransactionV1_1StandardInput: AptosSignTransactionInputV1_1 =\n {\n payload: transactionOrPayload.data,\n expirationTimestamp:\n transactionOrPayload.options?.expirationTimestamp,\n expirationSecondsFromNow:\n transactionOrPayload.options?.expirationSecondsFromNow,\n gasUnitPrice: transactionOrPayload.options?.gasUnitPrice,\n maxGasAmount: transactionOrPayload.options?.maxGasAmount,\n sequenceNumber: transactionOrPayload.options?.accountSequenceNumber,\n sender: transactionOrPayload.sender\n ? { address: AccountAddress.from(transactionOrPayload.sender) }\n : undefined,\n };\n\n const walletSignTransactionMethod = this._wallet?.features[\n \"aptos:signTransaction\"\n ].signTransaction as AptosSignTransactionMethod &\n AptosSignTransactionMethodV1_1;\n\n const response = (await walletSignTransactionMethod(\n signTransactionV1_1StandardInput\n )) as UserResponse<AptosSignTransactionOutputV1_1>;\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n return {\n authenticator: response.args.authenticator,\n rawTransaction: response.args.rawTransaction.bcsToBytes(),\n };\n } else {\n // dapp input is InputTransactionData but the wallet does not support it, so we convert it to a rawTransaction\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new Aptos(aptosConfig);\n\n const transaction = await aptos.transaction.build.simple({\n sender: this._account.address,\n data: transactionOrPayload.data,\n options: transactionOrPayload.options,\n withFeePayer: transactionOrPayload.withFeePayer,\n });\n\n const response = (await this._wallet?.features[\n \"aptos:signTransaction\"\n ].signTransaction(\n transaction,\n asFeePayer\n )) as UserResponse<AccountAuthenticator>;\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n\n return {\n authenticator: response.args,\n rawTransaction: transaction.bcsToBytes(),\n };\n }\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignTransactionError(errMsg).message;\n }\n }\n\n /**\n * Sign a message (doesnt submit to chain).\n *\n * @param message - AptosSignMessageInput\n *\n * @return response from the wallet's signMessage function\n * @throws WalletSignMessageError\n */\n async signMessage(\n message: AptosSignMessageInput\n ): Promise<AptosSignMessageOutput> {\n try {\n this.ensureWalletExists(this._wallet);\n this.recordEvent(\"sign_message\");\n\n const response =\n await this._wallet?.features[\"aptos:signMessage\"]?.signMessage(message);\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n return response.args;\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignMessageError(errMsg).message;\n }\n }\n\n /**\n * Submits transaction to chain\n *\n * @param transaction - InputSubmitTransactionData\n * @returns PendingTransactionResponse\n */\n async submitTransaction(\n transaction: InputSubmitTransactionData\n ): Promise<PendingTransactionResponse> {\n // The standard does not support submitTransaction, so we use the adapter to submit the transaction\n try {\n this.ensureWalletExists(this._wallet);\n\n const { additionalSignersAuthenticators } = transaction;\n const transactionType =\n additionalSignersAuthenticators !== undefined\n ? \"multi-agent\"\n : \"simple\";\n this.recordEvent(\"submit_transaction\", {\n transaction_type: transactionType,\n });\n\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const aptos = new Aptos(aptosConfig);\n if (additionalSignersAuthenticators !== undefined) {\n const multiAgentTxn = {\n ...transaction,\n additionalSignersAuthenticators,\n };\n return aptos.transaction.submit.multiAgent(multiAgentTxn);\n } else {\n return aptos.transaction.submit.simple(transaction);\n }\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSubmitTransactionError(errMsg).message;\n }\n }\n\n /**\n Event for when account has changed on the wallet\n @return the new account info\n @throws WalletAccountChangeError\n */\n async onAccountChange(): Promise<void> {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:onAccountChange\"]?.onAccountChange(\n async (data: AccountInfo) => {\n this.setAccount(data);\n await this.setAnsName();\n this.recordEvent(\"account_change\");\n this.emit(\"accountChange\", this._account);\n }\n );\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletAccountChangeError(errMsg).message;\n }\n }\n\n /**\n Event for when network has changed on the wallet\n @return the new network info\n @throws WalletNetworkChangeError\n */\n async onNetworkChange(): Promise<void> {\n try {\n this.ensureWalletExists(this._wallet);\n await this._wallet.features[\"aptos:onNetworkChange\"]?.onNetworkChange(\n async (data: NetworkInfo) => {\n this.setNetwork(data);\n await this.setAnsName();\n this.emit(\"networkChange\", this._network);\n }\n );\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletNetworkChangeError(errMsg).message;\n }\n }\n\n /**\n * Sends a change network request to the wallet to change the connected network\n *\n * @param network - Network\n * @returns AptosChangeNetworkOutput\n */\n async changeNetwork(network: Network): Promise<AptosChangeNetworkOutput> {\n try {\n this.ensureWalletExists(this._wallet);\n this.recordEvent(\"change_network_request\", {\n from: this._network?.name,\n to: network,\n });\n const chainId =\n network === Network.DEVNET\n ? await fetchDevnetChainId()\n : NetworkToChainId[network];\n\n const networkInfo: NetworkInfo = {\n name: network,\n chainId,\n };\n\n if (this._wallet.features[\"aptos:changeNetwork\"]) {\n const response =\n await this._wallet.features[\"aptos:changeNetwork\"].changeNetwork(\n networkInfo\n );\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"User has rejected the request\")\n .message;\n }\n return response.args;\n }\n\n throw new WalletChangeNetworkError(\n `${this._wallet.name} does not support changing network request`\n ).message;\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletChangeNetworkError(errMsg).message;\n }\n }\n\n /**\n * Signs a message and verifies the signer\n * @param message - AptosSignMessageInput\n * @returns boolean\n */\n async signMessageAndVerify(message: AptosSignMessageInput): Promise<boolean> {\n try {\n this.ensureWalletExists(this._wallet);\n this.ensureAccountExists(this._account);\n this.recordEvent(\"sign_message_and_verify\");\n\n // sign the message\n const response = (await this._wallet.features[\n \"aptos:signMessage\"\n ].signMessage(message)) as UserResponse<AptosSignMessageOutput>;\n\n if (response.status === UserResponseStatus.REJECTED) {\n throw new WalletConnectionError(\"Failed to sign a message\").message;\n }\n\n const aptosConfig = getAptosConfig(this._network, this._dappConfig);\n const signingMessage = new TextEncoder().encode(\n response.args.fullMessage\n );\n if (\"verifySignatureAsync\" in (this._account.publicKey as Object)) {\n return await this._account.publicKey.verifySignatureAsync({\n aptosConfig,\n message: signingMessage,\n signature: response.args.signature,\n options: { throwErrorWithReason: true },\n });\n }\n return this._account.publicKey.verifySignature({\n message: signingMessage,\n signature: response.args.signature,\n });\n } catch (error: any) {\n const errMsg = generalizedErrorMessage(error);\n throw new WalletSignMessageAndVerifyError(errMsg).message;\n }\n }\n}\n","export class GA4 {\n readonly aptosGAID: string | undefined = process.env.GAID;\n\n constructor() {\n // Inject Aptos Google Analytics 4 script\n this.injectGA(this.aptosGAID);\n }\n\n gtag(a: string, b: string | object, c?: object) {\n let dataLayer = (window as any).dataLayer || [];\n dataLayer.push(arguments);\n }\n\n private injectGA(gaID?: string) {\n if (typeof window === \"undefined\") return;\n if (!gaID) return;\n\n const head = document.getElementsByTagName(\"head\")[0];\n\n var myScript = document.createElement(\"script\");\n\n myScript.setAttribute(\n \"src\",\n `https://www.googletagmanager.com/gtag/js?id=${gaID}`,\n );\n\n const that = this;\n myScript.onload = function () {\n that.gtag(\"js\", new Date());\n that.gtag(\"config\", `${gaID}`, {\n send_page_view: false,\n });\n };\n\n head.insertBefore(myScript, head.children[1]);\n }\n}\n","export const WALLET_ADAPTER_CORE_VERSION = \"7.10.2\";\n","export class WalletError extends Error {\n public error: any;\n\n constructor(message?: string, error?: any) {\n super(message);\n this.error = error;\n }\n}\n\nexport class WalletNotSelectedError extends WalletError {\n name = \"WalletNotSelectedError\";\n}\n\nexport class WalletNotReadyError extends WalletError {\n name = \"WalletNotReadyError\";\n}\n\nexport class WalletLoadError extends WalletError {\n name = \"WalletLoadError\";\n}\n\nexport class WalletConfigError extends WalletError {\n name = \"WalletConfigError\";\n}\n\nexport class WalletConnectionError extends WalletError {\n name = \"WalletConnectionError\";\n}\n\nexport class WalletDisconnectedError extends WalletError {\n name = \"WalletDisconnectedError\";\n}\n\nexport class WalletDisconnectionError extends WalletError {\n name = \"WalletDisconnectionError\";\n}\n\nexport class WalletAccountError extends WalletError {\n name = \"WalletAccountError\";\n}\nexport class WalletGetNetworkError extends WalletError {\n name = \"WalletGetNetworkError\";\n}\n\nexport class WalletAccountChangeError extends WalletError {\n name = \"WalletAccountChangeError\";\n}\n\nexport class WalletNetworkChangeError extends WalletError {\n name = \"WalletNetworkChangeError\";\n}\n\nexport class WalletPublicKeyError extends WalletError {\n name = \"WalletPublicKeyError\";\n}\n\nexport class WalletKeypairError extends WalletError {\n name = \"WalletKeypairError\";\n}\n\nexport class WalletNotConnectedError extends WalletError {\n name = \"WalletNotConnectedError\";\n}\n\nexport class WalletSendTransactionError extends WalletError {\n name = \"WalletSendTransactionError\";\n}\n\nexport class WalletSignMessageError extends WalletError {\n name = \"WalletSignMessageError\";\n}\n\nexport class WalletSignMessageAndVerifyError extends WalletError {\n name = \"WalletSignMessageAndVerifyError\";\n}\n\nexport class WalletSignAndSubmitMessageError extends WalletError {\n name = \"WalletSignAndSubmitMessageError\";\n}\n\nexport class WalletSignTransactionError extends WalletError {\n name = \"WalletSignTransactionError\";\n}\n\nexport class WalletTimeoutError extends WalletError {\n name = \"WalletTimeoutError\";\n}\n\nexport class WalletWindowBlockedError extends WalletError {\n name = \"WalletWindowBlockedError\";\n}\n\nexport class WalletWindowClosedError extends WalletError {\n name = \"WalletWindowClosedError\";\n}\n\nexport class WalletResponseError extends WalletError {\n name = \"WalletResponseError\";\n}\n\nexport class WalletNotSupportedMethod extends WalletError {\n name = \"WalletNotSupportedMethod\";\n}\n\nexport class WalletChangeNetworkError extends WalletError {\n name = \"WalletChangeNetworkError\";\n}\n\nexport class WalletSubmitTransactionError extends WalletError {\n name = \"WalletSubmitTransactionError\";\n}\n\nexport class WalletNotFoundError extends WalletError {\n name = \"WalletNotFoundError\";\n}\n"]}
|