UNPKG

@mitojs/wx-mini

Version:
924 lines (910 loc) 39.4 kB
/* @mitojs/wx-mini version ' + 3.0.1 */ import { Severity, getBreadcrumbCategoryInWx, variableTypeDetection, setUrlQuery, getTimestamp, getCurrentRoute, parseErrorString, isError, extractErrorStack, logger, unknownToString, replaceOld, _support, firstStrtoLowerCase, isEmptyObject, throttle, fromHttpStatus, getRealPath, validateOptionsAndSet, toStringValidateOption, firstStrtoUppercase } from '@mitojs/utils'; import { globalVar, Silent, MitoLog, MitoLogEmptyMsg, MitoLogEmptyTag } from '@mitojs/shared'; import { BaseOptions, BaseTransport, Breadcrumb, BaseClient } from '@mitojs/core'; var extendStatics = function(d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; function __extends(d, b) { if (typeof b !== "function" && b !== null) throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); } var __assign = function() { __assign = Object.assign || function __assign(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; function __awaiter(thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); } function __generator(thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } } function __spreadArray(to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i); ar[i] = from[i]; } } return to.concat(ar || Array.prototype.slice.call(from)); } function getNavigateBackTargetUrl(delta) { if (!variableTypeDetection.isFunction(getCurrentPages)) { return ''; } var pages = getCurrentPages(); if (!pages.length) { return 'App'; } delta = delta || 1; var toPage = pages[pages.length - delta]; return setUrlQuery(toPage.route, toPage.options); } function getCurrentPagesPop() { return getCurrentPages().pop(); } function targetAsString(e) { var _a, _b; var id = ((_a = e.currentTarget) === null || _a === void 0 ? void 0 : _a.id) ? " id=\"".concat((_b = e.currentTarget) === null || _b === void 0 ? void 0 : _b.id, "\"") : ''; var dataSets = Object.keys(e.currentTarget.dataset).map(function (key) { return "data-".concat(key, "=").concat(e.currentTarget.dataset[key]); }); return "<element ".concat(id, " ").concat(dataSets.join(' '), "/>"); } function getWxMiniDeviceInfo() { return __awaiter(this, void 0, void 0, function () { var _a, pixelRatio, screenHeight, screenWidth, netType; return __generator(this, function (_b) { switch (_b.label) { case 0: _a = wx.getSystemInfoSync(), pixelRatio = _a.pixelRatio, screenHeight = _a.screenHeight, screenWidth = _a.screenWidth; return [4, getWxMiniNetWrokType()]; case 1: netType = _b.sent(); return [2, { ratio: pixelRatio, clientHeight: screenHeight, clientWidth: screenWidth, netType: netType }]; } }); }); } function getWxMiniNetWrokType() { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { return [2, new Promise(function (resolve) { wx.getNetworkType({ success: function (res) { resolve(res.networkType); }, fail: function (err) { console.error("\u83B7\u53D6\u5FAE\u4FE1\u5C0F\u7A0B\u5E8F\u7F51\u7EDC\u7C7B\u578B\u5931\u8D25:".concat(err)); resolve('getNetWrokType failed'); } }); })]; }); }); } function addBreadcrumbInWx(data, type, level, params) { if (level === void 0) { level = Severity.Info; } if (params === void 0) { params = {}; } return this.breadcrumb.push(__assign({ type: type, data: data, category: getBreadcrumbCategoryInWx(type), level: level }, params)); } var wxAppPluginMap = new Map(); wxAppPluginMap.set("AppOnLaunch", { transform: function (options) { var sdkOptions = this.options; sdkOptions.appOnLaunch(options); var data = { path: options.path, query: options.query }; return data; }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "App On Launch"); } }); wxAppPluginMap.set("AppOnShow", { transform: function (options) { var sdkOptions = this.options; sdkOptions.appOnShow(options); var data = { path: options.path, query: options.query }; return data; }, consumer: function (data) { return __awaiter(this, void 0, void 0, function () { var _a; return __generator(this, function (_b) { switch (_b.label) { case 0: _a = _support; return [4, getWxMiniDeviceInfo()]; case 1: _a.deviceInfo = _b.sent(); addBreadcrumbInWx.call(this, data, "App On Show"); return [2]; } }); }); } }); wxAppPluginMap.set("AppOnHide", { transform: function () { var sdkOptions = this.options; sdkOptions.appOnHide(); }, consumer: function () { addBreadcrumbInWx.call(this, null, "App On Hide"); } }); wxAppPluginMap.set("AppOnError", { transform: function (error) { var data = { type: "JAVASCRIPT", time: getTimestamp(), level: Severity.Normal, url: getCurrentRoute() }; if (typeof error === 'string') { var parsedError = parseErrorString(error); data = __assign(__assign({}, parsedError), data); } else if (isError(error)) { data = __assign(__assign({}, extractErrorStack(error, Severity.Normal)), data); } else { logger.error("AppOnError params isn't string or error"); } return data; }, consumer: function (transformedData) { var breadcrumbStack = addBreadcrumbInWx.call(this, transformedData, "Code Error", Severity.Error); this.transport.send(transformedData, breadcrumbStack); } }); wxAppPluginMap.set("AppOnPageNotFound", { transform: function (data) { var sdkOptions = this.options; sdkOptions.appOnPageNotFound(data); return data; }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Route", Severity.Error); } }); wxAppPluginMap.set("AppOnUnhandledRejection", { transform: function (ev) { var data = { type: "PROMISE", message: unknownToString(ev.reason), url: getCurrentRoute(), name: "Unhandledrejection", time: getTimestamp(), level: Severity.Low }; if (isError(ev.reason)) { data = __assign(__assign(__assign({}, data), extractErrorStack(ev.reason, Severity.Low)), { url: getCurrentRoute() }); } return data; }, consumer: function (transformedData) { var breadcrumbStack = addBreadcrumbInWx.call(this, transformedData, "Unhandledrejection", Severity.Error); this.transport.send(transformedData, breadcrumbStack); } }); function getWxAppPlugins() { if (!App) return []; var methodHooks = [ "AppOnLaunch", "AppOnShow", "AppOnHide", "AppOnPageNotFound", "AppOnError", "AppOnUnhandledRejection" ]; var plugins = methodHooks.map(function (method) { return { name: method, monitor: function (notify) { var originApp = App; App = function (appOptions) { replaceOld(appOptions, method.replace('AppOn', 'on'), function (originMethod) { return function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } if (originMethod) { originMethod.apply(this, args); } notify.apply(null, __spreadArray([method], args, true)); }; }, true); return originApp(appOptions); }; } }; }); return plugins.map(function (item) { return __assign(__assign({}, item), (wxAppPluginMap.has(item.name) ? wxAppPluginMap.get(item.name) : {})); }); } var wxAppPlugins = getWxAppPlugins(); var wxConsolePlugin = { name: "console", monitor: function (notify) { if (console && variableTypeDetection.isObject(console)) { var logType = ['log', 'debug', 'info', 'warn', 'error', 'assert']; logType.forEach(function (level) { if (!(level in console)) return; replaceOld(console, level, function (originalConsole) { return function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } if (originalConsole) { notify("console", { args: args, level: level }); originalConsole.apply(console, args); } }; }); }); } }, transform: function (collectedData) { return collectedData; }, consumer: function (transformedData) { if (globalVar.isLogAddBreadcrumb) { addBreadcrumbInWx.call(this, transformedData, "Console", Severity.fromString(transformedData.level)); } } }; function pageHookTransform(hook) { var page = getCurrentPagesPop(); var sdkOptions = this.options; if (page) { sdkOptions[firstStrtoLowerCase(hook)](page); return { path: page.route, query: page.options }; } sdkOptions[firstStrtoLowerCase(hook)](); } function pageHookTransformWithOptions(hook, options) { var page = getCurrentPagesPop(); var sdkOptions = this.options; sdkOptions[firstStrtoLowerCase(hook)](options, page); return { path: page === null || page === void 0 ? void 0 : page.route, query: page === null || page === void 0 ? void 0 : page.options, options: options }; } var wxPagePluginMap = new Map(); wxPagePluginMap.set("PageOnLoad", { transform: function () { return pageHookTransform.call(this, "PageOnLoad"); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Load"); } }); wxPagePluginMap.set("PageOnShow", { transform: function () { return pageHookTransform.call(this, "PageOnShow"); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Show"); } }); wxPagePluginMap.set("PageOnReady", { transform: function () { return pageHookTransform.call(this, "PageOnReady"); }, consumer: function () { addBreadcrumbInWx.call(this, null, "Page On Ready"); } }); wxPagePluginMap.set("PageOnHide", { transform: function () { return pageHookTransform.call(this, "PageOnHide"); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Hide"); } }); wxPagePluginMap.set("PageOnUnload", { transform: function () { return pageHookTransform.call(this, "PageOnUnload"); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Unload"); } }); wxPagePluginMap.set("PageOnShareTimeline", { transform: function (options) { return pageHookTransformWithOptions.call(this, "PageOnShareTimeline", options); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Share Timeline"); } }); wxPagePluginMap.set("PageOnShareAppMessage", { transform: function (options) { return pageHookTransformWithOptions.call(this, "PageOnShareAppMessage", options); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Share App Message"); } }); wxPagePluginMap.set("PageOnTabItemTap", { transform: function (options) { return pageHookTransformWithOptions.call(this, "PageOnTabItemTap", options); }, consumer: function (data) { addBreadcrumbInWx.call(this, data, "Page On Tab Item Tap"); } }); function getWxPagePlugins() { if (!Page) return []; var pageHooks = [ "PageOnLoad", "PageOnReady", "PageOnShow", "PageOnUnload", "PageOnHide", "PageOnShareAppMessage", "PageOnShareTimeline", "PageOnTabItemTap" ]; var plugins = pageHooks.map(function (hook) { return { name: hook, monitor: function (notify) { function monitorPageHookWithOptions(options) { replaceOld(options, hook.replace('PageOn', 'on'), function (originMethod) { return function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } notify.apply(null, __spreadArray([hook], args, true)); if (originMethod) { return originMethod.apply(this, args); } }; }, true); } invokeCallbackInReplacePage(function (pageOptions) { monitorPageHookWithOptions(pageOptions); }); invokeCallbackInReplaceComponent(function (componentOptions) { monitorPageHookWithOptions(componentOptions); }); } }; }); return plugins.map(function (item) { return __assign(__assign({}, item), (wxPagePluginMap.has(item.name) ? wxPagePluginMap.get(item.name) : {})); }); } function invokeCallbackInReplacePage(callback) { var originPage = Page; Page = function (pageOptions) { callback(pageOptions); return originPage(pageOptions); }; } function invokeCallbackInReplaceComponent(callback) { if (!Component) { return; } var originComponent = Component; Component = function (componentOptions) { if (!isEmptyObject(componentOptions.methods)) { callback(componentOptions.methods); } return originComponent.call(this, componentOptions); }; } var wxPagePlugins = getWxPagePlugins(); var wxDomPlugin = { name: "dom", monitor: function (notify) { var sdkOptions = this.options; function monitorDomWithOption(options) { function gestureTrigger(e) { e.mitoWorked = true; notify("dom", e); } var throttleGesturetrigger = throttle(gestureTrigger, sdkOptions.throttleDelayTime); var linstenerTypes = ["touchmove", "tap"]; if (options) { Object.keys(options).forEach(function (m) { if ('function' !== typeof options[m]) { return; } replaceOld(options, m, function (originMethod) { return function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } if (this.$vm && !this.$vm._mito_hook_) { var that_1 = this; if (!that_1._mito_hook_) { that_1._mito_hook_ = true; Object.keys(that_1).forEach(function (vmk) { if (~vmk.indexOf('$') || typeof that_1[vmk] !== 'function') return; var original = that_1[vmk]; that_1[vmk] = function () { var e = arguments[0]; if (e && e.type && e.currentTarget && !e.mitoWorked) { sdkOptions.triggerWxEvent(e); if (linstenerTypes.indexOf(e.type) > -1) { throttleGesturetrigger(e); } } return original.apply(this, arguments); }; }); } } var e = args[0]; if (e && e.type && e.currentTarget && !e.mitoWorked) { sdkOptions.triggerWxEvent(e); if (linstenerTypes.indexOf(e.type) > -1) { throttleGesturetrigger(e); } } return originMethod.apply(this, args); }; }, true); }); } } invokeCallbackInReplacePage(function (pageOptions) { monitorDomWithOption(pageOptions); }); invokeCallbackInReplaceBehavior(function (options) { monitorDomWithOption(options); }); invokeCallbackInReplaceComponent(function (componentOptions) { monitorDomWithOption(componentOptions); }); }, transform: function (e) { var type = "UI.Touchmove"; if (e.type === "tap") { type = "UI.Tap"; } var data = targetAsString(e); return { data: data, type: type }; }, consumer: function (_a) { var data = _a.data, type = _a.type; addBreadcrumbInWx.call(this, data, type); } }; function invokeCallbackInReplaceBehavior(callback) { if (!Behavior) { return; } var originBehavior = Behavior; Behavior = function (behaviorOptions) { if (!isEmptyObject(behaviorOptions.methods)) { callback(behaviorOptions.methods); } return originBehavior.call(this, behaviorOptions); }; } var WxXhrTypes; (function (WxXhrTypes) { WxXhrTypes["request"] = "request"; WxXhrTypes["downloadFile"] = "downloadFile"; WxXhrTypes["uploadFile"] = "uploadFile"; })(WxXhrTypes || (WxXhrTypes = {})); var wxRequestPlugin = { name: "request", monitor: function (notify) { monitorWxXhr.call(this, notify); }, transform: function (collectedData) { return httpTransform(collectedData); }, consumer: function (transformedData) { httpTransformedDataConsumer.call(this, transformedData); } }; function monitorWxXhr(notify) { var hookMethods = Object.keys(WxXhrTypes); var that = this; var wxOptions = this.options; hookMethods.forEach(function (hook) { var originRequest = wx[hook]; Object.defineProperty(wx, hook, { writable: true, enumerable: true, configurable: true, value: function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } var options = args[0]; var url = options.url; var method, reqData = undefined; if (options.method) { method = options.method; } else if (hook === WxXhrTypes.downloadFile) { method = "GET"; } else { method = "POST"; } var header = options.header; !header && (header = {}); if ((method === "POST" && that.transport.isSelfDsn(url)) || wxOptions.isFilterHttpUrl(url)) { return originRequest.call(this, options); } switch (hook) { case WxXhrTypes.request: reqData = options.data; break; case WxXhrTypes.downloadFile: reqData = { filePath: options.filePath }; break; default: reqData = { filePath: options.filePath, name: options.name }; } var httpCollect = { request: { httpType: "xhr", url: url, method: method, data: reqData }, response: {}, time: getTimestamp() }; wxOptions.setTraceId(url, function (headerFieldName, traceId) { httpCollect.request.traceId = traceId; header[headerFieldName] = traceId; }); function setRequestHeader(key, value) { header[key] = value; } wxOptions.beforeAppAjaxSend && wxOptions.beforeAppAjaxSend({ method: method, url: url }, { setRequestHeader: setRequestHeader }); var successHandler = function (res) { var endTime = getTimestamp(); httpCollect.response.data = (variableTypeDetection.isString(res.data) || variableTypeDetection.isObject(res.data)) && res.data; httpCollect.elapsedTime = endTime - httpCollect.time; httpCollect.response.status = res.statusCode; httpCollect.errMsg = res.errMsg; notify("request", httpCollect); if (variableTypeDetection.isFunction(options.success)) { return options.success(res); } }; var _fail = options.fail; var failHandler = function (err) { var endTime = getTimestamp(); httpCollect.elapsedTime = endTime - httpCollect.time; httpCollect.errMsg = err.errMsg; httpCollect.response.status = 0; notify("request", httpCollect); if (variableTypeDetection.isFunction(_fail)) { return _fail(err); } }; var actOptions = __assign(__assign({}, options), { success: successHandler, fail: failHandler }); return originRequest.call(this, actOptions); } }); }); } function httpTransform(httpCollectedData) { var message = ''; var _a = httpCollectedData.request, httpType = _a.httpType, method = _a.method, url = _a.url, status = httpCollectedData.response.status, elapsedTime = httpCollectedData.elapsedTime; var name = "".concat(httpType, "--").concat(method); if (status === 0) { message = elapsedTime <= globalVar.crossOriginThreshold ? 'http请求失败,失败原因:跨域限制或域名不存在' : 'http请求失败,失败原因:超时'; } else { message = fromHttpStatus(status); } message = message === "ok" ? message : "".concat(message, " ").concat(getRealPath(url)); return __assign(__assign({}, httpCollectedData), { type: "HTTP", url: getCurrentRoute(), level: Severity.Low, message: message, name: name }); } function httpTransformedDataConsumer(transformedData) { var type = "Xhr"; var status = transformedData.response.status, time = transformedData.time; var isError = status === 0 || status === 400 || status > 401; addBreadcrumbInWx.call(this, transformedData, type, Severity.Info, { time: time }); if (isError) { var breadcrumbStack = this.breadcrumb.push({ type: type, category: "exception", data: __assign({}, transformedData), level: Severity.Error, time: time }); this.transport.send(transformedData, breadcrumbStack); } } var wxRoutePlugin = { name: "route", monitor: function (notify) { monitorWxRoute.call(this, notify); }, transform: function (collectedData) { var reportData = { type: "ROUTE", message: collectedData.message, url: collectedData.to, name: 'MINI_' + "ROUTE", level: Severity.Error }; return { data: reportData, collectedData: collectedData }; }, consumer: function (transformedData) { var data = transformedData.data, collectedData = transformedData.collectedData; if (collectedData.isFail) { var breadcrumbStack = addBreadcrumbInWx.call(this, collectedData, "Code Error", Severity.Error); return this.transport.send(data, breadcrumbStack); } addBreadcrumbInWx.call(this, collectedData, "Route"); } }; function monitorWxRoute(notify) { var wxOptions = this.options; var methods = [ "switchTab", "reLaunch", "redirectTo", "navigateTo", "navigateBack", "navigateToMiniProgram" ]; methods.forEach(function (method) { var originMethod = wx[method]; Object.defineProperty(wx, method, { writable: true, enumerable: true, configurable: true, value: function (options) { var toUrl; if (method === "navigateBack") { toUrl = getNavigateBackTargetUrl(options === null || options === void 0 ? void 0 : options.delta); } else { toUrl = options.url; } var data = { from: getCurrentRoute(), to: toUrl }; notify("route", data); if (variableTypeDetection.isFunction(options.complete) || variableTypeDetection.isFunction(options.success) || variableTypeDetection.isFunction(options.fail)) { var _fail_1 = options.fail; var failHandler = function (res) { var failData = __assign(__assign({}, data), { isFail: true, message: res.errMsg }); notify("route", failData); if (variableTypeDetection.isFunction(_fail_1)) { return _fail_1(res); } }; options.fail = failHandler; } if (method === "navigateToMiniProgram" && variableTypeDetection.isFunction(wxOptions.wxNavigateToMiniProgram)) { options = wxOptions.wxNavigateToMiniProgram(options); } return originMethod.call(this, options); } }); }); } var WxOptions = (function (_super) { __extends(WxOptions, _super); function WxOptions(options) { var _this = _super.call(this) || this; _this.appOnLaunch = function () { }; _this.appOnShow = function () { }; _this.appOnHide = function () { }; _this.pageOnLoad = function () { }; _this.pageOnShow = function () { }; _this.pageOnReady = function () { }; _this.pageOnHide = function () { }; _this.pageOnUnload = function () { }; _this.appOnPageNotFound = function () { }; _this.pageOnShareAppMessage = function () { }; _this.pageOnShareTimeline = function () { }; _this.pageOnTabItemTap = function () { }; _this.triggerWxEvent = function () { }; _super.prototype.bindOptions.call(_this, options); _this.bindOptions(options); return _this; } WxOptions.prototype.bindOptions = function (options) { var beforeAppAjaxSend = options.beforeAppAjaxSend, appOnLaunch = options.appOnLaunch, appOnShow = options.appOnShow, appOnHide = options.appOnHide, appOnPageNotFound = options.appOnPageNotFound, pageOnLoad = options.pageOnLoad, pageOnReady = options.pageOnReady, pageOnShow = options.pageOnShow, pageOnUnload = options.pageOnUnload, pageOnHide = options.pageOnHide, pageOnShareAppMessage = options.pageOnShareAppMessage, pageOnShareTimeline = options.pageOnShareTimeline, pageOnTabItemTap = options.pageOnTabItemTap, wxNavigateToMiniProgram = options.wxNavigateToMiniProgram, triggerWxEvent = options.triggerWxEvent, silentRequest = options.silentRequest, silentConsole = options.silentConsole, silentDom = options.silentDom, silentRoute = options.silentRoute, silentAppOnError = options.silentAppOnError, silentAppOnUnhandledRejection = options.silentAppOnUnhandledRejection, silentAppOnPageNotFound = options.silentAppOnPageNotFound, silentPageOnShareAppMessage = options.silentPageOnShareAppMessage, silentPageOnShareTimeline = options.silentPageOnShareTimeline; var booleanType = "Boolean"; var functionType = "Function"; var optionArr = [ [silentRequest, 'silentRequest', booleanType], [silentConsole, 'silentConsole', booleanType], [silentDom, 'silentDom', booleanType], [silentRoute, 'silentRoute', booleanType], [silentAppOnError, 'silentAppOnError', booleanType], [silentAppOnUnhandledRejection, 'silentAppOnUnhandledRejection', booleanType], [silentAppOnPageNotFound, 'silentAppOnPageNotFound', booleanType], [silentPageOnShareAppMessage, 'silentPageOnShareAppMessage', booleanType], [silentPageOnShareTimeline, 'silentPageOnShareTimeline', booleanType], [beforeAppAjaxSend, 'beforeAppAjaxSend', functionType], [appOnLaunch, 'appOnLaunch', functionType], [appOnShow, 'appOnShow', functionType], [appOnHide, 'appOnHide', functionType], [appOnPageNotFound, 'appOnPageNotFound', functionType], [pageOnLoad, 'pageOnLoad', functionType], [pageOnReady, 'pageOnReady', functionType], [pageOnShow, 'pageOnShow', functionType], [pageOnUnload, 'pageOnUnload', functionType], [pageOnHide, 'pageOnHide', functionType], [pageOnShareAppMessage, 'pageOnShareAppMessage', functionType], [pageOnShareTimeline, 'pageOnShareTimeline', functionType], [pageOnTabItemTap, 'pageOnTabItemTap', functionType], [wxNavigateToMiniProgram, 'wxNavigateToMiniProgram', functionType], [triggerWxEvent, 'triggerWxEvent', functionType] ]; validateOptionsAndSet.call(this, optionArr); }; return WxOptions; }(BaseOptions)); var WxTransport = (function (_super) { __extends(WxTransport, _super); function WxTransport(options) { if (options === void 0) { options = {}; } var _this = _super.call(this) || this; _this.useImgUpload = false; _super.prototype.bindOptions.call(_this, options); _this.bindOptions(options); return _this; } WxTransport.prototype.post = function (data, url) { var _this = this; var requestFun = function () { var requestOptions = { method: 'POST' }; if (typeof _this.configReportWxRequest === 'function') { var params = _this.configReportWxRequest(data); requestOptions = __assign(__assign({}, requestOptions), params); } requestOptions = __assign(__assign({}, requestOptions), { data: JSON.stringify(data), url: url }); wx.request(requestOptions); }; this.queue.addTask(requestFun); }; WxTransport.prototype.sendToServer = function (data, url) { return this.post(data, url); }; WxTransport.prototype.getTransportData = function (data) { return { authInfo: this.getAuthInfo(), data: data, deviceInfo: _support.deviceInfo }; }; WxTransport.prototype.bindOptions = function (options) { if (options === void 0) { options = {}; } var configReportWxRequest = options.configReportWxRequest; toStringValidateOption(configReportWxRequest, 'configReportWxRequest', "Function") && (this.configReportWxRequest = configReportWxRequest); }; return WxTransport; }(BaseTransport)); var WxClient = (function (_super) { __extends(WxClient, _super); function WxClient(options) { if (options === void 0) { options = {}; } var _this = _super.call(this, options) || this; _this.options = new WxOptions(options); _this.transport = new WxTransport(options); _this.breadcrumb = new Breadcrumb(options); return _this; } WxClient.prototype.isPluginEnable = function (name) { var silentField = "".concat(Silent).concat(firstStrtoUppercase(name)); return !this.options[silentField]; }; WxClient.prototype.log = function (data) { var _a = data.message, message = _a === void 0 ? MitoLogEmptyMsg : _a, _b = data.tag, tag = _b === void 0 ? MitoLogEmptyTag : _b, _c = data.level, level = _c === void 0 ? Severity.Critical : _c, _d = data.ex, ex = _d === void 0 ? '' : _d; var errorInfo = {}; if (isError(ex)) { errorInfo = extractErrorStack(ex, level); } var reportData = __assign({ type: "LOG", level: level, message: unknownToString(message), name: MitoLog, customTag: unknownToString(tag), time: getTimestamp(), url: getCurrentRoute() }, errorInfo); var breadcrumbStack = addBreadcrumbInWx.call(this, message, "Customer", Severity.fromString(level.toString())); this.transport.send(reportData, breadcrumbStack); }; WxClient.prototype.trackSend = function (trackData) { this.transport.send(__assign({ isTrack: true }, trackData), this.breadcrumb.getStack()); }; return WxClient; }(BaseClient)); function createWxInstance(options, plugins) { if (plugins === void 0) { plugins = []; } var wxClient = new WxClient(options); var wxPlugins = __spreadArray(__spreadArray(__spreadArray([wxRequestPlugin, wxRoutePlugin, wxConsolePlugin, wxDomPlugin], wxAppPlugins, true), wxPagePlugins, true), plugins, true); wxClient.use(wxPlugins); return wxClient; } var init = createWxInstance; export { WxClient, init }; /* follow me on Github! @cjinhuo */ //# sourceMappingURL=wx-mini.esm.js.map