function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } export var Logger = /*#__PURE__*/function () { function Logger(config, debug) { _classCallCheck(this, Logger); _defineProperty(this, "logs", void 0); _defineProperty(this, "config", void 0); _defineProperty(this, "debug", void 0); _defineProperty(this, "componentStartTime", void 0); _defineProperty(this, "isLoaded", void 0); this.logs = []; this.config = config; this.debug = debug; this.componentStartTime = 0; this.isLoaded = false; } _createClass(Logger, [{ key: "setMedta", value: function setMedta(mdata) { var _window, _this = this; this.config.mdata = Object.assign(this.config.mdata, mdata); if ((_window = window) !== null && _window !== void 0 && _window.iTracker) { var _window2; (_window2 = window) === null || _window2 === void 0 || (_window2 = _window2.iTracker) === null || _window2 === void 0 || _window2.set({ mdata: this.config.mdata }); setTimeout(function () { _this.reportLogs(); }, 80); } else { this.initTracker(); } } }, { key: "logError", value: function logError(error, extra) { this.logs.push({ type: 'error', logPayload: error, extra: extra }); if (this.debug) { console.error(error); } this.send(); return this; } }, { key: "logInfo", value: function logInfo(info, extra) { this.logs.push({ type: 'info', logPayload: info, extra: extra }); if (this.debug) { console.log(info); } this.send(); return this; } }, { key: "reportRPC", value: function reportRPC(rpcData, extra) { this.logs.push({ type: 'rpc', logPayload: rpcData, extra: extra }); if (this.debug) { console.log(rpcData); } this.send(); return this; } }, { key: "reportLogs", value: function reportLogs() { var _window3; if (!((_window3 = window) !== null && _window3 !== void 0 && _window3.iTracker)) { return; } var _window$iTracker = window.iTracker, logError = _window$iTracker.logError, logInfo = _window$iTracker.logInfo, reportRPC = _window$iTracker.reportRPC; var logs = this.logs; var now = Date.now(); var fsDuration = now - this.componentStartTime; while (logs.length > 0) { try { var log = logs.pop(); if (log.type === 'error') { logError(log.logPayload, _objectSpread({ fsDuration: fsDuration, timeStamp: now }, log === null || log === void 0 ? void 0 : log.extra)); } else if (log.type === 'info') { logInfo(log.logPayload, _objectSpread({ fsDuration: fsDuration, timeStamp: now }, log === null || log === void 0 ? void 0 : log.extra)); } else if (log.type === 'rpc') { reportRPC(log.logPayload, _objectSpread({ fsDuration: fsDuration, timeStamp: now }, log === null || log === void 0 ? void 0 : log.extra)); } } catch (error) { console.error('Error occurred while calling iTracker method:', error); } } } }, { key: "loadScript", value: function loadScript(url, callback) { var script = document.createElement('script'); script.type = 'text/javascript'; script.src = url; script.onload = callback; script.onerror = function () { console.error("unable to load Antom script: ".concat(url)); }; document.body.appendChild(script); } }, { key: "initTracker", value: function initTracker() { var _this2 = this; if (this.isLoaded) return; this.isLoaded = true; try { if (typeof localStorage !== 'undefined') { this.loadScript(this.config.scriptUrl, function () { var _window4; (_window4 = window) === null || _window4 === void 0 || _window4.iTracker.initiTracker(_this2.config); setTimeout(function () { _this2.reportLogs(); }, 80); }); } } catch (error) { console.error('Failed to initialize iTracker:', error); } } }, { key: "send", value: function send() { var _window5; if ((_window5 = window) !== null && _window5 !== void 0 && _window5.iTracker) { this.reportLogs(); } else { this.initTracker(); } } }, { key: "setComponentStartTime", value: function setComponentStartTime(val) { this.componentStartTime = val; } }]); return Logger; }(); export var LogConfig = { scriptUrl: 'https://gw.alipayobjects.com/render/p/yuyan_npm/@alipay_intl-tracker/1.6.0/dist/common.min.js', spmConfig: {}, batchCount: 1, appId: 'antom_sdk', server: 'https://imdap-sea.alipay.com/loggw/dwcookieLogGet.do', bizType: 'antom_sdk', productId: 'ANTOM_SDK', version: 'iteration/20231021', mdata: { fistLogTime: Date.now() } };