@mitojs/wx-mini
Version:
A SDK For Monitoring wx-mini Errors
924 lines (910 loc) • 39.4 kB
JavaScript
/* @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