{"version":3,"file":"js/119be1f94428bc817d2a.chunk.js","mappings":"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","sources":["webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Helpers.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/HelperFuncs.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Enums.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/StorageHelperFuncs.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/applicationinsights-common.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Common/DataSanitizer.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/TelemetryItemCreator.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Event.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Trace.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Common/DataPoint.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Metric.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/PageView.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/PageViewPerformance.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/node_modules/@microsoft/applicationinsights-shims/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/node_modules/@microsoft/applicationinsights-shims/dist-esm/Helpers.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Exception.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/DomHelperFuncs.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/RequestResponseHeaders.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/UrlHelperFuncs.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Util.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/RemoteDependencyData.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/InstrumentHooks.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/JavaScriptSDK/Telemetry/PageViewManager.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/JavaScriptSDK/Telemetry/PageViewPerformanceManager.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/JavaScriptSDK/Telemetry/PageVisitTimeManager.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/JavaScriptSDK/Timing.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-analytics-js/dist-esm/JavaScriptSDK/AnalyticsPlugin.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Helpers.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Interfaces/Contracts/ContextTagKeys.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Interfaces/PartAExtensions.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Common/Envelope.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Telemetry/Common/Data.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/InternalConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/EnvelopeCreator.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/Offline.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/SendBuffer.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/Sender.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/Serializer.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/TelemetryProcessors/SamplingScoreGenerators/HashCodeScoreGenerator.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/TelemetryProcessors/SamplingScoreGenerators/SamplingScoreGenerator.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-channel-js/dist-esm/TelemetryProcessors/Sample.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/ConnectionStringParser.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-common/dist-esm/Interfaces/IConfig.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/ChannelController.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/TelemetryInitializerPlugin.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/BaseCore.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/NotificationManager.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK/AppInsightsCore.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Helpers.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/dist-esm/InternalConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/dist-esm/ajaxRecord.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-dependencies-js/dist-esm/ajax.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Constants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/Helpers.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/node_modules/@microsoft/applicationinsights-shims/dist-esm/TsLibShims.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/Application.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/Device.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/Internal.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/Location.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/Session.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/TelemetryTrace.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/Context/User.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/TelemetryContext.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-properties-js/dist-esm/PropertiesPlugin.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-web/dist-esm/InternalConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-web/dist-esm/Initialization.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-web/dist-esm/__DynamicConstants.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-web/dist-esm/ApplicationInsightsDeprecated.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-core-js/dist-esm/JavaScriptSDK.Enums/LoggingEnums.js","webpack://helloFlexReact/./node_modules/@microsoft/applicationinsights-web/dist-esm/ApplicationInsightsContainer.js"],"sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strShimHasOwnProperty = \"hasOwnProperty\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\nexport var ObjAssign = ObjClass[\"assign\"];\r\nexport var ObjCreate = ObjClass[\"create\"];\r\nexport var ObjDefineProperty = ObjClass[\"defineProperty\"];\r\nexport var ObjHasOwnProperty = ObjProto[strShimHasOwnProperty];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjCreate, strShimFunction, strShimObject, strShimPrototype, strShimUndefined } from \"./Constants\";\r\nvar _cachedGlobal = null;\r\n/**\r\n * Returns the current global scope object, for a normal web page this will be the current\r\n * window, for a Web Worker this will be current worker global scope via \"self\". The internal\r\n * implementation returns the first available instance object in the following order\r\n * - globalThis (New standard)\r\n * - self (Will return the current window instance for supported browsers)\r\n * - window (fallback for older browser implementations)\r\n * - global (NodeJS standard)\r\n * - (When all else fails)\r\n * While the return type is a Window for the normal case, not all environments will support all\r\n * of the properties or functions.\r\n */\r\nexport function getGlobal(useCached) {\r\n if (useCached === void 0) { useCached = true; }\r\n var result = useCached === false ? null : _cachedGlobal;\r\n if (!result) {\r\n if (typeof globalThis !== strShimUndefined) {\r\n result = globalThis;\r\n }\r\n if (!result && typeof self !== strShimUndefined) {\r\n result = self;\r\n }\r\n if (!result && typeof window !== strShimUndefined) {\r\n result = window;\r\n }\r\n if (!result && typeof global !== strShimUndefined) {\r\n result = global;\r\n }\r\n _cachedGlobal = result;\r\n }\r\n return result;\r\n}\r\nexport function throwTypeError(message) {\r\n throw new TypeError(message);\r\n}\r\n/**\r\n * Creates an object that has the specified prototype, and that optionally contains specified properties. This helper exists to avoid adding a polyfil\r\n * for older browsers that do not define Object.create eg. ES3 only, IE8 just in case any page checks for presence/absence of the prototype implementation.\r\n * Note: For consistency this will not use the Object.create implementation if it exists as this would cause a testing requirement to test with and without the implementations\r\n * @param obj Object to use as a prototype. May be null\r\n */\r\nexport function objCreateFn(obj) {\r\n var func = ObjCreate;\r\n // Use build in Object.create\r\n if (func) {\r\n // Use Object create method if it exists\r\n return func(obj);\r\n }\r\n if (obj == null) {\r\n return {};\r\n }\r\n var type = typeof obj;\r\n if (type !== strShimObject && type !== strShimFunction) {\r\n throwTypeError(\"Object prototype may only be an Object:\" + obj);\r\n }\r\n function tmpFunc() { }\r\n tmpFunc[strShimPrototype] = obj;\r\n return new tmpFunc();\r\n}\r\n//# sourceMappingURL=Helpers.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_SPLIT = \"split\"; // Count: 6\r\nexport var _DYN_LENGTH = \"length\"; // Count: 41\r\nexport var _DYN_TO_LOWER_CASE = \"toLowerCase\"; // Count: 6\r\nexport var _DYN_INGESTIONENDPOINT = \"ingestionendpoint\"; // Count: 4\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 12\r\nexport var _DYN_REMOVE_ITEM = \"removeItem\"; // Count: 3\r\nexport var _DYN_NAME = \"name\"; // Count: 11\r\nexport var _DYN_MESSAGE = \"message\"; // Count: 10\r\nexport var _DYN_COUNT = \"count\"; // Count: 8\r\nexport var _DYN_PRE_TRIGGER_DATE = \"preTriggerDate\"; // Count: 4\r\nexport var _DYN_DISABLED = \"disabled\"; // Count: 3\r\nexport var _DYN_INTERVAL = \"interval\"; // Count: 3\r\nexport var _DYN_DAYS_OF_MONTH = \"daysOfMonth\"; // Count: 3\r\nexport var _DYN_DATE = \"date\"; // Count: 5\r\nexport var _DYN_GET_UTCDATE = \"getUTCDate\"; // Count: 3\r\nexport var _DYN_STRINGIFY = \"stringify\"; // Count: 4\r\nexport var _DYN_PATHNAME = \"pathname\"; // Count: 4\r\nexport var _DYN_CORRELATION_HEADER_E0 = \"correlationHeaderExcludePatterns\"; // Count: 2\r\nexport var _DYN_INDEX_OF = \"indexOf\"; // Count: 4\r\nexport var _DYN_EXTENSION_CONFIG = \"extensionConfig\"; // Count: 4\r\nexport var _DYN_EXCEPTIONS = \"exceptions\"; // Count: 6\r\nexport var _DYN_PARSED_STACK = \"parsedStack\"; // Count: 13\r\nexport var _DYN_PROPERTIES = \"properties\"; // Count: 9\r\nexport var _DYN_MEASUREMENTS = \"measurements\"; // Count: 9\r\nexport var _DYN_SIZE_IN_BYTES = \"sizeInBytes\"; // Count: 11\r\nexport var _DYN_TYPE_NAME = \"typeName\"; // Count: 11\r\nexport var _DYN_SEVERITY_LEVEL = \"severityLevel\"; // Count: 5\r\nexport var _DYN_PROBLEM_GROUP = \"problemGroup\"; // Count: 3\r\nexport var _DYN_IS_MANUAL = \"isManual\"; // Count: 3\r\nexport var _DYN__CREATE_FROM_INTERFA1 = \"CreateFromInterface\"; // Count: 2\r\nexport var _DYN_ASSEMBLY = \"assembly\"; // Count: 7\r\nexport var _DYN_HAS_FULL_STACK = \"hasFullStack\"; // Count: 6\r\nexport var _DYN_LEVEL = \"level\"; // Count: 5\r\nexport var _DYN_METHOD = \"method\"; // Count: 7\r\nexport var _DYN_FILE_NAME = \"fileName\"; // Count: 6\r\nexport var _DYN_LINE = \"line\"; // Count: 6\r\nexport var _DYN_DURATION = \"duration\"; // Count: 4\r\nexport var _DYN_RECEIVED_RESPONSE = \"receivedResponse\"; // Count: 2\r\nexport var _DYN_SUBSTRING = \"substring\"; // Count: 6\r\nexport var _DYN_SANITIZE_KEY_AND_ADD2 = \"sanitizeKeyAndAddUniqueness\"; // Count: 2\r\nexport var _DYN_SANITIZE_EXCEPTION = \"sanitizeException\"; // Count: 2\r\nexport var _DYN_SANITIZE_PROPERTIES = \"sanitizeProperties\"; // Count: 2\r\nexport var _DYN_SANITIZE_MEASUREMENT3 = \"sanitizeMeasurements\"; // Count: 2\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar strEmpty = \"\";\r\nexport function stringToBoolOrDefault(str, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = false; }\r\n if (str === undefined || str === null) {\r\n return defaultValue;\r\n }\r\n return str.toString()[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === \"true\";\r\n}\r\n/**\r\n * Convert ms to c# time span format\r\n */\r\nexport function msToTimeSpan(totalms) {\r\n if (isNaN(totalms) || totalms < 0) {\r\n totalms = 0;\r\n }\r\n totalms = Math.round(totalms);\r\n var ms = strEmpty + totalms % 1000;\r\n var sec = strEmpty + Math.floor(totalms / 1000) % 60;\r\n var min = strEmpty + Math.floor(totalms / (1000 * 60)) % 60;\r\n var hour = strEmpty + Math.floor(totalms / (1000 * 60 * 60)) % 24;\r\n var days = Math.floor(totalms / (1000 * 60 * 60 * 24));\r\n ms = ms[_DYN_LENGTH /* @min:%2elength */] === 1 ? \"00\" + ms : ms[_DYN_LENGTH /* @min:%2elength */] === 2 ? \"0\" + ms : ms;\r\n sec = sec[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + sec : sec;\r\n min = min[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + min : min;\r\n hour = hour[_DYN_LENGTH /* @min:%2elength */] < 2 ? \"0\" + hour : hour;\r\n return (days > 0 ? days + \".\" : strEmpty) + hour + \":\" + min + \":\" + sec + \".\" + ms;\r\n}\r\nexport function getExtensionByName(extensions, identifier) {\r\n var extension = null;\r\n arrForEach(extensions, function (value) {\r\n if (value.identifier === identifier) {\r\n extension = value;\r\n return -1;\r\n }\r\n });\r\n return extension;\r\n}\r\nexport function isCrossOriginError(message, url, lineNumber, columnNumber, error) {\r\n return !error && isString(message) && (message === \"Script error.\" || message === \"Script error\");\r\n}\r\n//# sourceMappingURL=HelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createEnumStyle } from \"@microsoft/applicationinsights-core-js\";\r\nexport var StorageType = createEnumStyle({\r\n LocalStorage: 0 /* eStorageType.LocalStorage */,\r\n SessionStorage: 1 /* eStorageType.SessionStorage */\r\n});\r\nexport var DistributedTracingModes = createEnumStyle({\r\n AI: 0 /* eDistributedTracingModes.AI */,\r\n AI_AND_W3C: 1 /* eDistributedTracingModes.AI_AND_W3C */,\r\n W3C: 2 /* eDistributedTracingModes.W3C */\r\n});\r\n//# sourceMappingURL=Enums.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _throwInternal, dumpObj, getExceptionName, getGlobal, getGlobalInst, isNullOrUndefined, objForEachKey } from \"@microsoft/applicationinsights-core-js\";\r\nimport { StorageType } from \"./Enums\";\r\nimport { _DYN_REMOVE_ITEM, _DYN_TO_STRING } from \"./__DynamicConstants\";\r\nvar _canUseLocalStorage = undefined;\r\nvar _canUseSessionStorage = undefined;\r\n/**\r\n * Gets the localStorage object if available\r\n * @return {Storage} - Returns the storage object if available else returns null\r\n */\r\nfunction _getLocalStorageObject() {\r\n if (utlCanUseLocalStorage()) {\r\n return _getVerifiedStorageObject(StorageType.LocalStorage);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Tests storage object (localStorage or sessionStorage) to verify that it is usable\r\n * More details here: https://mathiasbynens.be/notes/localstorage-pattern\r\n * @param storageType Type of storage\r\n * @return {Storage} Returns storage object verified that it is usable\r\n */\r\nfunction _getVerifiedStorageObject(storageType) {\r\n try {\r\n if (isNullOrUndefined(getGlobal())) {\r\n return null;\r\n }\r\n var uid = (new Date)[_DYN_TO_STRING /* @min:%2etoString */]();\r\n var storage = getGlobalInst(storageType === StorageType.LocalStorage ? \"localStorage\" : \"sessionStorage\");\r\n storage.setItem(uid, uid);\r\n var fail = storage.getItem(uid) !== uid;\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](uid);\r\n if (!fail) {\r\n return storage;\r\n }\r\n }\r\n catch (exception) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return null;\r\n}\r\n/**\r\n * Gets the sessionStorage object if available\r\n * @return {Storage} - Returns the storage object if available else returns null\r\n */\r\nfunction _getSessionStorageObject() {\r\n if (utlCanUseSessionStorage()) {\r\n return _getVerifiedStorageObject(StorageType.SessionStorage);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Disables the global SDK usage of local or session storage if available\r\n */\r\nexport function utlDisableStorage() {\r\n _canUseLocalStorage = false;\r\n _canUseSessionStorage = false;\r\n}\r\n/**\r\n * Re-enables the global SDK usage of local or session storage if available\r\n */\r\nexport function utlEnableStorage() {\r\n _canUseLocalStorage = utlCanUseLocalStorage(true);\r\n _canUseSessionStorage = utlCanUseSessionStorage(true);\r\n}\r\n/**\r\n * Returns whether LocalStorage can be used, if the reset parameter is passed a true this will override\r\n * any previous disable calls.\r\n * @param reset - Should the usage be reset and determined only based on whether LocalStorage is available\r\n */\r\nexport function utlCanUseLocalStorage(reset) {\r\n if (reset || _canUseLocalStorage === undefined) {\r\n _canUseLocalStorage = !!_getVerifiedStorageObject(StorageType.LocalStorage);\r\n }\r\n return _canUseLocalStorage;\r\n}\r\nexport function utlGetLocalStorage(logger, name) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n return storage.getItem(name);\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 1 /* _eInternalMessageId.BrowserCannotReadLocalStorage */, \"Browser failed read of local storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return null;\r\n}\r\nexport function utlSetLocalStorage(logger, name, data) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage.setItem(name, data);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 3 /* _eInternalMessageId.BrowserCannotWriteLocalStorage */, \"Browser failed write to local storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlRemoveStorage(logger, name) {\r\n var storage = _getLocalStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](name);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseLocalStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 5 /* _eInternalMessageId.BrowserFailedRemovalFromLocalStorage */, \"Browser failed removal of local storage item. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlCanUseSessionStorage(reset) {\r\n if (reset || _canUseSessionStorage === undefined) {\r\n _canUseSessionStorage = !!_getVerifiedStorageObject(StorageType.SessionStorage);\r\n }\r\n return _canUseSessionStorage;\r\n}\r\nexport function utlGetSessionStorageKeys() {\r\n var keys = [];\r\n if (utlCanUseSessionStorage()) {\r\n objForEachKey(getGlobalInst(\"sessionStorage\"), function (key) {\r\n keys.push(key);\r\n });\r\n }\r\n return keys;\r\n}\r\nexport function utlGetSessionStorage(logger, name) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n return storage.getItem(name);\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 2 /* _eInternalMessageId.BrowserCannotReadSessionStorage */, \"Browser failed read of session storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return null;\r\n}\r\nexport function utlSetSessionStorage(logger, name, data) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage.setItem(name, data);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 4 /* _eInternalMessageId.BrowserCannotWriteSessionStorage */, \"Browser failed write to session storage. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\nexport function utlRemoveSessionStorage(logger, name) {\r\n var storage = _getSessionStorageObject();\r\n if (storage !== null) {\r\n try {\r\n storage[_DYN_REMOVE_ITEM /* @min:%2eremoveItem */](name);\r\n return true;\r\n }\r\n catch (e) {\r\n _canUseSessionStorage = false;\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 6 /* _eInternalMessageId.BrowserFailedRemovalFromSessionStorage */, \"Browser failed removal of session storage item. \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return false;\r\n}\r\n//# sourceMappingURL=StorageHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n// Licensed under the\r\nexport { Util, CorrelationIdHelper, DateTimeUtils, dateTimeUtilsNow, dateTimeUtilsDuration, UrlHelper, isInternalApplicationInsightsEndpoint, createDistributedTraceContextFromTrace } from \"./Util\";\r\nexport { ThrottleMgr } from \"./ThrottleMgr\";\r\nexport { parseConnectionString, ConnectionStringParser } from \"./ConnectionStringParser\";\r\nexport { RequestHeaders } from \"./RequestResponseHeaders\";\r\nexport { DisabledPropertyName, ProcessLegacy, SampleRate, HttpMethod, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, strNotSpecified } from \"./Constants\";\r\nexport { Envelope } from \"./Telemetry/Common/Envelope\";\r\nexport { Event } from \"./Telemetry/Event\";\r\nexport { Exception } from \"./Telemetry/Exception\";\r\nexport { Metric } from \"./Telemetry/Metric\";\r\nexport { PageView } from \"./Telemetry/PageView\";\r\nexport { RemoteDependencyData } from \"./Telemetry/RemoteDependencyData\";\r\nexport { Trace } from \"./Telemetry/Trace\";\r\nexport { PageViewPerformance } from \"./Telemetry/PageViewPerformance\";\r\nexport { Data } from \"./Telemetry/Common/Data\";\r\nexport { SeverityLevel } from \"./Interfaces/Contracts/SeverityLevel\";\r\nexport { ConfigurationManager } from \"./Interfaces/IConfig\";\r\nexport { ContextTagKeys } from \"./Interfaces/Contracts/ContextTagKeys\";\r\nexport { DataSanitizer, dataSanitizeKeyAndAddUniqueness, dataSanitizeKey, dataSanitizeString, dataSanitizeUrl, dataSanitizeMessage, dataSanitizeException, dataSanitizeProperties, dataSanitizeMeasurements, dataSanitizeId, dataSanitizeInput, dsPadNumber } from \"./Telemetry/Common/DataSanitizer\";\r\nexport { TelemetryItemCreator, createTelemetryItem } from \"./TelemetryItemCreator\";\r\nexport { CtxTagKeys, Extensions } from \"./Interfaces/PartAExtensions\";\r\nexport { DistributedTracingModes } from \"./Enums\";\r\nexport { stringToBoolOrDefault, msToTimeSpan, getExtensionByName, isCrossOriginError } from \"./HelperFuncs\";\r\nexport { isBeaconsSupported as isBeaconApiSupported, createTraceParent, parseTraceParent, isValidTraceId, isValidSpanId, isValidTraceParent, isSampledFlag, formatTraceParent, findW3cTraceParent } from \"@microsoft/applicationinsights-core-js\";\r\nexport { createDomEvent } from \"./DomHelperFuncs\";\r\nexport { utlDisableStorage, utlEnableStorage, utlCanUseLocalStorage, utlGetLocalStorage, utlSetLocalStorage, utlRemoveStorage, utlCanUseSessionStorage, utlGetSessionStorageKeys, utlGetSessionStorage, utlSetSessionStorage, utlRemoveSessionStorage } from \"./StorageHelperFuncs\";\r\nexport { urlParseUrl, urlGetAbsoluteUrl, urlGetPathName, urlGetCompleteUrl, urlParseHost, urlParseFullHost } from \"./UrlHelperFuncs\";\r\nexport var PropertiesPluginIdentifier = \"AppInsightsPropertiesPlugin\";\r\nexport var BreezeChannelIdentifier = \"AppInsightsChannelPlugin\";\r\nexport var AnalyticsPluginIdentifier = \"ApplicationInsightsAnalytics\";\r\n//# sourceMappingURL=applicationinsights-common.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar _a;\r\nimport { _throwInternal, getJSON, hasJSON, isObject, objForEachKey, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_SANITIZE_EXCEPTION, _DYN_SANITIZE_KEY_AND_ADD2, _DYN_SANITIZE_MEASUREMENT3, _DYN_SANITIZE_PROPERTIES, _DYN_STRINGIFY, _DYN_SUBSTRING, _DYN_TO_STRING } from \"../../__DynamicConstants\";\r\nexport function dataSanitizeKeyAndAddUniqueness(logger, key, map) {\r\n var origLength = key[_DYN_LENGTH /* @min:%2elength */];\r\n var field = dataSanitizeKey(logger, key);\r\n // validation truncated the length. We need to add uniqueness\r\n if (field[_DYN_LENGTH /* @min:%2elength */] !== origLength) {\r\n var i = 0;\r\n var uniqueField = field;\r\n while (map[uniqueField] !== undefined) {\r\n i++;\r\n uniqueField = field[_DYN_SUBSTRING /* @min:%2esubstring */](0, 150 /* DataSanitizerValues.MAX_NAME_LENGTH */ - 3) + dsPadNumber(i);\r\n }\r\n field = uniqueField;\r\n }\r\n return field;\r\n}\r\nexport function dataSanitizeKey(logger, name) {\r\n var nameTrunc;\r\n if (name) {\r\n // Remove any leading or trailing whitespace\r\n name = strTrim(name[_DYN_TO_STRING /* @min:%2etoString */]());\r\n // truncate the string to 150 chars\r\n if (name[_DYN_LENGTH /* @min:%2elength */] > 150 /* DataSanitizerValues.MAX_NAME_LENGTH */) {\r\n nameTrunc = name[_DYN_SUBSTRING /* @min:%2esubstring */](0, 150 /* DataSanitizerValues.MAX_NAME_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 57 /* _eInternalMessageId.NameTooLong */, \"name is too long. It has been truncated to \" + 150 /* DataSanitizerValues.MAX_NAME_LENGTH */ + \" characters.\", { name: name }, true);\r\n }\r\n }\r\n return nameTrunc || name;\r\n}\r\nexport function dataSanitizeString(logger, value, maxLength) {\r\n if (maxLength === void 0) { maxLength = 1024 /* DataSanitizerValues.MAX_STRING_LENGTH */; }\r\n var valueTrunc;\r\n if (value) {\r\n maxLength = maxLength ? maxLength : 1024 /* DataSanitizerValues.MAX_STRING_LENGTH */; // in case default parameters dont work\r\n value = strTrim(value);\r\n if (value.toString()[_DYN_LENGTH /* @min:%2elength */] > maxLength) {\r\n valueTrunc = value[_DYN_TO_STRING /* @min:%2etoString */]()[_DYN_SUBSTRING /* @min:%2esubstring */](0, maxLength);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 61 /* _eInternalMessageId.StringValueTooLong */, \"string value is too long. It has been truncated to \" + maxLength + \" characters.\", { value: value }, true);\r\n }\r\n }\r\n return valueTrunc || value;\r\n}\r\nexport function dataSanitizeUrl(logger, url) {\r\n return dataSanitizeInput(logger, url, 2048 /* DataSanitizerValues.MAX_URL_LENGTH */, 66 /* _eInternalMessageId.UrlTooLong */);\r\n}\r\nexport function dataSanitizeMessage(logger, message) {\r\n var messageTrunc;\r\n if (message) {\r\n if (message[_DYN_LENGTH /* @min:%2elength */] > 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */) {\r\n messageTrunc = message[_DYN_SUBSTRING /* @min:%2esubstring */](0, 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 56 /* _eInternalMessageId.MessageTruncated */, \"message is too long, it has been truncated to \" + 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */ + \" characters.\", { message: message }, true);\r\n }\r\n }\r\n return messageTrunc || message;\r\n}\r\nexport function dataSanitizeException(logger, exception) {\r\n var exceptionTrunc;\r\n if (exception) {\r\n // Make surte its a string\r\n var value = \"\" + exception;\r\n if (value[_DYN_LENGTH /* @min:%2elength */] > 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */) {\r\n exceptionTrunc = value[_DYN_SUBSTRING /* @min:%2esubstring */](0, 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 52 /* _eInternalMessageId.ExceptionTruncated */, \"exception is too long, it has been truncated to \" + 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */ + \" characters.\", { exception: exception }, true);\r\n }\r\n }\r\n return exceptionTrunc || exception;\r\n}\r\nexport function dataSanitizeProperties(logger, properties) {\r\n if (properties) {\r\n var tempProps_1 = {};\r\n objForEachKey(properties, function (prop, value) {\r\n if (isObject(value) && hasJSON()) {\r\n // Stringify any part C properties\r\n try {\r\n value = getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 49 /* _eInternalMessageId.CannotSerializeObjectNonSerializable */, \"custom property is not valid\", { exception: e }, true);\r\n }\r\n }\r\n value = dataSanitizeString(logger, value, 8192 /* DataSanitizerValues.MAX_PROPERTY_LENGTH */);\r\n prop = dataSanitizeKeyAndAddUniqueness(logger, prop, tempProps_1);\r\n tempProps_1[prop] = value;\r\n });\r\n properties = tempProps_1;\r\n }\r\n return properties;\r\n}\r\nexport function dataSanitizeMeasurements(logger, measurements) {\r\n if (measurements) {\r\n var tempMeasurements_1 = {};\r\n objForEachKey(measurements, function (measure, value) {\r\n measure = dataSanitizeKeyAndAddUniqueness(logger, measure, tempMeasurements_1);\r\n tempMeasurements_1[measure] = value;\r\n });\r\n measurements = tempMeasurements_1;\r\n }\r\n return measurements;\r\n}\r\nexport function dataSanitizeId(logger, id) {\r\n return id ? dataSanitizeInput(logger, id, 128 /* DataSanitizerValues.MAX_ID_LENGTH */, 69 /* _eInternalMessageId.IdTooLong */)[_DYN_TO_STRING /* @min:%2etoString */]() : id;\r\n}\r\nexport function dataSanitizeInput(logger, input, maxLength, _msgId) {\r\n var inputTrunc;\r\n if (input) {\r\n input = strTrim(input);\r\n if (input[_DYN_LENGTH /* @min:%2elength */] > maxLength) {\r\n inputTrunc = input[_DYN_SUBSTRING /* @min:%2esubstring */](0, maxLength);\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, _msgId, \"input is too long, it has been truncated to \" + maxLength + \" characters.\", { data: input }, true);\r\n }\r\n }\r\n return inputTrunc || input;\r\n}\r\nexport function dsPadNumber(num) {\r\n var s = \"00\" + num;\r\n return s.substr(s[_DYN_LENGTH /* @min:%2elength */] - 3);\r\n}\r\n/**\r\n * Provides the DataSanitizer functions within the previous namespace.\r\n */\r\nexport var DataSanitizer = (_a = {\r\n MAX_NAME_LENGTH: 150 /* DataSanitizerValues.MAX_NAME_LENGTH */,\r\n MAX_ID_LENGTH: 128 /* DataSanitizerValues.MAX_ID_LENGTH */,\r\n MAX_PROPERTY_LENGTH: 8192 /* DataSanitizerValues.MAX_PROPERTY_LENGTH */,\r\n MAX_STRING_LENGTH: 1024 /* DataSanitizerValues.MAX_STRING_LENGTH */,\r\n MAX_URL_LENGTH: 2048 /* DataSanitizerValues.MAX_URL_LENGTH */,\r\n MAX_MESSAGE_LENGTH: 32768 /* DataSanitizerValues.MAX_MESSAGE_LENGTH */,\r\n MAX_EXCEPTION_LENGTH: 32768 /* DataSanitizerValues.MAX_EXCEPTION_LENGTH */\r\n },\r\n _a[_DYN_SANITIZE_KEY_AND_ADD2 /* @min:sanitizeKeyAndAddUniqueness */] = dataSanitizeKeyAndAddUniqueness,\r\n _a.sanitizeKey = dataSanitizeKey,\r\n _a.sanitizeString = dataSanitizeString,\r\n _a.sanitizeUrl = dataSanitizeUrl,\r\n _a.sanitizeMessage = dataSanitizeMessage,\r\n _a[_DYN_SANITIZE_EXCEPTION /* @min:sanitizeException */] = dataSanitizeException,\r\n _a[_DYN_SANITIZE_PROPERTIES /* @min:sanitizeProperties */] = dataSanitizeProperties,\r\n _a[_DYN_SANITIZE_MEASUREMENT3 /* @min:sanitizeMeasurements */] = dataSanitizeMeasurements,\r\n _a.sanitizeId = dataSanitizeId,\r\n _a.sanitizeInput = dataSanitizeInput,\r\n _a.padNumber = dsPadNumber,\r\n _a.trim = strTrim,\r\n _a);\r\n//# sourceMappingURL=DataSanitizer.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n/**\r\n * This is an internal property used to cause internal (reporting) requests to be ignored from reporting\r\n * additional telemetry, to handle polyfil implementations ALL urls used with a disabled request will\r\n * also be ignored for future requests even when this property is not provided.\r\n * Tagging as Ignore as this is an internal value and is not expected to be used outside of the SDK\r\n * @ignore\r\n */\r\nexport var DisabledPropertyName = \"Microsoft_ApplicationInsights_BypassAjaxInstrumentation\";\r\nexport var SampleRate = \"sampleRate\";\r\nexport var ProcessLegacy = \"ProcessLegacy\";\r\nexport var HttpMethod = \"http.method\";\r\nexport var DEFAULT_BREEZE_ENDPOINT = \"https://dc.services.visualstudio.com\";\r\nexport var DEFAULT_BREEZE_PATH = \"/v2/track\";\r\nexport var strNotSpecified = \"not_specified\";\r\nexport var strIkey = \"iKey\";\r\n//# sourceMappingURL=Constants.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { isNullOrUndefined, objForEachKey, throwError, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strIkey, strNotSpecified } from \"./Constants\";\r\nimport { dataSanitizeString } from \"./Telemetry/Common/DataSanitizer\";\r\nimport { _DYN_NAME } from \"./__DynamicConstants\";\r\n/**\r\n * Create a telemetry item that the 1DS channel understands\r\n * @param item domain specific properties; part B\r\n * @param baseType telemetry item type. ie PageViewData\r\n * @param envelopeName name of the envelope. ie Microsoft.ApplicationInsights..PageView\r\n * @param customProperties user defined custom properties; part C\r\n * @param systemProperties system properties that are added to the context; part A\r\n * @returns ITelemetryItem that is sent to channel\r\n */\r\nexport function createTelemetryItem(item, baseType, envelopeName, logger, customProperties, systemProperties) {\r\n var _a;\r\n envelopeName = dataSanitizeString(logger, envelopeName) || strNotSpecified;\r\n if (isNullOrUndefined(item) ||\r\n isNullOrUndefined(baseType) ||\r\n isNullOrUndefined(envelopeName)) {\r\n throwError(\"Input doesn't contain all required fields\");\r\n }\r\n var iKey = \"\";\r\n if (item[strIkey]) {\r\n iKey = item[strIkey];\r\n delete item[strIkey];\r\n }\r\n var telemetryItem = (_a = {},\r\n _a[_DYN_NAME /* @min:name */] = envelopeName,\r\n _a.time = toISOString(new Date()),\r\n _a.iKey = iKey,\r\n _a.ext = systemProperties ? systemProperties : {},\r\n _a.tags = [],\r\n _a.data = {},\r\n _a.baseType = baseType,\r\n _a.baseData = item // Part B\r\n ,\r\n _a);\r\n // Part C\r\n if (!isNullOrUndefined(customProperties)) {\r\n objForEachKey(customProperties, function (prop, value) {\r\n telemetryItem.data[prop] = value;\r\n });\r\n }\r\n return telemetryItem;\r\n}\r\nvar TelemetryItemCreator = /** @class */ (function () {\r\n function TelemetryItemCreator() {\r\n }\r\n /**\r\n * Create a telemetry item that the 1DS channel understands\r\n * @param item domain specific properties; part B\r\n * @param baseType telemetry item type. ie PageViewData\r\n * @param envelopeName name of the envelope. ie Microsoft.ApplicationInsights..PageView\r\n * @param customProperties user defined custom properties; part C\r\n * @param systemProperties system properties that are added to the context; part A\r\n * @returns ITelemetryItem that is sent to channel\r\n */\r\n TelemetryItemCreator.create = createTelemetryItem;\r\n return TelemetryItemCreator;\r\n}());\r\nexport { TelemetryItemCreator };\r\n//# sourceMappingURL=TelemetryItemCreator.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\nvar Event = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the EventTelemetry object\r\n */\r\n function Event(logger, name, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 1 /* FieldType.Required */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n Event.envelopeType = \"Microsoft.ApplicationInsights.{0}.Event\";\r\n Event.dataType = \"EventData\";\r\n return Event;\r\n}());\r\nexport { Event };\r\n//# sourceMappingURL=Event.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_MEASUREMENTS, _DYN_MESSAGE, _DYN_PROPERTIES, _DYN_SEVERITY_LEVEL } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeMessage, dataSanitizeProperties } from \"./Common/DataSanitizer\";\r\nvar Trace = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the TraceTelemetry object\r\n */\r\n function Trace(logger, message, severityLevel, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n message: 1 /* FieldType.Required */,\r\n severityLevel: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n message = message || strNotSpecified;\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] = dataSanitizeMessage(logger, message);\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (severityLevel) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = severityLevel;\r\n }\r\n }\r\n Trace.envelopeType = \"Microsoft.ApplicationInsights.{0}.Message\";\r\n Trace.dataType = \"MessageData\";\r\n return Trace;\r\n}());\r\nexport { Trace };\r\n//# sourceMappingURL=Trace.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar DataPoint = /** @class */ (function () {\r\n function DataPoint() {\r\n /**\r\n * The data contract for serializing this object.\r\n */\r\n this.aiDataContract = {\r\n name: 1 /* FieldType.Required */,\r\n kind: 0 /* FieldType.Default */,\r\n value: 1 /* FieldType.Required */,\r\n count: 0 /* FieldType.Default */,\r\n min: 0 /* FieldType.Default */,\r\n max: 0 /* FieldType.Default */,\r\n stdDev: 0 /* FieldType.Default */\r\n };\r\n /**\r\n * Metric type. Single measurement or the aggregated value.\r\n */\r\n this.kind = 0 /* DataPointType.Measurement */;\r\n }\r\n return DataPoint;\r\n}());\r\nexport { DataPoint };\r\n//# sourceMappingURL=DataPoint.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_COUNT, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { DataPoint } from \"./Common/DataPoint\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\nvar Metric = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the MetricTelemetry object\r\n */\r\n function Metric(logger, name, value, count, min, max, stdDev, properties, measurements) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n metrics: 1 /* FieldType.Required */,\r\n properties: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n var dataPoint = new DataPoint();\r\n dataPoint[_DYN_COUNT /* @min:%2ecount */] = count > 0 ? count : undefined;\r\n dataPoint.max = isNaN(max) || max === null ? undefined : max;\r\n dataPoint.min = isNaN(min) || min === null ? undefined : min;\r\n dataPoint[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n dataPoint.value = value;\r\n dataPoint.stdDev = isNaN(stdDev) || stdDev === null ? undefined : stdDev;\r\n _self.metrics = [dataPoint];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n Metric.envelopeType = \"Microsoft.ApplicationInsights.{0}.Metric\";\r\n Metric.dataType = \"MetricData\";\r\n return Metric;\r\n}());\r\nexport { Metric };\r\n//# sourceMappingURL=Metric.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { msToTimeSpan } from \"../HelperFuncs\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeId, dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar PageView = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the PageEventTelemetry object\r\n */\r\n function PageView(logger, name, url, durationMs, properties, measurements, id) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n url: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */,\r\n id: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.id = dataSanitizeId(logger, id);\r\n _self.url = dataSanitizeUrl(logger, url);\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n if (!isNaN(durationMs)) {\r\n _self[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(durationMs);\r\n }\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n PageView.envelopeType = \"Microsoft.ApplicationInsights.{0}.Pageview\";\r\n PageView.dataType = \"PageviewData\";\r\n return PageView;\r\n}());\r\nexport { PageView };\r\n//# sourceMappingURL=PageView.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES, _DYN_RECEIVED_RESPONSE } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar PageViewPerformance = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the PageEventTelemetry object\r\n */\r\n function PageViewPerformance(logger, name, url, unused, properties, measurements, cs4BaseData) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n url: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n perfTotal: 0 /* FieldType.Default */,\r\n networkConnect: 0 /* FieldType.Default */,\r\n sentRequest: 0 /* FieldType.Default */,\r\n receivedResponse: 0 /* FieldType.Default */,\r\n domProcessing: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.url = dataSanitizeUrl(logger, url);\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (cs4BaseData) {\r\n _self.domProcessing = cs4BaseData.domProcessing;\r\n _self[_DYN_DURATION /* @min:%2eduration */] = cs4BaseData[_DYN_DURATION /* @min:%2eduration */];\r\n _self.networkConnect = cs4BaseData.networkConnect;\r\n _self.perfTotal = cs4BaseData.perfTotal;\r\n _self[_DYN_RECEIVED_RESPONSE /* @min:%2ereceivedResponse */] = cs4BaseData[_DYN_RECEIVED_RESPONSE /* @min:%2ereceivedResponse */];\r\n _self.sentRequest = cs4BaseData.sentRequest;\r\n }\r\n }\r\n PageViewPerformance.envelopeType = \"Microsoft.ApplicationInsights.{0}.PageviewPerformance\";\r\n PageViewPerformance.dataType = \"PageviewPerformanceData\";\r\n return PageViewPerformance;\r\n}());\r\nexport { PageViewPerformance };\r\n//# sourceMappingURL=PageViewPerformance.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strShimHasOwnProperty = \"hasOwnProperty\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\nexport var ObjAssign = ObjClass[\"assign\"];\r\nexport var ObjCreate = ObjClass[\"create\"];\r\nexport var ObjDefineProperty = ObjClass[\"defineProperty\"];\r\nexport var ObjHasOwnProperty = ObjProto[strShimHasOwnProperty];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjCreate, strShimFunction, strShimObject, strShimPrototype, strShimUndefined } from \"./Constants\";\r\nvar _cachedGlobal = null;\r\n/**\r\n * Returns the current global scope object, for a normal web page this will be the current\r\n * window, for a Web Worker this will be current worker global scope via \"self\". The internal\r\n * implementation returns the first available instance object in the following order\r\n * - globalThis (New standard)\r\n * - self (Will return the current window instance for supported browsers)\r\n * - window (fallback for older browser implementations)\r\n * - global (NodeJS standard)\r\n * - (When all else fails)\r\n * While the return type is a Window for the normal case, not all environments will support all\r\n * of the properties or functions.\r\n */\r\nexport function getGlobal(useCached) {\r\n if (useCached === void 0) { useCached = true; }\r\n var result = useCached === false ? null : _cachedGlobal;\r\n if (!result) {\r\n if (typeof globalThis !== strShimUndefined) {\r\n result = globalThis;\r\n }\r\n if (!result && typeof self !== strShimUndefined) {\r\n result = self;\r\n }\r\n if (!result && typeof window !== strShimUndefined) {\r\n result = window;\r\n }\r\n if (!result && typeof global !== strShimUndefined) {\r\n result = global;\r\n }\r\n _cachedGlobal = result;\r\n }\r\n return result;\r\n}\r\nexport function throwTypeError(message) {\r\n throw new TypeError(message);\r\n}\r\n/**\r\n * Creates an object that has the specified prototype, and that optionally contains specified properties. This helper exists to avoid adding a polyfil\r\n * for older browsers that do not define Object.create eg. ES3 only, IE8 just in case any page checks for presence/absence of the prototype implementation.\r\n * Note: For consistency this will not use the Object.create implementation if it exists as this would cause a testing requirement to test with and without the implementations\r\n * @param obj Object to use as a prototype. May be null\r\n */\r\nexport function objCreateFn(obj) {\r\n var func = ObjCreate;\r\n // Use build in Object.create\r\n if (func) {\r\n // Use Object create method if it exists\r\n return func(obj);\r\n }\r\n if (obj == null) {\r\n return {};\r\n }\r\n var type = typeof obj;\r\n if (type !== strShimObject && type !== strShimFunction) {\r\n throwTypeError(\"Object prototype may only be an Object:\" + obj);\r\n }\r\n function tmpFunc() { }\r\n tmpFunc[strShimPrototype] = obj;\r\n return new tmpFunc();\r\n}\r\n//# sourceMappingURL=Helpers.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { __assignFn as __assign } from \"@microsoft/applicationinsights-shims\";\r\nimport { arrForEach, arrMap, isArray, isError, isFunction, isNullOrUndefined, isObject, isString, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strNotSpecified } from \"../Constants\";\r\nimport { _DYN_ASSEMBLY, _DYN_EXCEPTIONS, _DYN_FILE_NAME, _DYN_HAS_FULL_STACK, _DYN_INDEX_OF, _DYN_IS_MANUAL, _DYN_LENGTH, _DYN_LEVEL, _DYN_LINE, _DYN_MEASUREMENTS, _DYN_MESSAGE, _DYN_METHOD, _DYN_NAME, _DYN_PARSED_STACK, _DYN_PROBLEM_GROUP, _DYN_PROPERTIES, _DYN_SEVERITY_LEVEL, _DYN_SIZE_IN_BYTES, _DYN_SPLIT, _DYN_STRINGIFY, _DYN_TO_STRING, _DYN_TYPE_NAME, _DYN__CREATE_FROM_INTERFA1 } from \"../__DynamicConstants\";\r\nimport { dataSanitizeException, dataSanitizeMeasurements, dataSanitizeMessage, dataSanitizeProperties, dataSanitizeString } from \"./Common/DataSanitizer\";\r\nvar NoMethod = \"\";\r\nvar strError = \"error\";\r\nvar strStack = \"stack\";\r\nvar strStackDetails = \"stackDetails\";\r\nvar strErrorSrc = \"errorSrc\";\r\nvar strMessage = \"message\";\r\nvar strDescription = \"description\";\r\nfunction _stringify(value, convertToString) {\r\n var result = value;\r\n if (result && !isString(result)) {\r\n if (JSON && JSON[_DYN_STRINGIFY /* @min:%2estringify */]) {\r\n result = JSON[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n if (convertToString && (!result || result === \"{}\")) {\r\n if (isFunction(value[_DYN_TO_STRING /* @min:%2etoString */])) {\r\n result = value[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n else {\r\n result = \"\" + value;\r\n }\r\n }\r\n }\r\n else {\r\n result = \"\" + value + \" - (Missing JSON.stringify)\";\r\n }\r\n }\r\n return result || \"\";\r\n}\r\nfunction _formatMessage(theEvent, errorType) {\r\n var evtMessage = theEvent;\r\n if (theEvent) {\r\n if (evtMessage && !isString(evtMessage)) {\r\n evtMessage = theEvent[strMessage] || theEvent[strDescription] || evtMessage;\r\n }\r\n // Make sure the message is a string\r\n if (evtMessage && !isString(evtMessage)) {\r\n // tslint:disable-next-line: prefer-conditional-expression\r\n evtMessage = _stringify(evtMessage, true);\r\n }\r\n if (theEvent[\"filename\"]) {\r\n // Looks like an event object with filename\r\n evtMessage = evtMessage + \" @\" + (theEvent[\"filename\"] || \"\") + \":\" + (theEvent[\"lineno\"] || \"?\") + \":\" + (theEvent[\"colno\"] || \"?\");\r\n }\r\n }\r\n // Automatically add the error type to the message if it does already appear to be present\r\n if (errorType && errorType !== \"String\" && errorType !== \"Object\" && errorType !== \"Error\" && (evtMessage || \"\")[_DYN_INDEX_OF /* @min:%2eindexOf */](errorType) === -1) {\r\n evtMessage = errorType + \": \" + evtMessage;\r\n }\r\n return evtMessage || \"\";\r\n}\r\nfunction _isExceptionDetailsInternal(value) {\r\n try {\r\n if (isObject(value)) {\r\n return \"hasFullStack\" in value && \"typeName\" in value;\r\n }\r\n }\r\n catch (e) {\r\n // This can happen with some native browser objects, but should not happen for the type we are checking for\r\n }\r\n return false;\r\n}\r\nfunction _isExceptionInternal(value) {\r\n try {\r\n if (isObject(value)) {\r\n return (\"ver\" in value && \"exceptions\" in value && \"properties\" in value);\r\n }\r\n }\r\n catch (e) {\r\n // This can happen with some native browser objects, but should not happen for the type we are checking for\r\n }\r\n return false;\r\n}\r\nfunction _isStackDetails(details) {\r\n return details && details.src && isString(details.src) && details.obj && isArray(details.obj);\r\n}\r\nfunction _convertStackObj(errorStack) {\r\n var src = errorStack || \"\";\r\n if (!isString(src)) {\r\n if (isString(src[strStack])) {\r\n src = src[strStack];\r\n }\r\n else {\r\n src = \"\" + src;\r\n }\r\n }\r\n var items = src[_DYN_SPLIT /* @min:%2esplit */](\"\\n\");\r\n return {\r\n src: src,\r\n obj: items\r\n };\r\n}\r\nfunction _getOperaStack(errorMessage) {\r\n var stack = [];\r\n var lines = errorMessage[_DYN_SPLIT /* @min:%2esplit */](\"\\n\");\r\n for (var lp = 0; lp < lines[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var entry = lines[lp];\r\n if (lines[lp + 1]) {\r\n entry += \"@\" + lines[lp + 1];\r\n lp++;\r\n }\r\n stack.push(entry);\r\n }\r\n return {\r\n src: errorMessage,\r\n obj: stack\r\n };\r\n}\r\nfunction _getStackFromErrorObj(errorObj) {\r\n var details = null;\r\n if (errorObj) {\r\n try {\r\n /* Using bracket notation is support older browsers (IE 7/8 -- dont remember the version) that throw when using dot\r\n notation for undefined objects and we don't want to loose the error from being reported */\r\n if (errorObj[strStack]) {\r\n // Chrome/Firefox\r\n details = _convertStackObj(errorObj[strStack]);\r\n }\r\n else if (errorObj[strError] && errorObj[strError][strStack]) {\r\n // Edge error event provides the stack and error object\r\n details = _convertStackObj(errorObj[strError][strStack]);\r\n }\r\n else if (errorObj[\"exception\"] && errorObj.exception[strStack]) {\r\n details = _convertStackObj(errorObj.exception[strStack]);\r\n }\r\n else if (_isStackDetails(errorObj)) {\r\n details = errorObj;\r\n }\r\n else if (_isStackDetails(errorObj[strStackDetails])) {\r\n details = errorObj[strStackDetails];\r\n }\r\n else if (window && window[\"opera\"] && errorObj[strMessage]) {\r\n // Opera\r\n details = _getOperaStack(errorObj[_DYN_MESSAGE /* @min:%2emessage */]);\r\n }\r\n else if (errorObj[\"reason\"] && errorObj.reason[strStack]) {\r\n // UnhandledPromiseRejection\r\n details = _convertStackObj(errorObj.reason[strStack]);\r\n }\r\n else if (isString(errorObj)) {\r\n details = _convertStackObj(errorObj);\r\n }\r\n else {\r\n var evtMessage = errorObj[strMessage] || errorObj[strDescription] || \"\";\r\n if (isString(errorObj[strErrorSrc])) {\r\n if (evtMessage) {\r\n evtMessage += \"\\n\";\r\n }\r\n evtMessage += \" from \" + errorObj[strErrorSrc];\r\n }\r\n if (evtMessage) {\r\n details = _convertStackObj(evtMessage);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // something unexpected happened so to avoid failing to report any error lets swallow the exception\r\n // and fallback to the callee/caller method\r\n details = _convertStackObj(e);\r\n }\r\n }\r\n return details || {\r\n src: \"\",\r\n obj: null\r\n };\r\n}\r\nfunction _formatStackTrace(stackDetails) {\r\n var stack = \"\";\r\n if (stackDetails) {\r\n if (stackDetails.obj) {\r\n arrForEach(stackDetails.obj, function (entry) {\r\n stack += entry + \"\\n\";\r\n });\r\n }\r\n else {\r\n stack = stackDetails.src || \"\";\r\n }\r\n }\r\n return stack;\r\n}\r\nfunction _parseStack(stack) {\r\n var parsedStack;\r\n var frames = stack.obj;\r\n if (frames && frames[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n parsedStack = [];\r\n var level_1 = 0;\r\n var totalSizeInBytes_1 = 0;\r\n arrForEach(frames, function (frame) {\r\n var theFrame = frame[_DYN_TO_STRING /* @min:%2etoString */]();\r\n if (_StackFrame.regex.test(theFrame)) {\r\n var parsedFrame = new _StackFrame(theFrame, level_1++);\r\n totalSizeInBytes_1 += parsedFrame[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n parsedStack.push(parsedFrame);\r\n }\r\n });\r\n // DP Constraint - exception parsed stack must be < 32KB\r\n // remove frames from the middle to meet the threshold\r\n var exceptionParsedStackThreshold = 32 * 1024;\r\n if (totalSizeInBytes_1 > exceptionParsedStackThreshold) {\r\n var left = 0;\r\n var right = parsedStack[_DYN_LENGTH /* @min:%2elength */] - 1;\r\n var size = 0;\r\n var acceptedLeft = left;\r\n var acceptedRight = right;\r\n while (left < right) {\r\n // check size\r\n var lSize = parsedStack[left][_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n var rSize = parsedStack[right][_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */];\r\n size += lSize + rSize;\r\n if (size > exceptionParsedStackThreshold) {\r\n // remove extra frames from the middle\r\n var howMany = acceptedRight - acceptedLeft + 1;\r\n parsedStack.splice(acceptedLeft, howMany);\r\n break;\r\n }\r\n // update pointers\r\n acceptedLeft = left;\r\n acceptedRight = right;\r\n left++;\r\n right--;\r\n }\r\n }\r\n }\r\n return parsedStack;\r\n}\r\nfunction _getErrorType(errorType) {\r\n // Gets the Error Type by passing the constructor (used to get the true type of native error object).\r\n var typeName = \"\";\r\n if (errorType) {\r\n typeName = errorType.typeName || errorType[_DYN_NAME /* @min:%2ename */] || \"\";\r\n if (!typeName) {\r\n try {\r\n var funcNameRegex = /function (.{1,200})\\(/;\r\n var results = (funcNameRegex).exec((errorType).constructor[_DYN_TO_STRING /* @min:%2etoString */]());\r\n typeName = (results && results[_DYN_LENGTH /* @min:%2elength */] > 1) ? results[1] : \"\";\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty -- Ignoring any failures as nothing we can do\r\n }\r\n }\r\n }\r\n return typeName;\r\n}\r\n/**\r\n * Formats the provided errorObj for display and reporting, it may be a String, Object, integer or undefined depending on the browser.\r\n * @param errorObj The supplied errorObj\r\n */\r\nexport function _formatErrorCode(errorObj) {\r\n if (errorObj) {\r\n try {\r\n if (!isString(errorObj)) {\r\n var errorType = _getErrorType(errorObj);\r\n var result = _stringify(errorObj, false);\r\n if (!result || result === \"{}\") {\r\n if (errorObj[strError]) {\r\n // Looks like an MS Error Event\r\n errorObj = errorObj[strError];\r\n errorType = _getErrorType(errorObj);\r\n }\r\n result = _stringify(errorObj, true);\r\n }\r\n if (result[_DYN_INDEX_OF /* @min:%2eindexOf */](errorType) !== 0 && errorType !== \"String\") {\r\n return errorType + \":\" + result;\r\n }\r\n return result;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty -- Ignoring any failures as nothing we can do\r\n }\r\n }\r\n // Fallback to just letting the object format itself into a string\r\n return \"\" + (errorObj || \"\");\r\n}\r\nvar Exception = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the ExceptionTelemetry object\r\n */\r\n function Exception(logger, exception, properties, measurements, severityLevel, id) {\r\n this.aiDataContract = {\r\n ver: 1 /* FieldType.Required */,\r\n exceptions: 1 /* FieldType.Required */,\r\n severityLevel: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2; // TODO: handle the CS\"4.0\" ==> breeze 2 conversion in a better way\r\n if (!_isExceptionInternal(exception)) {\r\n if (!properties) {\r\n properties = {};\r\n }\r\n _self[_DYN_EXCEPTIONS /* @min:%2eexceptions */] = [new _ExceptionDetails(logger, exception, properties)];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n if (severityLevel) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = severityLevel;\r\n }\r\n if (id) {\r\n _self.id = id;\r\n }\r\n }\r\n else {\r\n _self[_DYN_EXCEPTIONS /* @min:%2eexceptions */] = exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */] || [];\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = exception[_DYN_PROPERTIES /* @min:%2eproperties */];\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = exception[_DYN_MEASUREMENTS /* @min:%2emeasurements */];\r\n if (exception[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */]) {\r\n _self[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */] = exception[_DYN_SEVERITY_LEVEL /* @min:%2eseverityLevel */];\r\n }\r\n if (exception.id) {\r\n _self.id = exception.id;\r\n }\r\n if (exception[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */]) {\r\n _self[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */] = exception[_DYN_PROBLEM_GROUP /* @min:%2eproblemGroup */];\r\n }\r\n // bool/int types, use isNullOrUndefined\r\n if (!isNullOrUndefined(exception[_DYN_IS_MANUAL /* @min:%2eisManual */])) {\r\n _self[_DYN_IS_MANUAL /* @min:%2eisManual */] = exception[_DYN_IS_MANUAL /* @min:%2eisManual */];\r\n }\r\n }\r\n }\r\n Exception.CreateAutoException = function (message, url, lineNumber, columnNumber, error, evt, stack, errorSrc) {\r\n var _a;\r\n var errorType = _getErrorType(error || evt || message);\r\n return _a = {},\r\n _a[_DYN_MESSAGE /* @min:message */] = _formatMessage(message, errorType),\r\n _a.url = url,\r\n _a.lineNumber = lineNumber,\r\n _a.columnNumber = columnNumber,\r\n _a.error = _formatErrorCode(error || evt || message),\r\n _a.evt = _formatErrorCode(evt || message),\r\n _a[_DYN_TYPE_NAME /* @min:typeName */] = errorType,\r\n _a.stackDetails = _getStackFromErrorObj(stack || error || evt),\r\n _a.errorSrc = errorSrc,\r\n _a;\r\n };\r\n Exception.CreateFromInterface = function (logger, exception, properties, measurements) {\r\n var exceptions = exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */]\r\n && arrMap(exception[_DYN_EXCEPTIONS /* @min:%2eexceptions */], function (ex) { return _ExceptionDetails[_DYN__CREATE_FROM_INTERFA1 /* @min:%2eCreateFromInterface */](logger, ex); });\r\n var exceptionData = new Exception(logger, __assign(__assign({}, exception), { exceptions: exceptions }), properties, measurements);\r\n return exceptionData;\r\n };\r\n Exception.prototype.toInterface = function () {\r\n var _a;\r\n var _b = this, exceptions = _b.exceptions, properties = _b.properties, measurements = _b.measurements, severityLevel = _b.severityLevel, problemGroup = _b.problemGroup, id = _b.id, isManual = _b.isManual;\r\n var exceptionDetailsInterface = exceptions instanceof Array\r\n && arrMap(exceptions, function (exception) { return exception.toInterface(); })\r\n || undefined;\r\n return _a = {\r\n ver: \"4.0\"\r\n },\r\n _a[_DYN_EXCEPTIONS /* @min:exceptions */] = exceptionDetailsInterface,\r\n _a.severityLevel = severityLevel,\r\n _a.properties = properties,\r\n _a.measurements = measurements,\r\n _a.problemGroup = problemGroup,\r\n _a.id = id,\r\n _a.isManual = isManual,\r\n _a;\r\n };\r\n /**\r\n * Creates a simple exception with 1 stack frame. Useful for manual constracting of exception.\r\n */\r\n Exception.CreateSimpleException = function (message, typeName, assembly, fileName, details, line) {\r\n var _a;\r\n return {\r\n exceptions: [\r\n (_a = {},\r\n _a[_DYN_HAS_FULL_STACK /* @min:hasFullStack */] = true,\r\n _a.message = message,\r\n _a.stack = details,\r\n _a.typeName = typeName,\r\n _a)\r\n ]\r\n };\r\n };\r\n Exception.envelopeType = \"Microsoft.ApplicationInsights.{0}.Exception\";\r\n Exception.dataType = \"ExceptionData\";\r\n Exception.formatError = _formatErrorCode;\r\n return Exception;\r\n}());\r\nexport { Exception };\r\nvar _ExceptionDetails = /** @class */ (function () {\r\n function _ExceptionDetails(logger, exception, properties) {\r\n this.aiDataContract = {\r\n id: 0 /* FieldType.Default */,\r\n outerId: 0 /* FieldType.Default */,\r\n typeName: 1 /* FieldType.Required */,\r\n message: 1 /* FieldType.Required */,\r\n hasFullStack: 0 /* FieldType.Default */,\r\n stack: 0 /* FieldType.Default */,\r\n parsedStack: 2 /* FieldType.Array */\r\n };\r\n var _self = this;\r\n if (!_isExceptionDetailsInternal(exception)) {\r\n var error = exception;\r\n var evt = error && error.evt;\r\n if (!isError(error)) {\r\n error = error[strError] || evt || error;\r\n }\r\n _self[_DYN_TYPE_NAME /* @min:%2etypeName */] = dataSanitizeString(logger, _getErrorType(error)) || strNotSpecified;\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] = dataSanitizeMessage(logger, _formatMessage(exception || error, _self[_DYN_TYPE_NAME /* @min:%2etypeName */])) || strNotSpecified;\r\n var stack = exception[strStackDetails] || _getStackFromErrorObj(exception);\r\n _self[_DYN_PARSED_STACK /* @min:%2eparsedStack */] = _parseStack(stack);\r\n // after parsedStack is inited, iterate over each frame object, sanitize its assembly field\r\n if (isArray(_self[_DYN_PARSED_STACK /* @min:%2eparsedStack */])) {\r\n arrMap(_self[_DYN_PARSED_STACK /* @min:%2eparsedStack */], function (frame) { return frame[_DYN_ASSEMBLY /* @min:%2eassembly */] = dataSanitizeString(logger, frame[_DYN_ASSEMBLY /* @min:%2eassembly */]); });\r\n }\r\n _self[strStack] = dataSanitizeException(logger, _formatStackTrace(stack));\r\n _self.hasFullStack = isArray(_self.parsedStack) && _self.parsedStack[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n if (properties) {\r\n properties[_DYN_TYPE_NAME /* @min:%2etypeName */] = properties[_DYN_TYPE_NAME /* @min:%2etypeName */] || _self[_DYN_TYPE_NAME /* @min:%2etypeName */];\r\n }\r\n }\r\n else {\r\n _self[_DYN_TYPE_NAME /* @min:%2etypeName */] = exception[_DYN_TYPE_NAME /* @min:%2etypeName */];\r\n _self[_DYN_MESSAGE /* @min:%2emessage */] = exception[_DYN_MESSAGE /* @min:%2emessage */];\r\n _self[strStack] = exception[strStack];\r\n _self[_DYN_PARSED_STACK /* @min:%2eparsedStack */] = exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */] || [];\r\n _self[_DYN_HAS_FULL_STACK /* @min:%2ehasFullStack */] = exception[_DYN_HAS_FULL_STACK /* @min:%2ehasFullStack */];\r\n }\r\n }\r\n _ExceptionDetails.prototype.toInterface = function () {\r\n var _a;\r\n var _self = this;\r\n var parsedStack = _self[_DYN_PARSED_STACK /* @min:%2eparsedStack */] instanceof Array\r\n && arrMap(_self[_DYN_PARSED_STACK /* @min:%2eparsedStack */], function (frame) { return frame.toInterface(); });\r\n var exceptionDetailsInterface = (_a = {\r\n id: _self.id,\r\n outerId: _self.outerId,\r\n typeName: _self[_DYN_TYPE_NAME /* @min:%2etypeName */],\r\n message: _self[_DYN_MESSAGE /* @min:%2emessage */],\r\n hasFullStack: _self[_DYN_HAS_FULL_STACK /* @min:%2ehasFullStack */],\r\n stack: _self[strStack]\r\n },\r\n _a[_DYN_PARSED_STACK /* @min:parsedStack */] = parsedStack || undefined,\r\n _a);\r\n return exceptionDetailsInterface;\r\n };\r\n _ExceptionDetails.CreateFromInterface = function (logger, exception) {\r\n var parsedStack = (exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */] instanceof Array\r\n && arrMap(exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */], function (frame) { return _StackFrame[_DYN__CREATE_FROM_INTERFA1 /* @min:%2eCreateFromInterface */](frame); }))\r\n || exception[_DYN_PARSED_STACK /* @min:%2eparsedStack */];\r\n var exceptionDetails = new _ExceptionDetails(logger, __assign(__assign({}, exception), { parsedStack: parsedStack }));\r\n return exceptionDetails;\r\n };\r\n return _ExceptionDetails;\r\n}());\r\nexport { _ExceptionDetails };\r\nvar _StackFrame = /** @class */ (function () {\r\n function _StackFrame(sourceFrame, level) {\r\n this.aiDataContract = {\r\n level: 1 /* FieldType.Required */,\r\n method: 1 /* FieldType.Required */,\r\n assembly: 0 /* FieldType.Default */,\r\n fileName: 0 /* FieldType.Default */,\r\n line: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */] = 0;\r\n // Not converting this to isString() as typescript uses this logic to \"understand\" the different\r\n // types for the 2 different code paths\r\n if (typeof sourceFrame === \"string\") {\r\n var frame = sourceFrame;\r\n _self[_DYN_LEVEL /* @min:%2elevel */] = level;\r\n _self[_DYN_METHOD /* @min:%2emethod */] = NoMethod;\r\n _self[_DYN_ASSEMBLY /* @min:%2eassembly */] = strTrim(frame);\r\n _self[_DYN_FILE_NAME /* @min:%2efileName */] = \"\";\r\n _self[_DYN_LINE /* @min:%2eline */] = 0;\r\n var matches = frame.match(_StackFrame.regex);\r\n if (matches && matches[_DYN_LENGTH /* @min:%2elength */] >= 5) {\r\n _self[_DYN_METHOD /* @min:%2emethod */] = strTrim(matches[2]) || _self[_DYN_METHOD /* @min:%2emethod */];\r\n _self[_DYN_FILE_NAME /* @min:%2efileName */] = strTrim(matches[4]);\r\n _self[_DYN_LINE /* @min:%2eline */] = parseInt(matches[5]) || 0;\r\n }\r\n }\r\n else {\r\n _self[_DYN_LEVEL /* @min:%2elevel */] = sourceFrame[_DYN_LEVEL /* @min:%2elevel */];\r\n _self[_DYN_METHOD /* @min:%2emethod */] = sourceFrame[_DYN_METHOD /* @min:%2emethod */];\r\n _self[_DYN_ASSEMBLY /* @min:%2eassembly */] = sourceFrame[_DYN_ASSEMBLY /* @min:%2eassembly */];\r\n _self[_DYN_FILE_NAME /* @min:%2efileName */] = sourceFrame[_DYN_FILE_NAME /* @min:%2efileName */];\r\n _self[_DYN_LINE /* @min:%2eline */] = sourceFrame[_DYN_LINE /* @min:%2eline */];\r\n _self[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */] = 0;\r\n }\r\n _self.sizeInBytes += _self.method[_DYN_LENGTH /* @min:%2elength */];\r\n _self.sizeInBytes += _self.fileName[_DYN_LENGTH /* @min:%2elength */];\r\n _self.sizeInBytes += _self.assembly[_DYN_LENGTH /* @min:%2elength */];\r\n // todo: these might need to be removed depending on how the back-end settles on their size calculation\r\n _self[_DYN_SIZE_IN_BYTES /* @min:%2esizeInBytes */] += _StackFrame.baseSize;\r\n _self.sizeInBytes += _self.level.toString()[_DYN_LENGTH /* @min:%2elength */];\r\n _self.sizeInBytes += _self.line.toString()[_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n _StackFrame.CreateFromInterface = function (frame) {\r\n return new _StackFrame(frame, null /* level is available in frame interface */);\r\n };\r\n _StackFrame.prototype.toInterface = function () {\r\n var _self = this;\r\n return {\r\n level: _self[_DYN_LEVEL /* @min:%2elevel */],\r\n method: _self[_DYN_METHOD /* @min:%2emethod */],\r\n assembly: _self[_DYN_ASSEMBLY /* @min:%2eassembly */],\r\n fileName: _self[_DYN_FILE_NAME /* @min:%2efileName */],\r\n line: _self[_DYN_LINE /* @min:%2eline */]\r\n };\r\n };\r\n // regex to match stack frames from ie/chrome/ff\r\n // methodName=$2, fileName=$4, lineNo=$5, column=$6\r\n _StackFrame.regex = /^([\\s]+at)?[\\s]{0,50}([^\\@\\()]+?)[\\s]{0,50}(\\@|\\()([^\\(\\n]+):([0-9]+):([0-9]+)(\\)?)$/;\r\n _StackFrame.baseSize = 58; // '{\"method\":\"\",\"level\":,\"assembly\":\"\",\"fileName\":\"\",\"line\":}'.length\r\n return _StackFrame;\r\n}());\r\nexport { _StackFrame };\r\n//# sourceMappingURL=Exception.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { getDocument, isFunction } from \"@microsoft/applicationinsights-core-js\";\r\nexport function createDomEvent(eventName) {\r\n var event = null;\r\n if (isFunction(Event)) { // Use Event constructor when available\r\n event = new Event(eventName);\r\n }\r\n else { // Event has no constructor in IE\r\n var doc = getDocument();\r\n if (doc && doc.createEvent) {\r\n event = doc.createEvent(\"Event\");\r\n event.initEvent(eventName, true, true);\r\n }\r\n }\r\n return event;\r\n}\r\n//# sourceMappingURL=DomHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { createValueMap } from \"@microsoft/applicationinsights-core-js\";\r\nexport var RequestHeaders = createValueMap({\r\n requestContextHeader: [0 /* eRequestHeaders.requestContextHeader */, \"Request-Context\"],\r\n requestContextTargetKey: [1 /* eRequestHeaders.requestContextTargetKey */, \"appId\"],\r\n requestContextAppIdFormat: [2 /* eRequestHeaders.requestContextAppIdFormat */, \"appId=cid-v1:\"],\r\n requestIdHeader: [3 /* eRequestHeaders.requestIdHeader */, \"Request-Id\"],\r\n traceParentHeader: [4 /* eRequestHeaders.traceParentHeader */, \"traceparent\"],\r\n traceStateHeader: [5 /* eRequestHeaders.traceStateHeader */, \"tracestate\"],\r\n sdkContextHeader: [6 /* eRequestHeaders.sdkContextHeader */, \"Sdk-Context\"],\r\n sdkContextHeaderAppIdRequest: [7 /* eRequestHeaders.sdkContextHeaderAppIdRequest */, \"appId\"],\r\n requestContextHeaderLowerCase: [8 /* eRequestHeaders.requestContextHeaderLowerCase */, \"request-context\"]\r\n});\r\n//# sourceMappingURL=RequestResponseHeaders.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { getDocument, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_PATHNAME, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar _document = getDocument() || {};\r\nvar _htmlAnchorIdx = 0;\r\n// Use an array of temporary values as it's possible for multiple calls to parseUrl() will be called with different URLs\r\n// Using a cache size of 5 for now as it current depth usage is at least 2, so adding a minor buffer to handle future updates\r\nvar _htmlAnchorElement = [null, null, null, null, null];\r\nexport function urlParseUrl(url) {\r\n var anchorIdx = _htmlAnchorIdx;\r\n var anchorCache = _htmlAnchorElement;\r\n var tempAnchor = anchorCache[anchorIdx];\r\n if (!_document.createElement) {\r\n // Always create the temp instance if createElement is not available\r\n tempAnchor = { host: urlParseHost(url, true) };\r\n }\r\n else if (!anchorCache[anchorIdx]) {\r\n // Create and cache the unattached anchor instance\r\n tempAnchor = anchorCache[anchorIdx] = _document.createElement(\"a\");\r\n }\r\n tempAnchor.href = url;\r\n // Move the cache index forward\r\n anchorIdx++;\r\n if (anchorIdx >= anchorCache[_DYN_LENGTH /* @min:%2elength */]) {\r\n anchorIdx = 0;\r\n }\r\n _htmlAnchorIdx = anchorIdx;\r\n return tempAnchor;\r\n}\r\nexport function urlGetAbsoluteUrl(url) {\r\n var result;\r\n var a = urlParseUrl(url);\r\n if (a) {\r\n result = a.href;\r\n }\r\n return result;\r\n}\r\nexport function urlGetPathName(url) {\r\n var result;\r\n var a = urlParseUrl(url);\r\n if (a) {\r\n result = a[_DYN_PATHNAME /* @min:%2epathname */];\r\n }\r\n return result;\r\n}\r\nexport function urlGetCompleteUrl(method, absoluteUrl) {\r\n if (method) {\r\n return method.toUpperCase() + \" \" + absoluteUrl;\r\n }\r\n return absoluteUrl;\r\n}\r\n// Fallback method to grab host from url if document.createElement method is not available\r\nexport function urlParseHost(url, inclPort) {\r\n var fullHost = urlParseFullHost(url, inclPort) || \"\";\r\n if (fullHost) {\r\n var match = fullHost.match(/(www\\d{0,5}\\.)?([^\\/:]{1,256})(:\\d{1,20})?/i);\r\n if (match != null && match[_DYN_LENGTH /* @min:%2elength */] > 3 && isString(match[2]) && match[2][_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n return match[2] + (match[3] || \"\");\r\n }\r\n }\r\n return fullHost;\r\n}\r\nexport function urlParseFullHost(url, inclPort) {\r\n var result = null;\r\n if (url) {\r\n var match = url.match(/(\\w{1,150}):\\/\\/([^\\/:]{1,256})(:\\d{1,20})?/i);\r\n if (match != null && match[_DYN_LENGTH /* @min:%2elength */] > 2 && isString(match[2]) && match[2][_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n result = match[2] || \"\";\r\n if (inclPort && match[_DYN_LENGTH /* @min:%2elength */] > 2) {\r\n var protocol = (match[1] || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n var port = match[3] || \"\";\r\n // IE includes the standard port so pass it off if it's the same as the protocol\r\n if (protocol === \"http\" && port === \":80\") {\r\n port = \"\";\r\n }\r\n else if (protocol === \"https\" && port === \":443\") {\r\n port = \"\";\r\n }\r\n result += port;\r\n }\r\n }\r\n }\r\n return result;\r\n}\r\n//# sourceMappingURL=UrlHelperFuncs.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrForEach, arrIndexOf, attachEvent, canUseCookies as coreCanUseCookies, dateNow, deleteCookie as coreDeleteCookie, disableCookies as coreDisableCookies, dumpObj, generateW3CId, getCookie as coreGetCookie, getExceptionName as coreGetExceptionName, getIEVersion, getPerformance, isArray, isBeaconsSupported, isDate, isError, isNullOrUndefined, isValidSpanId, isValidTraceId, newId, random32, setCookie as coreSetCookie, strTrim, toISOString, uaDisallowsSameSiteNone } from \"@microsoft/applicationinsights-core-js\";\r\nimport { DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, strNotSpecified } from \"./Constants\";\r\nimport { createDomEvent } from \"./DomHelperFuncs\";\r\nimport { getExtensionByName, isCrossOriginError, msToTimeSpan, stringToBoolOrDefault } from \"./HelperFuncs\";\r\nimport { RequestHeaders } from \"./RequestResponseHeaders\";\r\nimport { utlCanUseLocalStorage, utlCanUseSessionStorage, utlDisableStorage, utlGetLocalStorage, utlGetSessionStorage, utlGetSessionStorageKeys, utlRemoveSessionStorage, utlRemoveStorage, utlSetLocalStorage, utlSetSessionStorage } from \"./StorageHelperFuncs\";\r\nimport { dataSanitizeString } from \"./Telemetry/Common/DataSanitizer\";\r\nimport { urlGetAbsoluteUrl, urlGetCompleteUrl, urlGetPathName, urlParseFullHost, urlParseHost, urlParseUrl } from \"./UrlHelperFuncs\";\r\nimport { _DYN_CORRELATION_HEADER_E0, _DYN_INDEX_OF, _DYN_LENGTH, _DYN_NAME, _DYN_PATHNAME, _DYN_SPLIT, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\n// listing only non-geo specific locations\r\nvar _internalEndpoints = [\r\n DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH,\r\n \"https://breeze.aimon.applicationinsights.io\" + DEFAULT_BREEZE_PATH,\r\n \"https://dc-int.services.visualstudio.com\" + DEFAULT_BREEZE_PATH\r\n];\r\nexport function isInternalApplicationInsightsEndpoint(endpointUrl) {\r\n return arrIndexOf(_internalEndpoints, endpointUrl[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]()) !== -1;\r\n}\r\nexport var Util = {\r\n NotSpecified: strNotSpecified,\r\n createDomEvent: createDomEvent,\r\n disableStorage: utlDisableStorage,\r\n isInternalApplicationInsightsEndpoint: isInternalApplicationInsightsEndpoint,\r\n canUseLocalStorage: utlCanUseLocalStorage,\r\n getStorage: utlGetLocalStorage,\r\n setStorage: utlSetLocalStorage,\r\n removeStorage: utlRemoveStorage,\r\n canUseSessionStorage: utlCanUseSessionStorage,\r\n getSessionStorageKeys: utlGetSessionStorageKeys,\r\n getSessionStorage: utlGetSessionStorage,\r\n setSessionStorage: utlSetSessionStorage,\r\n removeSessionStorage: utlRemoveSessionStorage,\r\n disableCookies: coreDisableCookies,\r\n canUseCookies: coreCanUseCookies,\r\n disallowsSameSiteNone: uaDisallowsSameSiteNone,\r\n setCookie: coreSetCookie,\r\n stringToBoolOrDefault: stringToBoolOrDefault,\r\n getCookie: coreGetCookie,\r\n deleteCookie: coreDeleteCookie,\r\n trim: strTrim,\r\n newId: newId,\r\n random32: function () {\r\n return random32(true);\r\n },\r\n generateW3CId: generateW3CId,\r\n isArray: isArray,\r\n isError: isError,\r\n isDate: isDate,\r\n toISOStringForIE8: toISOString,\r\n getIEVersion: getIEVersion,\r\n msToTimeSpan: msToTimeSpan,\r\n isCrossOriginError: isCrossOriginError,\r\n dump: dumpObj,\r\n getExceptionName: coreGetExceptionName,\r\n addEventHandler: attachEvent,\r\n IsBeaconApiSupported: isBeaconsSupported,\r\n getExtension: getExtensionByName\r\n};\r\nexport var UrlHelper = {\r\n parseUrl: urlParseUrl,\r\n getAbsoluteUrl: urlGetAbsoluteUrl,\r\n getPathName: urlGetPathName,\r\n getCompleteUrl: urlGetCompleteUrl,\r\n parseHost: urlParseHost,\r\n parseFullHost: urlParseFullHost\r\n};\r\nexport var CorrelationIdHelper = {\r\n correlationIdPrefix: \"cid-v1:\",\r\n /**\r\n * Checks if a request url is not on a excluded domain list and if it is safe to add correlation headers.\r\n * Headers are always included if the current domain matches the request domain. If they do not match (CORS),\r\n * they are regex-ed across correlationHeaderDomains and correlationHeaderExcludedDomains to determine if headers are included.\r\n * Some environments don't give information on currentHost via window.location.host (e.g. Cordova). In these cases, the user must\r\n * manually supply domains to include correlation headers on. Else, no headers will be included at all.\r\n */\r\n canIncludeCorrelationHeader: function (config, requestUrl, currentHost) {\r\n if (!requestUrl || (config && config.disableCorrelationHeaders)) {\r\n return false;\r\n }\r\n if (config && config[_DYN_CORRELATION_HEADER_E0 /* @min:%2ecorrelationHeaderExcludePatterns */]) {\r\n for (var i = 0; i < config.correlationHeaderExcludePatterns[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (config[_DYN_CORRELATION_HEADER_E0 /* @min:%2ecorrelationHeaderExcludePatterns */][i].test(requestUrl)) {\r\n return false;\r\n }\r\n }\r\n }\r\n var requestHost = urlParseUrl(requestUrl).host[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n if (requestHost && (requestHost[_DYN_INDEX_OF /* @min:%2eindexOf */](\":443\") !== -1 || requestHost[_DYN_INDEX_OF /* @min:%2eindexOf */](\":80\") !== -1)) {\r\n // [Bug #1260] IE can include the port even for http and https URLs so if present\r\n // try and parse it to remove if it matches the default protocol port\r\n requestHost = (urlParseFullHost(requestUrl, true) || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n }\r\n if ((!config || !config.enableCorsCorrelation) && (requestHost && requestHost !== currentHost)) {\r\n return false;\r\n }\r\n var includedDomains = config && config.correlationHeaderDomains;\r\n if (includedDomains) {\r\n var matchExists_1;\r\n arrForEach(includedDomains, function (domain) {\r\n var regex = new RegExp(domain.toLowerCase().replace(/\\\\/g, \"\\\\\\\\\").replace(/\\./g, \"\\\\.\").replace(/\\*/g, \".*\"));\r\n matchExists_1 = matchExists_1 || regex.test(requestHost);\r\n });\r\n if (!matchExists_1) {\r\n return false;\r\n }\r\n }\r\n var excludedDomains = config && config.correlationHeaderExcludedDomains;\r\n if (!excludedDomains || excludedDomains[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n return true;\r\n }\r\n for (var i = 0; i < excludedDomains[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n var regex = new RegExp(excludedDomains[i].toLowerCase().replace(/\\\\/g, \"\\\\\\\\\").replace(/\\./g, \"\\\\.\").replace(/\\*/g, \".*\"));\r\n if (regex.test(requestHost)) {\r\n return false;\r\n }\r\n }\r\n // if we don't know anything about the requestHost, require the user to use included/excludedDomains.\r\n // Previously we always returned false for a falsy requestHost\r\n return requestHost && requestHost[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n },\r\n /**\r\n * Combines target appId and target role name from response header.\r\n */\r\n getCorrelationContext: function (responseHeader) {\r\n if (responseHeader) {\r\n var correlationId = CorrelationIdHelper.getCorrelationContextValue(responseHeader, RequestHeaders[1 /* eRequestHeaders.requestContextTargetKey */]);\r\n if (correlationId && correlationId !== CorrelationIdHelper.correlationIdPrefix) {\r\n return correlationId;\r\n }\r\n }\r\n },\r\n /**\r\n * Gets key from correlation response header\r\n */\r\n getCorrelationContextValue: function (responseHeader, key) {\r\n if (responseHeader) {\r\n var keyValues = responseHeader[_DYN_SPLIT /* @min:%2esplit */](\",\");\r\n for (var i = 0; i < keyValues[_DYN_LENGTH /* @min:%2elength */]; ++i) {\r\n var keyValue = keyValues[i][_DYN_SPLIT /* @min:%2esplit */](\"=\");\r\n if (keyValue[_DYN_LENGTH /* @min:%2elength */] === 2 && keyValue[0] === key) {\r\n return keyValue[1];\r\n }\r\n }\r\n }\r\n }\r\n};\r\nexport function AjaxHelperParseDependencyPath(logger, absoluteUrl, method, commandName) {\r\n var target, name = commandName, data = commandName;\r\n if (absoluteUrl && absoluteUrl[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var parsedUrl = urlParseUrl(absoluteUrl);\r\n target = parsedUrl.host;\r\n if (!name) {\r\n if (parsedUrl[_DYN_PATHNAME /* @min:%2epathname */] != null) {\r\n var pathName = (parsedUrl.pathname[_DYN_LENGTH /* @min:%2elength */] === 0) ? \"/\" : parsedUrl[_DYN_PATHNAME /* @min:%2epathname */];\r\n if (pathName.charAt(0) !== \"/\") {\r\n pathName = \"/\" + pathName;\r\n }\r\n data = parsedUrl[_DYN_PATHNAME /* @min:%2epathname */];\r\n name = dataSanitizeString(logger, method ? method + \" \" + pathName : pathName);\r\n }\r\n else {\r\n name = dataSanitizeString(logger, absoluteUrl);\r\n }\r\n }\r\n }\r\n else {\r\n target = commandName;\r\n name = commandName;\r\n }\r\n return {\r\n target: target,\r\n name: name,\r\n data: data\r\n };\r\n}\r\nexport function dateTimeUtilsNow() {\r\n // returns the window or webworker performance object\r\n var perf = getPerformance();\r\n if (perf && perf.now && perf.timing) {\r\n var now = perf.now() + perf.timing.navigationStart;\r\n // Known issue with IE where this calculation can be negative, so if it is then ignore and fallback\r\n if (now > 0) {\r\n return now;\r\n }\r\n }\r\n return dateNow();\r\n}\r\nexport function dateTimeUtilsDuration(start, end) {\r\n var result = null;\r\n if (start !== 0 && end !== 0 && !isNullOrUndefined(start) && !isNullOrUndefined(end)) {\r\n result = end - start;\r\n }\r\n return result;\r\n}\r\n/**\r\n * A utility class that helps getting time related parameters\r\n */\r\nexport var DateTimeUtils = {\r\n Now: dateTimeUtilsNow,\r\n GetDuration: dateTimeUtilsDuration\r\n};\r\n/**\r\n * Creates a IDistributedTraceContext from an optional telemetryTrace\r\n * @param telemetryTrace - The telemetryTrace instance that is being wrapped\r\n * @param parentCtx - An optional parent distributed trace instance, almost always undefined as this scenario is only used in the case of multiple property handlers.\r\n * @returns A new IDistributedTraceContext instance that is backed by the telemetryTrace or temporary object\r\n */\r\nexport function createDistributedTraceContextFromTrace(telemetryTrace, parentCtx) {\r\n var trace = telemetryTrace || {};\r\n return {\r\n getName: function () {\r\n return trace[_DYN_NAME /* @min:%2ename */];\r\n },\r\n setName: function (newValue) {\r\n parentCtx && parentCtx.setName(newValue);\r\n trace[_DYN_NAME /* @min:%2ename */] = newValue;\r\n },\r\n getTraceId: function () {\r\n return trace.traceID;\r\n },\r\n setTraceId: function (newValue) {\r\n parentCtx && parentCtx.setTraceId(newValue);\r\n if (isValidTraceId(newValue)) {\r\n trace.traceID = newValue;\r\n }\r\n },\r\n getSpanId: function () {\r\n return trace.parentID;\r\n },\r\n setSpanId: function (newValue) {\r\n parentCtx && parentCtx.setSpanId(newValue);\r\n if (isValidSpanId(newValue)) {\r\n trace.parentID = newValue;\r\n }\r\n },\r\n getTraceFlags: function () {\r\n return trace.traceFlags;\r\n },\r\n setTraceFlags: function (newTraceFlags) {\r\n parentCtx && parentCtx.setTraceFlags(newTraceFlags);\r\n trace.traceFlags = newTraceFlags;\r\n }\r\n };\r\n}\r\n//# sourceMappingURL=Util.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { msToTimeSpan } from \"../HelperFuncs\";\r\nimport { AjaxHelperParseDependencyPath } from \"../Util\";\r\nimport { _DYN_DURATION, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_PROPERTIES } from \"../__DynamicConstants\";\r\nimport { dataSanitizeMeasurements, dataSanitizeProperties, dataSanitizeString, dataSanitizeUrl } from \"./Common/DataSanitizer\";\r\nvar RemoteDependencyData = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the RemoteDependencyData object\r\n */\r\n function RemoteDependencyData(logger, id, absoluteUrl, commandName, value, success, resultCode, method, requestAPI, correlationContext, properties, measurements) {\r\n if (requestAPI === void 0) { requestAPI = \"Ajax\"; }\r\n this.aiDataContract = {\r\n id: 1 /* FieldType.Required */,\r\n ver: 1 /* FieldType.Required */,\r\n name: 0 /* FieldType.Default */,\r\n resultCode: 0 /* FieldType.Default */,\r\n duration: 0 /* FieldType.Default */,\r\n success: 0 /* FieldType.Default */,\r\n data: 0 /* FieldType.Default */,\r\n target: 0 /* FieldType.Default */,\r\n type: 0 /* FieldType.Default */,\r\n properties: 0 /* FieldType.Default */,\r\n measurements: 0 /* FieldType.Default */,\r\n kind: 0 /* FieldType.Default */,\r\n value: 0 /* FieldType.Default */,\r\n count: 0 /* FieldType.Default */,\r\n min: 0 /* FieldType.Default */,\r\n max: 0 /* FieldType.Default */,\r\n stdDev: 0 /* FieldType.Default */,\r\n dependencyKind: 0 /* FieldType.Default */,\r\n dependencySource: 0 /* FieldType.Default */,\r\n commandName: 0 /* FieldType.Default */,\r\n dependencyTypeName: 0 /* FieldType.Default */\r\n };\r\n var _self = this;\r\n _self.ver = 2;\r\n _self.id = id;\r\n _self[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(value);\r\n _self.success = success;\r\n _self.resultCode = resultCode + \"\";\r\n _self.type = dataSanitizeString(logger, requestAPI);\r\n var dependencyFields = AjaxHelperParseDependencyPath(logger, absoluteUrl, method, commandName);\r\n _self.data = dataSanitizeUrl(logger, commandName) || dependencyFields.data; // get a value from hosturl if commandName not available\r\n _self.target = dataSanitizeString(logger, dependencyFields.target);\r\n if (correlationContext) {\r\n _self.target = \"\".concat(_self.target, \" | \").concat(correlationContext);\r\n }\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, dependencyFields[_DYN_NAME /* @min:%2ename */]);\r\n _self[_DYN_PROPERTIES /* @min:%2eproperties */] = dataSanitizeProperties(logger, properties);\r\n _self[_DYN_MEASUREMENTS /* @min:%2emeasurements */] = dataSanitizeMeasurements(logger, measurements);\r\n }\r\n RemoteDependencyData.envelopeType = \"Microsoft.ApplicationInsights.{0}.RemoteDependency\";\r\n RemoteDependencyData.dataType = \"RemoteDependencyData\";\r\n return RemoteDependencyData;\r\n}());\r\nexport { RemoteDependencyData };\r\n//# sourceMappingURL=RemoteDependencyData.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { strShimFunction, strShimPrototype } from \"@microsoft/applicationinsights-shims\";\r\nimport { _DYN_APPLY, _DYN_LENGTH, _DYN_NAME, _DYN_PUSH, _DYN_SPLICE } from \"../__DynamicConstants\";\r\nimport { getGlobalInst } from \"./EnvUtils\";\r\nimport { _getObjProto, hasOwnProperty } from \"./HelperFuncs\";\r\nvar aiInstrumentHooks = \"_aiHooks\";\r\nvar cbNames = [\r\n \"req\", \"rsp\", \"hkErr\", \"fnErr\"\r\n];\r\n/** @ignore */\r\nfunction _arrLoop(arr, fn) {\r\n if (arr) {\r\n for (var lp = 0; lp < arr[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n if (fn(arr[lp], lp)) {\r\n break;\r\n }\r\n }\r\n }\r\n}\r\n/** @ignore */\r\nfunction _doCallbacks(hooks, callDetails, cbArgs, hookCtx, type) {\r\n if (type >= 0 /* CallbackType.Request */ && type <= 2 /* CallbackType.HookError */) {\r\n _arrLoop(hooks, function (hook, idx) {\r\n var cbks = hook.cbks;\r\n var cb = cbks[cbNames[type]];\r\n if (cb) {\r\n // Set the specific hook context implementation using a lazy creation pattern\r\n callDetails.ctx = function () {\r\n var ctx = hookCtx[idx] = (hookCtx[idx] || {});\r\n return ctx;\r\n };\r\n try {\r\n cb[_DYN_APPLY /* @min:%2eapply */](callDetails.inst, cbArgs);\r\n }\r\n catch (err) {\r\n var orgEx = callDetails.err;\r\n try {\r\n // Report Hook error via the callback\r\n var hookErrorCb = cbks[cbNames[2 /* CallbackType.HookError */]];\r\n if (hookErrorCb) {\r\n callDetails.err = err;\r\n hookErrorCb[_DYN_APPLY /* @min:%2eapply */](callDetails.inst, cbArgs);\r\n }\r\n }\r\n catch (e) {\r\n // Not much we can do here -- swallowing the exception to avoid crashing the hosting app\r\n }\r\n finally {\r\n // restore the original exception (if any)\r\n callDetails.err = orgEx;\r\n }\r\n }\r\n }\r\n });\r\n }\r\n}\r\n/** @ignore */\r\nfunction _createFunctionHook(aiHook) {\r\n // Define a temporary method that queues-up a the real method call\r\n return function () {\r\n var _a;\r\n var funcThis = this;\r\n // Capture the original arguments passed to the method\r\n var orgArgs = arguments;\r\n var hooks = aiHook.h;\r\n var funcArgs = (_a = {},\r\n _a[_DYN_NAME /* @min:name */] = aiHook.n,\r\n _a.inst = funcThis,\r\n _a.ctx = null,\r\n _a.set = _replaceArg,\r\n _a);\r\n var hookCtx = [];\r\n var cbArgs = _createArgs([funcArgs], orgArgs);\r\n funcArgs.evt = getGlobalInst(\"event\");\r\n function _createArgs(target, theArgs) {\r\n _arrLoop(theArgs, function (arg) {\r\n target[_DYN_PUSH /* @min:%2epush */](arg);\r\n });\r\n return target;\r\n }\r\n function _replaceArg(idx, value) {\r\n orgArgs = _createArgs([], orgArgs);\r\n orgArgs[idx] = value;\r\n cbArgs = _createArgs([funcArgs], orgArgs);\r\n }\r\n // Call the pre-request hooks\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 0 /* CallbackType.Request */);\r\n // Call the original function was called\r\n var theFunc = aiHook.f;\r\n if (theFunc) {\r\n try {\r\n funcArgs.rslt = theFunc[_DYN_APPLY /* @min:%2eapply */](funcThis, orgArgs);\r\n }\r\n catch (err) {\r\n // Report the request callback\r\n funcArgs.err = err;\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 3 /* CallbackType.FunctionError */);\r\n // rethrow the original exception so anyone listening for it can catch the exception\r\n throw err;\r\n }\r\n }\r\n // Call the post-request hooks\r\n _doCallbacks(hooks, funcArgs, cbArgs, hookCtx, 1 /* CallbackType.Response */);\r\n return funcArgs.rslt;\r\n };\r\n}\r\n/** @ignore */\r\nfunction _getOwner(target, name, checkPrototype, checkParentProto) {\r\n var owner = null;\r\n if (target) {\r\n if (hasOwnProperty(target, name)) {\r\n owner = target;\r\n }\r\n else if (checkPrototype) {\r\n owner = _getOwner(_getObjProto(target), name, checkParentProto, false);\r\n }\r\n }\r\n return owner;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcName - The function name\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n */\r\nexport function InstrumentProto(target, funcName, callbacks) {\r\n if (target) {\r\n return InstrumentFunc(target[strShimPrototype], funcName, callbacks, false);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcNames - The function names to intercept and call\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n */\r\nexport function InstrumentProtos(target, funcNames, callbacks) {\r\n if (target) {\r\n return InstrumentFuncs(target[strShimPrototype], funcNames, callbacks, false);\r\n }\r\n return null;\r\n}\r\nfunction _createInstrumentHook(owner, funcName, fn, callbacks) {\r\n var aiHook = fn && fn[aiInstrumentHooks];\r\n if (!aiHook) {\r\n // Only hook the function once\r\n aiHook = {\r\n i: 0,\r\n n: funcName,\r\n f: fn,\r\n h: []\r\n };\r\n // Override (hook) the original function\r\n var newFunc = _createFunctionHook(aiHook);\r\n newFunc[aiInstrumentHooks] = aiHook; // Tag and store the function hooks\r\n owner[funcName] = newFunc;\r\n }\r\n var theHook = {\r\n // tslint:disable:object-literal-shorthand\r\n id: aiHook.i,\r\n cbks: callbacks,\r\n rm: function () {\r\n // DO NOT Use () => { shorthand for the function as the this gets replaced\r\n // with the outer this and not the this for theHook instance.\r\n var id = this.id;\r\n _arrLoop(aiHook.h, function (hook, idx) {\r\n if (hook.id === id) {\r\n aiHook.h[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n return 1;\r\n }\r\n });\r\n }\r\n // tslint:enable:object-literal-shorthand\r\n };\r\n aiHook.i++;\r\n aiHook.h[_DYN_PUSH /* @min:%2epush */](theHook);\r\n return theHook;\r\n}\r\n/**\r\n * Intercept the named prototype functions for the target class / object\r\n * @param target - The target object\r\n * @param funcName - The function name\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentFunc(target, funcName, callbacks, checkPrototype, checkParentProto) {\r\n if (checkPrototype === void 0) { checkPrototype = true; }\r\n if (target && funcName && callbacks) {\r\n var owner = _getOwner(target, funcName, checkPrototype, checkParentProto);\r\n if (owner) {\r\n var fn = owner[funcName];\r\n if (typeof fn === strShimFunction) {\r\n return _createInstrumentHook(owner, funcName, fn, callbacks);\r\n }\r\n }\r\n }\r\n return null;\r\n}\r\n/**\r\n * Intercept the named functions for the target class / object\r\n * @param target - The target object\r\n * @param funcNames - The function names to intercept and call\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentFuncs(target, funcNames, callbacks, checkPrototype, checkParentProto) {\r\n if (checkPrototype === void 0) { checkPrototype = true; }\r\n var hooks = null;\r\n _arrLoop(funcNames, function (funcName) {\r\n var hook = InstrumentFunc(target, funcName, callbacks, checkPrototype, checkParentProto);\r\n if (hook) {\r\n if (!hooks) {\r\n hooks = [];\r\n }\r\n hooks[_DYN_PUSH /* @min:%2epush */](hook);\r\n }\r\n });\r\n return hooks;\r\n}\r\n/**\r\n * Add an instrumentation hook to the provided named \"event\" for the target class / object, this doesn't check whether the\r\n * named \"event\" is in fact a function and just assigns the instrumentation hook to the target[evtName]\r\n * @param target - The target object\r\n * @param evtName - The name of the event\r\n * @param callbacks - The callbacks to configure and call whenever the function is called\r\n * @param checkPrototype - If the function doesn't exist on the target should it attempt to hook the prototype function\r\n * @param checkParentProto - If the function doesn't exist on the target or it's prototype should it attempt to hook the parent's prototype\r\n */\r\nexport function InstrumentEvent(target, evtName, callbacks, checkPrototype, checkParentProto) {\r\n if (target && evtName && callbacks) {\r\n var owner = _getOwner(target, evtName, checkPrototype, checkParentProto) || target;\r\n if (owner) {\r\n return _createInstrumentHook(owner, evtName, owner[evtName], callbacks);\r\n }\r\n }\r\n return null;\r\n}\r\n//# sourceMappingURL=InstrumentHooks.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 4\r\nexport var _DYN_DISABLE_EXCEPTION_TR0 = \"disableExceptionTracking\"; // Count: 3\r\nexport var _DYN_AUTO_TRACK_PAGE_VISI1 = \"autoTrackPageVisitTime\"; // Count: 4\r\nexport var _DYN_OVERRIDE_PAGE_VIEW_D2 = \"overridePageViewDuration\"; // Count: 3\r\nexport var _DYN_ENABLE_UNHANDLED_PRO3 = \"enableUnhandledPromiseRejectionTracking\"; // Count: 3\r\nexport var _DYN_SAMPLING_PERCENTAGE = \"samplingPercentage\"; // Count: 4\r\nexport var _DYN_IS_STORAGE_USE_DISAB4 = \"isStorageUseDisabled\"; // Count: 4\r\nexport var _DYN_IS_BROWSER_LINK_TRAC5 = \"isBrowserLinkTrackingEnabled\"; // Count: 4\r\nexport var _DYN_ENABLE_AUTO_ROUTE_TR6 = \"enableAutoRouteTracking\"; // Count: 3\r\nexport var _DYN_NAME_PREFIX = \"namePrefix\"; // Count: 3\r\nexport var _DYN_DISABLE_FLUSH_ON_BEF7 = \"disableFlushOnBeforeUnload\"; // Count: 3\r\nexport var _DYN_DISABLE_FLUSH_ON_UNL8 = \"disableFlushOnUnload\"; // Count: 2\r\nexport var _DYN_CORE = \"core\"; // Count: 7\r\nexport var _DYN_DATA_TYPE = \"dataType\"; // Count: 8\r\nexport var _DYN_ENVELOPE_TYPE = \"envelopeType\"; // Count: 7\r\nexport var _DYN_DIAG_LOG = \"diagLog\"; // Count: 13\r\nexport var _DYN_TRACK = \"track\"; // Count: 7\r\nexport var _DYN_TRACK_PAGE_VIEW = \"trackPageView\"; // Count: 4\r\nexport var _DYN_TRACK_PREVIOUS_PAGE_9 = \"trackPreviousPageVisit\"; // Count: 3\r\nexport var _DYN_SEND_PAGE_VIEW_INTER10 = \"sendPageViewInternal\"; // Count: 7\r\nexport var _DYN_SEND_PAGE_VIEW_PERFO11 = \"sendPageViewPerformanceInternal\"; // Count: 3\r\nexport var _DYN_POPULATE_PAGE_VIEW_P12 = \"populatePageViewPerformanceEvent\"; // Count: 3\r\nexport var _DYN_HREF = \"href\"; // Count: 6\r\nexport var _DYN_SEND_EXCEPTION_INTER13 = \"sendExceptionInternal\"; // Count: 2\r\nexport var _DYN_EXCEPTION = \"exception\"; // Count: 3\r\nexport var _DYN_ERROR = \"error\"; // Count: 5\r\nexport var _DYN__ONERROR = \"_onerror\"; // Count: 3\r\nexport var _DYN_ERROR_SRC = \"errorSrc\"; // Count: 3\r\nexport var _DYN_LINE_NUMBER = \"lineNumber\"; // Count: 5\r\nexport var _DYN_COLUMN_NUMBER = \"columnNumber\"; // Count: 5\r\nexport var _DYN_MESSAGE = \"message\"; // Count: 4\r\nexport var _DYN__CREATE_AUTO_EXCEPTI14 = \"CreateAutoException\"; // Count: 3\r\nexport var _DYN_ADD_TELEMETRY_INITIA15 = \"addTelemetryInitializer\"; // Count: 4\r\nexport var _DYN_DURATION = \"duration\"; // Count: 10\r\nexport var _DYN_LENGTH = \"length\"; // Count: 5\r\nexport var _DYN_IS_PERFORMANCE_TIMIN16 = \"isPerformanceTimingSupported\"; // Count: 2\r\nexport var _DYN_GET_PERFORMANCE_TIMI17 = \"getPerformanceTiming\"; // Count: 2\r\nexport var _DYN_NAVIGATION_START = \"navigationStart\"; // Count: 4\r\nexport var _DYN_SHOULD_COLLECT_DURAT18 = \"shouldCollectDuration\"; // Count: 3\r\nexport var _DYN_IS_PERFORMANCE_TIMIN19 = \"isPerformanceTimingDataReady\"; // Count: 2\r\nexport var _DYN_GET_ENTRIES_BY_TYPE = \"getEntriesByType\"; // Count: 3\r\nexport var _DYN_RESPONSE_START = \"responseStart\"; // Count: 5\r\nexport var _DYN_REQUEST_START = \"requestStart\"; // Count: 3\r\nexport var _DYN_LOAD_EVENT_END = \"loadEventEnd\"; // Count: 4\r\nexport var _DYN_RESPONSE_END = \"responseEnd\"; // Count: 5\r\nexport var _DYN_CONNECT_END = \"connectEnd\"; // Count: 4\r\nexport var _DYN_PAGE_VISIT_START_TIM20 = \"pageVisitStartTime\"; // Count: 2\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { dateTimeUtilsDuration } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, arrForEach, dumpObj, getDocument, getExceptionName, getLocation, isNullOrUndefined } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_DURATION, _DYN_GET_PERFORMANCE_TIMI17, _DYN_HREF, _DYN_IS_PERFORMANCE_TIMIN16, _DYN_IS_PERFORMANCE_TIMIN19, _DYN_LENGTH, _DYN_NAVIGATION_START, _DYN_POPULATE_PAGE_VIEW_P12, _DYN_SEND_PAGE_VIEW_INTER10, _DYN_SEND_PAGE_VIEW_PERFO11, _DYN_SHOULD_COLLECT_DURAT18, _DYN_TRACK_PAGE_VIEW } from \"../../__DynamicConstants\";\r\nvar _isWebWorker = null;\r\nfunction isWebWorker() {\r\n if (_isWebWorker == null) {\r\n try {\r\n _isWebWorker = !!(self && self instanceof WorkerGlobalScope);\r\n }\r\n catch (e) {\r\n _isWebWorker = false;\r\n }\r\n }\r\n return _isWebWorker;\r\n}\r\n/**\r\n * Class encapsulates sending page views and page view performance telemetry.\r\n */\r\nvar PageViewManager = /** @class */ (function () {\r\n function PageViewManager(appInsights, overridePageViewDuration, core, pageViewPerformanceManager) {\r\n dynamicProto(PageViewManager, this, function (_self) {\r\n var queueTimer = null;\r\n var itemQueue = [];\r\n var pageViewPerformanceSent = false;\r\n var _logger;\r\n if (core) {\r\n _logger = core.logger;\r\n }\r\n function _flushChannels(isAsync) {\r\n if (core) {\r\n core.flush(isAsync);\r\n }\r\n }\r\n function _startTimer() {\r\n if (!queueTimer) {\r\n queueTimer = setTimeout((function () {\r\n queueTimer = null;\r\n var allItems = itemQueue.slice(0);\r\n var doFlush = false;\r\n itemQueue = [];\r\n arrForEach(allItems, function (item) {\r\n if (!item()) {\r\n // Not processed so rescheduled\r\n itemQueue.push(item);\r\n }\r\n else {\r\n doFlush = true;\r\n }\r\n });\r\n if (itemQueue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _startTimer();\r\n }\r\n if (doFlush) {\r\n // We process at least one item so flush the queue\r\n _flushChannels(true);\r\n }\r\n }), 100);\r\n }\r\n }\r\n function _addQueue(cb) {\r\n itemQueue.push(cb);\r\n _startTimer();\r\n }\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (pageView, customProperties) {\r\n var name = pageView.name;\r\n if (isNullOrUndefined(name) || typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = pageView.name = doc && doc.title || \"\";\r\n }\r\n var uri = pageView.uri;\r\n if (isNullOrUndefined(uri) || typeof uri !== \"string\") {\r\n var location_1 = getLocation();\r\n uri = pageView.uri = location_1 && location_1[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n // case 1a. if performance timing is not supported by the browser, send the page view telemetry with the duration provided by the user. If the user\r\n // do not provide the duration, set duration to undefined\r\n // Also this is case 4\r\n if (!pageViewPerformanceManager[_DYN_IS_PERFORMANCE_TIMIN16 /* @min:%2eisPerformanceTimingSupported */]()) {\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n _flushChannels(true);\r\n if (!isWebWorker()) {\r\n // no navigation timing (IE 8, iOS Safari 8.4, Opera Mini 8 - see http://caniuse.com/#feat=nav-timing)\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 25 /* _eInternalMessageId.NavigationTimingNotSupported */, \"trackPageView: navigation timing API used for calculation of page duration is not supported in this browser. This page view will be collected without duration and timing info.\");\r\n }\r\n return;\r\n }\r\n var pageViewSent = false;\r\n var customDuration;\r\n // if the performance timing is supported by the browser, calculate the custom duration\r\n var start = pageViewPerformanceManager[_DYN_GET_PERFORMANCE_TIMI17 /* @min:%2egetPerformanceTiming */]()[_DYN_NAVIGATION_START /* @min:%2enavigationStart */];\r\n if (start > 0) {\r\n customDuration = dateTimeUtilsDuration(start, +new Date);\r\n if (!pageViewPerformanceManager[_DYN_SHOULD_COLLECT_DURAT18 /* @min:%2eshouldCollectDuration */](customDuration)) {\r\n customDuration = undefined;\r\n }\r\n }\r\n // if the user has provided duration, send a page view telemetry with the provided duration. Otherwise, if\r\n // overridePageViewDuration is set to true, send a page view telemetry with the custom duration calculated earlier\r\n var duration;\r\n if (!isNullOrUndefined(customProperties) &&\r\n !isNullOrUndefined(customProperties[_DYN_DURATION /* @min:%2eduration */])) {\r\n duration = customProperties[_DYN_DURATION /* @min:%2eduration */];\r\n }\r\n if (overridePageViewDuration || !isNaN(duration)) {\r\n if (isNaN(duration)) {\r\n // case 3\r\n if (!customProperties) {\r\n customProperties = {};\r\n }\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = customDuration;\r\n }\r\n // case 2\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n _flushChannels(true);\r\n pageViewSent = true;\r\n }\r\n // now try to send the page view performance telemetry\r\n var maxDurationLimit = 60000;\r\n if (!customProperties) {\r\n customProperties = {};\r\n }\r\n // Queue the event for processing\r\n _addQueue(function () {\r\n var processed = false;\r\n try {\r\n if (pageViewPerformanceManager[_DYN_IS_PERFORMANCE_TIMIN19 /* @min:%2eisPerformanceTimingDataReady */]()) {\r\n processed = true;\r\n var pageViewPerformance = {\r\n name: name,\r\n uri: uri\r\n };\r\n pageViewPerformanceManager[_DYN_POPULATE_PAGE_VIEW_P12 /* @min:%2epopulatePageViewPerformanceEvent */](pageViewPerformance);\r\n if (!pageViewPerformance.isValid && !pageViewSent) {\r\n // If navigation timing gives invalid numbers, then go back to \"override page view duration\" mode.\r\n // That's the best value we can get that makes sense.\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = customDuration;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n else {\r\n if (!pageViewSent) {\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = pageViewPerformance.durationMs;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n if (!pageViewPerformanceSent) {\r\n appInsights[_DYN_SEND_PAGE_VIEW_PERFO11 /* @min:%2esendPageViewPerformanceInternal */](pageViewPerformance, customProperties);\r\n pageViewPerformanceSent = true;\r\n }\r\n }\r\n }\r\n else if (start > 0 && dateTimeUtilsDuration(start, +new Date) > maxDurationLimit) {\r\n // if performance timings are not ready but we exceeded the maximum duration limit, just log a page view telemetry\r\n // with the maximum duration limit. Otherwise, keep waiting until performance timings are ready\r\n processed = true;\r\n if (!pageViewSent) {\r\n customProperties[_DYN_DURATION /* @min:%2eduration */] = maxDurationLimit;\r\n appInsights[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageView, customProperties);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 38 /* _eInternalMessageId.TrackPVFailedCalc */, \"trackPageView failed on page load calculation: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n return processed;\r\n });\r\n };\r\n _self.teardown = function (unloadCtx, unloadState) {\r\n if (queueTimer) {\r\n clearTimeout(queueTimer);\r\n queueTimer = null;\r\n var allItems = itemQueue.slice(0);\r\n var doFlush_1 = false;\r\n itemQueue = [];\r\n arrForEach(allItems, function (item) {\r\n if (item()) {\r\n doFlush_1 = true;\r\n }\r\n });\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for PageViewManager.prototype.trackPageView.\r\n// Removed Stub for PageViewManager.prototype.teardown.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n PageViewManager.__ieDyn=1;\n\n return PageViewManager;\r\n}());\r\nexport { PageViewManager };\r\n//# sourceMappingURL=PageViewManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { dateTimeUtilsDuration, msToTimeSpan } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, getNavigator, getPerformance, safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_CONNECT_END, _DYN_DURATION, _DYN_GET_ENTRIES_BY_TYPE, _DYN_GET_PERFORMANCE_TIMI17, _DYN_IS_PERFORMANCE_TIMIN16, _DYN_IS_PERFORMANCE_TIMIN19, _DYN_LENGTH, _DYN_LOAD_EVENT_END, _DYN_NAVIGATION_START, _DYN_POPULATE_PAGE_VIEW_P12, _DYN_REQUEST_START, _DYN_RESPONSE_END, _DYN_RESPONSE_START, _DYN_SHOULD_COLLECT_DURAT18 } from \"../../__DynamicConstants\";\r\nvar MAX_DURATION_ALLOWED = 3600000; // 1h\r\nvar botAgentNames = [\"googlebot\", \"adsbot-google\", \"apis-google\", \"mediapartners-google\"];\r\nfunction _isPerformanceTimingSupported() {\r\n var perf = getPerformance();\r\n return perf && !!perf.timing;\r\n}\r\nfunction _isPerformanceNavigationTimingSupported() {\r\n var perf = getPerformance();\r\n return perf && perf.getEntriesByType && perf.getEntriesByType(\"navigation\")[_DYN_LENGTH /* @min:%2elength */] > 0;\r\n}\r\nfunction _isPerformanceTimingDataReady() {\r\n var perf = getPerformance();\r\n var timing = perf ? perf.timing : 0;\r\n return timing\r\n && timing.domainLookupStart > 0\r\n && timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */] > 0\r\n && timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */] > 0\r\n && timing[_DYN_REQUEST_START /* @min:%2erequestStart */] > 0\r\n && timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */] > 0\r\n && timing[_DYN_RESPONSE_END /* @min:%2eresponseEnd */] > 0\r\n && timing[_DYN_CONNECT_END /* @min:%2econnectEnd */] > 0\r\n && timing.domLoading > 0;\r\n}\r\nfunction _getPerformanceTiming() {\r\n if (_isPerformanceTimingSupported()) {\r\n return getPerformance().timing;\r\n }\r\n return null;\r\n}\r\nfunction _getPerformanceNavigationTiming() {\r\n if (_isPerformanceNavigationTimingSupported()) {\r\n return getPerformance()[_DYN_GET_ENTRIES_BY_TYPE /* @min:%2egetEntriesByType */](\"navigation\")[0];\r\n }\r\n return null;\r\n}\r\n/**\r\n* This method tells if given durations should be excluded from collection.\r\n*/\r\nfunction _shouldCollectDuration() {\r\n var durations = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n durations[_i] = arguments[_i];\r\n }\r\n var _navigator = getNavigator() || {};\r\n // a full list of Google crawlers user agent strings - https://support.google.com/webmasters/answer/1061943?hl=en\r\n var userAgent = _navigator.userAgent;\r\n var isGoogleBot = false;\r\n if (userAgent) {\r\n for (var i = 0; i < botAgentNames[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n isGoogleBot = isGoogleBot || userAgent.toLowerCase().indexOf(botAgentNames[i]) !== -1;\r\n }\r\n }\r\n if (isGoogleBot) {\r\n // Don't report durations for GoogleBot, it is returning invalid values in performance.timing API.\r\n return false;\r\n }\r\n else {\r\n // for other page views, don't report if it's outside of a reasonable range\r\n for (var i = 0; i < durations[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (durations[i] < 0 || durations[i] >= MAX_DURATION_ALLOWED) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n}\r\n/**\r\n * Class encapsulates sending page view performance telemetry.\r\n */\r\nvar PageViewPerformanceManager = /** @class */ (function () {\r\n function PageViewPerformanceManager(core) {\r\n var _logger = safeGetLogger(core);\r\n dynamicProto(PageViewPerformanceManager, this, function (_self) {\r\n _self[_DYN_POPULATE_PAGE_VIEW_P12 /* @min:%2epopulatePageViewPerformanceEvent */] = function (pageViewPerformance) {\r\n pageViewPerformance.isValid = false;\r\n /*\r\n * http://www.w3.org/TR/navigation-timing/#processing-model\r\n * |-navigationStart\r\n * | |-connectEnd\r\n * | ||-requestStart\r\n * | || |-responseStart\r\n * | || | |-responseEnd\r\n * | || | |\r\n * | || | | |-loadEventEnd\r\n * |---network---||---request---|---response---|---dom---|\r\n * |--------------------------total----------------------|\r\n *\r\n * total = The difference between the load event of the current document is completed and the first recorded timestamp of the performance entry : https://developer.mozilla.org/en-US/docs/Web/Performance/Navigation_and_resource_timings#duration\r\n * network = Redirect time + App Cache + DNS lookup time + TCP connection time\r\n * request = Request time : https://developer.mozilla.org/en-US/docs/Web/Performance/Navigation_and_resource_timings#request_time\r\n * response = Response time\r\n * dom = Document load time : https://html.spec.whatwg.org/multipage/dom.html#document-load-timing-info\r\n * = Document processing time : https://developers.google.com/web/fundamentals/performance/navigation-and-resource-timing/#document_processing\r\n * + Loading time : https://developers.google.com/web/fundamentals/performance/navigation-and-resource-timing/#loading\r\n */\r\n var navigationTiming = _getPerformanceNavigationTiming();\r\n var timing = _getPerformanceTiming();\r\n var total = 0;\r\n var network = 0;\r\n var request = 0;\r\n var response = 0;\r\n var dom = 0;\r\n if (navigationTiming || timing) {\r\n if (navigationTiming) {\r\n total = navigationTiming[_DYN_DURATION /* @min:%2eduration */];\r\n /**\r\n * support both cases:\r\n * - startTime is always zero: https://developer.mozilla.org/en-US/docs/Web/API/PerformanceNavigationTiming\r\n * - for older browsers where the startTime is not zero\r\n */\r\n network = navigationTiming.startTime === 0 ? navigationTiming[_DYN_CONNECT_END /* @min:%2econnectEnd */] : dateTimeUtilsDuration(navigationTiming.startTime, navigationTiming[_DYN_CONNECT_END /* @min:%2econnectEnd */]);\r\n request = dateTimeUtilsDuration(navigationTiming.requestStart, navigationTiming[_DYN_RESPONSE_START /* @min:%2eresponseStart */]);\r\n response = dateTimeUtilsDuration(navigationTiming[_DYN_RESPONSE_START /* @min:%2eresponseStart */], navigationTiming[_DYN_RESPONSE_END /* @min:%2eresponseEnd */]);\r\n dom = dateTimeUtilsDuration(navigationTiming.responseEnd, navigationTiming[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n }\r\n else {\r\n total = dateTimeUtilsDuration(timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */], timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n network = dateTimeUtilsDuration(timing[_DYN_NAVIGATION_START /* @min:%2enavigationStart */], timing[_DYN_CONNECT_END /* @min:%2econnectEnd */]);\r\n request = dateTimeUtilsDuration(timing.requestStart, timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */]);\r\n response = dateTimeUtilsDuration(timing[_DYN_RESPONSE_START /* @min:%2eresponseStart */], timing[_DYN_RESPONSE_END /* @min:%2eresponseEnd */]);\r\n dom = dateTimeUtilsDuration(timing.responseEnd, timing[_DYN_LOAD_EVENT_END /* @min:%2eloadEventEnd */]);\r\n }\r\n if (total === 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 10 /* _eInternalMessageId.ErrorPVCalc */, \"error calculating page view performance.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else if (!_self[_DYN_SHOULD_COLLECT_DURAT18 /* @min:%2eshouldCollectDuration */](total, network, request, response, dom)) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 45 /* _eInternalMessageId.InvalidDurationValue */, \"Invalid page load duration value. Browser perf data won't be sent.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else if (total < Math.floor(network) + Math.floor(request) + Math.floor(response) + Math.floor(dom)) {\r\n // some browsers may report individual components incorrectly so that the sum of the parts will be bigger than total PLT\r\n // in this case, don't report client performance from this page\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 8 /* _eInternalMessageId.ClientPerformanceMathError */, \"client performance math error.\", { total: total, network: network, request: request, response: response, dom: dom });\r\n }\r\n else {\r\n pageViewPerformance.durationMs = total;\r\n // // convert to timespans\r\n pageViewPerformance.perfTotal = pageViewPerformance[_DYN_DURATION /* @min:%2eduration */] = msToTimeSpan(total);\r\n pageViewPerformance.networkConnect = msToTimeSpan(network);\r\n pageViewPerformance.sentRequest = msToTimeSpan(request);\r\n pageViewPerformance.receivedResponse = msToTimeSpan(response);\r\n pageViewPerformance.domProcessing = msToTimeSpan(dom);\r\n pageViewPerformance.isValid = true;\r\n }\r\n }\r\n };\r\n _self[_DYN_GET_PERFORMANCE_TIMI17 /* @min:%2egetPerformanceTiming */] = _getPerformanceTiming;\r\n _self[_DYN_IS_PERFORMANCE_TIMIN16 /* @min:%2eisPerformanceTimingSupported */] = _isPerformanceTimingSupported;\r\n _self[_DYN_IS_PERFORMANCE_TIMIN19 /* @min:%2eisPerformanceTimingDataReady */] = _isPerformanceTimingDataReady;\r\n _self[_DYN_SHOULD_COLLECT_DURAT18 /* @min:%2eshouldCollectDuration */] = _shouldCollectDuration;\r\n });\r\n }\r\n// Removed Stub for PageViewPerformanceManager.prototype.populatePageViewPerformanceEvent.\r\n// Removed Stub for PageViewPerformanceManager.prototype.getPerformanceTiming.\r\n// Removed Stub for PageViewPerformanceManager.prototype.isPerformanceTimingSupported.\r\n// Removed Stub for PageViewPerformanceManager.prototype.isPerformanceTimingDataReady.\r\n// Removed Stub for PageViewPerformanceManager.prototype.shouldCollectDuration.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n PageViewPerformanceManager.__ieDyn=1;\n\n return PageViewPerformanceManager;\r\n}());\r\nexport { PageViewPerformanceManager };\r\n//# sourceMappingURL=PageViewPerformanceManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlCanUseSessionStorage, utlGetSessionStorage, utlRemoveSessionStorage, utlSetSessionStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _warnToConsole, dateNow, dumpObj, getJSON, hasJSON, objDefineAccessors, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_PAGE_VISIT_START_TIM20, _DYN_TRACK_PREVIOUS_PAGE_9 } from \"../../__DynamicConstants\";\r\n/**\r\n * Used to track page visit durations\r\n */\r\nvar PageVisitTimeManager = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of PageVisitTimeManager\r\n * @param pageVisitTimeTrackingHandler Delegate that will be called to send telemetry data to AI (when trackPreviousPageVisit is called)\r\n * @returns {}\r\n */\r\n function PageVisitTimeManager(logger, pageVisitTimeTrackingHandler) {\r\n var prevPageVisitDataKeyName = \"prevPageVisitData\";\r\n dynamicProto(PageVisitTimeManager, this, function (_self) {\r\n _self[_DYN_TRACK_PREVIOUS_PAGE_9 /* @min:%2etrackPreviousPageVisit */] = function (currentPageName, currentPageUrl) {\r\n try {\r\n // Restart timer for new page view\r\n var prevPageVisitTimeData = restartPageVisitTimer(currentPageName, currentPageUrl);\r\n // If there was a page already being timed, track the visit time for it now.\r\n if (prevPageVisitTimeData) {\r\n pageVisitTimeTrackingHandler(prevPageVisitTimeData.pageName, prevPageVisitTimeData.pageUrl, prevPageVisitTimeData.pageVisitTime);\r\n }\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Auto track page visit time failed, metric will not be collected: \" + dumpObj(e));\r\n }\r\n };\r\n /**\r\n * Stops timing of current page (if exists) and starts timing for duration of visit to pageName\r\n * @param pageName Name of page to begin timing visit duration\r\n * @returns {PageVisitData} Page visit data (including duration) of pageName from last call to start or restart, if exists. Null if not.\r\n */\r\n function restartPageVisitTimer(pageName, pageUrl) {\r\n var prevPageVisitData = null;\r\n try {\r\n prevPageVisitData = stopPageVisitTimer();\r\n startPageVisitTimer(pageName, pageUrl);\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Call to restart failed: \" + dumpObj(e));\r\n prevPageVisitData = null;\r\n }\r\n return prevPageVisitData;\r\n }\r\n /**\r\n * Starts timing visit duration of pageName\r\n * @param pageName\r\n * @returns {}\r\n */\r\n function startPageVisitTimer(pageName, pageUrl) {\r\n try {\r\n if (utlCanUseSessionStorage()) {\r\n if (utlGetSessionStorage(logger, prevPageVisitDataKeyName) != null) {\r\n throwError(\"Cannot call startPageVisit consecutively without first calling stopPageVisit\");\r\n }\r\n var currPageVisitData = new PageVisitData(pageName, pageUrl);\r\n var currPageVisitDataStr = getJSON().stringify(currPageVisitData);\r\n utlSetSessionStorage(logger, prevPageVisitDataKeyName, currPageVisitDataStr);\r\n }\r\n }\r\n catch (e) {\r\n // TODO: Remove this catch in next phase, since if start is called twice in a row the exception needs to be propagated out\r\n _warnToConsole(logger, \"Call to start failed: \" + dumpObj(e));\r\n }\r\n }\r\n /**\r\n * Stops timing of current page, if exists.\r\n * @returns {PageVisitData} Page visit data (including duration) of pageName from call to start, if exists. Null if not.\r\n */\r\n function stopPageVisitTimer() {\r\n var prevPageVisitData = null;\r\n try {\r\n if (utlCanUseSessionStorage()) {\r\n // Define end time of page's visit\r\n var pageVisitEndTime = dateNow();\r\n // Try to retrieve page name and start time from session storage\r\n var pageVisitDataJsonStr = utlGetSessionStorage(logger, prevPageVisitDataKeyName);\r\n if (pageVisitDataJsonStr && hasJSON()) {\r\n // if previous page data exists, set end time of visit\r\n prevPageVisitData = getJSON().parse(pageVisitDataJsonStr);\r\n prevPageVisitData.pageVisitTime = pageVisitEndTime - prevPageVisitData[_DYN_PAGE_VISIT_START_TIM20 /* @min:%2epageVisitStartTime */];\r\n // Remove data from storage since we already used it\r\n utlRemoveSessionStorage(logger, prevPageVisitDataKeyName);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _warnToConsole(logger, \"Stop page visit timer failed: \" + dumpObj(e));\r\n prevPageVisitData = null;\r\n }\r\n return prevPageVisitData;\r\n }\r\n // For backward compatibility\r\n objDefineAccessors(_self, \"_logger\", function () { return logger; });\r\n objDefineAccessors(_self, \"pageVisitTimeTrackingHandler\", function () { return pageVisitTimeTrackingHandler; });\r\n });\r\n }\r\n// Removed Stub for PageVisitTimeManager.prototype.trackPreviousPageVisit.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n PageVisitTimeManager.__ieDyn=1;\n\n return PageVisitTimeManager;\r\n}());\r\nexport { PageVisitTimeManager };\r\nvar PageVisitData = /** @class */ (function () {\r\n function PageVisitData(pageName, pageUrl) {\r\n this[_DYN_PAGE_VISIT_START_TIM20 /* @min:%2epageVisitStartTime */] = dateNow();\r\n this.pageName = pageName;\r\n this.pageUrl = pageUrl;\r\n }\r\n return PageVisitData;\r\n}());\r\nexport { PageVisitData };\r\n//# sourceMappingURL=PageVisitTimeManager.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dateTimeUtilsDuration } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal } from \"@microsoft/applicationinsights-core-js\";\r\n/**\r\n * Used to record timed events and page views.\r\n */\r\nvar Timing = /** @class */ (function () {\r\n function Timing(logger, name) {\r\n var _self = this;\r\n var _events = {};\r\n _self.start = function (name) {\r\n if (typeof _events[name] !== \"undefined\") {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 62 /* _eInternalMessageId.StartCalledMoreThanOnce */, \"start was called more than once for this event without calling stop.\", { name: name, key: name }, true);\r\n }\r\n _events[name] = +new Date;\r\n };\r\n _self.stop = function (name, url, properties, measurements) {\r\n var start = _events[name];\r\n if (isNaN(start)) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 63 /* _eInternalMessageId.StopCalledWithoutStart */, \"stop was called without a corresponding start.\", { name: name, key: name }, true);\r\n }\r\n else {\r\n var end = +new Date;\r\n var duration = dateTimeUtilsDuration(start, end);\r\n _self.action(name, url, duration, properties, measurements);\r\n }\r\n delete _events[name];\r\n _events[name] = undefined;\r\n };\r\n }\r\n return Timing;\r\n}());\r\nexport { Timing };\r\n//# sourceMappingURL=Timing.js.map","/*\n * Application Insights JavaScript SDK - Web Analytics, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* ApplicationInsights.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { AnalyticsPluginIdentifier, Event as EventTelemetry, Exception, Metric, PageView, PageViewPerformance, PropertiesPluginIdentifier, RemoteDependencyData, Trace, createDistributedTraceContextFromTrace, createDomEvent, createTelemetryItem, dataSanitizeString, isCrossOriginError, strNotSpecified, stringToBoolOrDefault, utlDisableStorage, utlEnableStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, InstrumentEvent, arrForEach, createProcessTelemetryContext, createUniqueNamespace, dumpObj, eventOff, eventOn, generateW3CId, getDocument, getExceptionName, getHistory, getLocation, getWindow, hasHistory, hasWindow, isError, isFunction, isNullOrUndefined, isString, isUndefined, mergeEvtNamespace, objDefineAccessors, objForEachKey, safeGetCookieMgr, strUndefined, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_ADD_TELEMETRY_INITIA15, _DYN_AUTO_TRACK_PAGE_VISI1, _DYN_COLUMN_NUMBER, _DYN_CORE, _DYN_DATA_TYPE, _DYN_DIAG_LOG, _DYN_DISABLE_EXCEPTION_TR0, _DYN_DISABLE_FLUSH_ON_BEF7, _DYN_ENABLE_AUTO_ROUTE_TR6, _DYN_ENABLE_UNHANDLED_PRO3, _DYN_ENVELOPE_TYPE, _DYN_ERROR, _DYN_ERROR_SRC, _DYN_EXCEPTION, _DYN_HREF, _DYN_IS_BROWSER_LINK_TRAC5, _DYN_IS_STORAGE_USE_DISAB4, _DYN_LENGTH, _DYN_LINE_NUMBER, _DYN_MESSAGE, _DYN_NAME_PREFIX, _DYN_OVERRIDE_PAGE_VIEW_D2, _DYN_POPULATE_PAGE_VIEW_P12, _DYN_SAMPLING_PERCENTAGE, _DYN_SEND_EXCEPTION_INTER13, _DYN_SEND_PAGE_VIEW_INTER10, _DYN_SEND_PAGE_VIEW_PERFO11, _DYN_TO_STRING, _DYN_TRACK, _DYN_TRACK_PAGE_VIEW, _DYN_TRACK_PREVIOUS_PAGE_9, _DYN__CREATE_AUTO_EXCEPTI14, _DYN__ONERROR } from \"../__DynamicConstants\";\r\nimport { PageViewManager } from \"./Telemetry/PageViewManager\";\r\nimport { PageViewPerformanceManager } from \"./Telemetry/PageViewPerformanceManager\";\r\nimport { PageVisitTimeManager } from \"./Telemetry/PageVisitTimeManager\";\r\nimport { Timing } from \"./Timing\";\r\nvar strEvent = \"event\";\r\nfunction _dispatchEvent(target, evnt) {\r\n if (target && target.dispatchEvent && evnt) {\r\n target.dispatchEvent(evnt);\r\n }\r\n}\r\nfunction _getReason(error) {\r\n if (error && error.reason) {\r\n var reason = error.reason;\r\n if (!isString(reason) && isFunction(reason[_DYN_TO_STRING /* @min:%2etoString */])) {\r\n return reason[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n return dumpObj(reason);\r\n }\r\n // Pass the original object down which will eventually get evaluated for any message or description\r\n return error || \"\";\r\n}\r\nvar MinMilliSeconds = 60000;\r\nfunction _configMilliseconds(value, defValue) {\r\n value = value || defValue;\r\n if (value < MinMilliSeconds) {\r\n value = MinMilliSeconds;\r\n }\r\n return value;\r\n}\r\nfunction _getDefaultConfig(config) {\r\n if (!config) {\r\n config = {};\r\n }\r\n // set default values\r\n config.sessionRenewalMs = _configMilliseconds(config.sessionRenewalMs, 30 * 60 * 1000);\r\n config.sessionExpirationMs = _configMilliseconds(config.sessionExpirationMs, 24 * 60 * 60 * 1000);\r\n config[_DYN_DISABLE_EXCEPTION_TR0 /* @min:%2edisableExceptionTracking */] = stringToBoolOrDefault(config[_DYN_DISABLE_EXCEPTION_TR0 /* @min:%2edisableExceptionTracking */]);\r\n config[_DYN_AUTO_TRACK_PAGE_VISI1 /* @min:%2eautoTrackPageVisitTime */] = stringToBoolOrDefault(config[_DYN_AUTO_TRACK_PAGE_VISI1 /* @min:%2eautoTrackPageVisitTime */]);\r\n config[_DYN_OVERRIDE_PAGE_VIEW_D2 /* @min:%2eoverridePageViewDuration */] = stringToBoolOrDefault(config[_DYN_OVERRIDE_PAGE_VIEW_D2 /* @min:%2eoverridePageViewDuration */]);\r\n config[_DYN_ENABLE_UNHANDLED_PRO3 /* @min:%2eenableUnhandledPromiseRejectionTracking */] = stringToBoolOrDefault(config[_DYN_ENABLE_UNHANDLED_PRO3 /* @min:%2eenableUnhandledPromiseRejectionTracking */]);\r\n if (isNaN(config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */]) || config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] <= 0 || config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] >= 100) {\r\n config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] = 100;\r\n }\r\n config[_DYN_IS_STORAGE_USE_DISAB4 /* @min:%2eisStorageUseDisabled */] = stringToBoolOrDefault(config[_DYN_IS_STORAGE_USE_DISAB4 /* @min:%2eisStorageUseDisabled */]);\r\n config[_DYN_IS_BROWSER_LINK_TRAC5 /* @min:%2eisBrowserLinkTrackingEnabled */] = stringToBoolOrDefault(config[_DYN_IS_BROWSER_LINK_TRAC5 /* @min:%2eisBrowserLinkTrackingEnabled */]);\r\n config[_DYN_ENABLE_AUTO_ROUTE_TR6 /* @min:%2eenableAutoRouteTracking */] = stringToBoolOrDefault(config[_DYN_ENABLE_AUTO_ROUTE_TR6 /* @min:%2eenableAutoRouteTracking */]);\r\n config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] = config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] || \"\";\r\n config.enableDebug = stringToBoolOrDefault(config.enableDebug);\r\n config[_DYN_DISABLE_FLUSH_ON_BEF7 /* @min:%2edisableFlushOnBeforeUnload */] = stringToBoolOrDefault(config[_DYN_DISABLE_FLUSH_ON_BEF7 /* @min:%2edisableFlushOnBeforeUnload */]);\r\n config.disableFlushOnUnload = stringToBoolOrDefault(config.disableFlushOnUnload, config[_DYN_DISABLE_FLUSH_ON_BEF7 /* @min:%2edisableFlushOnBeforeUnload */]);\r\n return config;\r\n}\r\nfunction _updateStorageUsage(extConfig) {\r\n // Not resetting the storage usage as someone may have manually called utlDisableStorage, so this will only\r\n // reset based if the configuration option is provided\r\n if (!isUndefined(extConfig[_DYN_IS_STORAGE_USE_DISAB4 /* @min:%2eisStorageUseDisabled */])) {\r\n if (extConfig[_DYN_IS_STORAGE_USE_DISAB4 /* @min:%2eisStorageUseDisabled */]) {\r\n utlDisableStorage();\r\n }\r\n else {\r\n utlEnableStorage();\r\n }\r\n }\r\n}\r\nvar AnalyticsPlugin = /** @class */ (function (_super) {\r\n __extends(AnalyticsPlugin, _super);\r\n function AnalyticsPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = AnalyticsPluginIdentifier; // do not change name or priority\r\n _this.priority = 180; // take from reserved priority range 100- 200\r\n _this.autoRoutePVDelay = 500; // ms; Time to wait after a route change before triggering a pageview to allow DOM changes to take place\r\n var _eventTracking;\r\n var _pageTracking;\r\n var _pageViewManager;\r\n var _pageViewPerformanceManager;\r\n var _pageVisitTimeManager;\r\n var _preInitTelemetryInitializers;\r\n var _isBrowserLinkTrackingEnabled;\r\n var _browserLinkInitializerAdded;\r\n var _enableAutoRouteTracking;\r\n var _historyListenerAdded;\r\n var _disableExceptionTracking;\r\n var _autoExceptionInstrumented;\r\n var _enableUnhandledPromiseRejectionTracking;\r\n var _autoUnhandledPromiseInstrumented;\r\n // Counts number of trackAjax invocations.\r\n // By default we only monitor X ajax call per view to avoid too much load.\r\n // Default value is set in config.\r\n // This counter keeps increasing even after the limit is reached.\r\n var _trackAjaxAttempts = 0;\r\n // array with max length of 2 that store current url and previous url for SPA page route change trackPageview use.\r\n var _prevUri; // Assigned in the constructor\r\n var _currUri;\r\n var _evtNamespace;\r\n dynamicProto(AnalyticsPlugin, _this, function (_self, _base) {\r\n var _addHook = _base._addHook;\r\n _initDefaults();\r\n _self.getCookieMgr = function () {\r\n return safeGetCookieMgr(_self[_DYN_CORE /* @min:%2ecore */]);\r\n };\r\n _self.processTelemetry = function (env, itemCtx) {\r\n _self.processNext(env, itemCtx);\r\n };\r\n _self.trackEvent = function (event, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(event, EventTelemetry[_DYN_DATA_TYPE /* @min:%2edataType */], EventTelemetry[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(2 /* eLoggingSeverity.WARNING */, 39 /* _eInternalMessageId.TrackTraceFailed */, \"trackTrace failed, trace will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Start timing an extended event. Call `stopTrackEvent` to log the event when it ends.\r\n * @param name A string that identifies this event uniquely within the document.\r\n */\r\n _self.startTrackEvent = function (name) {\r\n try {\r\n _eventTracking.start(name);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 29 /* _eInternalMessageId.StartTrackEventFailed */, \"startTrackEvent failed, event will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Log an extended event that you started timing with `startTrackEvent`.\r\n * @param name The string you used to identify this event in `startTrackEvent`.\r\n * @param properties map[string, string] - additional data used to filter events and metrics in the portal. Defaults to empty.\r\n * @param measurements map[string, number] - metrics associated with this event, displayed in Metrics Explorer on the portal. Defaults to empty.\r\n */\r\n _self.stopTrackEvent = function (name, properties, measurements) {\r\n try {\r\n _eventTracking.stop(name, undefined, properties, measurements);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 30 /* _eInternalMessageId.StopTrackEventFailed */, \"stopTrackEvent failed, event will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Log a diagnostic message\r\n * @param {ITraceTelemetry} trace\r\n * @param ICustomProperties.\r\n * @memberof ApplicationInsights\r\n */\r\n _self.trackTrace = function (trace, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(trace, Trace[_DYN_DATA_TYPE /* @min:%2edataType */], Trace[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(2 /* eLoggingSeverity.WARNING */, 39 /* _eInternalMessageId.TrackTraceFailed */, \"trackTrace failed, trace will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Log a numeric value that is not associated with a specific event. Typically\r\n * used to send regular reports of performance indicators. To send single measurement, just\r\n * use the name and average fields of {@link IMetricTelemetry}. If you take measurements\r\n * frequently, you can reduce the telemetry bandwidth by aggregating multiple measurements\r\n * and sending the resulting average at intervals\r\n * @param {IMetricTelemetry} metric input object argument. Only name and average are mandatory.\r\n * @param {{[key: string]: any}} customProperties additional data used to filter metrics in the\r\n * portal. Defaults to empty.\r\n * @memberof ApplicationInsights\r\n */\r\n _self.trackMetric = function (metric, customProperties) {\r\n try {\r\n var telemetryItem = createTelemetryItem(metric, Metric[_DYN_DATA_TYPE /* @min:%2edataType */], Metric[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 36 /* _eInternalMessageId.TrackMetricFailed */, \"trackMetric failed, metric will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Logs that a page or other item was viewed.\r\n * @param IPageViewTelemetry The string you used as the name in startTrackPage. Defaults to the document title.\r\n * @param customProperties Additional data used to filter events and metrics. Defaults to empty.\r\n * If a user wants to provide duration for pageLoad, it'll have to be in pageView.properties.duration\r\n */\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (pageView, customProperties) {\r\n try {\r\n var inPv = pageView || {};\r\n _pageViewManager[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */](inPv, __assign(__assign(__assign({}, inPv.properties), inPv.measurements), customProperties));\r\n if (_self.config[_DYN_AUTO_TRACK_PAGE_VISI1 /* @min:%2eautoTrackPageVisitTime */]) {\r\n _pageVisitTimeManager[_DYN_TRACK_PREVIOUS_PAGE_9 /* @min:%2etrackPreviousPageVisit */](inPv.name, inPv.uri);\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 37 /* _eInternalMessageId.TrackPVFailed */, \"trackPageView failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Create a page view telemetry item and send it to the SDK pipeline through the core.track API\r\n * @param pageView Page view item to be sent\r\n * @param properties Custom properties (Part C) that a user can add to the telemetry item\r\n * @param systemProperties System level properties (Part A) that a user can add to the telemetry item\r\n */\r\n _self[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */] = function (pageView, properties, systemProperties) {\r\n var doc = getDocument();\r\n if (doc) {\r\n pageView.refUri = pageView.refUri === undefined ? doc.referrer : pageView.refUri;\r\n }\r\n var telemetryItem = createTelemetryItem(pageView, PageView[_DYN_DATA_TYPE /* @min:%2edataType */], PageView[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n // reset ajaxes counter\r\n _trackAjaxAttempts = 0;\r\n };\r\n /**\r\n * @ignore INTERNAL ONLY\r\n * @param pageViewPerformance\r\n * @param properties\r\n */\r\n _self[_DYN_SEND_PAGE_VIEW_PERFO11 /* @min:%2esendPageViewPerformanceInternal */] = function (pageViewPerformance, properties, systemProperties) {\r\n var telemetryItem = createTelemetryItem(pageViewPerformance, PageViewPerformance[_DYN_DATA_TYPE /* @min:%2edataType */], PageViewPerformance[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n };\r\n /**\r\n * Send browser performance metrics.\r\n * @param pageViewPerformance\r\n * @param customProperties\r\n */\r\n _self.trackPageViewPerformance = function (pageViewPerformance, customProperties) {\r\n var inPvp = pageViewPerformance || {};\r\n try {\r\n _pageViewPerformanceManager[_DYN_POPULATE_PAGE_VIEW_P12 /* @min:%2epopulatePageViewPerformanceEvent */](inPvp);\r\n _self[_DYN_SEND_PAGE_VIEW_PERFO11 /* @min:%2esendPageViewPerformanceInternal */](inPvp, customProperties);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 37 /* _eInternalMessageId.TrackPVFailed */, \"trackPageViewPerformance failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Starts the timer for tracking a page load time. Use this instead of `trackPageView` if you want to control when the page view timer starts and stops,\r\n * but don't want to calculate the duration yourself. This method doesn't send any telemetry. Call `stopTrackPage` to log the end of the page view\r\n * and send the event.\r\n * @param name A string that idenfities this item, unique within this HTML document. Defaults to the document title.\r\n */\r\n _self.startTrackPage = function (name) {\r\n try {\r\n if (typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = doc && doc.title || \"\";\r\n }\r\n _pageTracking.start(name);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 31 /* _eInternalMessageId.StartTrackFailed */, \"startTrackPage failed, page view may not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * Stops the timer that was started by calling `startTrackPage` and sends the pageview load time telemetry with the specified properties and measurements.\r\n * The duration of the page view will be the time between calling `startTrackPage` and `stopTrackPage`.\r\n * @param name The string you used as the name in startTrackPage. Defaults to the document title.\r\n * @param url String - a relative or absolute URL that identifies the page or other item. Defaults to the window location.\r\n * @param properties map[string, string] - additional data used to filter pages and metrics in the portal. Defaults to empty.\r\n * @param measurements map[string, number] - metrics associated with this page, displayed in Metrics Explorer on the portal. Defaults to empty.\r\n */\r\n _self.stopTrackPage = function (name, url, properties, measurement) {\r\n try {\r\n if (typeof name !== \"string\") {\r\n var doc = getDocument();\r\n name = doc && doc.title || \"\";\r\n }\r\n if (typeof url !== \"string\") {\r\n var loc = getLocation();\r\n url = loc && loc[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n _pageTracking.stop(name, url, properties, measurement);\r\n if (_self.config[_DYN_AUTO_TRACK_PAGE_VISI1 /* @min:%2eautoTrackPageVisitTime */]) {\r\n _pageVisitTimeManager[_DYN_TRACK_PREVIOUS_PAGE_9 /* @min:%2etrackPreviousPageVisit */](name, url);\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 32 /* _eInternalMessageId.StopTrackFailed */, \"stopTrackPage failed, page view will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @ignore INTERNAL ONLY\r\n * @param exception\r\n * @param properties\r\n * @param systemProperties\r\n */\r\n _self[_DYN_SEND_EXCEPTION_INTER13 /* @min:%2esendExceptionInternal */] = function (exception, customProperties, systemProperties) {\r\n // Adding additional edge cases to handle\r\n // - Not passing anything (null / undefined)\r\n var theError = (exception && (exception[_DYN_EXCEPTION /* @min:%2eexception */] || exception[_DYN_ERROR /* @min:%2eerror */])) ||\r\n // - Handle someone calling trackException based of v1 API where the exception was the Error\r\n isError(exception) && exception ||\r\n // - Handles no error being defined and instead of creating a new Error() instance attempt to map so any stacktrace\r\n // is preserved and does not list ApplicationInsights code as the source\r\n { name: (exception && typeof exception), message: exception || strNotSpecified };\r\n // If no exception object was passed assign to an empty object to avoid internal exceptions\r\n exception = exception || {};\r\n var exceptionPartB = new Exception(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), theError, exception.properties || customProperties, exception.measurements, exception.severityLevel, exception.id).toInterface();\r\n var telemetryItem = createTelemetryItem(exceptionPartB, Exception[_DYN_DATA_TYPE /* @min:%2edataType */], Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), customProperties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n };\r\n /**\r\n * Log an exception you have caught.\r\n *\r\n * @param {IExceptionTelemetry} exception Object which contains exception to be sent\r\n * @param {{[key: string]: any}} customProperties Additional data used to filter pages and metrics in the portal. Defaults to empty.\r\n *\r\n * Any property of type double will be considered a measurement, and will be treated by Application Insights as a metric.\r\n * @memberof ApplicationInsights\r\n */\r\n _self.trackException = function (exception, customProperties) {\r\n if (exception && !exception[_DYN_EXCEPTION /* @min:%2eexception */] && exception[_DYN_ERROR /* @min:%2eerror */]) {\r\n exception[_DYN_EXCEPTION /* @min:%2eexception */] = exception[_DYN_ERROR /* @min:%2eerror */];\r\n }\r\n try {\r\n _self[_DYN_SEND_EXCEPTION_INTER13 /* @min:%2esendExceptionInternal */](exception, customProperties);\r\n }\r\n catch (e) {\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 35 /* _eInternalMessageId.TrackExceptionFailed */, \"trackException failed, exception will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n };\r\n /**\r\n * @description Custom error handler for Application Insights Analytics\r\n * @param {IAutoExceptionTelemetry} exception\r\n * @memberof ApplicationInsights\r\n */\r\n _self[_DYN__ONERROR /* @min:%2e_onerror */] = function (exception) {\r\n var error = exception && exception[_DYN_ERROR /* @min:%2eerror */];\r\n var evt = exception && exception.evt;\r\n try {\r\n if (!evt) {\r\n var _window = getWindow();\r\n if (_window) {\r\n evt = _window[strEvent];\r\n }\r\n }\r\n var url = (exception && exception.url) || (getDocument() || {}).URL;\r\n // If no error source is provided assume the default window.onerror handler\r\n var errorSrc = exception[_DYN_ERROR_SRC /* @min:%2eerrorSrc */] || \"window.onerror@\" + url + \":\" + (exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0) + \":\" + (exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0);\r\n var properties = {\r\n errorSrc: errorSrc,\r\n url: url,\r\n lineNumber: exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0,\r\n columnNumber: exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0,\r\n message: exception[_DYN_MESSAGE /* @min:%2emessage */]\r\n };\r\n if (isCrossOriginError(exception.message, exception.url, exception.lineNumber, exception.columnNumber, exception[_DYN_ERROR /* @min:%2eerror */])) {\r\n _sendCORSException(Exception[_DYN__CREATE_AUTO_EXCEPTI14 /* @min:%2eCreateAutoException */](\"Script error: The browser's same-origin policy prevents us from getting the details of this exception. Consider using the 'crossorigin' attribute.\", url, exception[_DYN_LINE_NUMBER /* @min:%2elineNumber */] || 0, exception[_DYN_COLUMN_NUMBER /* @min:%2ecolumnNumber */] || 0, error, evt, null, errorSrc), properties);\r\n }\r\n else {\r\n if (!exception[_DYN_ERROR_SRC /* @min:%2eerrorSrc */]) {\r\n exception[_DYN_ERROR_SRC /* @min:%2eerrorSrc */] = errorSrc;\r\n }\r\n _self.trackException({ exception: exception, severityLevel: 3 /* eSeverityLevel.Error */ }, properties);\r\n }\r\n }\r\n catch (e) {\r\n var errorString = error ? (error.name + \", \" + error[_DYN_MESSAGE /* @min:%2emessage */]) : \"null\";\r\n _throwInternal(1 /* eLoggingSeverity.CRITICAL */, 11 /* _eInternalMessageId.ExceptionWhileLoggingError */, \"_onError threw exception while logging error, error will not be collected: \"\r\n + getExceptionName(e), { exception: dumpObj(e), errorString: errorString });\r\n }\r\n };\r\n _self[_DYN_ADD_TELEMETRY_INITIA15 /* @min:%2eaddTelemetryInitializer */] = function (telemetryInitializer) {\r\n if (_self[_DYN_CORE /* @min:%2ecore */]) {\r\n // Just add to the core\r\n return _self[_DYN_CORE /* @min:%2ecore */][_DYN_ADD_TELEMETRY_INITIA15 /* @min:%2eaddTelemetryInitializer */](telemetryInitializer);\r\n }\r\n // Handle \"pre-initialization\" telemetry initializers (for backward compatibility)\r\n if (!_preInitTelemetryInitializers) {\r\n _preInitTelemetryInitializers = [];\r\n }\r\n _preInitTelemetryInitializers.push(telemetryInitializer);\r\n };\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n if (_self.isInitialized()) {\r\n return;\r\n }\r\n if (isNullOrUndefined(core)) {\r\n throwError(\"Error initializing\");\r\n }\r\n _base.initialize(config, core, extensions, pluginChain);\r\n try {\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(_self.identifier), core.evtNamespace && core.evtNamespace());\r\n if (_preInitTelemetryInitializers) {\r\n arrForEach(_preInitTelemetryInitializers, function (initializer) {\r\n core[_DYN_ADD_TELEMETRY_INITIA15 /* @min:%2eaddTelemetryInitializer */](initializer);\r\n });\r\n _preInitTelemetryInitializers = null;\r\n }\r\n var extConfig = _populateDefaults(config);\r\n _updateStorageUsage(extConfig);\r\n _pageViewPerformanceManager = new PageViewPerformanceManager(_self[_DYN_CORE /* @min:%2ecore */]);\r\n _pageViewManager = new PageViewManager(_self, extConfig[_DYN_OVERRIDE_PAGE_VIEW_D2 /* @min:%2eoverridePageViewDuration */], _self[_DYN_CORE /* @min:%2ecore */], _pageViewPerformanceManager);\r\n _pageVisitTimeManager = new PageVisitTimeManager(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), function (pageName, pageUrl, pageVisitTime) { return trackPageVisitTime(pageName, pageUrl, pageVisitTime); });\r\n _updateBrowserLinkTracking(extConfig, config);\r\n _eventTracking = new Timing(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), \"trackEvent\");\r\n _eventTracking.action =\r\n function (name, url, duration, properties, measurements) {\r\n if (!properties) {\r\n properties = {};\r\n }\r\n if (!measurements) {\r\n measurements = {};\r\n }\r\n properties.duration = duration[_DYN_TO_STRING /* @min:%2etoString */]();\r\n _self.trackEvent({ name: name, properties: properties, measurements: measurements });\r\n };\r\n // initialize page view timing\r\n _pageTracking = new Timing(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), \"trackPageView\");\r\n _pageTracking.action = function (name, url, duration, properties, measurements) {\r\n // duration must be a custom property in order for the collector to extract it\r\n if (isNullOrUndefined(properties)) {\r\n properties = {};\r\n }\r\n properties.duration = duration[_DYN_TO_STRING /* @min:%2etoString */]();\r\n var pageViewItem = {\r\n name: name,\r\n uri: url,\r\n properties: properties,\r\n measurements: measurements\r\n };\r\n _self[_DYN_SEND_PAGE_VIEW_INTER10 /* @min:%2esendPageViewInternal */](pageViewItem, properties);\r\n };\r\n if (hasWindow()) {\r\n _updateExceptionTracking(extConfig);\r\n _updateLocationChange(extConfig);\r\n }\r\n }\r\n catch (e) {\r\n // resetting the initialized state because of failure\r\n _self.setInitialized(false);\r\n throw e;\r\n }\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n _pageViewManager && _pageViewManager.teardown(unloadCtx, unloadState);\r\n // Just register to remove all events associated with this namespace\r\n eventOff(window, null, null, _evtNamespace);\r\n _initDefaults();\r\n };\r\n function _populateDefaults(config) {\r\n var ctx = createProcessTelemetryContext(null, config, _self[_DYN_CORE /* @min:%2ecore */]);\r\n var identifier = _self.identifier;\r\n // load default values if specified\r\n var defaults = _getDefaultConfig(config);\r\n var extConfig = _self.config = ctx.getExtCfg(identifier);\r\n if (defaults !== undefined) {\r\n objForEachKey(defaults, function (field, value) {\r\n // for each unspecified field, set the default value\r\n extConfig[field] = ctx.getConfig(identifier, field, value);\r\n if (extConfig[field] === undefined) {\r\n extConfig = value;\r\n }\r\n });\r\n }\r\n return extConfig;\r\n }\r\n function _updateBrowserLinkTracking(extConfig, config) {\r\n _isBrowserLinkTrackingEnabled = extConfig[_DYN_IS_BROWSER_LINK_TRAC5 /* @min:%2eisBrowserLinkTrackingEnabled */] || config[_DYN_IS_BROWSER_LINK_TRAC5 /* @min:%2eisBrowserLinkTrackingEnabled */];\r\n _addDefaultTelemetryInitializers();\r\n }\r\n /**\r\n * Log a page visit time\r\n * @param pageName Name of page\r\n * @param pageVisitDuration Duration of visit to the page in milleseconds\r\n */\r\n function trackPageVisitTime(pageName, pageUrl, pageVisitTime) {\r\n var properties = { PageName: pageName, PageUrl: pageUrl };\r\n _self.trackMetric({\r\n name: \"PageVisitTime\",\r\n average: pageVisitTime,\r\n max: pageVisitTime,\r\n min: pageVisitTime,\r\n sampleCount: 1\r\n }, properties);\r\n }\r\n function _addDefaultTelemetryInitializers() {\r\n if (!_browserLinkInitializerAdded && _isBrowserLinkTrackingEnabled) {\r\n var browserLinkPaths_1 = [\"/browserLinkSignalR/\", \"/__browserLink/\"];\r\n var dropBrowserLinkRequests = function (envelope) {\r\n if (_isBrowserLinkTrackingEnabled && envelope.baseType === RemoteDependencyData[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n var remoteData = envelope.baseData;\r\n if (remoteData) {\r\n for (var i = 0; i < browserLinkPaths_1[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n if (remoteData.target && remoteData.target.indexOf(browserLinkPaths_1[i]) >= 0) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n _self[_DYN_ADD_TELEMETRY_INITIA15 /* @min:%2eaddTelemetryInitializer */](dropBrowserLinkRequests);\r\n _browserLinkInitializerAdded = true;\r\n }\r\n }\r\n function _sendCORSException(exception, properties) {\r\n var telemetryItem = createTelemetryItem(exception, Exception[_DYN_DATA_TYPE /* @min:%2edataType */], Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], _self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), properties);\r\n _self[_DYN_CORE /* @min:%2ecore */][_DYN_TRACK /* @min:%2etrack */](telemetryItem);\r\n }\r\n function _updateExceptionTracking(extConfig) {\r\n var _window = getWindow();\r\n var locn = getLocation(true);\r\n _disableExceptionTracking = extConfig[_DYN_DISABLE_EXCEPTION_TR0 /* @min:%2edisableExceptionTracking */];\r\n if (!_disableExceptionTracking && !_autoExceptionInstrumented && !extConfig.autoExceptionInstrumented) {\r\n // We want to enable exception auto collection and it has not been done so yet\r\n _addHook(InstrumentEvent(_window, \"onerror\", {\r\n ns: _evtNamespace,\r\n rsp: function (callDetails, message, url, lineNumber, columnNumber, error) {\r\n if (!_disableExceptionTracking && callDetails.rslt !== true) {\r\n _self[_DYN__ONERROR /* @min:%2e_onerror */](Exception[_DYN__CREATE_AUTO_EXCEPTI14 /* @min:%2eCreateAutoException */](message, url, lineNumber, columnNumber, error, callDetails.evt));\r\n }\r\n }\r\n }, false));\r\n _autoExceptionInstrumented = true;\r\n }\r\n _addUnhandledPromiseRejectionTracking(extConfig, _window, locn);\r\n }\r\n function _updateLocationChange(extConfig) {\r\n var win = getWindow();\r\n var locn = getLocation(true);\r\n _enableAutoRouteTracking = extConfig[_DYN_ENABLE_AUTO_ROUTE_TR6 /* @min:%2eenableAutoRouteTracking */] === true;\r\n /**\r\n * Create a custom \"locationchange\" event which is triggered each time the history object is changed\r\n */\r\n if (win && _enableAutoRouteTracking && hasHistory()) {\r\n var _history = getHistory();\r\n if (isFunction(_history.pushState) && isFunction(_history.replaceState) && typeof Event !== strUndefined) {\r\n _addHistoryListener(extConfig, win, _history, locn);\r\n }\r\n }\r\n }\r\n function _getDistributedTraceCtx() {\r\n var distributedTraceCtx = null;\r\n if (_self[_DYN_CORE /* @min:%2ecore */] && _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx) {\r\n distributedTraceCtx = _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx(false);\r\n }\r\n if (!distributedTraceCtx) {\r\n // Fallback when using an older Core and PropertiesPlugin\r\n var properties = _self[_DYN_CORE /* @min:%2ecore */].getPlugin(PropertiesPluginIdentifier);\r\n if (properties) {\r\n var context = properties.plugin.context;\r\n if (context) {\r\n distributedTraceCtx = createDistributedTraceContextFromTrace(context.telemetryTrace);\r\n }\r\n }\r\n }\r\n return distributedTraceCtx;\r\n }\r\n /**\r\n * Create a custom \"locationchange\" event which is triggered each time the history object is changed\r\n */\r\n function _addHistoryListener(extConfig, win, history, locn) {\r\n var namePrefix = extConfig[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] || \"\";\r\n function _popstateHandler() {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n function _locationChangeHandler() {\r\n // We always track the changes (if the handler is installed) to handle the feature being disabled between location changes\r\n if (_currUri) {\r\n _prevUri = _currUri;\r\n _currUri = locn && locn[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n else {\r\n _currUri = locn && locn[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n }\r\n if (_enableAutoRouteTracking) {\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n if (distributedTraceCtx) {\r\n distributedTraceCtx.setTraceId(generateW3CId());\r\n var traceLocationName = \"_unknown_\";\r\n if (locn && locn.pathname) {\r\n traceLocationName = locn.pathname + (locn.hash || \"\");\r\n }\r\n // This populates the ai.operation.name which has a maximum size of 1024 so we need to sanitize it\r\n distributedTraceCtx.setName(dataSanitizeString(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), traceLocationName));\r\n }\r\n setTimeout((function (uri) {\r\n // todo: override start time so that it is not affected by autoRoutePVDelay\r\n _self[_DYN_TRACK_PAGE_VIEW /* @min:%2etrackPageView */]({ refUri: uri, properties: { duration: 0 } }); // SPA route change loading durations are undefined, so send 0\r\n }).bind(_self, _prevUri), _self.autoRoutePVDelay);\r\n }\r\n }\r\n if (!_historyListenerAdded) {\r\n _addHook(InstrumentEvent(history, \"pushState\", {\r\n ns: _evtNamespace,\r\n rsp: function () {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"pushState\"));\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n }, true));\r\n _addHook(InstrumentEvent(history, \"replaceState\", {\r\n ns: _evtNamespace,\r\n rsp: function () {\r\n if (_enableAutoRouteTracking) {\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"replaceState\"));\r\n _dispatchEvent(win, createDomEvent(namePrefix + \"locationchange\"));\r\n }\r\n }\r\n }, true));\r\n eventOn(win, namePrefix + \"popstate\", _popstateHandler, _evtNamespace);\r\n eventOn(win, namePrefix + \"locationchange\", _locationChangeHandler, _evtNamespace);\r\n _historyListenerAdded = true;\r\n }\r\n }\r\n function _addUnhandledPromiseRejectionTracking(extConfig, _window, _location) {\r\n _enableUnhandledPromiseRejectionTracking = extConfig[_DYN_ENABLE_UNHANDLED_PRO3 /* @min:%2eenableUnhandledPromiseRejectionTracking */] === true;\r\n if (_enableUnhandledPromiseRejectionTracking && !_autoUnhandledPromiseInstrumented) {\r\n // We want to enable exception auto collection and it has not been done so yet\r\n _addHook(InstrumentEvent(_window, \"onunhandledrejection\", {\r\n ns: _evtNamespace,\r\n rsp: function (callDetails, error) {\r\n if (_enableUnhandledPromiseRejectionTracking && callDetails.rslt !== true) { // handled could be typeof function\r\n _self[_DYN__ONERROR /* @min:%2e_onerror */](Exception[_DYN__CREATE_AUTO_EXCEPTI14 /* @min:%2eCreateAutoException */](_getReason(error), _location ? _location[_DYN_HREF /* @min:%2ehref */] : \"\", 0, 0, error, callDetails.evt));\r\n }\r\n }\r\n }, false));\r\n _autoUnhandledPromiseInstrumented = true;\r\n extConfig.autoUnhandledPromiseInstrumented = _autoUnhandledPromiseInstrumented;\r\n }\r\n }\r\n /**\r\n * This method will throw exceptions in debug mode or attempt to log the error as a console warning.\r\n * @param severity {eLoggingSeverity} - The severity of the log message\r\n * @param message {_InternalLogMessage} - The log message.\r\n */\r\n function _throwInternal(severity, msgId, msg, properties, isUserAct) {\r\n _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]().throwInternal(severity, msgId, msg, properties, isUserAct);\r\n }\r\n function _initDefaults() {\r\n _eventTracking = null;\r\n _pageTracking = null;\r\n _pageViewManager = null;\r\n _pageViewPerformanceManager = null;\r\n _pageVisitTimeManager = null;\r\n _preInitTelemetryInitializers = null;\r\n _isBrowserLinkTrackingEnabled = false;\r\n _browserLinkInitializerAdded = false;\r\n _enableAutoRouteTracking = false;\r\n _historyListenerAdded = false;\r\n _disableExceptionTracking = false;\r\n _autoExceptionInstrumented = false;\r\n _enableUnhandledPromiseRejectionTracking = false;\r\n _autoUnhandledPromiseInstrumented = false;\r\n // Counts number of trackAjax invocations.\r\n // By default we only monitor X ajax call per view to avoid too much load.\r\n // Default value is set in config.\r\n // This counter keeps increasing even after the limit is reached.\r\n _trackAjaxAttempts = 0;\r\n // array with max length of 2 that store current url and previous url for SPA page route change trackPageview use.\r\n var location = getLocation(true);\r\n _prevUri = location && location[_DYN_HREF /* @min:%2ehref */] || \"\";\r\n _currUri = null;\r\n _evtNamespace = null;\r\n }\r\n // For backward compatibility\r\n objDefineAccessors(_self, \"_pageViewManager\", function () { return _pageViewManager; });\r\n objDefineAccessors(_self, \"_pageViewPerformanceManager\", function () { return _pageViewPerformanceManager; });\r\n objDefineAccessors(_self, \"_pageVisitTimeManager\", function () { return _pageVisitTimeManager; });\r\n objDefineAccessors(_self, \"_evtNamespace\", function () { return \".\" + _evtNamespace; });\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for AnalyticsPlugin.prototype.getCookieMgr.\r\n// Removed Stub for AnalyticsPlugin.prototype.processTelemetry.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.startTrackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.stopTrackEvent.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackTrace.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackMetric.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackPageView.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendPageViewInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendPageViewPerformanceInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackPageViewPerformance.\r\n// Removed Stub for AnalyticsPlugin.prototype.startTrackPage.\r\n// Removed Stub for AnalyticsPlugin.prototype.stopTrackPage.\r\n// Removed Stub for AnalyticsPlugin.prototype.sendExceptionInternal.\r\n// Removed Stub for AnalyticsPlugin.prototype.trackException.\r\n// Removed Stub for AnalyticsPlugin.prototype._onerror.\r\n// Removed Stub for AnalyticsPlugin.prototype.addTelemetryInitializer.\r\n// Removed Stub for AnalyticsPlugin.prototype.initialize.\r\n AnalyticsPlugin.Version = '2.8.14'; // Not currently used anywhere\r\n AnalyticsPlugin.getDefaultConfig = _getDefaultConfig;\r\n return AnalyticsPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport { AnalyticsPlugin };\r\n//# sourceMappingURL=AnalyticsPlugin.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strShimHasOwnProperty = \"hasOwnProperty\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\nexport var ObjAssign = ObjClass[\"assign\"];\r\nexport var ObjCreate = ObjClass[\"create\"];\r\nexport var ObjDefineProperty = ObjClass[\"defineProperty\"];\r\nexport var ObjHasOwnProperty = ObjProto[strShimHasOwnProperty];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjCreate, strShimFunction, strShimObject, strShimPrototype, strShimUndefined } from \"./Constants\";\r\nvar _cachedGlobal = null;\r\n/**\r\n * Returns the current global scope object, for a normal web page this will be the current\r\n * window, for a Web Worker this will be current worker global scope via \"self\". The internal\r\n * implementation returns the first available instance object in the following order\r\n * - globalThis (New standard)\r\n * - self (Will return the current window instance for supported browsers)\r\n * - window (fallback for older browser implementations)\r\n * - global (NodeJS standard)\r\n * - (When all else fails)\r\n * While the return type is a Window for the normal case, not all environments will support all\r\n * of the properties or functions.\r\n */\r\nexport function getGlobal(useCached) {\r\n if (useCached === void 0) { useCached = true; }\r\n var result = useCached === false ? null : _cachedGlobal;\r\n if (!result) {\r\n if (typeof globalThis !== strShimUndefined) {\r\n result = globalThis;\r\n }\r\n if (!result && typeof self !== strShimUndefined) {\r\n result = self;\r\n }\r\n if (!result && typeof window !== strShimUndefined) {\r\n result = window;\r\n }\r\n if (!result && typeof global !== strShimUndefined) {\r\n result = global;\r\n }\r\n _cachedGlobal = result;\r\n }\r\n return result;\r\n}\r\nexport function throwTypeError(message) {\r\n throw new TypeError(message);\r\n}\r\n/**\r\n * Creates an object that has the specified prototype, and that optionally contains specified properties. This helper exists to avoid adding a polyfil\r\n * for older browsers that do not define Object.create eg. ES3 only, IE8 just in case any page checks for presence/absence of the prototype implementation.\r\n * Note: For consistency this will not use the Object.create implementation if it exists as this would cause a testing requirement to test with and without the implementations\r\n * @param obj Object to use as a prototype. May be null\r\n */\r\nexport function objCreateFn(obj) {\r\n var func = ObjCreate;\r\n // Use build in Object.create\r\n if (func) {\r\n // Use Object create method if it exists\r\n return func(obj);\r\n }\r\n if (obj == null) {\r\n return {};\r\n }\r\n var type = typeof obj;\r\n if (type !== strShimObject && type !== strShimFunction) {\r\n throwTypeError(\"Object prototype may only be an Object:\" + obj);\r\n }\r\n function tmpFunc() { }\r\n tmpFunc[strShimPrototype] = obj;\r\n return new tmpFunc();\r\n}\r\n//# sourceMappingURL=Helpers.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport { createClassFromInterface } from \"@microsoft/applicationinsights-core-js\";\r\nfunction _aiNameFunc(baseName) {\r\n var aiName = \"ai.\" + baseName + \".\";\r\n return function (name) {\r\n return aiName + name;\r\n };\r\n}\r\nvar _aiApplication = _aiNameFunc(\"application\");\r\nvar _aiDevice = _aiNameFunc(\"device\");\r\nvar _aiLocation = _aiNameFunc(\"location\");\r\nvar _aiOperation = _aiNameFunc(\"operation\");\r\nvar _aiSession = _aiNameFunc(\"session\");\r\nvar _aiUser = _aiNameFunc(\"user\");\r\nvar _aiCloud = _aiNameFunc(\"cloud\");\r\nvar _aiInternal = _aiNameFunc(\"internal\");\r\nvar ContextTagKeys = /** @class */ (function (_super) {\r\n __extends(ContextTagKeys, _super);\r\n function ContextTagKeys() {\r\n return _super.call(this) || this;\r\n }\r\n return ContextTagKeys;\r\n}(createClassFromInterface({\r\n applicationVersion: _aiApplication(\"ver\"),\r\n applicationBuild: _aiApplication(\"build\"),\r\n applicationTypeId: _aiApplication(\"typeId\"),\r\n applicationId: _aiApplication(\"applicationId\"),\r\n applicationLayer: _aiApplication(\"layer\"),\r\n deviceId: _aiDevice(\"id\"),\r\n deviceIp: _aiDevice(\"ip\"),\r\n deviceLanguage: _aiDevice(\"language\"),\r\n deviceLocale: _aiDevice(\"locale\"),\r\n deviceModel: _aiDevice(\"model\"),\r\n deviceFriendlyName: _aiDevice(\"friendlyName\"),\r\n deviceNetwork: _aiDevice(\"network\"),\r\n deviceNetworkName: _aiDevice(\"networkName\"),\r\n deviceOEMName: _aiDevice(\"oemName\"),\r\n deviceOS: _aiDevice(\"os\"),\r\n deviceOSVersion: _aiDevice(\"osVersion\"),\r\n deviceRoleInstance: _aiDevice(\"roleInstance\"),\r\n deviceRoleName: _aiDevice(\"roleName\"),\r\n deviceScreenResolution: _aiDevice(\"screenResolution\"),\r\n deviceType: _aiDevice(\"type\"),\r\n deviceMachineName: _aiDevice(\"machineName\"),\r\n deviceVMName: _aiDevice(\"vmName\"),\r\n deviceBrowser: _aiDevice(\"browser\"),\r\n deviceBrowserVersion: _aiDevice(\"browserVersion\"),\r\n locationIp: _aiLocation(\"ip\"),\r\n locationCountry: _aiLocation(\"country\"),\r\n locationProvince: _aiLocation(\"province\"),\r\n locationCity: _aiLocation(\"city\"),\r\n operationId: _aiOperation(\"id\"),\r\n operationName: _aiOperation(\"name\"),\r\n operationParentId: _aiOperation(\"parentId\"),\r\n operationRootId: _aiOperation(\"rootId\"),\r\n operationSyntheticSource: _aiOperation(\"syntheticSource\"),\r\n operationCorrelationVector: _aiOperation(\"correlationVector\"),\r\n sessionId: _aiSession(\"id\"),\r\n sessionIsFirst: _aiSession(\"isFirst\"),\r\n sessionIsNew: _aiSession(\"isNew\"),\r\n userAccountAcquisitionDate: _aiUser(\"accountAcquisitionDate\"),\r\n userAccountId: _aiUser(\"accountId\"),\r\n userAgent: _aiUser(\"userAgent\"),\r\n userId: _aiUser(\"id\"),\r\n userStoreRegion: _aiUser(\"storeRegion\"),\r\n userAuthUserId: _aiUser(\"authUserId\"),\r\n userAnonymousUserAcquisitionDate: _aiUser(\"anonUserAcquisitionDate\"),\r\n userAuthenticatedUserAcquisitionDate: _aiUser(\"authUserAcquisitionDate\"),\r\n cloudName: _aiCloud(\"name\"),\r\n cloudRole: _aiCloud(\"role\"),\r\n cloudRoleVer: _aiCloud(\"roleVer\"),\r\n cloudRoleInstance: _aiCloud(\"roleInstance\"),\r\n cloudEnvironment: _aiCloud(\"environment\"),\r\n cloudLocation: _aiCloud(\"location\"),\r\n cloudDeploymentUnit: _aiCloud(\"deploymentUnit\"),\r\n internalNodeName: _aiInternal(\"nodeName\"),\r\n internalSdkVersion: _aiInternal(\"sdkVersion\"),\r\n internalAgentVersion: _aiInternal(\"agentVersion\"),\r\n internalSnippet: _aiInternal(\"snippet\"),\r\n internalSdkSrc: _aiInternal(\"sdkSrc\")\r\n})));\r\nexport { ContextTagKeys };\r\n//# sourceMappingURL=ContextTagKeys.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { ContextTagKeys } from \"./Contracts/ContextTagKeys\";\r\nexport var Extensions = {\r\n UserExt: \"user\",\r\n DeviceExt: \"device\",\r\n TraceExt: \"trace\",\r\n WebExt: \"web\",\r\n AppExt: \"app\",\r\n OSExt: \"os\",\r\n SessionExt: \"ses\",\r\n SDKExt: \"sdk\"\r\n};\r\nexport var CtxTagKeys = new ContextTagKeys();\r\n//# sourceMappingURL=PartAExtensions.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { strNotSpecified } from \"../../Constants\";\r\nimport { _DYN_NAME } from \"../../__DynamicConstants\";\r\nimport { dataSanitizeString } from \"./DataSanitizer\";\r\nvar Envelope = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of telemetry data.\r\n */\r\n function Envelope(logger, data, name) {\r\n var _this = this;\r\n var _self = this;\r\n _self.ver = 1;\r\n _self.sampleRate = 100.0;\r\n _self.tags = {};\r\n _self[_DYN_NAME /* @min:%2ename */] = dataSanitizeString(logger, name) || strNotSpecified;\r\n _self.data = data;\r\n _self.time = toISOString(new Date());\r\n _self.aiDataContract = {\r\n time: 1 /* FieldType.Required */,\r\n iKey: 1 /* FieldType.Required */,\r\n name: 1 /* FieldType.Required */,\r\n sampleRate: function () {\r\n return (_this.sampleRate === 100) ? 4 /* FieldType.Hidden */ : 1 /* FieldType.Required */;\r\n },\r\n tags: 1 /* FieldType.Required */,\r\n data: 1 /* FieldType.Required */\r\n };\r\n }\r\n return Envelope;\r\n}());\r\nexport { Envelope };\r\n//# sourceMappingURL=Envelope.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Data = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of telemetry data.\r\n */\r\n function Data(baseType, data) {\r\n /**\r\n * The data contract for serializing this object.\r\n */\r\n this.aiDataContract = {\r\n baseType: 1 /* FieldType.Required */,\r\n baseData: 1 /* FieldType.Required */\r\n };\r\n this.baseType = baseType;\r\n this.baseData = data;\r\n }\r\n return Data;\r\n}());\r\nexport { Data };\r\n//# sourceMappingURL=Data.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nexport var STR_DURATION = \"duration\";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_TAGS = \"tags\"; // Count: 17\r\nexport var _DYN_DEVICE_TYPE = \"deviceType\"; // Count: 3\r\nexport var _DYN_DATA = \"data\"; // Count: 13\r\nexport var _DYN_NAME = \"name\"; // Count: 8\r\nexport var _DYN_TRACE_ID = \"traceID\"; // Count: 5\r\nexport var _DYN_LENGTH = \"length\"; // Count: 36\r\nexport var _DYN_STRINGIFY = \"stringify\"; // Count: 5\r\nexport var _DYN_MEASUREMENTS = \"measurements\"; // Count: 7\r\nexport var _DYN_DATA_TYPE = \"dataType\"; // Count: 10\r\nexport var _DYN_ENVELOPE_TYPE = \"envelopeType\"; // Count: 7\r\nexport var _DYN_TO_STRING = \"toString\"; // Count: 7\r\nexport var _DYN_ON_LINE = \"onLine\"; // Count: 4\r\nexport var _DYN_IS_ONLINE = \"isOnline\"; // Count: 3\r\nexport var _DYN_ENQUEUE = \"enqueue\"; // Count: 5\r\nexport var _DYN_COUNT = \"count\"; // Count: 6\r\nexport var _DYN_PUSH = \"push\"; // Count: 6\r\nexport var _DYN_EMIT_LINE_DELIMITED_0 = \"emitLineDelimitedJson\"; // Count: 3\r\nexport var _DYN_CLEAR = \"clear\"; // Count: 6\r\nexport var _DYN_BATCH_PAYLOADS = \"batchPayloads\"; // Count: 5\r\nexport var _DYN_MARK_AS_SENT = \"markAsSent\"; // Count: 6\r\nexport var _DYN_CLEAR_SENT = \"clearSent\"; // Count: 5\r\nexport var _DYN_BUFFER_OVERRIDE = \"bufferOverride\"; // Count: 3\r\nexport var _DYN__BUFFER__KEY = \"BUFFER_KEY\"; // Count: 5\r\nexport var _DYN__SENT__BUFFER__KEY = \"SENT_BUFFER_KEY\"; // Count: 7\r\nexport var _DYN__MAX__BUFFER__SIZE = \"MAX_BUFFER_SIZE\"; // Count: 5\r\nexport var _DYN_NAME_PREFIX = \"namePrefix\"; // Count: 6\r\nexport var _DYN_MAX_BATCH_SIZE_IN_BY1 = \"maxBatchSizeInBytes\"; // Count: 3\r\nexport var _DYN_TRIGGER_SEND = \"triggerSend\"; // Count: 6\r\nexport var _DYN_DIAG_LOG = \"diagLog\"; // Count: 15\r\nexport var _DYN_ONUNLOAD_DISABLE_BEA2 = \"onunloadDisableBeacon\"; // Count: 2\r\nexport var _DYN_IS_BEACON_API_DISABL3 = \"isBeaconApiDisabled\"; // Count: 3\r\nexport var _DYN__SENDER = \"_sender\"; // Count: 5\r\nexport var _DYN__SENDER_CONFIG = \"_senderConfig\"; // Count: 4\r\nexport var _DYN_ENABLE_SESSION_STORA4 = \"enableSessionStorageBuffer\"; // Count: 2\r\nexport var _DYN__BUFFER = \"_buffer\"; // Count: 9\r\nexport var _DYN_SAMPLING_PERCENTAGE = \"samplingPercentage\"; // Count: 2\r\nexport var _DYN_INSTRUMENTATION_KEY = \"instrumentationKey\"; // Count: 4\r\nexport var _DYN_ENDPOINT_URL = \"endpointUrl\"; // Count: 8\r\nexport var _DYN_CUSTOM_HEADERS = \"customHeaders\"; // Count: 4\r\nexport var _DYN_DISABLE_XHR = \"disableXhr\"; // Count: 5\r\nexport var _DYN_ONUNLOAD_DISABLE_FET5 = \"onunloadDisableFetch\"; // Count: 2\r\nexport var _DYN_DISABLE_TELEMETRY = \"disableTelemetry\"; // Count: 2\r\nexport var _DYN_BASE_TYPE = \"baseType\"; // Count: 4\r\nexport var _DYN_SAMPLE_RATE = \"sampleRate\"; // Count: 4\r\nexport var _DYN_CONVERT_UNDEFINED = \"convertUndefined\"; // Count: 2\r\nexport var _DYN__XHR_READY_STATE_CHA6 = \"_xhrReadyStateChange\"; // Count: 2\r\nexport var _DYN__ON_ERROR = \"_onError\"; // Count: 11\r\nexport var _DYN__ON_PARTIAL_SUCCESS = \"_onPartialSuccess\"; // Count: 3\r\nexport var _DYN__ON_SUCCESS = \"_onSuccess\"; // Count: 6\r\nexport var _DYN_ITEMS_ACCEPTED = \"itemsAccepted\"; // Count: 5\r\nexport var _DYN_ITEMS_RECEIVED = \"itemsReceived\"; // Count: 6\r\nexport var _DYN_IS_RETRY_DISABLED = \"isRetryDisabled\"; // Count: 5\r\nexport var _DYN_SET_REQUEST_HEADER = \"setRequestHeader\"; // Count: 3\r\nexport var _DYN_MAX_BATCH_INTERVAL = \"maxBatchInterval\"; // Count: 2\r\nexport var _DYN_EVENTS_SEND_REQUEST = \"eventsSendRequest\"; // Count: 2\r\nexport var _DYN_DISABLE_INSTRUMENTAT7 = \"disableInstrumentationKeyValidation\"; // Count: 2\r\nexport var _DYN_GET_SAMPLING_SCORE = \"getSamplingScore\"; // Count: 2\r\nexport var _DYN_GET_HASH_CODE_SCORE = \"getHashCodeScore\"; // Count: 4\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { __assignFn as __assign } from \"@microsoft/applicationinsights-shims\";\r\nimport { CtxTagKeys, Data, Envelope, Event, Exception, HttpMethod, Metric, PageView, PageViewPerformance, RemoteDependencyData, SampleRate, Trace, dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, _warnToConsole, getJSON, hasJSON, isNullOrUndefined, isNumber, isString, isTruthy, objForEachKey, optimizeObject, setValue, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { STR_DURATION } from \"./InternalConstants\";\r\nimport { _DYN_DATA, _DYN_DATA_TYPE, _DYN_DEVICE_TYPE, _DYN_ENVELOPE_TYPE, _DYN_LENGTH, _DYN_MEASUREMENTS, _DYN_NAME, _DYN_STRINGIFY, _DYN_TAGS, _DYN_TO_STRING, _DYN_TRACE_ID } from \"./__DynamicConstants\";\r\n// these two constants are used to filter out properties not needed when trying to extract custom properties and measurements from the incoming payload\r\nvar strBaseType = \"baseType\";\r\nvar strBaseData = \"baseData\";\r\nvar strProperties = \"properties\";\r\nvar strTrue = \"true\";\r\nfunction _setValueIf(target, field, value) {\r\n return setValue(target, field, value, isTruthy);\r\n}\r\n/*\r\n * Maps Part A data from CS 4.0\r\n */\r\nfunction _extractPartAExtensions(logger, item, env) {\r\n // todo: switch to keys from common in this method\r\n var envTags = env[_DYN_TAGS /* @min:%2etags */] = env[_DYN_TAGS /* @min:%2etags */] || {};\r\n var itmExt = item.ext = item.ext || {};\r\n var itmTags = item[_DYN_TAGS /* @min:%2etags */] = item[_DYN_TAGS /* @min:%2etags */] || [];\r\n var extUser = itmExt.user;\r\n if (extUser) {\r\n _setValueIf(envTags, CtxTagKeys.userAuthUserId, extUser.authId);\r\n _setValueIf(envTags, CtxTagKeys.userId, extUser.id || extUser.localId);\r\n }\r\n var extApp = itmExt.app;\r\n if (extApp) {\r\n _setValueIf(envTags, CtxTagKeys.sessionId, extApp.sesId);\r\n }\r\n var extDevice = itmExt.device;\r\n if (extDevice) {\r\n _setValueIf(envTags, CtxTagKeys.deviceId, extDevice.id || extDevice.localId);\r\n _setValueIf(envTags, CtxTagKeys[_DYN_DEVICE_TYPE /* @min:%2edeviceType */], extDevice.deviceClass);\r\n _setValueIf(envTags, CtxTagKeys.deviceIp, extDevice.ip);\r\n _setValueIf(envTags, CtxTagKeys.deviceModel, extDevice.model);\r\n _setValueIf(envTags, CtxTagKeys[_DYN_DEVICE_TYPE /* @min:%2edeviceType */], extDevice[_DYN_DEVICE_TYPE /* @min:%2edeviceType */]);\r\n }\r\n var web = item.ext.web;\r\n if (web) {\r\n _setValueIf(envTags, CtxTagKeys.deviceLanguage, web.browserLang);\r\n _setValueIf(envTags, CtxTagKeys.deviceBrowserVersion, web.browserVer);\r\n _setValueIf(envTags, CtxTagKeys.deviceBrowser, web.browser);\r\n var envData = env[_DYN_DATA /* @min:%2edata */] = env[_DYN_DATA /* @min:%2edata */] || {};\r\n var envBaseData = envData[strBaseData] = envData[strBaseData] || {};\r\n var envProps = envBaseData[strProperties] = envBaseData[strProperties] || {};\r\n _setValueIf(envProps, \"domain\", web.domain);\r\n _setValueIf(envProps, \"isManual\", web.isManual ? strTrue : null);\r\n _setValueIf(envProps, \"screenRes\", web.screenRes);\r\n _setValueIf(envProps, \"userConsent\", web.userConsent ? strTrue : null);\r\n }\r\n var extOs = itmExt.os;\r\n if (extOs) {\r\n _setValueIf(envTags, CtxTagKeys.deviceOS, extOs[_DYN_NAME /* @min:%2ename */]);\r\n }\r\n // No support for mapping Trace.traceState to 2.0 as it is currently empty\r\n var extTrace = itmExt.trace;\r\n if (extTrace) {\r\n _setValueIf(envTags, CtxTagKeys.operationParentId, extTrace.parentID);\r\n _setValueIf(envTags, CtxTagKeys.operationName, dataSanitizeString(logger, extTrace[_DYN_NAME /* @min:%2ename */]));\r\n _setValueIf(envTags, CtxTagKeys.operationId, extTrace[_DYN_TRACE_ID /* @min:%2etraceID */]);\r\n }\r\n // Sample 4.0 schema\r\n // {\r\n // \"time\" : \"2018-09-05T22:51:22.4936Z\",\r\n // \"name\" : \"MetricWithNamespace\",\r\n // \"iKey\" : \"ABC-5a4cbd20-e601-4ef5-a3c6-5d6577e4398e\",\r\n // \"ext\": { \"cloud\": {\r\n // \"role\": \"WATSON3\",\r\n // \"roleInstance\": \"CO4AEAP00000260\"\r\n // },\r\n // \"device\": {}, \"correlation\": {} },\r\n // \"tags\": [\r\n // { \"amazon.region\" : \"east2\" },\r\n // { \"os.expid\" : \"wp:02df239\" }\r\n // ]\r\n // }\r\n var tgs = {};\r\n // deals with tags.push({object})\r\n for (var i = itmTags[_DYN_LENGTH /* @min:%2elength */] - 1; i >= 0; i--) {\r\n var tg = itmTags[i];\r\n objForEachKey(tg, function (key, value) {\r\n tgs[key] = value;\r\n });\r\n itmTags.splice(i, 1);\r\n }\r\n // deals with tags[key]=value (and handles hasOwnProperty)\r\n objForEachKey(itmTags, function (tg, value) {\r\n tgs[tg] = value;\r\n });\r\n var theTags = __assign(__assign({}, envTags), tgs);\r\n if (!theTags[CtxTagKeys.internalSdkVersion]) {\r\n // Append a version in case it is not already set\r\n theTags[CtxTagKeys.internalSdkVersion] = dataSanitizeString(logger, \"javascript:\".concat(EnvelopeCreator.Version), 64);\r\n }\r\n env[_DYN_TAGS /* @min:%2etags */] = optimizeObject(theTags);\r\n}\r\nfunction _extractPropsAndMeasurements(data, properties, measurements) {\r\n if (!isNullOrUndefined(data)) {\r\n objForEachKey(data, function (key, value) {\r\n if (isNumber(value)) {\r\n measurements[key] = value;\r\n }\r\n else if (isString(value)) {\r\n properties[key] = value;\r\n }\r\n else if (hasJSON()) {\r\n properties[key] = getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](value);\r\n }\r\n });\r\n }\r\n}\r\nfunction _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue) {\r\n if (!isNullOrUndefined(properties)) {\r\n objForEachKey(properties, function (key, value) {\r\n properties[key] = value || customUndefinedValue;\r\n });\r\n }\r\n}\r\n// TODO: Do we want this to take logger as arg or use this._logger as nonstatic?\r\nfunction _createEnvelope(logger, envelopeType, telemetryItem, data) {\r\n var envelope = new Envelope(logger, data, envelopeType);\r\n _setValueIf(envelope, \"sampleRate\", telemetryItem[SampleRate]);\r\n if ((telemetryItem[strBaseData] || {}).startTime) {\r\n envelope.time = toISOString(telemetryItem[strBaseData].startTime);\r\n }\r\n envelope.iKey = telemetryItem.iKey;\r\n var iKeyNoDashes = telemetryItem.iKey.replace(/-/g, \"\");\r\n envelope[_DYN_NAME /* @min:%2ename */] = envelope[_DYN_NAME /* @min:%2ename */].replace(\"{0}\", iKeyNoDashes);\r\n // extract all extensions from ctx\r\n _extractPartAExtensions(logger, telemetryItem, envelope);\r\n // loop through the envelope tags (extension of Part A) and pick out the ones that should go in outgoing envelope tags\r\n telemetryItem[_DYN_TAGS /* @min:%2etags */] = telemetryItem[_DYN_TAGS /* @min:%2etags */] || [];\r\n return optimizeObject(envelope);\r\n}\r\nfunction EnvelopeCreatorInit(logger, telemetryItem) {\r\n if (isNullOrUndefined(telemetryItem[strBaseData])) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 46 /* _eInternalMessageId.TelemetryEnvelopeInvalid */, \"telemetryItem.baseData cannot be null.\");\r\n }\r\n}\r\nexport var EnvelopeCreator = {\r\n Version: '2.8.14'\r\n};\r\nexport function DependencyEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n var customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n if (isNullOrUndefined(bd)) {\r\n _warnToConsole(logger, \"Invalid input for dependency data\");\r\n return null;\r\n }\r\n var method = bd[strProperties] && bd[strProperties][HttpMethod] ? bd[strProperties][HttpMethod] : \"GET\";\r\n var remoteDepData = new RemoteDependencyData(logger, bd.id, bd.target, bd[_DYN_NAME /* @min:%2ename */], bd[STR_DURATION /* @min:%2eduration */], bd.success, bd.responseCode, method, bd.type, bd.correlationContext, customProperties, customMeasurements);\r\n var data = new Data(RemoteDependencyData[_DYN_DATA_TYPE /* @min:%2edataType */], remoteDepData);\r\n return _createEnvelope(logger, RemoteDependencyData[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function EventEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var customProperties = {};\r\n var customMeasurements = {};\r\n if (telemetryItem[strBaseType] !== Event[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n customProperties[\"baseTypeSource\"] = telemetryItem[strBaseType]; // save the passed in base type as a property\r\n }\r\n if (telemetryItem[strBaseType] === Event[_DYN_DATA_TYPE /* @min:%2edataType */]) { // take collection\r\n customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n }\r\n else { // if its not a known type, convert to custom event\r\n if (telemetryItem[strBaseData]) {\r\n _extractPropsAndMeasurements(telemetryItem[strBaseData], customProperties, customMeasurements);\r\n }\r\n }\r\n // Extract root level properties from part C telemetryItem.data\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var eventName = telemetryItem[strBaseData][_DYN_NAME /* @min:%2ename */];\r\n var eventData = new Event(logger, eventName, customProperties, customMeasurements);\r\n var data = new Data(Event[_DYN_DATA_TYPE /* @min:%2edataType */], eventData);\r\n return _createEnvelope(logger, Event[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function ExceptionEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n // Extract root level properties from part C telemetryItem.data\r\n var customMeasurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n var customProperties = telemetryItem[strBaseData][strProperties] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], customProperties, customMeasurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(customProperties, customUndefinedValue);\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n var exData = Exception.CreateFromInterface(logger, bd, customProperties, customMeasurements);\r\n var data = new Data(Exception[_DYN_DATA_TYPE /* @min:%2edataType */], exData);\r\n return _createEnvelope(logger, Exception[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function MetricEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var baseData = telemetryItem[strBaseData];\r\n var props = baseData[strProperties] || {};\r\n var measurements = baseData[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], props, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(props, customUndefinedValue);\r\n }\r\n var baseMetricData = new Metric(logger, baseData[_DYN_NAME /* @min:%2ename */], baseData.average, baseData.sampleCount, baseData.min, baseData.max, baseData.stdDev, props, measurements);\r\n var data = new Data(Metric[_DYN_DATA_TYPE /* @min:%2edataType */], baseMetricData);\r\n return _createEnvelope(logger, Metric[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function PageViewEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n // Since duration is not part of the domain properties in Common Schema, extract it from part C\r\n var duration;\r\n var baseData = telemetryItem[strBaseData];\r\n if (!isNullOrUndefined(baseData) &&\r\n !isNullOrUndefined(baseData[strProperties]) &&\r\n !isNullOrUndefined(baseData[strProperties][STR_DURATION])) { // from part B properties\r\n duration = baseData[strProperties][STR_DURATION];\r\n delete baseData[strProperties][STR_DURATION];\r\n }\r\n else if (!isNullOrUndefined(telemetryItem[_DYN_DATA /* @min:%2edata */]) &&\r\n !isNullOrUndefined(telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION])) { // from custom properties\r\n duration = telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION];\r\n delete telemetryItem[_DYN_DATA /* @min:%2edata */][STR_DURATION];\r\n }\r\n var bd = telemetryItem[strBaseData];\r\n // special case: pageview.id is grabbed from current operation id. Analytics plugin is decoupled from properties plugin, so this is done here instead. This can be made a default telemetry intializer instead if needed to be decoupled from channel\r\n var currentContextId;\r\n if (((telemetryItem.ext || {}).trace || {})[_DYN_TRACE_ID /* @min:%2etraceID */]) {\r\n currentContextId = telemetryItem.ext.trace[_DYN_TRACE_ID /* @min:%2etraceID */];\r\n }\r\n var id = bd.id || currentContextId;\r\n var name = bd[_DYN_NAME /* @min:%2ename */];\r\n var url = bd.uri;\r\n var properties = bd[strProperties] || {};\r\n var measurements = bd[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n // refUri is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.refUri)) {\r\n properties[\"refUri\"] = bd.refUri;\r\n }\r\n // pageType is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.pageType)) {\r\n properties[\"pageType\"] = bd.pageType;\r\n }\r\n // isLoggedIn is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd.isLoggedIn)) {\r\n properties[\"isLoggedIn\"] = bd.isLoggedIn[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n // pageTags is a field that Breeze still does not recognize as part of Part B. For now, put it in Part C until it supports it as a domain property\r\n if (!isNullOrUndefined(bd[strProperties])) {\r\n var pageTags = bd[strProperties];\r\n objForEachKey(pageTags, function (key, value) {\r\n properties[key] = value;\r\n });\r\n }\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], properties, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue);\r\n }\r\n var pageViewData = new PageView(logger, name, url, duration, properties, measurements, id);\r\n var data = new Data(PageView[_DYN_DATA_TYPE /* @min:%2edataType */], pageViewData);\r\n return _createEnvelope(logger, PageView[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function PageViewPerformanceEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var bd = telemetryItem[strBaseData];\r\n var name = bd[_DYN_NAME /* @min:%2ename */];\r\n var url = bd.uri || bd.url;\r\n var properties = bd[strProperties] || {};\r\n var measurements = bd[_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], properties, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(properties, customUndefinedValue);\r\n }\r\n var baseData = new PageViewPerformance(logger, name, url, undefined, properties, measurements, bd);\r\n var data = new Data(PageViewPerformance[_DYN_DATA_TYPE /* @min:%2edataType */], baseData);\r\n return _createEnvelope(logger, PageViewPerformance[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\nexport function TraceEnvelopeCreator(logger, telemetryItem, customUndefinedValue) {\r\n EnvelopeCreatorInit(logger, telemetryItem);\r\n var message = telemetryItem[strBaseData].message;\r\n var severityLevel = telemetryItem[strBaseData].severityLevel;\r\n var props = telemetryItem[strBaseData][strProperties] || {};\r\n var measurements = telemetryItem[strBaseData][_DYN_MEASUREMENTS /* @min:%2emeasurements */] || {};\r\n _extractPropsAndMeasurements(telemetryItem[_DYN_DATA /* @min:%2edata */], props, measurements);\r\n if (!isNullOrUndefined(customUndefinedValue)) {\r\n _convertPropsUndefinedToCustomDefinedValue(props, customUndefinedValue);\r\n }\r\n var baseData = new Trace(logger, message, severityLevel, props, measurements);\r\n var data = new Data(Trace[_DYN_DATA_TYPE /* @min:%2edataType */], baseData);\r\n return _createEnvelope(logger, Trace[_DYN_ENVELOPE_TYPE /* @min:%2eenvelopeType */], telemetryItem, data);\r\n}\r\n//# sourceMappingURL=EnvelopeCreator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { createUniqueNamespace, eventOff, eventOn, getDocument, getNavigator, getWindow, isNullOrUndefined, isUndefined, mergeEvtNamespace } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_IS_ONLINE, _DYN_ON_LINE } from \"./__DynamicConstants\";\r\nfunction _disableEvents(target, evtNamespace) {\r\n eventOff(target, null, null, evtNamespace);\r\n}\r\n/**\r\n * Create a new OfflineListener instance to monitor browser online / offline events\r\n * @param parentEvtNamespace - The parent event namespace to append to any specific events for this instance\r\n */\r\nexport function createOfflineListener(parentEvtNamespace) {\r\n var _a;\r\n var _document = getDocument();\r\n var _navigator = getNavigator(); // Gets the window.navigator or workerNavigator depending on the global\r\n var _isListening = false;\r\n var _onlineStatus = true;\r\n var _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"OfflineListener\"), parentEvtNamespace);\r\n try {\r\n if (_enableEvents(getWindow())) {\r\n _isListening = true;\r\n }\r\n if (_document) {\r\n // Also attach to the document.body or document\r\n var target = _document.body || _document;\r\n if (target.ononline) {\r\n if (_enableEvents(target)) {\r\n _isListening = true;\r\n }\r\n }\r\n }\r\n if (_isListening) {\r\n // We are listening to events so lets set the current status rather than assuming we are online #1538\r\n if (_navigator && !isNullOrUndefined(_navigator[_DYN_ON_LINE /* @min:%2eonLine */])) { // navigator.onLine is undefined in react-native\r\n _onlineStatus = _navigator[_DYN_ON_LINE /* @min:%2eonLine */];\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // this makes react-native less angry\r\n _isListening = false;\r\n }\r\n function _enableEvents(target) {\r\n var enabled = false;\r\n if (target) {\r\n enabled = eventOn(target, \"online\", _setOnline, _evtNamespace);\r\n if (enabled) {\r\n eventOn(target, \"offline\", _setOffline, _evtNamespace);\r\n }\r\n }\r\n return enabled;\r\n }\r\n function _setOnline() {\r\n _onlineStatus = true;\r\n }\r\n function _setOffline() {\r\n _onlineStatus = false;\r\n }\r\n function _isOnline() {\r\n var result = true;\r\n if (_isListening) {\r\n result = _onlineStatus;\r\n }\r\n else if (_navigator && !isNullOrUndefined(_navigator[_DYN_ON_LINE /* @min:%2eonLine */])) { // navigator.onLine is undefined in react-native\r\n result = _navigator[_DYN_ON_LINE /* @min:%2eonLine */];\r\n }\r\n return result;\r\n }\r\n function _unload() {\r\n var win = getWindow();\r\n if (win && _isListening) {\r\n _disableEvents(win, _evtNamespace);\r\n if (_document) {\r\n // Also attach to the document.body or document\r\n var target = _document.body || _document;\r\n if (!isUndefined(target.ononline)) {\r\n _disableEvents(target, _evtNamespace);\r\n }\r\n }\r\n _isListening = false;\r\n }\r\n }\r\n return _a = {},\r\n _a[_DYN_IS_ONLINE /* @min:isOnline */] = _isOnline,\r\n _a.isListening = function () { return _isListening; },\r\n _a.unload = _unload,\r\n _a;\r\n}\r\n//# sourceMappingURL=Offline.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlGetSessionStorage, utlSetSessionStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, arrForEach, arrIndexOf, dumpObj, getExceptionName, getJSON, isArray, isFunction, isString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_BATCH_PAYLOADS, _DYN_BUFFER_OVERRIDE, _DYN_CLEAR, _DYN_CLEAR_SENT, _DYN_COUNT, _DYN_EMIT_LINE_DELIMITED_0, _DYN_ENQUEUE, _DYN_LENGTH, _DYN_MARK_AS_SENT, _DYN_NAME_PREFIX, _DYN_PUSH, _DYN_STRINGIFY, _DYN__BUFFER__KEY, _DYN__MAX__BUFFER__SIZE, _DYN__SENT__BUFFER__KEY } from \"./__DynamicConstants\";\r\nvar BaseSendBuffer = /** @class */ (function () {\r\n function BaseSendBuffer(logger, config) {\r\n var _buffer = [];\r\n var _bufferFullMessageSent = false;\r\n this._get = function () {\r\n return _buffer;\r\n };\r\n this._set = function (buffer) {\r\n _buffer = buffer;\r\n return _buffer;\r\n };\r\n dynamicProto(BaseSendBuffer, this, function (_self) {\r\n _self[_DYN_ENQUEUE /* @min:%2eenqueue */] = function (payload) {\r\n if (_self[_DYN_COUNT /* @min:%2ecount */]() >= config.eventsLimitInMem()) {\r\n // sent internal log only once per page view\r\n if (!_bufferFullMessageSent) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 105 /* _eInternalMessageId.InMemoryStorageBufferFull */, \"Maximum in-memory buffer size reached: \" + _self[_DYN_COUNT /* @min:%2ecount */](), true);\r\n _bufferFullMessageSent = true;\r\n }\r\n return;\r\n }\r\n _buffer[_DYN_PUSH /* @min:%2epush */](payload);\r\n };\r\n _self[_DYN_COUNT /* @min:%2ecount */] = function () {\r\n return _buffer[_DYN_LENGTH /* @min:%2elength */];\r\n };\r\n _self.size = function () {\r\n var size = _buffer[_DYN_LENGTH /* @min:%2elength */];\r\n for (var lp = 0; lp < _buffer[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n size += _buffer[lp][_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n if (!config[_DYN_EMIT_LINE_DELIMITED_0 /* @min:%2eemitLineDelimitedJson */]()) {\r\n size += 2;\r\n }\r\n return size;\r\n };\r\n _self[_DYN_CLEAR /* @min:%2eclear */] = function () {\r\n _buffer = [];\r\n _bufferFullMessageSent = false;\r\n };\r\n _self.getItems = function () {\r\n return _buffer.slice(0);\r\n };\r\n _self[_DYN_BATCH_PAYLOADS /* @min:%2ebatchPayloads */] = function (payload) {\r\n if (payload && payload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var batch = config[_DYN_EMIT_LINE_DELIMITED_0 /* @min:%2eemitLineDelimitedJson */]() ?\r\n payload.join(\"\\n\") :\r\n \"[\" + payload.join(\",\") + \"]\";\r\n return batch;\r\n }\r\n return null;\r\n };\r\n });\r\n }\r\n// Removed Stub for BaseSendBuffer.prototype.enqueue.\r\n// Removed Stub for BaseSendBuffer.prototype.count.\r\n// Removed Stub for BaseSendBuffer.prototype.size.\r\n// Removed Stub for BaseSendBuffer.prototype.clear.\r\n// Removed Stub for BaseSendBuffer.prototype.getItems.\r\n// Removed Stub for BaseSendBuffer.prototype.batchPayloads.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n BaseSendBuffer.__ieDyn=1;\n\n return BaseSendBuffer;\r\n}());\r\n/*\r\n * An array based send buffer.\r\n */\r\nvar ArraySendBuffer = /** @class */ (function (_super) {\r\n __extends(ArraySendBuffer, _super);\r\n function ArraySendBuffer(logger, config) {\r\n var _this = _super.call(this, logger, config) || this;\r\n dynamicProto(ArraySendBuffer, _this, function (_self, _base) {\r\n _self[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */] = function (payload) {\r\n _base[_DYN_CLEAR /* @min:%2eclear */]();\r\n };\r\n _self[_DYN_CLEAR_SENT /* @min:%2eclearSent */] = function (payload) {\r\n // not supported\r\n };\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for ArraySendBuffer.prototype.markAsSent.\r\n// Removed Stub for ArraySendBuffer.prototype.clearSent.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n ArraySendBuffer.__ieDyn=1;\n\n return ArraySendBuffer;\r\n}(BaseSendBuffer));\r\nexport { ArraySendBuffer };\r\n/*\r\n * Session storage buffer holds a copy of all unsent items in the browser session storage.\r\n */\r\nvar SessionStorageSendBuffer = /** @class */ (function (_super) {\r\n __extends(SessionStorageSendBuffer, _super);\r\n function SessionStorageSendBuffer(logger, config) {\r\n var _this = _super.call(this, logger, config) || this;\r\n var _bufferFullMessageSent = false;\r\n var _a = config[_DYN_BUFFER_OVERRIDE /* @min:%2ebufferOverride */]() || { getItem: utlGetSessionStorage, setItem: utlSetSessionStorage }, getItem = _a.getItem, setItem = _a.setItem;\r\n dynamicProto(SessionStorageSendBuffer, _this, function (_self, _base) {\r\n var bufferItems = _getBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */]);\r\n var notDeliveredItems = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n var buffer = _self._set(bufferItems.concat(notDeliveredItems));\r\n // If the buffer has too many items, drop items from the end.\r\n if (buffer[_DYN_LENGTH /* @min:%2elength */] > SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n buffer[_DYN_LENGTH /* @min:%2elength */] = SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */];\r\n }\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], []);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], buffer);\r\n _self[_DYN_ENQUEUE /* @min:%2eenqueue */] = function (payload) {\r\n if (_self[_DYN_COUNT /* @min:%2ecount */]() >= SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n // sent internal log only once per page view\r\n if (!_bufferFullMessageSent) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 67 /* _eInternalMessageId.SessionStorageBufferFull */, \"Maximum buffer size reached: \" + _self[_DYN_COUNT /* @min:%2ecount */](), true);\r\n _bufferFullMessageSent = true;\r\n }\r\n return;\r\n }\r\n _base[_DYN_ENQUEUE /* @min:%2eenqueue */](payload);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._get());\r\n };\r\n _self[_DYN_CLEAR /* @min:%2eclear */] = function () {\r\n _base[_DYN_CLEAR /* @min:%2eclear */]();\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._get());\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], []);\r\n _bufferFullMessageSent = false;\r\n };\r\n _self[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */] = function (payload) {\r\n _setBuffer(SessionStorageSendBuffer[_DYN__BUFFER__KEY /* @min:%2eBUFFER_KEY */], _self._set(_removePayloadsFromBuffer(payload, _self._get())));\r\n var sentElements = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n if (sentElements instanceof Array && payload instanceof Array) {\r\n sentElements = sentElements.concat(payload);\r\n if (sentElements[_DYN_LENGTH /* @min:%2elength */] > SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */]) {\r\n // We send telemetry normally. If the SENT_BUFFER is too big we don't add new elements\r\n // until we receive a response from the backend and the buffer has free space again (see clearSent method)\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 67 /* _eInternalMessageId.SessionStorageBufferFull */, \"Sent buffer reached its maximum size: \" + sentElements[_DYN_LENGTH /* @min:%2elength */], true);\r\n sentElements[_DYN_LENGTH /* @min:%2elength */] = SessionStorageSendBuffer[_DYN__MAX__BUFFER__SIZE /* @min:%2eMAX_BUFFER_SIZE */];\r\n }\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], sentElements);\r\n }\r\n };\r\n _self[_DYN_CLEAR_SENT /* @min:%2eclearSent */] = function (payload) {\r\n var sentElements = _getBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */]);\r\n sentElements = _removePayloadsFromBuffer(payload, sentElements);\r\n _setBuffer(SessionStorageSendBuffer[_DYN__SENT__BUFFER__KEY /* @min:%2eSENT_BUFFER_KEY */], sentElements);\r\n };\r\n function _removePayloadsFromBuffer(payloads, buffer) {\r\n var remaining = [];\r\n arrForEach(buffer, function (value) {\r\n if (!isFunction(value) && arrIndexOf(payloads, value) === -1) {\r\n remaining[_DYN_PUSH /* @min:%2epush */](value);\r\n }\r\n });\r\n return remaining;\r\n }\r\n function _getBuffer(key) {\r\n var prefixedKey = key;\r\n try {\r\n prefixedKey = config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] && config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() ? config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() + \"_\" + prefixedKey : prefixedKey;\r\n var bufferJson = getItem(logger, prefixedKey);\r\n if (bufferJson) {\r\n var buffer_1 = getJSON().parse(bufferJson);\r\n if (isString(buffer_1)) {\r\n // When using some version prototype.js the stringify / parse cycle does not decode array's correctly\r\n buffer_1 = getJSON().parse(buffer_1);\r\n }\r\n if (buffer_1 && isArray(buffer_1)) {\r\n return buffer_1;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 42 /* _eInternalMessageId.FailedToRestoreStorageBuffer */, \" storage key: \" + prefixedKey + \", \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n return [];\r\n }\r\n function _setBuffer(key, buffer) {\r\n var prefixedKey = key;\r\n try {\r\n prefixedKey = config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] && config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() ? config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() + \"_\" + prefixedKey : prefixedKey;\r\n var bufferJson = JSON[_DYN_STRINGIFY /* @min:%2estringify */](buffer);\r\n setItem(logger, prefixedKey, bufferJson);\r\n }\r\n catch (e) {\r\n // if there was an error, clear the buffer\r\n // telemetry is stored in the _buffer array so we won't loose any items\r\n setItem(logger, prefixedKey, JSON[_DYN_STRINGIFY /* @min:%2estringify */]([]));\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 41 /* _eInternalMessageId.FailedToSetStorageBuffer */, \" storage key: \" + prefixedKey + \", \" + getExceptionName(e) + \". Buffer cleared\", { exception: dumpObj(e) });\r\n }\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for SessionStorageSendBuffer.prototype.enqueue.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.clear.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.markAsSent.\r\n// Removed Stub for SessionStorageSendBuffer.prototype.clearSent.\r\n SessionStorageSendBuffer.BUFFER_KEY = \"AI_buffer\";\r\n SessionStorageSendBuffer.SENT_BUFFER_KEY = \"AI_sentBuffer\";\r\n // Maximum number of payloads stored in the buffer. If the buffer is full, new elements will be dropped.\r\n SessionStorageSendBuffer.MAX_BUFFER_SIZE = 2000;\r\n return SessionStorageSendBuffer;\r\n}(BaseSendBuffer));\r\nexport { SessionStorageSendBuffer };\r\n//# sourceMappingURL=SendBuffer.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nvar _a;\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { BreezeChannelIdentifier, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, DisabledPropertyName, Event, Exception, Metric, PageView, PageViewPerformance, ProcessLegacy, RemoteDependencyData, RequestHeaders, SampleRate, Trace, isInternalApplicationInsightsEndpoint, utlCanUseSessionStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, _throwInternal, _warnToConsole, arrForEach, createUniqueNamespace, dateNow, dumpObj, getExceptionName, getIEVersion, getJSON, getNavigator, getWindow, isArray, isBeaconsSupported, isFetchSupported, isNullOrUndefined, isXhrSupported, mergeEvtNamespace, objForEachKey, objKeys, useXDomainRequest } from \"@microsoft/applicationinsights-core-js\";\r\nimport { DependencyEnvelopeCreator, EventEnvelopeCreator, ExceptionEnvelopeCreator, MetricEnvelopeCreator, PageViewEnvelopeCreator, PageViewPerformanceEnvelopeCreator, TraceEnvelopeCreator } from \"./EnvelopeCreator\";\r\nimport { createOfflineListener } from \"./Offline\";\r\nimport { ArraySendBuffer, SessionStorageSendBuffer } from \"./SendBuffer\";\r\nimport { Serializer } from \"./Serializer\";\r\nimport { Sample } from \"./TelemetryProcessors/Sample\";\r\nimport { _DYN_BASE_TYPE, _DYN_BATCH_PAYLOADS, _DYN_BUFFER_OVERRIDE, _DYN_CLEAR, _DYN_CLEAR_SENT, _DYN_CONVERT_UNDEFINED, _DYN_COUNT, _DYN_CUSTOM_HEADERS, _DYN_DIAG_LOG, _DYN_DISABLE_INSTRUMENTAT7, _DYN_DISABLE_TELEMETRY, _DYN_DISABLE_XHR, _DYN_EMIT_LINE_DELIMITED_0, _DYN_ENABLE_SESSION_STORA4, _DYN_ENDPOINT_URL, _DYN_ENQUEUE, _DYN_EVENTS_SEND_REQUEST, _DYN_INSTRUMENTATION_KEY, _DYN_IS_BEACON_API_DISABL3, _DYN_IS_ONLINE, _DYN_IS_RETRY_DISABLED, _DYN_ITEMS_ACCEPTED, _DYN_ITEMS_RECEIVED, _DYN_LENGTH, _DYN_MARK_AS_SENT, _DYN_MAX_BATCH_INTERVAL, _DYN_MAX_BATCH_SIZE_IN_BY1, _DYN_NAME_PREFIX, _DYN_ONUNLOAD_DISABLE_BEA2, _DYN_ONUNLOAD_DISABLE_FET5, _DYN_PUSH, _DYN_SAMPLE_RATE, _DYN_SAMPLING_PERCENTAGE, _DYN_SET_REQUEST_HEADER, _DYN_TAGS, _DYN_TRIGGER_SEND, _DYN__BUFFER, _DYN__ON_ERROR, _DYN__ON_PARTIAL_SUCCESS, _DYN__ON_SUCCESS, _DYN__SENDER, _DYN__SENDER_CONFIG, _DYN__XHR_READY_STATE_CHA6 } from \"./__DynamicConstants\";\r\nvar FetchSyncRequestSizeLimitBytes = 65000; // approx 64kb (the current Edge, Firefox and Chrome max limit)\r\nfunction _getResponseText(xhr) {\r\n try {\r\n return xhr.responseText;\r\n }\r\n catch (e) {\r\n // Best effort, as XHR may throw while XDR wont so just ignore\r\n }\r\n return null;\r\n}\r\nfunction _getDefaultAppInsightsChannelConfig() {\r\n var _a;\r\n var defaultValue;\r\n var defaultCustomHeaders;\r\n // set default values\r\n return _a = {\r\n endpointUrl: function () { return DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH; }\r\n },\r\n _a[_DYN_EMIT_LINE_DELIMITED_0 /* @min:emitLineDelimitedJson */] = function () { return false; },\r\n _a[_DYN_MAX_BATCH_INTERVAL /* @min:maxBatchInterval */] = function () { return 15000; },\r\n _a[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:maxBatchSizeInBytes */] = function () { return 102400; },\r\n _a[_DYN_DISABLE_TELEMETRY /* @min:disableTelemetry */] = function () { return false; },\r\n _a[_DYN_ENABLE_SESSION_STORA4 /* @min:enableSessionStorageBuffer */] = function () { return true; },\r\n _a[_DYN_BUFFER_OVERRIDE /* @min:bufferOverride */] = function () { return false; },\r\n _a[_DYN_IS_RETRY_DISABLED /* @min:isRetryDisabled */] = function () { return false; },\r\n _a[_DYN_IS_BEACON_API_DISABL3 /* @min:isBeaconApiDisabled */] = function () { return true; },\r\n _a[_DYN_DISABLE_XHR /* @min:disableXhr */] = function () { return false; },\r\n _a[_DYN_ONUNLOAD_DISABLE_FET5 /* @min:onunloadDisableFetch */] = function () { return false; },\r\n _a[_DYN_ONUNLOAD_DISABLE_BEA2 /* @min:onunloadDisableBeacon */] = function () { return false; },\r\n _a[_DYN_INSTRUMENTATION_KEY /* @min:instrumentationKey */] = function () { return defaultValue; },\r\n _a[_DYN_NAME_PREFIX /* @min:namePrefix */] = function () { return defaultValue; },\r\n _a[_DYN_SAMPLING_PERCENTAGE /* @min:samplingPercentage */] = function () { return 100; },\r\n _a[_DYN_CUSTOM_HEADERS /* @min:customHeaders */] = function () { return defaultCustomHeaders; },\r\n _a[_DYN_CONVERT_UNDEFINED /* @min:convertUndefined */] = function () { return defaultValue; },\r\n _a.eventsLimitInMem = function () { return 10000; },\r\n _a;\r\n}\r\nvar EnvelopeTypeCreator = (_a = {},\r\n _a[Event.dataType] = EventEnvelopeCreator,\r\n _a[Trace.dataType] = TraceEnvelopeCreator,\r\n _a[PageView.dataType] = PageViewEnvelopeCreator,\r\n _a[PageViewPerformance.dataType] = PageViewPerformanceEnvelopeCreator,\r\n _a[Exception.dataType] = ExceptionEnvelopeCreator,\r\n _a[Metric.dataType] = MetricEnvelopeCreator,\r\n _a[RemoteDependencyData.dataType] = DependencyEnvelopeCreator,\r\n _a);\r\nvar Sender = /** @class */ (function (_super) {\r\n __extends(Sender, _super);\r\n function Sender() {\r\n var _this = _super.call(this) || this;\r\n _this.priority = 1001;\r\n _this.identifier = BreezeChannelIdentifier;\r\n /**\r\n * The configuration for this sender instance\r\n */\r\n _this._senderConfig = _getDefaultAppInsightsChannelConfig();\r\n // Don't set the defaults here, set them in the _initDefaults() as this is also called during unload\r\n var _consecutiveErrors; // How many times in a row a retryable error condition has occurred.\r\n var _retryAt; // The time to retry at in milliseconds from 1970/01/01 (this makes the timer calculation easy).\r\n var _lastSend; // The time of the last send operation.\r\n var _paused; // Flag indicating that the sending should be paused\r\n var _timeoutHandle; // Handle to the timer for delayed sending of batches of data.\r\n var _serializer;\r\n var _stamp_specific_redirects;\r\n var _headers;\r\n var _syncFetchPayload = 0; // Keep track of the outstanding sync fetch payload total (as sync fetch has limits)\r\n var _fallbackSender; // The sender to use if the payload size is too large\r\n var _syncUnloadSender; // The identified sender to use for the synchronous unload stage\r\n var _offlineListener;\r\n var _evtNamespace;\r\n dynamicProto(Sender, _this, function (_self, _base) {\r\n _initDefaults();\r\n _self.pause = function () {\r\n _clearScheduledTimer();\r\n _paused = true;\r\n };\r\n _self.resume = function () {\r\n if (_paused) {\r\n _paused = false;\r\n _retryAt = null;\r\n // flush if we have exceeded the max-size already\r\n if (_self._buffer.size() > _self._senderConfig[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */]()) {\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, null, 10 /* SendRequestReason.MaxBatchSize */);\r\n }\r\n _setupTimer();\r\n }\r\n };\r\n _self.flush = function (isAsync, callBack, sendReason) {\r\n if (isAsync === void 0) { isAsync = true; }\r\n if (!_paused) {\r\n // Clear the normal schedule timer as we are going to try and flush ASAP\r\n _clearScheduledTimer();\r\n try {\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](isAsync, null, sendReason || 1 /* SendRequestReason.ManualFlush */);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 22 /* _eInternalMessageId.FlushFailed */, \"flush failed, telemetry will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n };\r\n _self.onunloadFlush = function () {\r\n if (!_paused) {\r\n if ((_self._senderConfig[_DYN_ONUNLOAD_DISABLE_BEA2 /* @min:%2eonunloadDisableBeacon */]() === false || _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_IS_BEACON_API_DISABL3 /* @min:%2eisBeaconApiDisabled */]() === false) && isBeaconsSupported()) {\r\n try {\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, _doUnloadSend, 2 /* SendRequestReason.Unload */);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 20 /* _eInternalMessageId.FailedToSendQueuedTelemetry */, \"failed to flush with beacon sender on page unload, telemetry will not be collected: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n else {\r\n _self.flush();\r\n }\r\n }\r\n };\r\n _self.addHeader = function (name, value) {\r\n _headers[name] = value;\r\n };\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n if (_self.isInitialized()) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"Sender is already initialized\");\r\n }\r\n _base.initialize(config, core, extensions, pluginChain);\r\n var ctx = _self._getTelCtx();\r\n var identifier = _self.identifier;\r\n _serializer = new Serializer(core.logger);\r\n _consecutiveErrors = 0;\r\n _retryAt = null;\r\n _lastSend = 0;\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = null;\r\n _stamp_specific_redirects = 0;\r\n var diagLog = _self[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"Sender\"), core.evtNamespace && core.evtNamespace());\r\n _offlineListener = createOfflineListener(_evtNamespace);\r\n // TODO v3.x: Change the ISenderConfig to not be function calls\r\n var defaultConfig = _getDefaultAppInsightsChannelConfig();\r\n objForEachKey(defaultConfig, function (field, value) {\r\n _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][field] = function () {\r\n var theValue = ctx.getConfig(identifier, field, value());\r\n if (!theValue && field === \"endpointUrl\") {\r\n // Use the default value (handles empty string in the configuration)\r\n theValue = value();\r\n }\r\n return theValue;\r\n };\r\n });\r\n var useSessionStorage = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENABLE_SESSION_STORA4 /* @min:%2eenableSessionStorageBuffer */]() &&\r\n !!(_self._senderConfig[_DYN_BUFFER_OVERRIDE /* @min:%2ebufferOverride */]() || utlCanUseSessionStorage());\r\n _self[_DYN__BUFFER /* @min:%2e_buffer */] = useSessionStorage\r\n ? new SessionStorageSendBuffer(diagLog, _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */])\r\n : new ArraySendBuffer(diagLog, _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */]);\r\n _self._sample = new Sample(_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */](), diagLog);\r\n if (!_validateInstrumentationKey(config)) {\r\n _throwInternal(diagLog, 1 /* eLoggingSeverity.CRITICAL */, 100 /* _eInternalMessageId.InvalidInstrumentationKey */, \"Invalid Instrumentation key \" + config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */]);\r\n }\r\n if (!isInternalApplicationInsightsEndpoint(_self._senderConfig.endpointUrl()) && _self._senderConfig.customHeaders() && _self._senderConfig.customHeaders()[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_CUSTOM_HEADERS /* @min:%2ecustomHeaders */](), function (customHeader) {\r\n _this.addHeader(customHeader.header, customHeader.value);\r\n });\r\n }\r\n var senderConfig = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */];\r\n var sendPostFunc = null;\r\n if (!senderConfig[_DYN_DISABLE_XHR /* @min:%2edisableXhr */]() && useXDomainRequest()) {\r\n sendPostFunc = _xdrSender; // IE 8 and 9\r\n }\r\n else if (!senderConfig[_DYN_DISABLE_XHR /* @min:%2edisableXhr */]() && isXhrSupported()) {\r\n sendPostFunc = _xhrSender;\r\n }\r\n if (!sendPostFunc && isFetchSupported()) {\r\n sendPostFunc = _fetchSender;\r\n }\r\n // always fallback to XHR\r\n _fallbackSender = sendPostFunc || _xhrSender;\r\n if (!senderConfig[_DYN_IS_BEACON_API_DISABL3 /* @min:%2eisBeaconApiDisabled */]() && isBeaconsSupported()) {\r\n // Config is set to always used beacon sending\r\n sendPostFunc = _beaconSender;\r\n }\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = sendPostFunc || _xhrSender;\r\n if (!senderConfig[_DYN_ONUNLOAD_DISABLE_FET5 /* @min:%2eonunloadDisableFetch */]() && isFetchSupported(true)) {\r\n // Try and use the fetch with keepalive\r\n _syncUnloadSender = _fetchKeepAliveSender;\r\n }\r\n else if (isBeaconsSupported()) {\r\n // Try and use sendBeacon\r\n _syncUnloadSender = _beaconSender;\r\n }\r\n else if (!senderConfig[_DYN_DISABLE_XHR /* @min:%2edisableXhr */]() && useXDomainRequest()) {\r\n _syncUnloadSender = _xdrSender; // IE 8 and 9\r\n }\r\n else if (!senderConfig[_DYN_DISABLE_XHR /* @min:%2edisableXhr */]() && isXhrSupported()) {\r\n _syncUnloadSender = _xhrSender;\r\n }\r\n else {\r\n _syncUnloadSender = _fallbackSender;\r\n }\r\n };\r\n _self.processTelemetry = function (telemetryItem, itemCtx) {\r\n itemCtx = _self._getTelCtx(itemCtx);\r\n var diagLogger = itemCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */]();\r\n try {\r\n // if master off switch is set, don't send any data\r\n if (_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_DISABLE_TELEMETRY /* @min:%2edisableTelemetry */]()) {\r\n // Do not send/save data\r\n return;\r\n }\r\n // validate input\r\n if (!telemetryItem) {\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 7 /* _eInternalMessageId.CannotSendEmptyTelemetry */, \"Cannot send empty telemetry\");\r\n return;\r\n }\r\n // validate event\r\n if (telemetryItem.baseData && !telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */]) {\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 70 /* _eInternalMessageId.InvalidEvent */, \"Cannot send telemetry without baseData and baseType\");\r\n return;\r\n }\r\n if (!telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */]) {\r\n // Default\r\n telemetryItem[_DYN_BASE_TYPE /* @min:%2ebaseType */] = \"EventData\";\r\n }\r\n // ensure a sender was constructed\r\n if (!_self[_DYN__SENDER /* @min:%2e_sender */]) {\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 28 /* _eInternalMessageId.SenderNotInitialized */, \"Sender was not initialized\");\r\n return;\r\n }\r\n // check if this item should be sampled in, else add sampleRate tag\r\n if (!_isSampledIn(telemetryItem)) {\r\n // Item is sampled out, do not send it\r\n _throwInternal(diagLogger, 2 /* eLoggingSeverity.WARNING */, 33 /* _eInternalMessageId.TelemetrySampledAndNotSent */, \"Telemetry item was sampled out and not sent\", { SampleRate: _self._sample[_DYN_SAMPLE_RATE /* @min:%2esampleRate */] });\r\n return;\r\n }\r\n else {\r\n telemetryItem[SampleRate] = _self._sample[_DYN_SAMPLE_RATE /* @min:%2esampleRate */];\r\n }\r\n var convertUndefined = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_CONVERT_UNDEFINED /* @min:%2econvertUndefined */]() || undefined;\r\n // construct an envelope that Application Insights endpoint can understand\r\n // if ikey of telemetry is provided and not empty, envelope will use this iKey instead of senderConfig iKey\r\n var defaultEnvelopeIkey = telemetryItem.iKey || _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */]();\r\n var aiEnvelope_1 = Sender.constructEnvelope(telemetryItem, defaultEnvelopeIkey, diagLogger, convertUndefined);\r\n if (!aiEnvelope_1) {\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 47 /* _eInternalMessageId.CreateEnvelopeError */, \"Unable to create an AppInsights envelope\");\r\n return;\r\n }\r\n var doNotSendItem_1 = false;\r\n // this is for running in legacy mode, where customer may already have a custom initializer present\r\n if (telemetryItem[_DYN_TAGS /* @min:%2etags */] && telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy]) {\r\n arrForEach(telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy], function (callBack) {\r\n try {\r\n if (callBack && callBack(aiEnvelope_1) === false) {\r\n doNotSendItem_1 = true;\r\n _warnToConsole(diagLogger, \"Telemetry processor check returns false\");\r\n }\r\n }\r\n catch (e) {\r\n // log error but dont stop executing rest of the telemetry initializers\r\n // doNotSendItem = true;\r\n _throwInternal(diagLogger, 1 /* eLoggingSeverity.CRITICAL */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"One of telemetry initializers failed, telemetry item will not be sent: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n });\r\n delete telemetryItem[_DYN_TAGS /* @min:%2etags */][ProcessLegacy];\r\n }\r\n if (doNotSendItem_1) {\r\n return; // do not send, no need to execute next plugin\r\n }\r\n // check if the incoming payload is too large, truncate if necessary\r\n var payload = _serializer.serialize(aiEnvelope_1);\r\n // flush if we would exceed the max-size limit by adding this item\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n var bufferSize = buffer.size();\r\n if ((bufferSize + payload[_DYN_LENGTH /* @min:%2elength */]) > _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */]()) {\r\n if (!_offlineListener || _offlineListener[_DYN_IS_ONLINE /* @min:%2eisOnline */]()) { // only trigger send when currently online\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, null, 10 /* SendRequestReason.MaxBatchSize */);\r\n }\r\n }\r\n // enqueue the payload\r\n buffer[_DYN_ENQUEUE /* @min:%2eenqueue */](payload);\r\n // ensure an invocation timeout is set\r\n _setupTimer();\r\n }\r\n catch (e) {\r\n _throwInternal(diagLogger, 2 /* eLoggingSeverity.WARNING */, 12 /* _eInternalMessageId.FailedAddingTelemetryToBuffer */, \"Failed adding telemetry to the sender's buffer, some telemetry will be lost: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n // hand off the telemetry item to the next plugin\r\n _self.processNext(telemetryItem, itemCtx);\r\n };\r\n /**\r\n * xhr state changes\r\n */\r\n _self[_DYN__XHR_READY_STATE_CHA6 /* @min:%2e_xhrReadyStateChange */] = function (xhr, payload, countOfItemsInPayload) {\r\n if (xhr.readyState === 4) {\r\n _checkResponsStatus(xhr.status, payload, xhr.responseURL, countOfItemsInPayload, _formatErrorMessageXhr(xhr), _getResponseText(xhr) || xhr.response);\r\n }\r\n };\r\n /**\r\n * Immediately send buffered data\r\n * @param async {boolean} - Indicates if the events should be sent asynchronously\r\n * @param forcedSender {SenderFunction} - Indicates the forcedSender, undefined if not passed\r\n */\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */] = function (async, forcedSender, sendReason) {\r\n if (async === void 0) { async = true; }\r\n if (!_paused) {\r\n try {\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n // Send data only if disableTelemetry is false\r\n if (!_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_DISABLE_TELEMETRY /* @min:%2edisableTelemetry */]()) {\r\n if (buffer[_DYN_COUNT /* @min:%2ecount */]() > 0) {\r\n var payload = buffer.getItems();\r\n _notifySendRequest(sendReason || 0 /* SendRequestReason.Undefined */, async);\r\n // invoke send\r\n if (forcedSender) {\r\n forcedSender.call(_self, payload, async);\r\n }\r\n else {\r\n _self[_DYN__SENDER /* @min:%2e_sender */](payload, async);\r\n }\r\n }\r\n // update lastSend time to enable throttling\r\n _lastSend = +new Date;\r\n }\r\n else {\r\n buffer[_DYN_CLEAR /* @min:%2eclear */]();\r\n }\r\n _clearScheduledTimer();\r\n }\r\n catch (e) {\r\n /* Ignore this error for IE under v10 */\r\n var ieVer = getIEVersion();\r\n if (!ieVer || ieVer > 9) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 40 /* _eInternalMessageId.TransmissionFailed */, \"Telemetry transmission failed, some telemetry will be lost: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n }\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n _self.onunloadFlush();\r\n _offlineListener.unload();\r\n _initDefaults();\r\n };\r\n /**\r\n * error handler\r\n */\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */] = function (payload, message, event) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 26 /* _eInternalMessageId.OnError */, \"Failed to send telemetry.\", { message: message });\r\n _self._buffer && _self._buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n };\r\n /**\r\n * partial success handler\r\n */\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */] = function (payload, results) {\r\n var failed = [];\r\n var retry = [];\r\n // Iterate through the reversed array of errors so that splicing doesn't have invalid indexes after the first item.\r\n var errors = results.errors.reverse();\r\n for (var _i = 0, errors_1 = errors; _i < errors_1.length; _i++) {\r\n var error = errors_1[_i];\r\n var extracted = payload.splice(error.index, 1)[0];\r\n if (_isRetriable(error.statusCode)) {\r\n retry[_DYN_PUSH /* @min:%2epush */](extracted);\r\n }\r\n else {\r\n // All other errors, including: 402 (Monthly quota exceeded) and 439 (Too many requests and refresh cache).\r\n failed[_DYN_PUSH /* @min:%2epush */](extracted);\r\n }\r\n }\r\n if (payload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */]);\r\n }\r\n if (failed[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](failed, _formatErrorMessageXhr(null, [\"partial success\", results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */], \"of\", results.itemsReceived].join(\" \")));\r\n }\r\n if (retry[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _resendPayload(retry);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \"Partial success. \" +\r\n \"Delivered: \" + payload[_DYN_LENGTH /* @min:%2elength */] + \", Failed: \" + failed[_DYN_LENGTH /* @min:%2elength */] +\r\n \". Will retry to send \" + retry[_DYN_LENGTH /* @min:%2elength */] + \" our of \" + results[_DYN_ITEMS_RECEIVED /* @min:%2eitemsReceived */] + \" items\");\r\n }\r\n };\r\n /**\r\n * success handler\r\n */\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */] = function (payload, countOfItemsInPayload) {\r\n _self._buffer && _self._buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n };\r\n /**\r\n * xdr state changes\r\n */\r\n _self._xdrOnLoad = function (xdr, payload) {\r\n var responseText = _getResponseText(xdr);\r\n if (xdr && (responseText + \"\" === \"200\" || responseText === \"\")) {\r\n _consecutiveErrors = 0;\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, 0);\r\n }\r\n else {\r\n var results = _parseResponse(responseText);\r\n if (results && results.itemsReceived && results.itemsReceived > results[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */]\r\n && !_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_IS_RETRY_DISABLED /* @min:%2eisRetryDisabled */]()) {\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */](payload, results);\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, _formatErrorMessageXdr(xdr));\r\n }\r\n }\r\n };\r\n function _isSampledIn(envelope) {\r\n return _self._sample.isSampledIn(envelope);\r\n }\r\n function _checkResponsStatus(status, payload, responseUrl, countOfItemsInPayload, errorMessage, res) {\r\n var response = null;\r\n if (!_self._appId) {\r\n response = _parseResponse(res);\r\n if (response && response.appId) {\r\n _self._appId = response.appId;\r\n }\r\n }\r\n if ((status < 200 || status >= 300) && status !== 0) {\r\n // Update End Point url if permanent redirect or moved permanently\r\n // Updates the end point url before retry\r\n if (status === 301 || status === 307 || status === 308) {\r\n if (!_checkAndUpdateEndPointUrl(responseUrl)) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n return;\r\n }\r\n }\r\n if (!_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_IS_RETRY_DISABLED /* @min:%2eisRetryDisabled */]() && _isRetriable(status)) {\r\n _resendPayload(payload);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" +\r\n \"Response code \" + status + \". Will retry to send \" + payload[_DYN_LENGTH /* @min:%2elength */] + \" items.\");\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n }\r\n }\r\n else if (_offlineListener && !_offlineListener[_DYN_IS_ONLINE /* @min:%2eisOnline */]()) { // offline\r\n // Note: Don't check for status == 0, since adblock gives this code\r\n if (!_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_IS_RETRY_DISABLED /* @min:%2eisRetryDisabled */]()) {\r\n var offlineBackOffMultiplier = 10; // arbritrary number\r\n _resendPayload(payload, offlineBackOffMultiplier);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". Offline - Response Code: \".concat(status, \". Offline status: \").concat(!_offlineListener.isOnline(), \". Will retry to send \").concat(payload.length, \" items.\"));\r\n }\r\n }\r\n else {\r\n // check if the xhr's responseURL or fetch's response.url is same as endpoint url\r\n // TODO after 10 redirects force send telemetry with 'redirect=false' as query parameter.\r\n _checkAndUpdateEndPointUrl(responseUrl);\r\n if (status === 206) {\r\n if (!response) {\r\n response = _parseResponse(res);\r\n }\r\n if (response && !_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_IS_RETRY_DISABLED /* @min:%2eisRetryDisabled */]()) {\r\n _self[_DYN__ON_PARTIAL_SUCCESS /* @min:%2e_onPartialSuccess */](payload, response);\r\n }\r\n else {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, errorMessage);\r\n }\r\n }\r\n else {\r\n _consecutiveErrors = 0;\r\n _self[_DYN__ON_SUCCESS /* @min:%2e_onSuccess */](payload, countOfItemsInPayload);\r\n }\r\n }\r\n }\r\n function _checkAndUpdateEndPointUrl(responseUrl) {\r\n // Maximum stamp specific redirects allowed(uncomment this when breeze is ready with not allowing redirects feature)\r\n if (_stamp_specific_redirects >= 10) {\r\n // _self._senderConfig.endpointUrl = () => Sender._getDefaultAppInsightsChannelConfig().endpointUrl()+\"/?redirect=false\";\r\n // _stamp_specific_redirects = 0;\r\n return false;\r\n }\r\n if (!isNullOrUndefined(responseUrl) && responseUrl !== \"\") {\r\n if (responseUrl !== _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]()) {\r\n _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] = function () { return responseUrl; };\r\n ++_stamp_specific_redirects;\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n function _doUnloadSend(payload, isAsync) {\r\n if (_syncUnloadSender) {\r\n // We are unloading so always call the sender with sync set to false\r\n _syncUnloadSender(payload, false);\r\n }\r\n else {\r\n // Fallback to the previous beacon Sender (which causes a CORB warning on chrome now)\r\n _beaconSender(payload, isAsync);\r\n }\r\n }\r\n function _doBeaconSend(payload) {\r\n var nav = getNavigator();\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n var url = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]();\r\n var batch = _self._buffer[_DYN_BATCH_PAYLOADS /* @min:%2ebatchPayloads */](payload);\r\n // Chrome only allows CORS-safelisted values for the sendBeacon data argument\r\n // see: https://bugs.chromium.org/p/chromium/issues/detail?id=720283\r\n var plainTextBatch = new Blob([batch], { type: \"text/plain;charset=UTF-8\" });\r\n // The sendBeacon method returns true if the user agent is able to successfully queue the data for transfer. Otherwise it returns false.\r\n var queued = nav.sendBeacon(url, plainTextBatch);\r\n if (queued) {\r\n buffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](payload);\r\n // no response from beaconSender, clear buffer\r\n _self._onSuccess(payload, payload[_DYN_LENGTH /* @min:%2elength */]);\r\n }\r\n return queued;\r\n }\r\n /**\r\n * Send Beacon API request\r\n * @param payload {string} - The data payload to be sent.\r\n * @param isAsync {boolean} - not used\r\n * Note: Beacon API does not support custom headers and we are not able to get\r\n * appId from the backend for the correct correlation.\r\n */\r\n function _beaconSender(payload, isAsync) {\r\n if (isArray(payload) && payload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n // The sendBeacon method returns true if the user agent is able to successfully queue the data for transfer. Otherwise it returns false.\r\n if (!_doBeaconSend(payload)) {\r\n // Failed to send entire payload so try and split data and try to send as much events as possible\r\n var droppedPayload = [];\r\n for (var lp = 0; lp < payload[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n var thePayload = payload[lp];\r\n if (!_doBeaconSend([thePayload])) {\r\n // Can't send anymore, so split the batch and drop the rest\r\n droppedPayload[_DYN_PUSH /* @min:%2epush */](thePayload);\r\n }\r\n }\r\n if (droppedPayload[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _fallbackSender && _fallbackSender(droppedPayload, true);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with normal sender.\");\r\n }\r\n }\r\n }\r\n }\r\n /**\r\n * Send XMLHttpRequest\r\n * @param payload {string} - The data payload to be sent.\r\n * @param isAsync {boolean} - Indicates if the request should be sent asynchronously\r\n */\r\n function _xhrSender(payload, isAsync) {\r\n var xhr = new XMLHttpRequest();\r\n var endPointUrl = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]();\r\n try {\r\n xhr[DisabledPropertyName] = true;\r\n }\r\n catch (e) {\r\n // If the environment has locked down the XMLHttpRequest (preventExtensions and/or freeze), this would\r\n // cause the request to fail and we no telemetry would be sent\r\n }\r\n xhr.open(\"POST\", endPointUrl, isAsync);\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](\"Content-type\", \"application/json\");\r\n // append Sdk-Context request header only in case of breeze endpoint\r\n if (isInternalApplicationInsightsEndpoint(endPointUrl)) {\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[6 /* eRequestHeaders.sdkContextHeader */], RequestHeaders[7 /* eRequestHeaders.sdkContextHeaderAppIdRequest */]);\r\n }\r\n arrForEach(objKeys(_headers), function (headerName) {\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](headerName, _headers[headerName]);\r\n });\r\n xhr.onreadystatechange = function () { return _self._xhrReadyStateChange(xhr, payload, payload[_DYN_LENGTH /* @min:%2elength */]); };\r\n xhr.onerror = function (event) { return _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, _formatErrorMessageXhr(xhr), event); };\r\n // compose an array of payloads\r\n var batch = _self._buffer[_DYN_BATCH_PAYLOADS /* @min:%2ebatchPayloads */](payload);\r\n xhr.send(batch);\r\n _self._buffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](payload);\r\n }\r\n function _fetchKeepAliveSender(payload, isAsync) {\r\n if (isArray(payload)) {\r\n var payloadSize = payload[_DYN_LENGTH /* @min:%2elength */];\r\n for (var lp = 0; lp < payload[_DYN_LENGTH /* @min:%2elength */]; lp++) {\r\n payloadSize += payload[lp][_DYN_LENGTH /* @min:%2elength */];\r\n }\r\n if ((_syncFetchPayload + payloadSize) <= FetchSyncRequestSizeLimitBytes) {\r\n _doFetchSender(payload, false);\r\n }\r\n else if (isBeaconsSupported()) {\r\n // Fallback to beacon sender as we at least get told which events can't be scheduled\r\n _beaconSender(payload, isAsync);\r\n }\r\n else {\r\n // Payload is going to be too big so just try and send via XHR\r\n _fallbackSender && _fallbackSender(payload, true);\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" + \"Failed to send telemetry with Beacon API, retried with xhrSender.\");\r\n }\r\n }\r\n }\r\n /**\r\n * Send fetch API request\r\n * @param payload {string} - The data payload to be sent.\r\n * @param isAsync {boolean} - not used\r\n */\r\n function _fetchSender(payload, isAsync) {\r\n _doFetchSender(payload, true);\r\n }\r\n /**\r\n * Send fetch API request\r\n * @param payload {string} - The data payload to be sent.\r\n * @param isAsync {boolean} - For fetch this identifies whether we are \"unloading\" (false) or a normal request\r\n */\r\n function _doFetchSender(payload, isAsync) {\r\n var _a;\r\n var endPointUrl = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]();\r\n var batch = _self._buffer[_DYN_BATCH_PAYLOADS /* @min:%2ebatchPayloads */](payload);\r\n var plainTextBatch = new Blob([batch], { type: \"application/json\" });\r\n var requestHeaders = new Headers();\r\n var batchLength = batch[_DYN_LENGTH /* @min:%2elength */];\r\n var ignoreResponse = false;\r\n var responseHandled = false;\r\n // append Sdk-Context request header only in case of breeze endpoint\r\n if (isInternalApplicationInsightsEndpoint(endPointUrl)) {\r\n requestHeaders.append(RequestHeaders[6 /* eRequestHeaders.sdkContextHeader */], RequestHeaders[7 /* eRequestHeaders.sdkContextHeaderAppIdRequest */]);\r\n }\r\n arrForEach(objKeys(_headers), function (headerName) {\r\n requestHeaders.append(headerName, _headers[headerName]);\r\n });\r\n var init = (_a = {\r\n method: \"POST\",\r\n headers: requestHeaders,\r\n body: plainTextBatch\r\n },\r\n _a[DisabledPropertyName] = true // Mark so we don't attempt to track this request\r\n ,\r\n _a);\r\n if (!isAsync) {\r\n init.keepalive = true;\r\n // As a sync request (during unload), it is unlikely that we will get a chance to process the response so\r\n // just like beacon send assume that the events have been accepted and processed\r\n ignoreResponse = true;\r\n _syncFetchPayload += batchLength;\r\n }\r\n var request = new Request(endPointUrl, init);\r\n try {\r\n // Also try and tag the request (just in case the value in init is not copied over)\r\n request[DisabledPropertyName] = true;\r\n }\r\n catch (e) {\r\n // If the environment has locked down the XMLHttpRequest (preventExtensions and/or freeze), this would\r\n // cause the request to fail and we no telemetry would be sent\r\n }\r\n _self._buffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](payload);\r\n try {\r\n fetch(request).then(function (response) {\r\n if (!isAsync) {\r\n _syncFetchPayload -= batchLength;\r\n batchLength = 0;\r\n }\r\n if (!responseHandled) {\r\n responseHandled = true;\r\n /**\r\n * The Promise returned from fetch() won’t reject on HTTP error status even if the response is an HTTP 404 or 500.\r\n * Instead, it will resolve normally (with ok status set to false), and it will only reject on network failure\r\n * or if anything prevented the request from completing.\r\n */\r\n if (!response.ok) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, response.statusText);\r\n }\r\n else {\r\n response.text().then(function (text) {\r\n _checkResponsStatus(response.status, payload, response.url, payload[_DYN_LENGTH /* @min:%2elength */], response.statusText, text);\r\n });\r\n }\r\n }\r\n })[\"catch\"](function (error) {\r\n if (!isAsync) {\r\n _syncFetchPayload -= batchLength;\r\n batchLength = 0;\r\n }\r\n if (!responseHandled) {\r\n responseHandled = true;\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, error.message);\r\n }\r\n });\r\n }\r\n catch (e) {\r\n if (!responseHandled) {\r\n _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, dumpObj(e));\r\n }\r\n }\r\n if (ignoreResponse && !responseHandled) {\r\n // Assume success during unload processing as we most likely won't get the response\r\n responseHandled = true;\r\n _self._onSuccess(payload, payload[_DYN_LENGTH /* @min:%2elength */]);\r\n }\r\n }\r\n /**\r\n * Parses the response from the backend.\r\n * @param response - XMLHttpRequest or XDomainRequest response\r\n */\r\n function _parseResponse(response) {\r\n try {\r\n if (response && response !== \"\") {\r\n var result = getJSON().parse(response);\r\n if (result && result.itemsReceived && result.itemsReceived >= result[_DYN_ITEMS_ACCEPTED /* @min:%2eitemsAccepted */] &&\r\n result.itemsReceived - result.itemsAccepted === result.errors[_DYN_LENGTH /* @min:%2elength */]) {\r\n return result;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 43 /* _eInternalMessageId.InvalidBackendResponse */, \"Cannot parse the response. \" + getExceptionName(e), {\r\n response: response\r\n });\r\n }\r\n return null;\r\n }\r\n /**\r\n * Resend payload. Adds payload back to the send buffer and setup a send timer (with exponential backoff).\r\n * @param payload\r\n */\r\n function _resendPayload(payload, linearFactor) {\r\n if (linearFactor === void 0) { linearFactor = 1; }\r\n if (!payload || payload[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n return;\r\n }\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n buffer[_DYN_CLEAR_SENT /* @min:%2eclearSent */](payload);\r\n _consecutiveErrors++;\r\n for (var _i = 0, payload_1 = payload; _i < payload_1.length; _i++) {\r\n var item = payload_1[_i];\r\n buffer[_DYN_ENQUEUE /* @min:%2eenqueue */](item);\r\n }\r\n // setup timer\r\n _setRetryTime(linearFactor);\r\n _setupTimer();\r\n }\r\n /**\r\n * Calculates the time to wait before retrying in case of an error based on\r\n * http://en.wikipedia.org/wiki/Exponential_backoff\r\n */\r\n function _setRetryTime(linearFactor) {\r\n var SlotDelayInSeconds = 10;\r\n var delayInSeconds;\r\n if (_consecutiveErrors <= 1) {\r\n delayInSeconds = SlotDelayInSeconds;\r\n }\r\n else {\r\n var backOffSlot = (Math.pow(2, _consecutiveErrors) - 1) / 2;\r\n // tslint:disable-next-line:insecure-random\r\n var backOffDelay = Math.floor(Math.random() * backOffSlot * SlotDelayInSeconds) + 1;\r\n backOffDelay = linearFactor * backOffDelay;\r\n delayInSeconds = Math.max(Math.min(backOffDelay, 3600), SlotDelayInSeconds);\r\n }\r\n // TODO: Log the backoff time like the C# version does.\r\n var retryAfterTimeSpan = dateNow() + (delayInSeconds * 1000);\r\n // TODO: Log the retry at time like the C# version does.\r\n _retryAt = retryAfterTimeSpan;\r\n }\r\n /**\r\n * Sets up the timer which triggers actually sending the data.\r\n */\r\n function _setupTimer() {\r\n if (!_timeoutHandle && !_paused) {\r\n var retryInterval = _retryAt ? Math.max(0, _retryAt - dateNow()) : 0;\r\n var timerValue = Math.max(_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_MAX_BATCH_INTERVAL /* @min:%2emaxBatchInterval */](), retryInterval);\r\n _timeoutHandle = setTimeout(function () {\r\n _timeoutHandle = null;\r\n _self[_DYN_TRIGGER_SEND /* @min:%2etriggerSend */](true, null, 1 /* SendRequestReason.NormalSchedule */);\r\n }, timerValue);\r\n }\r\n }\r\n function _clearScheduledTimer() {\r\n clearTimeout(_timeoutHandle);\r\n _timeoutHandle = null;\r\n _retryAt = null;\r\n }\r\n /**\r\n * Checks if the SDK should resend the payload after receiving this status code from the backend.\r\n * @param statusCode\r\n */\r\n function _isRetriable(statusCode) {\r\n return statusCode === 401 // Unauthorized\r\n || statusCode === 403 // Forbidden\r\n || statusCode === 408 // Timeout\r\n || statusCode === 429 // Too many requests.\r\n || statusCode === 500 // Internal server error.\r\n || statusCode === 502 // Bad Gateway.\r\n || statusCode === 503 // Service unavailable.\r\n || statusCode === 504; // Gateway timeout.\r\n }\r\n function _formatErrorMessageXhr(xhr, message) {\r\n if (xhr) {\r\n return \"XMLHttpRequest,Status:\" + xhr.status + \",Response:\" + _getResponseText(xhr) || xhr.response || \"\";\r\n }\r\n return message;\r\n }\r\n /**\r\n * Send XDomainRequest\r\n * @param payload {string} - The data payload to be sent.\r\n * @param isAsync {boolean} - Indicates if the request should be sent asynchronously\r\n *\r\n * Note: XDomainRequest does not support sync requests. This 'isAsync' parameter is added\r\n * to maintain consistency with the xhrSender's contract\r\n * Note: XDomainRequest does not support custom headers and we are not able to get\r\n * appId from the backend for the correct correlation.\r\n */\r\n function _xdrSender(payload, isAsync) {\r\n var buffer = _self[_DYN__BUFFER /* @min:%2e_buffer */];\r\n var _window = getWindow();\r\n var xdr = new XDomainRequest();\r\n xdr.onload = function () { return _self._xdrOnLoad(xdr, payload); };\r\n xdr.onerror = function (event) { return _self[_DYN__ON_ERROR /* @min:%2e_onError */](payload, _formatErrorMessageXdr(xdr), event); };\r\n // XDomainRequest requires the same protocol as the hosting page.\r\n // If the protocol doesn't match, we can't send the telemetry :(.\r\n var hostingProtocol = _window && _window.location && _window.location.protocol || \"\";\r\n if (_self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]().lastIndexOf(hostingProtocol, 0) !== 0) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 2 /* eLoggingSeverity.WARNING */, 40 /* _eInternalMessageId.TransmissionFailed */, \". \" +\r\n \"Cannot send XDomain request. The endpoint URL protocol doesn't match the hosting page protocol.\");\r\n buffer[_DYN_CLEAR /* @min:%2eclear */]();\r\n return;\r\n }\r\n var endpointUrl = _self[_DYN__SENDER_CONFIG /* @min:%2e_senderConfig */][_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]().replace(/^(https?:)/, \"\");\r\n xdr.open(\"POST\", endpointUrl);\r\n // compose an array of payloads\r\n var batch = buffer[_DYN_BATCH_PAYLOADS /* @min:%2ebatchPayloads */](payload);\r\n xdr.send(batch);\r\n buffer[_DYN_MARK_AS_SENT /* @min:%2emarkAsSent */](payload);\r\n }\r\n function _formatErrorMessageXdr(xdr, message) {\r\n if (xdr) {\r\n return \"XDomainRequest,Response:\" + _getResponseText(xdr) || \"\";\r\n }\r\n return message;\r\n }\r\n // Using function lookups for backward compatibility as the getNotifyMgr() did not exist until after v2.5.6\r\n function _getNotifyMgr() {\r\n var func = \"getNotifyMgr\";\r\n if (_self.core[func]) {\r\n return _self.core[func]();\r\n }\r\n // using _self.core['_notificationManager'] for backward compatibility\r\n return _self.core[\"_notificationManager\"];\r\n }\r\n function _notifySendRequest(sendRequest, isAsync) {\r\n var manager = _getNotifyMgr();\r\n if (manager && manager[_DYN_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */]) {\r\n try {\r\n manager[_DYN_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */](sendRequest, isAsync);\r\n }\r\n catch (e) {\r\n _throwInternal(_self[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 74 /* _eInternalMessageId.NotificationException */, \"send request notification failed: \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n }\r\n /**\r\n * Validate UUID Format\r\n * Specs taken from https://tools.ietf.org/html/rfc4122 and breeze repo\r\n */\r\n function _validateInstrumentationKey(config) {\r\n var disableIKeyValidationFlag = isNullOrUndefined(config[_DYN_DISABLE_INSTRUMENTAT7 /* @min:%2edisableInstrumentationKeyValidation */]) ? false : config[_DYN_DISABLE_INSTRUMENTAT7 /* @min:%2edisableInstrumentationKeyValidation */];\r\n if (disableIKeyValidationFlag) {\r\n return true;\r\n }\r\n var UUID_Regex = \"^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$\";\r\n var regexp = new RegExp(UUID_Regex);\r\n return regexp.test(config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */]);\r\n }\r\n function _initDefaults() {\r\n _self[_DYN__SENDER /* @min:%2e_sender */] = null;\r\n _self[_DYN__BUFFER /* @min:%2e_buffer */] = null;\r\n _self._appId = null;\r\n _self._sample = null;\r\n _headers = {};\r\n _offlineListener = null;\r\n _consecutiveErrors = 0;\r\n _retryAt = null;\r\n _lastSend = null;\r\n _paused = false;\r\n _timeoutHandle = null;\r\n _serializer = null;\r\n _stamp_specific_redirects = 0;\r\n _syncFetchPayload = 0;\r\n _fallbackSender = null;\r\n _syncUnloadSender = null;\r\n _evtNamespace = null;\r\n }\r\n });\r\n return _this;\r\n }\r\n Sender.constructEnvelope = function (orig, iKey, logger, convertUndefined) {\r\n var envelope;\r\n if (iKey !== orig.iKey && !isNullOrUndefined(iKey)) {\r\n envelope = __assign(__assign({}, orig), { iKey: iKey });\r\n }\r\n else {\r\n envelope = orig;\r\n }\r\n var creator = EnvelopeTypeCreator[envelope.baseType] || EventEnvelopeCreator;\r\n return creator(logger, envelope, convertUndefined);\r\n };\r\n// Removed Stub for Sender.prototype.pause.\r\n// Removed Stub for Sender.prototype.resume.\r\n// Removed Stub for Sender.prototype.flush.\r\n// Removed Stub for Sender.prototype.onunloadFlush.\r\n// Removed Stub for Sender.prototype.initialize.\r\n// Removed Stub for Sender.prototype.processTelemetry.\r\n// Removed Stub for Sender.prototype._xhrReadyStateChange.\r\n// Removed Stub for Sender.prototype.triggerSend.\r\n// Removed Stub for Sender.prototype._onError.\r\n// Removed Stub for Sender.prototype._onPartialSuccess.\r\n// Removed Stub for Sender.prototype._onSuccess.\r\n// Removed Stub for Sender.prototype._xdrOnLoad.\r\n// Removed Stub for Sender.prototype.addHeader.\r\n return Sender;\r\n}(BaseTelemetryPlugin));\r\nexport { Sender };\r\n//# sourceMappingURL=Sender.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { _throwInternal, getJSON, isArray, isFunction, isObject, objForEachKey } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_LENGTH, _DYN_PUSH, _DYN_STRINGIFY, _DYN_TO_STRING } from \"./__DynamicConstants\";\r\nvar Serializer = /** @class */ (function () {\r\n function Serializer(logger) {\r\n dynamicProto(Serializer, this, function (_self) {\r\n /**\r\n * Serializes the current object to a JSON string.\r\n */\r\n _self.serialize = function (input) {\r\n var output = _serializeObject(input, \"root\");\r\n try {\r\n return getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](output);\r\n }\r\n catch (e) {\r\n // if serialization fails return an empty string\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, (e && isFunction(e[_DYN_TO_STRING /* @min:%2etoString */])) ? e[_DYN_TO_STRING /* @min:%2etoString */]() : \"Error serializing object\", null, true);\r\n }\r\n };\r\n function _serializeObject(source, name) {\r\n var circularReferenceCheck = \"__aiCircularRefCheck\";\r\n var output = {};\r\n if (!source) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, \"cannot serialize object because it is null or undefined\", { name: name }, true);\r\n return output;\r\n }\r\n if (source[circularReferenceCheck]) {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 50 /* _eInternalMessageId.CircularReferenceDetected */, \"Circular reference detected while serializing object\", { name: name }, true);\r\n return output;\r\n }\r\n if (!source.aiDataContract) {\r\n // special case for measurements/properties/tags\r\n if (name === \"measurements\") {\r\n output = _serializeStringMap(source, \"number\", name);\r\n }\r\n else if (name === \"properties\") {\r\n output = _serializeStringMap(source, \"string\", name);\r\n }\r\n else if (name === \"tags\") {\r\n output = _serializeStringMap(source, \"string\", name);\r\n }\r\n else if (isArray(source)) {\r\n output = _serializeArray(source, name);\r\n }\r\n else {\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 49 /* _eInternalMessageId.CannotSerializeObjectNonSerializable */, \"Attempting to serialize an object which does not implement ISerializable\", { name: name }, true);\r\n try {\r\n // verify that the object can be stringified\r\n getJSON()[_DYN_STRINGIFY /* @min:%2estringify */](source);\r\n output = source;\r\n }\r\n catch (e) {\r\n // if serialization fails return an empty string\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 48 /* _eInternalMessageId.CannotSerializeObject */, (e && isFunction(e[_DYN_TO_STRING /* @min:%2etoString */])) ? e[_DYN_TO_STRING /* @min:%2etoString */]() : \"Error serializing object\", null, true);\r\n }\r\n }\r\n return output;\r\n }\r\n source[circularReferenceCheck] = true;\r\n objForEachKey(source.aiDataContract, function (field, contract) {\r\n var isRequired = (isFunction(contract)) ? (contract() & 1 /* FieldType.Required */) : (contract & 1 /* FieldType.Required */);\r\n var isHidden = (isFunction(contract)) ? (contract() & 4 /* FieldType.Hidden */) : (contract & 4 /* FieldType.Hidden */);\r\n var isArray = contract & 2 /* FieldType.Array */;\r\n var isPresent = source[field] !== undefined;\r\n var isObj = isObject(source[field]) && source[field] !== null;\r\n if (isRequired && !isPresent && !isArray) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 24 /* _eInternalMessageId.MissingRequiredFieldSpecification */, \"Missing required field specification. The field is required but not present on source\", { field: field, name: name });\r\n // If not in debug mode, continue and hope the error is permissible\r\n }\r\n else if (!isHidden) { // Don't serialize hidden fields\r\n var value = void 0;\r\n if (isObj) {\r\n if (isArray) {\r\n // special case; recurse on each object in the source array\r\n value = _serializeArray(source[field], field);\r\n }\r\n else {\r\n // recurse on the source object in this field\r\n value = _serializeObject(source[field], field);\r\n }\r\n }\r\n else {\r\n // assign the source field to the output even if undefined or required\r\n value = source[field];\r\n }\r\n // only emit this field if the value is defined\r\n if (value !== undefined) {\r\n output[field] = value;\r\n }\r\n }\r\n });\r\n delete source[circularReferenceCheck];\r\n return output;\r\n }\r\n function _serializeArray(sources, name) {\r\n var output;\r\n if (!!sources) {\r\n if (!isArray(sources)) {\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, 54 /* _eInternalMessageId.ItemNotInArray */, \"This field was specified as an array in the contract but the item is not an array.\\r\\n\", { name: name }, true);\r\n }\r\n else {\r\n output = [];\r\n for (var i = 0; i < sources[_DYN_LENGTH /* @min:%2elength */]; i++) {\r\n var source = sources[i];\r\n var item = _serializeObject(source, name + \"[\" + i + \"]\");\r\n output[_DYN_PUSH /* @min:%2epush */](item);\r\n }\r\n }\r\n }\r\n return output;\r\n }\r\n function _serializeStringMap(map, expectedType, name) {\r\n var output;\r\n if (map) {\r\n output = {};\r\n objForEachKey(map, function (field, value) {\r\n if (expectedType === \"string\") {\r\n if (value === undefined) {\r\n output[field] = \"undefined\";\r\n }\r\n else if (value === null) {\r\n output[field] = \"null\";\r\n }\r\n else if (!value[_DYN_TO_STRING /* @min:%2etoString */]) {\r\n output[field] = \"invalid field: toString() is not defined.\";\r\n }\r\n else {\r\n output[field] = value[_DYN_TO_STRING /* @min:%2etoString */]();\r\n }\r\n }\r\n else if (expectedType === \"number\") {\r\n if (value === undefined) {\r\n output[field] = \"undefined\";\r\n }\r\n else if (value === null) {\r\n output[field] = \"null\";\r\n }\r\n else {\r\n var num = parseFloat(value);\r\n if (isNaN(num)) {\r\n output[field] = \"NaN\";\r\n }\r\n else {\r\n output[field] = num;\r\n }\r\n }\r\n }\r\n else {\r\n output[field] = \"invalid field: \" + name + \" is of unknown type.\";\r\n _throwInternal(logger, 1 /* eLoggingSeverity.CRITICAL */, output[field], null, true);\r\n }\r\n });\r\n }\r\n return output;\r\n }\r\n });\r\n }\r\n// Removed Stub for Serializer.prototype.serialize.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n Serializer.__ieDyn=1;\n\n return Serializer;\r\n}());\r\nexport { Serializer };\r\n//# sourceMappingURL=Serializer.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _DYN_LENGTH } from \"../../__DynamicConstants\";\r\n// (Magic number) DJB algorithm can't work on shorter strings (results in poor distribution\r\nvar MIN_INPUT_LENGTH = 8;\r\nvar HashCodeScoreGenerator = /** @class */ (function () {\r\n function HashCodeScoreGenerator() {\r\n }\r\n HashCodeScoreGenerator.prototype.getHashCodeScore = function (key) {\r\n var score = this.getHashCode(key) / HashCodeScoreGenerator.INT_MAX_VALUE;\r\n return score * 100;\r\n };\r\n HashCodeScoreGenerator.prototype.getHashCode = function (input) {\r\n if (input === \"\") {\r\n return 0;\r\n }\r\n while (input[_DYN_LENGTH /* @min:%2elength */] < MIN_INPUT_LENGTH) {\r\n input = input.concat(input);\r\n }\r\n // 5381 is a magic number: http://stackoverflow.com/questions/10696223/reason-for-5381-number-in-djb-hash-function\r\n var hash = 5381;\r\n for (var i = 0; i < input[_DYN_LENGTH /* @min:%2elength */]; ++i) {\r\n hash = ((hash << 5) + hash) + input.charCodeAt(i);\r\n // 'hash' is of number type which means 53 bit integer (http://www.ecma-international.org/ecma-262/6.0/#sec-ecmascript-language-types-number-type)\r\n // 'hash & hash' will keep it 32 bit integer - just to make it clearer what the result is.\r\n hash = hash & hash;\r\n }\r\n return Math.abs(hash);\r\n };\r\n // We're using 32 bit math, hence max value is (2^31 - 1)\r\n HashCodeScoreGenerator.INT_MAX_VALUE = 2147483647;\r\n return HashCodeScoreGenerator;\r\n}());\r\nexport { HashCodeScoreGenerator };\r\n//# sourceMappingURL=HashCodeScoreGenerator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { ContextTagKeys } from \"@microsoft/applicationinsights-common\";\r\nimport { _DYN_GET_HASH_CODE_SCORE, _DYN_GET_SAMPLING_SCORE, _DYN_TAGS, _DYN_TRACE_ID } from \"../../__DynamicConstants\";\r\nimport { HashCodeScoreGenerator } from \"./HashCodeScoreGenerator\";\r\nvar SamplingScoreGenerator = /** @class */ (function () {\r\n function SamplingScoreGenerator() {\r\n var _self = this;\r\n var hashCodeGenerator = new HashCodeScoreGenerator();\r\n var keys = new ContextTagKeys();\r\n _self[_DYN_GET_SAMPLING_SCORE /* @min:%2egetSamplingScore */] = function (item) {\r\n var score = 0;\r\n if (item[_DYN_TAGS /* @min:%2etags */] && item[_DYN_TAGS /* @min:%2etags */][keys.userId]) { // search in tags first, then ext\r\n score = hashCodeGenerator.getHashCodeScore(item[_DYN_TAGS /* @min:%2etags */][keys.userId]);\r\n }\r\n else if (item.ext && item.ext.user && item.ext.user.id) {\r\n score = hashCodeGenerator[_DYN_GET_HASH_CODE_SCORE /* @min:%2egetHashCodeScore */](item.ext.user.id);\r\n }\r\n else if (item[_DYN_TAGS /* @min:%2etags */] && item[_DYN_TAGS /* @min:%2etags */][keys.operationId]) { // search in tags first, then ext\r\n score = hashCodeGenerator.getHashCodeScore(item[_DYN_TAGS /* @min:%2etags */][keys.operationId]);\r\n }\r\n else if (item.ext && item.ext.telemetryTrace && item.ext.telemetryTrace[_DYN_TRACE_ID /* @min:%2etraceID */]) {\r\n score = hashCodeGenerator.getHashCodeScore(item.ext.telemetryTrace[_DYN_TRACE_ID /* @min:%2etraceID */]);\r\n }\r\n else {\r\n // tslint:disable-next-line:insecure-random\r\n score = (Math.random() * 100);\r\n }\r\n return score;\r\n };\r\n }\r\n return SamplingScoreGenerator;\r\n}());\r\nexport { SamplingScoreGenerator };\r\n//# sourceMappingURL=SamplingScoreGenerator.js.map","/*\n * Application Insights JavaScript SDK - Channel, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { Metric } from \"@microsoft/applicationinsights-common\";\r\nimport { safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_DATA_TYPE, _DYN_GET_SAMPLING_SCORE, _DYN_SAMPLE_RATE } from \"../__DynamicConstants\";\r\nimport { SamplingScoreGenerator } from \"./SamplingScoreGenerators/SamplingScoreGenerator\";\r\nvar Sample = /** @class */ (function () {\r\n function Sample(sampleRate, logger) {\r\n // We're using 32 bit math, hence max value is (2^31 - 1)\r\n this.INT_MAX_VALUE = 2147483647;\r\n var _logger = logger || safeGetLogger(null);\r\n if (sampleRate > 100 || sampleRate < 0) {\r\n _logger.throwInternal(2 /* eLoggingSeverity.WARNING */, 58 /* _eInternalMessageId.SampleRateOutOfRange */, \"Sampling rate is out of range (0..100). Sampling will be disabled, you may be sending too much data which may affect your AI service level.\", { samplingRate: sampleRate }, true);\r\n sampleRate = 100;\r\n }\r\n this[_DYN_SAMPLE_RATE /* @min:%2esampleRate */] = sampleRate;\r\n this.samplingScoreGenerator = new SamplingScoreGenerator();\r\n }\r\n /**\r\n * Determines if an envelope is sampled in (i.e. will be sent) or not (i.e. will be dropped).\r\n */\r\n Sample.prototype.isSampledIn = function (envelope) {\r\n var samplingPercentage = this[_DYN_SAMPLE_RATE /* @min:%2esampleRate */]; // 0 - 100\r\n var isSampledIn = false;\r\n if (samplingPercentage === null || samplingPercentage === undefined || samplingPercentage >= 100) {\r\n return true;\r\n }\r\n else if (envelope.baseType === Metric[_DYN_DATA_TYPE /* @min:%2edataType */]) {\r\n // exclude MetricData telemetry from sampling\r\n return true;\r\n }\r\n isSampledIn = this.samplingScoreGenerator[_DYN_GET_SAMPLING_SCORE /* @min:%2egetSamplingScore */](envelope) < samplingPercentage;\r\n return isSampledIn;\r\n };\r\n return Sample;\r\n}());\r\nexport { Sample };\r\n//# sourceMappingURL=Sample.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { arrReduce, objKeys } from \"@microsoft/applicationinsights-core-js\";\r\nimport { DEFAULT_BREEZE_ENDPOINT } from \"./Constants\";\r\nimport { _DYN_INGESTIONENDPOINT, _DYN_LENGTH, _DYN_SPLIT, _DYN_TO_LOWER_CASE } from \"./__DynamicConstants\";\r\nvar _FIELDS_SEPARATOR = \";\";\r\nvar _FIELD_KEY_VALUE_SEPARATOR = \"=\";\r\nexport function parseConnectionString(connectionString) {\r\n if (!connectionString) {\r\n return {};\r\n }\r\n var kvPairs = connectionString[_DYN_SPLIT /* @min:%2esplit */](_FIELDS_SEPARATOR);\r\n var result = arrReduce(kvPairs, function (fields, kv) {\r\n var kvParts = kv[_DYN_SPLIT /* @min:%2esplit */](_FIELD_KEY_VALUE_SEPARATOR);\r\n if (kvParts[_DYN_LENGTH /* @min:%2elength */] === 2) { // only save fields with valid formats\r\n var key = kvParts[0][_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n var value = kvParts[1];\r\n fields[key] = value;\r\n }\r\n return fields;\r\n }, {});\r\n if (objKeys(result)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n // this is a valid connection string, so parse the results\r\n if (result.endpointsuffix) {\r\n // use endpoint suffix where overrides are not provided\r\n var locationPrefix = result.location ? result.location + \".\" : \"\";\r\n result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] = result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] || (\"https://\" + locationPrefix + \"dc.\" + result.endpointsuffix);\r\n }\r\n // apply the default endpoints\r\n result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] = result[_DYN_INGESTIONENDPOINT /* @min:%2eingestionendpoint */] || DEFAULT_BREEZE_ENDPOINT;\r\n }\r\n return result;\r\n}\r\nexport var ConnectionStringParser = {\r\n parse: parseConnectionString\r\n};\r\n//# sourceMappingURL=ConnectionStringParser.js.map","/*\n * Application Insights JavaScript SDK - Common, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { isNullOrUndefined } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_EXTENSION_CONFIG } from \"../__DynamicConstants\";\r\nvar ConfigurationManager = /** @class */ (function () {\r\n function ConfigurationManager() {\r\n }\r\n ConfigurationManager.getConfig = function (config, field, identifier, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = false; }\r\n var configValue;\r\n if (identifier && config[_DYN_EXTENSION_CONFIG /* @min:%2eextensionConfig */] && config[_DYN_EXTENSION_CONFIG /* @min:%2eextensionConfig */][identifier] && !isNullOrUndefined(config[_DYN_EXTENSION_CONFIG /* @min:%2eextensionConfig */][identifier][field])) {\r\n configValue = config[_DYN_EXTENSION_CONFIG /* @min:%2eextensionConfig */][identifier][field];\r\n }\r\n else {\r\n configValue = config[field];\r\n }\r\n return !isNullOrUndefined(configValue) ? configValue : defaultValue;\r\n };\r\n return ConfigurationManager;\r\n}());\r\nexport { ConfigurationManager };\r\n//# sourceMappingURL=IConfig.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n// \r\nimport { _DYN_CONFIG, _DYN_CREATE_NEW, _DYN_FLUSH, _DYN_IDENTIFIER, _DYN_LENGTH, _DYN_ON_COMPLETE, _DYN_PROCESS_NEXT, _DYN_PUSH } from \"../__DynamicConstants\";\r\nimport { arrForEach, isArray, objFreeze, throwError } from \"./HelperFuncs\";\r\nimport { STR_PRIORITY } from \"./InternalConstants\";\r\nimport { createProcessTelemetryContext, createTelemetryProxyChain } from \"./ProcessTelemetryContext\";\r\nimport { initializePlugins } from \"./TelemetryHelpers\";\r\nexport var ChannelControllerPriority = 500;\r\nvar ChannelValidationMessage = \"Channel has invalid priority - \";\r\nfunction _addChannelQueue(channelQueue, queue, core) {\r\n if (queue && isArray(queue) && queue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n queue = queue.sort(function (a, b) {\r\n return a[STR_PRIORITY /* @min:%2epriority */] - b[STR_PRIORITY /* @min:%2epriority */];\r\n });\r\n arrForEach(queue, function (queueItem) {\r\n if (queueItem[STR_PRIORITY /* @min:%2epriority */] < ChannelControllerPriority) {\r\n throwError(ChannelValidationMessage + queueItem[_DYN_IDENTIFIER /* @min:%2eidentifier */]);\r\n }\r\n });\r\n channelQueue[_DYN_PUSH /* @min:%2epush */]({\r\n queue: objFreeze(queue),\r\n chain: createTelemetryProxyChain(queue, core[_DYN_CONFIG /* @min:%2econfig */], core)\r\n });\r\n }\r\n}\r\nexport function createChannelControllerPlugin(channelQueue, core) {\r\n function _getTelCtx() {\r\n return createProcessTelemetryContext(null, core[_DYN_CONFIG /* @min:%2econfig */], core, null);\r\n }\r\n function _processChannelQueue(theChannels, itemCtx, processFn, onComplete) {\r\n var waiting = theChannels ? (theChannels[_DYN_LENGTH /* @min:%2elength */] + 1) : 1;\r\n function _runChainOnComplete() {\r\n waiting--;\r\n if (waiting === 0) {\r\n onComplete && onComplete();\r\n onComplete = null;\r\n }\r\n }\r\n if (waiting > 0) {\r\n arrForEach(theChannels, function (channels) {\r\n // pass on to first item in queue\r\n if (channels && channels.queue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var channelChain = channels.chain;\r\n var chainCtx = itemCtx[_DYN_CREATE_NEW /* @min:%2ecreateNew */](channelChain);\r\n chainCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](_runChainOnComplete);\r\n // Cause this chain to start processing\r\n processFn(chainCtx);\r\n }\r\n else {\r\n waiting--;\r\n }\r\n });\r\n }\r\n _runChainOnComplete();\r\n }\r\n function _doUpdate(updateCtx, updateState) {\r\n var theUpdateState = updateState || {\r\n reason: 0 /* TelemetryUpdateReason.Unknown */\r\n };\r\n _processChannelQueue(channelQueue, updateCtx, function (chainCtx) {\r\n chainCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](theUpdateState);\r\n }, function () {\r\n updateCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](theUpdateState);\r\n });\r\n return true;\r\n }\r\n function _doTeardown(unloadCtx, unloadState) {\r\n var theUnloadState = unloadState || {\r\n reason: 0 /* TelemetryUnloadReason.ManualTeardown */,\r\n isAsync: false\r\n };\r\n _processChannelQueue(channelQueue, unloadCtx, function (chainCtx) {\r\n chainCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](theUnloadState);\r\n }, function () {\r\n unloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](theUnloadState);\r\n isInitialized = false;\r\n });\r\n return true;\r\n }\r\n function _getChannel(pluginIdentifier) {\r\n var thePlugin = null;\r\n if (channelQueue && channelQueue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(channelQueue, function (channels) {\r\n // pass on to first item in queue\r\n if (channels && channels.queue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n arrForEach(channels.queue, function (ext) {\r\n if (ext[_DYN_IDENTIFIER /* @min:%2eidentifier */] === pluginIdentifier) {\r\n thePlugin = ext;\r\n // Cause arrForEach to stop iterating\r\n return -1;\r\n }\r\n });\r\n if (thePlugin) {\r\n // Cause arrForEach to stop iterating\r\n return -1;\r\n }\r\n }\r\n });\r\n }\r\n return thePlugin;\r\n }\r\n var isInitialized = false;\r\n var channelController = {\r\n identifier: \"ChannelControllerPlugin\",\r\n priority: ChannelControllerPriority,\r\n initialize: function (config, core, extensions, pluginChain) {\r\n isInitialized = true;\r\n arrForEach(channelQueue, function (channels) {\r\n if (channels && channels.queue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n initializePlugins(createProcessTelemetryContext(channels.chain, config, core), extensions);\r\n }\r\n });\r\n },\r\n isInitialized: function () {\r\n return isInitialized;\r\n },\r\n processTelemetry: function (item, itemCtx) {\r\n _processChannelQueue(channelQueue, itemCtx || _getTelCtx(), function (chainCtx) {\r\n chainCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](item);\r\n }, function () {\r\n itemCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](item);\r\n });\r\n },\r\n update: _doUpdate,\r\n pause: function () {\r\n _processChannelQueue(channelQueue, _getTelCtx(), function (chainCtx) {\r\n chainCtx.iterate(function (plugin) {\r\n plugin.pause && plugin.pause();\r\n });\r\n }, null);\r\n },\r\n resume: function () {\r\n _processChannelQueue(channelQueue, _getTelCtx(), function (chainCtx) {\r\n chainCtx.iterate(function (plugin) {\r\n plugin.resume && plugin.resume();\r\n });\r\n }, null);\r\n },\r\n teardown: _doTeardown,\r\n getChannel: _getChannel,\r\n flush: function (isAsync, callBack, sendReason, cbTimeout) {\r\n // Setting waiting to one so that we don't call the callBack until we finish iterating\r\n var waiting = 1;\r\n var doneIterating = false;\r\n var cbTimer = null;\r\n cbTimeout = cbTimeout || 5000;\r\n function doCallback() {\r\n waiting--;\r\n if (doneIterating && waiting === 0) {\r\n if (cbTimer) {\r\n clearTimeout(cbTimer);\r\n cbTimer = null;\r\n }\r\n callBack && callBack(doneIterating);\r\n callBack = null;\r\n }\r\n }\r\n _processChannelQueue(channelQueue, _getTelCtx(), function (chainCtx) {\r\n chainCtx.iterate(function (plugin) {\r\n if (plugin[_DYN_FLUSH /* @min:%2eflush */]) {\r\n waiting++;\r\n var handled_1 = false;\r\n // Not all channels will call this callback for every scenario\r\n if (!plugin[_DYN_FLUSH /* @min:%2eflush */](isAsync, function () {\r\n handled_1 = true;\r\n doCallback();\r\n }, sendReason)) {\r\n if (!handled_1) {\r\n // If any channel doesn't return true and it didn't call the callback, then we should assume that the callback\r\n // will never be called, so use a timeout to allow the channel(s) some time to \"finish\" before triggering any\r\n // followup function (such as unloading)\r\n if (isAsync && cbTimer == null) {\r\n cbTimer = setTimeout(function () {\r\n cbTimer = null;\r\n doCallback();\r\n }, cbTimeout);\r\n }\r\n else {\r\n doCallback();\r\n }\r\n }\r\n }\r\n }\r\n });\r\n }, function () {\r\n doneIterating = true;\r\n doCallback();\r\n });\r\n return true;\r\n },\r\n _setQueue: function (queue) {\r\n channelQueue = queue;\r\n }\r\n };\r\n return channelController;\r\n}\r\nexport function createChannelQueues(channels, extensions, core) {\r\n var channelQueue = [];\r\n if (channels) {\r\n // Add and sort the configuration channel queues\r\n arrForEach(channels, function (queue) { return _addChannelQueue(channelQueue, queue, core); });\r\n }\r\n if (extensions) {\r\n // Create a new channel queue for any extensions with a priority > the ChannelControllerPriority\r\n var extensionQueue_1 = [];\r\n arrForEach(extensions, function (plugin) {\r\n if (plugin[STR_PRIORITY /* @min:%2epriority */] > ChannelControllerPriority) {\r\n extensionQueue_1[_DYN_PUSH /* @min:%2epush */](plugin);\r\n }\r\n });\r\n _addChannelQueue(channelQueue, extensionQueue_1, core);\r\n }\r\n return channelQueue;\r\n}\r\n//# sourceMappingURL=ChannelController.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n// \r\n// \r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { _DYN_APPLY, _DYN_DIAG_LOG, _DYN_LENGTH, _DYN_PROCESS_NEXT, _DYN_PUSH, _DYN_SPLICE, _DYN__DO_TEARDOWN } from \"../__DynamicConstants\";\r\nimport { BaseTelemetryPlugin } from \"./BaseTelemetryPlugin\";\r\nimport { _throwInternal } from \"./DiagnosticLogger\";\r\nimport { dumpObj } from \"./EnvUtils\";\r\nimport { arrForEach, getExceptionName } from \"./HelperFuncs\";\r\nimport { STR_PROCESS_TELEMETRY } from \"./InternalConstants\";\r\nvar TelemetryInitializerPlugin = /** @class */ (function (_super) {\r\n __extends(TelemetryInitializerPlugin, _super);\r\n function TelemetryInitializerPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = \"TelemetryInitializerPlugin\";\r\n _this.priority = 199;\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var _id;\r\n var _initializers;\r\n _initDefaults();\r\n dynamicProto(TelemetryInitializerPlugin, _this, function (_self, _base) {\r\n _self.addTelemetryInitializer = function (telemetryInitializer) {\r\n var theInitializer = {\r\n id: _id++,\r\n fn: telemetryInitializer\r\n };\r\n _initializers[_DYN_PUSH /* @min:%2epush */](theInitializer);\r\n var handler = {\r\n remove: function () {\r\n arrForEach(_initializers, function (initializer, idx) {\r\n if (initializer.id === theInitializer.id) {\r\n _initializers[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n return -1;\r\n }\r\n });\r\n }\r\n };\r\n return handler;\r\n };\r\n _self[STR_PROCESS_TELEMETRY /* @min:%2eprocessTelemetry */] = function (item, itemCtx) {\r\n var doNotSendItem = false;\r\n var telemetryInitializersCount = _initializers[_DYN_LENGTH /* @min:%2elength */];\r\n for (var i = 0; i < telemetryInitializersCount; ++i) {\r\n var telemetryInitializer = _initializers[i];\r\n if (telemetryInitializer) {\r\n try {\r\n if (telemetryInitializer.fn[_DYN_APPLY /* @min:%2eapply */](null, [item]) === false) {\r\n doNotSendItem = true;\r\n break;\r\n }\r\n }\r\n catch (e) {\r\n // log error but dont stop executing rest of the telemetry initializers\r\n // doNotSendItem = true;\r\n _throwInternal(itemCtx[_DYN_DIAG_LOG /* @min:%2ediagLog */](), 1 /* eLoggingSeverity.CRITICAL */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"One of telemetry initializers failed, telemetry item will not be sent: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n }\r\n }\r\n if (!doNotSendItem) {\r\n _self[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](item, itemCtx);\r\n }\r\n };\r\n _self[_DYN__DO_TEARDOWN /* @min:%2e_doTeardown */] = function () {\r\n _initDefaults();\r\n };\r\n });\r\n function _initDefaults() {\r\n _id = 0;\r\n _initializers = [];\r\n }\r\n return _this;\r\n }\r\n// Removed Stub for TelemetryInitializerPlugin.prototype.addTelemetryInitializer.\r\n// Removed Stub for TelemetryInitializerPlugin.prototype.processTelemetry.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n TelemetryInitializerPlugin.__ieDyn=1;\n\n return TelemetryInitializerPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport { TelemetryInitializerPlugin };\r\n//# sourceMappingURL=TelemetryInitializerPlugin.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport { __spreadArrayFn as __spreadArray } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { objCreateFn } from \"@microsoft/applicationinsights-shims\";\r\nimport { _DYN_ADD_NOTIFICATION_LIS1, _DYN_CONFIG, _DYN_FLUSH, _DYN_GET_NOTIFY_MGR, _DYN_GET_PLUGIN, _DYN_GET_PROCESS_TEL_CONT0, _DYN_IDENTIFIER, _DYN_INITIALIZE, _DYN_INSTRUMENTATION_KEY, _DYN_IS_ASYNC, _DYN_IS_INITIALIZED, _DYN_LENGTH, _DYN_LOGGER, _DYN_MESSAGE, _DYN_MESSAGE_ID, _DYN_NAME, _DYN_ON_COMPLETE, _DYN_PROCESS_NEXT, _DYN_PUSH, _DYN_REMOVE_NOTIFICATION_2, _DYN_SET_ENABLED, _DYN_SPLICE, _DYN_STOP_POLLING_INTERNA3, _DYN_TEARDOWN, _DYN_TIME, _DYN__EXTENSIONS } from \"../__DynamicConstants\";\r\nimport { ChannelControllerPriority, createChannelControllerPlugin, createChannelQueues } from \"./ChannelController\";\r\nimport { createCookieMgr } from \"./CookieMgr\";\r\nimport { createUniqueNamespace } from \"./DataCacheHelper\";\r\nimport { getDebugListener } from \"./DbgExtensionUtils\";\r\nimport { DiagnosticLogger, _InternalLogMessage, _throwInternal, _warnToConsole } from \"./DiagnosticLogger\";\r\nimport { arrForEach, arrIndexOf, getCfgValue, getSetValue, isFunction, isNullOrUndefined, objExtend, objFreeze, proxyFunctionAs, proxyFunctions, throwError, toISOString } from \"./HelperFuncs\";\r\nimport { STR_CHANNELS, STR_CORE, STR_CREATE_PERF_MGR, STR_DISABLED, STR_EVENTS_DISCARDED, STR_EVENTS_SEND_REQUEST, STR_EVENTS_SENT, STR_EXTENSIONS, STR_EXTENSION_CONFIG, STR_GET_PERF_MGR, STR_PRIORITY } from \"./InternalConstants\";\r\nimport { PerfManager, getGblPerfMgr } from \"./PerfManager\";\r\nimport { createProcessTelemetryContext, createProcessTelemetryUnloadContext, createProcessTelemetryUpdateContext, createTelemetryProxyChain } from \"./ProcessTelemetryContext\";\r\nimport { _getPluginState, createDistributedTraceContext, initializePlugins, sortPlugins } from \"./TelemetryHelpers\";\r\nimport { TelemetryInitializerPlugin } from \"./TelemetryInitializerPlugin\";\r\nimport { createUnloadHandlerContainer } from \"./UnloadHandlerContainer\";\r\nvar strValidationError = \"Plugins must provide initialize method\";\r\nvar strNotificationManager = \"_notificationManager\";\r\nvar strSdkUnloadingError = \"SDK is still unloading...\";\r\nvar strSdkNotInitialized = \"SDK is not initialized\";\r\n// const strPluginUnloadFailed = \"Failed to unload plugin\";\r\nvar defaultInitConfig = {\r\n // Have the Diagnostic Logger default to log critical errors to the console\r\n loggingLevelConsole: 1 /* eLoggingSeverity.CRITICAL */\r\n};\r\n/**\r\n * Helper to create the default performance manager\r\n * @param core\r\n * @param notificationMgr\r\n */\r\nfunction _createPerfManager(core, notificationMgr) {\r\n return new PerfManager(notificationMgr);\r\n}\r\nfunction _validateExtensions(logger, channelPriority, allExtensions) {\r\n var _a;\r\n // Concat all available extensions\r\n var coreExtensions = [];\r\n // Check if any two extensions have the same priority, then warn to console\r\n // And extract the local extensions from the\r\n var extPriorities = {};\r\n // Extension validation\r\n arrForEach(allExtensions, function (ext) {\r\n // Check for ext.initialize\r\n if (isNullOrUndefined(ext) || isNullOrUndefined(ext[_DYN_INITIALIZE /* @min:%2einitialize */])) {\r\n throwError(strValidationError);\r\n }\r\n var extPriority = ext[STR_PRIORITY /* @min:%2epriority */];\r\n var identifier = ext[_DYN_IDENTIFIER /* @min:%2eidentifier */];\r\n if (ext && extPriority) {\r\n if (!isNullOrUndefined(extPriorities[extPriority])) {\r\n _warnToConsole(logger, \"Two extensions have same priority #\" + extPriority + \" - \" + extPriorities[extPriority] + \", \" + identifier);\r\n }\r\n else {\r\n // set a value\r\n extPriorities[extPriority] = identifier;\r\n }\r\n }\r\n // Split extensions to core and channelController\r\n if (!extPriority || extPriority < channelPriority) {\r\n // Add to core extension that will be managed by BaseCore\r\n coreExtensions[_DYN_PUSH /* @min:%2epush */](ext);\r\n }\r\n });\r\n return _a = {\r\n all: allExtensions\r\n },\r\n _a[STR_CORE /* @min:core */] = coreExtensions,\r\n _a;\r\n}\r\nfunction _isPluginPresent(thePlugin, plugins) {\r\n var exists = false;\r\n arrForEach(plugins, function (plugin) {\r\n if (plugin === thePlugin) {\r\n exists = true;\r\n return -1;\r\n }\r\n });\r\n return exists;\r\n}\r\nfunction _createDummyNotificationManager() {\r\n var _a;\r\n return objCreateFn((_a = {},\r\n _a[_DYN_ADD_NOTIFICATION_LIS1 /* @min:addNotificationListener */] = function (listener) { },\r\n _a[_DYN_REMOVE_NOTIFICATION_2 /* @min:removeNotificationListener */] = function (listener) { },\r\n _a[STR_EVENTS_SENT /* @min:eventsSent */] = function (events) { },\r\n _a[STR_EVENTS_DISCARDED /* @min:eventsDiscarded */] = function (events, reason) { },\r\n _a[STR_EVENTS_SEND_REQUEST /* @min:eventsSendRequest */] = function (sendReason, isAsync) { },\r\n _a));\r\n}\r\nvar BaseCore = /** @class */ (function () {\r\n function BaseCore() {\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var _config;\r\n var _isInitialized;\r\n var _eventQueue;\r\n var _notificationManager;\r\n var _perfManager;\r\n var _cfgPerfManager;\r\n var _cookieManager;\r\n var _pluginChain;\r\n var _configExtensions;\r\n var _coreExtensions;\r\n var _channelControl;\r\n var _channelConfig;\r\n var _channelQueue;\r\n var _isUnloading;\r\n var _telemetryInitializerPlugin;\r\n var _internalLogsEventName;\r\n var _evtNamespace;\r\n var _unloadHandlers;\r\n var _debugListener;\r\n var _traceCtx;\r\n /**\r\n * Internal log poller\r\n */\r\n var _internalLogPoller = 0;\r\n var _forceStopInternalLogPoller = false;\r\n dynamicProto(BaseCore, this, function (_self) {\r\n // Set the default values (also called during teardown)\r\n _initDefaults();\r\n _self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */] = function () { return _isInitialized; };\r\n // Creating the self.initialize = ()\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, extensions, logger, notificationManager) {\r\n if (_isUnloading) {\r\n throwError(strSdkUnloadingError);\r\n }\r\n // Make sure core is only initialized once\r\n if (_self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]()) {\r\n throwError(\"Core should not be initialized more than once\");\r\n }\r\n _config = config || {};\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = _config;\r\n if (isNullOrUndefined(config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */])) {\r\n throwError(\"Please provide instrumentation key\");\r\n }\r\n _notificationManager = notificationManager;\r\n // For backward compatibility only\r\n _self[strNotificationManager] = notificationManager;\r\n _initDebugListener();\r\n _initPerfManager();\r\n // add notification to the extensions in the config so other plugins can access it\r\n _initExtConfig();\r\n if (logger) {\r\n _self[_DYN_LOGGER /* @min:%2elogger */] = logger;\r\n }\r\n var cfgExtensions = getSetValue(_config, STR_EXTENSIONS, []);\r\n // Extension validation\r\n _configExtensions = [];\r\n _configExtensions[_DYN_PUSH /* @min:%2epush */].apply(_configExtensions, __spreadArray(__spreadArray([], extensions, false), cfgExtensions, false));\r\n _channelConfig = getSetValue(_config, STR_CHANNELS, []);\r\n _initPluginChain(null);\r\n if (!_channelQueue || _channelQueue[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n throwError(\"No \" + STR_CHANNELS + \" available\");\r\n }\r\n _isInitialized = true;\r\n _self.releaseQueue();\r\n };\r\n _self.getTransmissionControls = function () {\r\n var controls = [];\r\n if (_channelQueue) {\r\n arrForEach(_channelQueue, function (channels) {\r\n controls[_DYN_PUSH /* @min:%2epush */](channels.queue);\r\n });\r\n }\r\n return objFreeze(controls);\r\n };\r\n _self.track = function (telemetryItem) {\r\n // setup default iKey if not passed in\r\n telemetryItem.iKey = telemetryItem.iKey || _config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n // add default timestamp if not passed in\r\n telemetryItem[_DYN_TIME /* @min:%2etime */] = telemetryItem[_DYN_TIME /* @min:%2etime */] || toISOString(new Date());\r\n // Common Schema 4.0\r\n telemetryItem.ver = telemetryItem.ver || \"4.0\";\r\n if (!_isUnloading && _self[_DYN_IS_INITIALIZED /* @min:%2eisInitialized */]()) {\r\n // Process the telemetry plugin chain\r\n _createTelCtx()[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](telemetryItem);\r\n }\r\n else {\r\n // Queue events until all extensions are initialized\r\n _eventQueue[_DYN_PUSH /* @min:%2epush */](telemetryItem);\r\n }\r\n };\r\n _self[_DYN_GET_PROCESS_TEL_CONT0 /* @min:%2egetProcessTelContext */] = _createTelCtx;\r\n _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */] = function () {\r\n if (!_notificationManager) {\r\n // Create Dummy notification manager\r\n _notificationManager = _createDummyNotificationManager();\r\n // For backward compatibility only\r\n _self[strNotificationManager] = _notificationManager;\r\n }\r\n return _notificationManager;\r\n };\r\n /**\r\n * Adds a notification listener. The SDK calls methods on the listener when an appropriate notification is raised.\r\n * The added plugins must raise notifications. If the plugins do not implement the notifications, then no methods will be\r\n * called.\r\n * @param {INotificationListener} listener - An INotificationListener object.\r\n */\r\n _self[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */] = function (listener) {\r\n if (_notificationManager) {\r\n _notificationManager[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */](listener);\r\n }\r\n };\r\n /**\r\n * Removes all instances of the listener.\r\n * @param {INotificationListener} listener - INotificationListener to remove.\r\n */\r\n _self[_DYN_REMOVE_NOTIFICATION_2 /* @min:%2eremoveNotificationListener */] = function (listener) {\r\n if (_notificationManager) {\r\n _notificationManager[_DYN_REMOVE_NOTIFICATION_2 /* @min:%2eremoveNotificationListener */](listener);\r\n }\r\n };\r\n _self.getCookieMgr = function () {\r\n if (!_cookieManager) {\r\n _cookieManager = createCookieMgr(_config, _self[_DYN_LOGGER /* @min:%2elogger */]);\r\n }\r\n return _cookieManager;\r\n };\r\n _self.setCookieMgr = function (cookieMgr) {\r\n _cookieManager = cookieMgr;\r\n };\r\n _self[STR_GET_PERF_MGR /* @min:%2egetPerfMgr */] = function () {\r\n if (!_perfManager && !_cfgPerfManager) {\r\n if (getCfgValue(_config.enablePerfMgr)) {\r\n var createPerfMgr = getCfgValue(_config[STR_CREATE_PERF_MGR /* @min:%2ecreatePerfMgr */]);\r\n if (isFunction(createPerfMgr)) {\r\n _cfgPerfManager = createPerfMgr(_self, _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */]());\r\n }\r\n }\r\n }\r\n return _perfManager || _cfgPerfManager || getGblPerfMgr();\r\n };\r\n _self.setPerfMgr = function (perfMgr) {\r\n _perfManager = perfMgr;\r\n };\r\n _self.eventCnt = function () {\r\n return _eventQueue[_DYN_LENGTH /* @min:%2elength */];\r\n };\r\n _self.releaseQueue = function () {\r\n if (_isInitialized && _eventQueue[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var eventQueue = _eventQueue;\r\n _eventQueue = [];\r\n arrForEach(eventQueue, function (event) {\r\n _createTelCtx()[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](event);\r\n });\r\n }\r\n };\r\n _self.pollInternalLogs = function (eventName) {\r\n _internalLogsEventName = eventName || null;\r\n _forceStopInternalLogPoller = false;\r\n if (_internalLogPoller) {\r\n clearInterval(_internalLogPoller);\r\n _internalLogPoller = null;\r\n }\r\n return _startInternalLogTimer(true);\r\n };\r\n function _startInternalLogTimer(alwaysStart) {\r\n if (!_internalLogPoller && !_forceStopInternalLogPoller) {\r\n var shouldStart = alwaysStart || (_self[_DYN_LOGGER /* @min:%2elogger */] && _self[_DYN_LOGGER /* @min:%2elogger */].queue[_DYN_LENGTH /* @min:%2elength */] > 0);\r\n if (shouldStart) {\r\n var interval = getCfgValue(_config.diagnosticLogInterval);\r\n if (!interval || !(interval > 0)) {\r\n interval = 10000;\r\n }\r\n // Keeping as an interval timer for backward compatibility as it returns the result\r\n _internalLogPoller = setInterval(function () {\r\n clearInterval(_internalLogPoller);\r\n _internalLogPoller = 0;\r\n _flushInternalLogs();\r\n }, interval);\r\n }\r\n }\r\n return _internalLogPoller;\r\n }\r\n _self[_DYN_STOP_POLLING_INTERNA3 /* @min:%2estopPollingInternalLogs */] = function () {\r\n _forceStopInternalLogPoller = true;\r\n if (_internalLogPoller) {\r\n clearInterval(_internalLogPoller);\r\n _internalLogPoller = 0;\r\n _flushInternalLogs();\r\n }\r\n };\r\n // Add addTelemetryInitializer\r\n proxyFunctions(_self, function () { return _telemetryInitializerPlugin; }, [\"addTelemetryInitializer\"]);\r\n _self.unload = function (isAsync, unloadComplete, cbTimeout) {\r\n var _a;\r\n if (isAsync === void 0) { isAsync = true; }\r\n if (!_isInitialized) {\r\n // The SDK is not initialized\r\n throwError(strSdkNotInitialized);\r\n }\r\n // Check if the SDK still unloading so throw\r\n if (_isUnloading) {\r\n // The SDK is already unloading\r\n throwError(strSdkUnloadingError);\r\n }\r\n var unloadState = (_a = {\r\n reason: 50 /* TelemetryUnloadReason.SdkUnload */\r\n },\r\n _a[_DYN_IS_ASYNC /* @min:isAsync */] = isAsync,\r\n _a.flushComplete = false,\r\n _a);\r\n var processUnloadCtx = createProcessTelemetryUnloadContext(_getPluginChain(), _self);\r\n processUnloadCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](function () {\r\n _initDefaults();\r\n unloadComplete && unloadComplete(unloadState);\r\n }, _self);\r\n function _doUnload(flushComplete) {\r\n unloadState.flushComplete = flushComplete;\r\n _isUnloading = true;\r\n // Run all of the unload handlers first (before unloading the plugins)\r\n _unloadHandlers.run(processUnloadCtx, unloadState);\r\n // Stop polling the internal logs\r\n _self[_DYN_STOP_POLLING_INTERNA3 /* @min:%2estopPollingInternalLogs */]();\r\n // Start unloading the components, from this point onwards the SDK should be considered to be in an unstable state\r\n processUnloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](unloadState);\r\n }\r\n _flushInternalLogs();\r\n if (!_flushChannels(isAsync, _doUnload, 6 /* SendRequestReason.SdkUnload */, cbTimeout)) {\r\n _doUnload(false);\r\n }\r\n };\r\n _self[_DYN_GET_PLUGIN /* @min:%2egetPlugin */] = _getPlugin;\r\n _self.addPlugin = function (plugin, replaceExisting, isAsync, addCb) {\r\n if (!plugin) {\r\n addCb && addCb(false);\r\n _logOrThrowError(strValidationError);\r\n return;\r\n }\r\n var existingPlugin = _getPlugin(plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */]);\r\n if (existingPlugin && !replaceExisting) {\r\n addCb && addCb(false);\r\n _logOrThrowError(\"Plugin [\" + plugin[_DYN_IDENTIFIER /* @min:%2eidentifier */] + \"] is already loaded!\");\r\n return;\r\n }\r\n var updateState = {\r\n reason: 16 /* TelemetryUpdateReason.PluginAdded */\r\n };\r\n function _addPlugin(removed) {\r\n _configExtensions[_DYN_PUSH /* @min:%2epush */](plugin);\r\n updateState.added = [plugin];\r\n // Re-Initialize the plugin chain\r\n _initPluginChain(updateState);\r\n addCb && addCb(true);\r\n }\r\n if (existingPlugin) {\r\n var removedPlugins_1 = [existingPlugin.plugin];\r\n var unloadState = {\r\n reason: 2 /* TelemetryUnloadReason.PluginReplace */,\r\n isAsync: !!isAsync\r\n };\r\n _removePlugins(removedPlugins_1, unloadState, function (removed) {\r\n if (!removed) {\r\n // Previous plugin was successfully removed or was not installed\r\n addCb && addCb(false);\r\n }\r\n else {\r\n updateState.removed = removedPlugins_1;\r\n updateState.reason |= 32 /* TelemetryUpdateReason.PluginRemoved */;\r\n _addPlugin(true);\r\n }\r\n });\r\n }\r\n else {\r\n _addPlugin(false);\r\n }\r\n };\r\n _self.evtNamespace = function () {\r\n return _evtNamespace;\r\n };\r\n _self[_DYN_FLUSH /* @min:%2eflush */] = _flushChannels;\r\n _self.getTraceCtx = function (createNew) {\r\n if (!_traceCtx) {\r\n _traceCtx = createDistributedTraceContext();\r\n }\r\n return _traceCtx;\r\n };\r\n _self.setTraceCtx = function (traceCtx) {\r\n _traceCtx = traceCtx || null;\r\n };\r\n // Create the addUnloadCb\r\n proxyFunctionAs(_self, \"addUnloadCb\", function () { return _unloadHandlers; }, \"add\");\r\n function _initDefaults() {\r\n _isInitialized = false;\r\n // Use a default logger so initialization errors are not dropped on the floor with full logging\r\n _config = objExtend(true, {}, defaultInitConfig);\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = _config;\r\n _self[_DYN_LOGGER /* @min:%2elogger */] = new DiagnosticLogger(_config);\r\n _self[_DYN__EXTENSIONS /* @min:%2e_extensions */] = [];\r\n _telemetryInitializerPlugin = new TelemetryInitializerPlugin();\r\n _eventQueue = [];\r\n _notificationManager = null;\r\n _perfManager = null;\r\n _cfgPerfManager = null;\r\n _cookieManager = null;\r\n _pluginChain = null;\r\n _coreExtensions = null;\r\n _configExtensions = [];\r\n _channelControl = null;\r\n _channelConfig = null;\r\n _channelQueue = null;\r\n _isUnloading = false;\r\n _internalLogsEventName = null;\r\n _evtNamespace = createUniqueNamespace(\"AIBaseCore\", true);\r\n _unloadHandlers = createUnloadHandlerContainer();\r\n _traceCtx = null;\r\n }\r\n function _createTelCtx() {\r\n var theCtx = createProcessTelemetryContext(_getPluginChain(), _config, _self);\r\n theCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](_startInternalLogTimer);\r\n return theCtx;\r\n }\r\n // Initialize or Re-initialize the plugins\r\n function _initPluginChain(updateState) {\r\n // Extension validation\r\n var theExtensions = _validateExtensions(_self[_DYN_LOGGER /* @min:%2elogger */], ChannelControllerPriority, _configExtensions);\r\n _coreExtensions = theExtensions[STR_CORE /* @min:%2ecore */];\r\n _pluginChain = null;\r\n // Sort the complete set of extensions by priority\r\n var allExtensions = theExtensions.all;\r\n // Initialize the Channel Queues and the channel plugins first\r\n _channelQueue = objFreeze(createChannelQueues(_channelConfig, allExtensions, _self));\r\n if (_channelControl) {\r\n // During add / remove of a plugin this may get called again, so don't re-add if already present\r\n // But we also want the controller as the last, so remove if already present\r\n // And reusing the existing instance, just in case an installed plugin has a reference and\r\n // is using it.\r\n var idx = arrIndexOf(allExtensions, _channelControl);\r\n if (idx !== -1) {\r\n allExtensions[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n }\r\n idx = arrIndexOf(_coreExtensions, _channelControl);\r\n if (idx !== -1) {\r\n _coreExtensions[_DYN_SPLICE /* @min:%2esplice */](idx, 1);\r\n }\r\n _channelControl._setQueue(_channelQueue);\r\n }\r\n else {\r\n _channelControl = createChannelControllerPlugin(_channelQueue, _self);\r\n }\r\n // Add on \"channelController\" as the last \"plugin\"\r\n allExtensions[_DYN_PUSH /* @min:%2epush */](_channelControl);\r\n _coreExtensions[_DYN_PUSH /* @min:%2epush */](_channelControl);\r\n // Required to allow plugins to call core.getPlugin() during their own initialization\r\n _self[_DYN__EXTENSIONS /* @min:%2e_extensions */] = sortPlugins(allExtensions);\r\n // Initialize the controls\r\n _channelControl[_DYN_INITIALIZE /* @min:%2einitialize */](_config, _self, allExtensions);\r\n var initCtx = _createTelCtx();\r\n initializePlugins(initCtx, allExtensions);\r\n // Now reset the extensions to just those being managed by Basecore\r\n _self[_DYN__EXTENSIONS /* @min:%2e_extensions */] = objFreeze(sortPlugins(_coreExtensions || [])).slice();\r\n if (updateState) {\r\n _doUpdate(updateState);\r\n }\r\n }\r\n function _getPlugin(pluginIdentifier) {\r\n var _a;\r\n var theExt = null;\r\n var thePlugin = null;\r\n arrForEach(_self[_DYN__EXTENSIONS /* @min:%2e_extensions */], function (ext) {\r\n if (ext[_DYN_IDENTIFIER /* @min:%2eidentifier */] === pluginIdentifier && ext !== _channelControl && ext !== _telemetryInitializerPlugin) {\r\n thePlugin = ext;\r\n return -1;\r\n }\r\n });\r\n if (!thePlugin && _channelControl) {\r\n // Check the channel Controller\r\n thePlugin = _channelControl.getChannel(pluginIdentifier);\r\n }\r\n if (thePlugin) {\r\n theExt = (_a = {\r\n plugin: thePlugin\r\n },\r\n _a[_DYN_SET_ENABLED /* @min:setEnabled */] = function (enabled) {\r\n _getPluginState(thePlugin)[STR_DISABLED] = !enabled;\r\n },\r\n _a.isEnabled = function () {\r\n var pluginState = _getPluginState(thePlugin);\r\n return !pluginState[_DYN_TEARDOWN /* @min:%2eteardown */] && !pluginState[STR_DISABLED];\r\n },\r\n _a.remove = function (isAsync, removeCb) {\r\n var _a;\r\n if (isAsync === void 0) { isAsync = true; }\r\n var pluginsToRemove = [thePlugin];\r\n var unloadState = (_a = {\r\n reason: 1 /* TelemetryUnloadReason.PluginUnload */\r\n },\r\n _a[_DYN_IS_ASYNC /* @min:isAsync */] = isAsync,\r\n _a);\r\n _removePlugins(pluginsToRemove, unloadState, function (removed) {\r\n if (removed) {\r\n // Re-Initialize the plugin chain\r\n _initPluginChain({\r\n reason: 32 /* TelemetryUpdateReason.PluginRemoved */,\r\n removed: pluginsToRemove\r\n });\r\n }\r\n removeCb && removeCb(removed);\r\n });\r\n },\r\n _a);\r\n }\r\n return theExt;\r\n }\r\n function _getPluginChain() {\r\n if (!_pluginChain) {\r\n // copy the collection of extensions\r\n var extensions = (_coreExtensions || []).slice();\r\n // During add / remove this may get called again, so don't readd if already present\r\n if (arrIndexOf(extensions, _telemetryInitializerPlugin) === -1) {\r\n extensions[_DYN_PUSH /* @min:%2epush */](_telemetryInitializerPlugin);\r\n }\r\n _pluginChain = createTelemetryProxyChain(sortPlugins(extensions), _config, _self);\r\n }\r\n return _pluginChain;\r\n }\r\n function _removePlugins(thePlugins, unloadState, removeComplete) {\r\n if (thePlugins && thePlugins[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n var unloadChain = createTelemetryProxyChain(thePlugins, _config, _self);\r\n var unloadCtx = createProcessTelemetryUnloadContext(unloadChain, _self);\r\n unloadCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](function () {\r\n var removed = false;\r\n // Remove the listed config extensions\r\n var newConfigExtensions = [];\r\n arrForEach(_configExtensions, function (plugin, idx) {\r\n if (!_isPluginPresent(plugin, thePlugins)) {\r\n newConfigExtensions[_DYN_PUSH /* @min:%2epush */](plugin);\r\n }\r\n else {\r\n removed = true;\r\n }\r\n });\r\n _configExtensions = newConfigExtensions;\r\n // Re-Create the channel config\r\n var newChannelConfig = [];\r\n if (_channelConfig) {\r\n arrForEach(_channelConfig, function (queue, idx) {\r\n var newQueue = [];\r\n arrForEach(queue, function (channel) {\r\n if (!_isPluginPresent(channel, thePlugins)) {\r\n newQueue[_DYN_PUSH /* @min:%2epush */](channel);\r\n }\r\n else {\r\n removed = true;\r\n }\r\n });\r\n newChannelConfig[_DYN_PUSH /* @min:%2epush */](newQueue);\r\n });\r\n _channelConfig = newChannelConfig;\r\n }\r\n removeComplete && removeComplete(removed);\r\n _startInternalLogTimer();\r\n });\r\n unloadCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](unloadState);\r\n }\r\n else {\r\n removeComplete(false);\r\n }\r\n }\r\n function _flushInternalLogs() {\r\n if (_self[_DYN_LOGGER /* @min:%2elogger */] && _self[_DYN_LOGGER /* @min:%2elogger */].queue) {\r\n var queue = _self[_DYN_LOGGER /* @min:%2elogger */].queue.slice(0);\r\n _self[_DYN_LOGGER /* @min:%2elogger */].queue[_DYN_LENGTH /* @min:%2elength */] = 0;\r\n arrForEach(queue, function (logMessage) {\r\n var _a;\r\n var item = (_a = {},\r\n _a[_DYN_NAME /* @min:name */] = _internalLogsEventName ? _internalLogsEventName : \"InternalMessageId: \" + logMessage[_DYN_MESSAGE_ID /* @min:%2emessageId */],\r\n _a.iKey = getCfgValue(_config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */]),\r\n _a.time = toISOString(new Date()),\r\n _a.baseType = _InternalLogMessage.dataType,\r\n _a.baseData = { message: logMessage[_DYN_MESSAGE /* @min:%2emessage */] },\r\n _a);\r\n _self.track(item);\r\n });\r\n }\r\n }\r\n function _flushChannels(isAsync, callBack, sendReason, cbTimeout) {\r\n if (_channelControl) {\r\n return _channelControl[_DYN_FLUSH /* @min:%2eflush */](isAsync, callBack, sendReason || 6 /* SendRequestReason.SdkUnload */, cbTimeout);\r\n }\r\n callBack && callBack(false);\r\n return true;\r\n }\r\n function _initDebugListener() {\r\n var disableDbgExt = getCfgValue(_config.disableDbgExt);\r\n if (disableDbgExt === true && _debugListener) {\r\n // Remove any previously loaded debug listener\r\n _notificationManager[_DYN_REMOVE_NOTIFICATION_2 /* @min:%2eremoveNotificationListener */](_debugListener);\r\n _debugListener = null;\r\n }\r\n if (_notificationManager && !_debugListener && disableDbgExt !== true) {\r\n _debugListener = getDebugListener(_config);\r\n _notificationManager[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */](_debugListener);\r\n }\r\n }\r\n function _initPerfManager() {\r\n var enablePerfMgr = getCfgValue(_config.enablePerfMgr);\r\n if (!enablePerfMgr && _cfgPerfManager) {\r\n // Remove any existing config based performance manager\r\n _cfgPerfManager = null;\r\n }\r\n if (enablePerfMgr) {\r\n // Set the performance manager creation function if not defined\r\n getSetValue(_config, STR_CREATE_PERF_MGR, _createPerfManager);\r\n }\r\n }\r\n function _initExtConfig() {\r\n var extConfig = getSetValue(_config, STR_EXTENSION_CONFIG, {});\r\n extConfig.NotificationManager = _notificationManager;\r\n }\r\n function _doUpdate(updateState) {\r\n var updateCtx = createProcessTelemetryUpdateContext(_getPluginChain(), _self);\r\n updateCtx[_DYN_ON_COMPLETE /* @min:%2eonComplete */](_startInternalLogTimer);\r\n if (!_self._updateHook || _self._updateHook(updateCtx, updateState) !== true) {\r\n updateCtx[_DYN_PROCESS_NEXT /* @min:%2eprocessNext */](updateState);\r\n }\r\n }\r\n function _logOrThrowError(message) {\r\n var logger = _self[_DYN_LOGGER /* @min:%2elogger */];\r\n if (logger) {\r\n // there should always be a logger\r\n _throwInternal(logger, 2 /* eLoggingSeverity.WARNING */, 73 /* _eInternalMessageId.PluginException */, message);\r\n _startInternalLogTimer();\r\n }\r\n else {\r\n throwError(message);\r\n }\r\n }\r\n });\r\n }\r\n// Removed Stub for BaseCore.prototype.initialize.\r\n// Removed Stub for BaseCore.prototype.getTransmissionControls.\r\n// Removed Stub for BaseCore.prototype.track.\r\n// Removed Stub for BaseCore.prototype.getProcessTelContext.\r\n// Removed Stub for BaseCore.prototype.getNotifyMgr.\r\n// Removed Stub for BaseCore.prototype.addNotificationListener.\r\n// Removed Stub for BaseCore.prototype.removeNotificationListener.\r\n// Removed Stub for BaseCore.prototype.getCookieMgr.\r\n// Removed Stub for BaseCore.prototype.setCookieMgr.\r\n// Removed Stub for BaseCore.prototype.getPerfMgr.\r\n// Removed Stub for BaseCore.prototype.setPerfMgr.\r\n// Removed Stub for BaseCore.prototype.eventCnt.\r\n// Removed Stub for BaseCore.prototype.pollInternalLogs.\r\n// Removed Stub for BaseCore.prototype.stopPollingInternalLogs.\r\n// Removed Stub for BaseCore.prototype.addTelemetryInitializer.\r\n// Removed Stub for BaseCore.prototype.unload.\r\n// Removed Stub for BaseCore.prototype.getPlugin.\r\n// Removed Stub for BaseCore.prototype.addPlugin.\r\n// Removed Stub for BaseCore.prototype.evtNamespace.\r\n// Removed Stub for BaseCore.prototype.addUnloadCb.\r\n// Removed Stub for BaseCore.prototype.flush.\r\n// Removed Stub for BaseCore.prototype.getTraceCtx.\r\n// Removed Stub for BaseCore.prototype.setTraceCtx.\r\n// Removed Stub for BaseCore.prototype.releaseQueue.\r\n// Removed Stub for BaseCore.prototype._updateHook.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n BaseCore.__ieDyn=1;\n\n return BaseCore;\r\n}());\r\nexport { BaseCore };\r\n//# sourceMappingURL=BaseCore.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { _DYN_ADD_NOTIFICATION_LIS1, _DYN_IS_ASYNC, _DYN_IS_CHILD_EVT, _DYN_LISTENERS, _DYN_PUSH, _DYN_REMOVE_NOTIFICATION_2, _DYN_SPLICE } from \"../__DynamicConstants\";\r\nimport { arrForEach, arrIndexOf } from \"./HelperFuncs\";\r\nimport { STR_EVENTS_DISCARDED, STR_EVENTS_SEND_REQUEST, STR_EVENTS_SENT, STR_PERF_EVENT } from \"./InternalConstants\";\r\nfunction _runListeners(listeners, name, isAsync, callback) {\r\n arrForEach(listeners, function (listener) {\r\n if (listener && listener[name]) {\r\n if (isAsync) {\r\n setTimeout(function () { return callback(listener); }, 0);\r\n }\r\n else {\r\n try {\r\n callback(listener);\r\n }\r\n catch (e) {\r\n // Catch errors to ensure we don't block sending the requests\r\n }\r\n }\r\n }\r\n });\r\n}\r\n/**\r\n * Class to manage sending notifications to all the listeners.\r\n */\r\nvar NotificationManager = /** @class */ (function () {\r\n function NotificationManager(config) {\r\n this.listeners = [];\r\n var perfEvtsSendAll = !!(config || {}).perfEvtsSendAll;\r\n dynamicProto(NotificationManager, this, function (_self) {\r\n _self[_DYN_ADD_NOTIFICATION_LIS1 /* @min:%2eaddNotificationListener */] = function (listener) {\r\n _self.listeners[_DYN_PUSH /* @min:%2epush */](listener);\r\n };\r\n /**\r\n * Removes all instances of the listener.\r\n * @param {INotificationListener} listener - AWTNotificationListener to remove.\r\n */\r\n _self[_DYN_REMOVE_NOTIFICATION_2 /* @min:%2eremoveNotificationListener */] = function (listener) {\r\n var index = arrIndexOf(_self[_DYN_LISTENERS /* @min:%2elisteners */], listener);\r\n while (index > -1) {\r\n _self.listeners[_DYN_SPLICE /* @min:%2esplice */](index, 1);\r\n index = arrIndexOf(_self[_DYN_LISTENERS /* @min:%2elisteners */], listener);\r\n }\r\n };\r\n /**\r\n * Notification for events sent.\r\n * @param {ITelemetryItem[]} events - The array of events that have been sent.\r\n */\r\n _self[STR_EVENTS_SENT /* @min:%2eeventsSent */] = function (events) {\r\n _runListeners(_self[_DYN_LISTENERS /* @min:%2elisteners */], STR_EVENTS_SENT, true, function (listener) {\r\n listener[STR_EVENTS_SENT /* @min:%2eeventsSent */](events);\r\n });\r\n };\r\n /**\r\n * Notification for events being discarded.\r\n * @param {ITelemetryItem[]} events - The array of events that have been discarded by the SDK.\r\n * @param {number} reason - The reason for which the SDK discarded the events. The EventsDiscardedReason\r\n * constant should be used to check the different values.\r\n */\r\n _self[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */] = function (events, reason) {\r\n _runListeners(_self[_DYN_LISTENERS /* @min:%2elisteners */], STR_EVENTS_DISCARDED, true, function (listener) {\r\n listener[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */](events, reason);\r\n });\r\n };\r\n /**\r\n * [Optional] A function called when the events have been requested to be sent to the sever.\r\n * @param {number} sendReason - The reason why the event batch is being sent.\r\n * @param {boolean} isAsync - A flag which identifies whether the requests are being sent in an async or sync manner.\r\n */\r\n _self[STR_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */] = function (sendReason, isAsync) {\r\n _runListeners(_self[_DYN_LISTENERS /* @min:%2elisteners */], STR_EVENTS_SEND_REQUEST, isAsync, function (listener) {\r\n listener[STR_EVENTS_SEND_REQUEST /* @min:%2eeventsSendRequest */](sendReason, isAsync);\r\n });\r\n };\r\n _self[STR_PERF_EVENT /* @min:%2eperfEvent */] = function (perfEvent) {\r\n if (perfEvent) {\r\n // Send all events or only parent events\r\n if (perfEvtsSendAll || !perfEvent[_DYN_IS_CHILD_EVT /* @min:%2eisChildEvt */]()) {\r\n _runListeners(_self[_DYN_LISTENERS /* @min:%2elisteners */], STR_PERF_EVENT, false, function (listener) {\r\n if (perfEvent[_DYN_IS_ASYNC /* @min:%2eisAsync */]) {\r\n setTimeout(function () { return listener[STR_PERF_EVENT /* @min:%2eperfEvent */](perfEvent); }, 0);\r\n }\r\n else {\r\n listener[STR_PERF_EVENT /* @min:%2eperfEvent */](perfEvent);\r\n }\r\n });\r\n }\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for NotificationManager.prototype.addNotificationListener.\r\n// Removed Stub for NotificationManager.prototype.removeNotificationListener.\r\n// Removed Stub for NotificationManager.prototype.eventsSent.\r\n// Removed Stub for NotificationManager.prototype.eventsDiscarded.\r\n// Removed Stub for NotificationManager.prototype.eventsSendRequest.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n NotificationManager.__ieDyn=1;\n\n return NotificationManager;\r\n}());\r\nexport { NotificationManager };\r\n//# sourceMappingURL=NotificationManager.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { _DYN_GET_NOTIFY_MGR, _DYN_INITIALIZE, _DYN_NAME } from \"../__DynamicConstants\";\r\nimport { BaseCore } from \"./BaseCore\";\r\nimport { DiagnosticLogger } from \"./DiagnosticLogger\";\r\nimport { isNullOrUndefined, throwError } from \"./HelperFuncs\";\r\nimport { STR_EVENTS_DISCARDED, STR_GET_PERF_MGR } from \"./InternalConstants\";\r\nimport { NotificationManager } from \"./NotificationManager\";\r\nimport { doPerf } from \"./PerfManager\";\r\nvar AppInsightsCore = /** @class */ (function (_super) {\r\n __extends(AppInsightsCore, _super);\r\n function AppInsightsCore() {\r\n var _this = _super.call(this) || this;\r\n dynamicProto(AppInsightsCore, _this, function (_self, _base) {\r\n _self[_DYN_INITIALIZE /* @min:%2einitialize */] = function (config, extensions, logger, notificationManager) {\r\n _base[_DYN_INITIALIZE /* @min:%2einitialize */](config, extensions, logger || new DiagnosticLogger(config), notificationManager || new NotificationManager(config));\r\n };\r\n _self.track = function (telemetryItem) {\r\n doPerf(_self[STR_GET_PERF_MGR /* @min:%2egetPerfMgr */](), function () { return \"AppInsightsCore:track\"; }, function () {\r\n if (telemetryItem === null) {\r\n _notifyInvalidEvent(telemetryItem);\r\n // throw error\r\n throwError(\"Invalid telemetry item\");\r\n }\r\n // do basic validation before sending it through the pipeline\r\n _validateTelemetryItem(telemetryItem);\r\n _base.track(telemetryItem);\r\n }, function () { return ({ item: telemetryItem }); }, !(telemetryItem.sync));\r\n };\r\n function _validateTelemetryItem(telemetryItem) {\r\n if (isNullOrUndefined(telemetryItem[_DYN_NAME /* @min:%2ename */])) {\r\n _notifyInvalidEvent(telemetryItem);\r\n throwError(\"telemetry name required\");\r\n }\r\n }\r\n function _notifyInvalidEvent(telemetryItem) {\r\n var manager = _self[_DYN_GET_NOTIFY_MGR /* @min:%2egetNotifyMgr */]();\r\n if (manager) {\r\n manager[STR_EVENTS_DISCARDED /* @min:%2eeventsDiscarded */]([telemetryItem], 2 /* eEventsDiscardedReason.InvalidEvent */);\r\n }\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for AppInsightsCore.prototype.initialize.\r\n// Removed Stub for AppInsightsCore.prototype.track.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n AppInsightsCore.__ieDyn=1;\n\n return AppInsightsCore;\r\n}(BaseCore));\r\nexport { AppInsightsCore };\r\n//# sourceMappingURL=AppInsightsCore.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strShimHasOwnProperty = \"hasOwnProperty\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\nexport var ObjAssign = ObjClass[\"assign\"];\r\nexport var ObjCreate = ObjClass[\"create\"];\r\nexport var ObjDefineProperty = ObjClass[\"defineProperty\"];\r\nexport var ObjHasOwnProperty = ObjProto[strShimHasOwnProperty];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjCreate, strShimFunction, strShimObject, strShimPrototype, strShimUndefined } from \"./Constants\";\r\nvar _cachedGlobal = null;\r\n/**\r\n * Returns the current global scope object, for a normal web page this will be the current\r\n * window, for a Web Worker this will be current worker global scope via \"self\". The internal\r\n * implementation returns the first available instance object in the following order\r\n * - globalThis (New standard)\r\n * - self (Will return the current window instance for supported browsers)\r\n * - window (fallback for older browser implementations)\r\n * - global (NodeJS standard)\r\n * - (When all else fails)\r\n * While the return type is a Window for the normal case, not all environments will support all\r\n * of the properties or functions.\r\n */\r\nexport function getGlobal(useCached) {\r\n if (useCached === void 0) { useCached = true; }\r\n var result = useCached === false ? null : _cachedGlobal;\r\n if (!result) {\r\n if (typeof globalThis !== strShimUndefined) {\r\n result = globalThis;\r\n }\r\n if (!result && typeof self !== strShimUndefined) {\r\n result = self;\r\n }\r\n if (!result && typeof window !== strShimUndefined) {\r\n result = window;\r\n }\r\n if (!result && typeof global !== strShimUndefined) {\r\n result = global;\r\n }\r\n _cachedGlobal = result;\r\n }\r\n return result;\r\n}\r\nexport function throwTypeError(message) {\r\n throw new TypeError(message);\r\n}\r\n/**\r\n * Creates an object that has the specified prototype, and that optionally contains specified properties. This helper exists to avoid adding a polyfil\r\n * for older browsers that do not define Object.create eg. ES3 only, IE8 just in case any page checks for presence/absence of the prototype implementation.\r\n * Note: For consistency this will not use the Object.create implementation if it exists as this would cause a testing requirement to test with and without the implementations\r\n * @param obj Object to use as a prototype. May be null\r\n */\r\nexport function objCreateFn(obj) {\r\n var func = ObjCreate;\r\n // Use build in Object.create\r\n if (func) {\r\n // Use Object create method if it exists\r\n return func(obj);\r\n }\r\n if (obj == null) {\r\n return {};\r\n }\r\n var type = typeof obj;\r\n if (type !== strShimObject && type !== strShimFunction) {\r\n throwTypeError(\"Object prototype may only be an Object:\" + obj);\r\n }\r\n function tmpFunc() { }\r\n tmpFunc[strShimPrototype] = obj;\r\n return new tmpFunc();\r\n}\r\n//# sourceMappingURL=Helpers.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nexport var STR_DURATION = \"duration\";\r\nexport var STR_PROPERTIES = \"properties\";\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_REQUEST_URL = \"requestUrl\"; // Count: 12\r\nexport var _DYN_INST = \"inst\"; // Count: 5\r\nexport var _DYN_LENGTH = \"length\"; // Count: 10\r\nexport var _DYN_TRACE_ID = \"traceID\"; // Count: 9\r\nexport var _DYN_SPAN_ID = \"spanID\"; // Count: 8\r\nexport var _DYN_TRACE_FLAGS = \"traceFlags\"; // Count: 13\r\nexport var _DYN_CONTEXT = \"context\"; // Count: 7\r\nexport var _DYN_ABORTED = \"aborted\"; // Count: 7\r\nexport var _DYN_TRACE_ID0 = \"traceId\"; // Count: 5\r\nexport var _DYN_SPAN_ID1 = \"spanId\"; // Count: 5\r\nexport var _DYN_CORE = \"core\"; // Count: 8\r\nexport var _DYN_INCLUDE_CORRELATION_2 = \"includeCorrelationHeaders\"; // Count: 4\r\nexport var _DYN_CAN_INCLUDE_CORRELAT3 = \"canIncludeCorrelationHeader\"; // Count: 2\r\nexport var _DYN_GET_ABSOLUTE_URL = \"getAbsoluteUrl\"; // Count: 3\r\nexport var _DYN_HEADERS = \"headers\"; // Count: 6\r\nexport var _DYN_REQUEST_HEADERS = \"requestHeaders\"; // Count: 13\r\nexport var _DYN_APP_ID = \"appId\"; // Count: 5\r\nexport var _DYN_SET_REQUEST_HEADER = \"setRequestHeader\"; // Count: 3\r\nexport var _DYN_TRACK_DEPENDENCY_DAT4 = \"trackDependencyDataInternal\"; // Count: 2\r\nexport var _DYN_DISTRIBUTED_TRACING_5 = \"distributedTracingMode\"; // Count: 3\r\nexport var _DYN_START_TIME = \"startTime\"; // Count: 6\r\nexport var _DYN_TO_LOWER_CASE = \"toLowerCase\"; // Count: 6\r\nexport var _DYN_ENABLE_REQUEST_HEADE6 = \"enableRequestHeaderTracking\"; // Count: 2\r\nexport var _DYN_ENABLE_AJAX_ERROR_ST7 = \"enableAjaxErrorStatusText\"; // Count: 2\r\nexport var _DYN_ENABLE_AJAX_PERF_TRA8 = \"enableAjaxPerfTracking\"; // Count: 2\r\nexport var _DYN_MAX_AJAX_CALLS_PER_V9 = \"maxAjaxCallsPerView\"; // Count: 2\r\nexport var _DYN_ENABLE_RESPONSE_HEAD10 = \"enableResponseHeaderTracking\"; // Count: 2\r\nexport var _DYN_EXCLUDE_REQUEST_FROM11 = \"excludeRequestFromAutoTrackingPatterns\"; // Count: 2\r\nexport var _DYN_ADD_REQUEST_CONTEXT = \"addRequestContext\"; // Count: 2\r\nexport var _DYN_DISABLE_AJAX_TRACKIN12 = \"disableAjaxTracking\"; // Count: 2\r\nexport var _DYN_DISABLE_FETCH_TRACKI13 = \"disableFetchTracking\"; // Count: 2\r\nexport var _DYN_STATUS = \"status\"; // Count: 11\r\nexport var _DYN_STATUS_TEXT = \"statusText\"; // Count: 9\r\nexport var _DYN_HEADER_MAP = \"headerMap\"; // Count: 8\r\nexport var _DYN_OPEN_DONE = \"openDone\"; // Count: 3\r\nexport var _DYN_SEND_DONE = \"sendDone\"; // Count: 3\r\nexport var _DYN_REQUEST_SENT_TIME = \"requestSentTime\"; // Count: 9\r\nexport var _DYN_ABORT_DONE = \"abortDone\"; // Count: 3\r\nexport var _DYN_GET_TRACE_ID = \"getTraceId\"; // Count: 3\r\nexport var _DYN_GET_TRACE_FLAGS = \"getTraceFlags\"; // Count: 3\r\nexport var _DYN_METHOD = \"method\"; // Count: 8\r\nexport var _DYN_ERROR_STATUS_TEXT = \"errorStatusText\"; // Count: 3\r\nexport var _DYN_STATE_CHANGE_ATTACHE14 = \"stateChangeAttached\"; // Count: 2\r\nexport var _DYN_RESPONSE_TEXT = \"responseText\"; // Count: 6\r\nexport var _DYN_RESPONSE_FINISHED_TI15 = \"responseFinishedTime\"; // Count: 7\r\nexport var _DYN__CREATE_TRACK_ITEM = \"CreateTrackItem\"; // Count: 3\r\nexport var _DYN_RESPONSE = \"response\"; // Count: 4\r\nexport var _DYN_GET_ALL_RESPONSE_HEA16 = \"getAllResponseHeaders\"; // Count: 2\r\nexport var _DYN_GET_PART_APROPS = \"getPartAProps\"; // Count: 3\r\nexport var _DYN_GET_CORRELATION_CONT17 = \"getCorrelationContext\"; // Count: 2\r\nexport var _DYN_PERF_MARK = \"perfMark\"; // Count: 4\r\nexport var _DYN_AJAX_PERF_LOOKUP_DEL18 = \"ajaxPerfLookupDelay\"; // Count: 2\r\nexport var _DYN_NAME = \"name\"; // Count: 6\r\nexport var _DYN_PERF_TIMING = \"perfTiming\"; // Count: 3\r\nexport var _DYN_AJAX_DIAGNOSTICS_MES19 = \"ajaxDiagnosticsMessage\"; // Count: 3\r\nexport var _DYN_CORRELATION_CONTEXT = \"correlationContext\"; // Count: 3\r\nexport var _DYN_AJAX_TOTAL_DURATION = \"ajaxTotalDuration\"; // Count: 3\r\nexport var _DYN_EVENT_TRACE_CTX = \"eventTraceCtx\"; // Count: 3\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { Extensions, dataSanitizeUrl, dateTimeUtilsDuration, msToTimeSpan, urlGetAbsoluteUrl, urlGetCompleteUrl } from \"@microsoft/applicationinsights-common\";\r\nimport { arrForEach, isNullOrUndefined, isNumber, isString, normalizeJsName, objForEachKey, objKeys } from \"@microsoft/applicationinsights-core-js\";\r\nimport { STR_DURATION, STR_PROPERTIES } from \"./InternalConstants\";\r\nimport { _DYN_ABORTED, _DYN_ABORT_DONE, _DYN_AJAX_TOTAL_DURATION, _DYN_CORRELATION_CONTEXT, _DYN_ERROR_STATUS_TEXT, _DYN_EVENT_TRACE_CTX, _DYN_GET_ABSOLUTE_URL, _DYN_GET_PART_APROPS, _DYN_GET_TRACE_FLAGS, _DYN_GET_TRACE_ID, _DYN_HEADER_MAP, _DYN_LENGTH, _DYN_METHOD, _DYN_NAME, _DYN_OPEN_DONE, _DYN_PERF_MARK, _DYN_PERF_TIMING, _DYN_REQUEST_HEADERS, _DYN_REQUEST_SENT_TIME, _DYN_REQUEST_URL, _DYN_RESPONSE, _DYN_RESPONSE_FINISHED_TI15, _DYN_SEND_DONE, _DYN_SPAN_ID, _DYN_SPAN_ID1, _DYN_START_TIME, _DYN_STATE_CHANGE_ATTACHE14, _DYN_STATUS, _DYN_STATUS_TEXT, _DYN_TRACE_FLAGS, _DYN_TRACE_ID, _DYN_TRACE_ID0, _DYN__CREATE_TRACK_ITEM } from \"./__DynamicConstants\";\r\n/** @ignore */\r\nfunction _calcPerfDuration(resourceEntry, start, end) {\r\n var result = 0;\r\n var from = resourceEntry[start];\r\n var to = resourceEntry[end];\r\n if (from && to) {\r\n result = dateTimeUtilsDuration(from, to);\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _setPerfDuration(props, name, resourceEntry, start, end) {\r\n var result = 0;\r\n var value = _calcPerfDuration(resourceEntry, start, end);\r\n if (value) {\r\n result = _setPerfValue(props, name, msToTimeSpan(value));\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _setPerfValue(props, name, value) {\r\n var strPerf = \"ajaxPerf\";\r\n var result = 0;\r\n if (props && name && value) {\r\n var perfData = props[strPerf] = (props[strPerf] || {});\r\n perfData[name] = value;\r\n result = 1;\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _populatePerfData(ajaxData, dependency) {\r\n /*\r\n * https://developer.mozilla.org/en-US/docs/Web/API/Resource_Timing_API/Using_the_Resource_Timing_API\r\n * | -startTime\r\n * | -redirectStart\r\n * | | -redirectEnd\r\n * | | | -fetchStart\r\n * | | | | -domainLookupStart\r\n * | | | | |- domainLookupEnd\r\n * | | | | | | -connectStart\r\n * | | | | | | | -secureConnectionStart\r\n * | | | | | | | | -connectEnd\r\n * | | | | | | | | | -requestStart\r\n * | | | | | | | | | | | -responseStart\r\n * | | | | | | | | | | | | | -responseEnd\r\n * +------------+-+---+----------------+-+--+--------+-+-----------+-+------------+-+\r\n * |--redirect--| |---|--domainLookup--| |--connect--| |--request--| |--response--| |\r\n * |-------------------networkConnect----------------|\r\n * | |---------sentRequest--------|\r\n * |------------------------------------perfTotal-----------------------------------|\r\n */\r\n var resourceEntry = ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */];\r\n var props = dependency[STR_PROPERTIES /* @min:%2eproperties */] || {};\r\n var propsSet = 0;\r\n var strName = \"name\";\r\n var strStart = \"Start\";\r\n var strEnd = \"End\";\r\n var strDomainLookup = \"domainLookup\";\r\n var strConnect = \"connect\";\r\n var strRedirect = \"redirect\";\r\n var strRequest = \"request\";\r\n var strResponse = \"response\";\r\n var strStartTime = \"startTime\";\r\n var strDomainLookupStart = strDomainLookup + strStart;\r\n var strDomainLookupEnd = strDomainLookup + strEnd;\r\n var strConnectStart = strConnect + strStart;\r\n var strConnectEnd = strConnect + strEnd;\r\n var strRequestStart = strRequest + strStart;\r\n var strRequestEnd = strRequest + strEnd;\r\n var strResponseStart = strResponse + strStart;\r\n var strResponseEnd = strResponse + strEnd;\r\n var strRedirectStart = strRedirect + strStart;\r\n var strRedirectEnd = strRedirect = strEnd;\r\n var strTransferSize = \"transferSize\";\r\n var strEncodedBodySize = \"encodedBodySize\";\r\n var strDecodedBodySize = \"decodedBodySize\";\r\n var strServerTiming = \"serverTiming\";\r\n if (resourceEntry) {\r\n // redirect\r\n propsSet |= _setPerfDuration(props, strRedirect, resourceEntry, strRedirectStart, strRedirectEnd);\r\n // domainLookup\r\n propsSet |= _setPerfDuration(props, strDomainLookup, resourceEntry, strDomainLookupStart, strDomainLookupEnd);\r\n // connect\r\n propsSet |= _setPerfDuration(props, strConnect, resourceEntry, strConnectStart, strConnectEnd);\r\n // request\r\n propsSet |= _setPerfDuration(props, strRequest, resourceEntry, strRequestStart, strRequestEnd);\r\n // response\r\n propsSet |= _setPerfDuration(props, strResponse, resourceEntry, strResponseStart, strResponseEnd);\r\n // Network connection time\r\n propsSet |= _setPerfDuration(props, \"networkConnect\", resourceEntry, strStartTime, strConnectEnd);\r\n // Sent Request\r\n propsSet |= _setPerfDuration(props, \"sentRequest\", resourceEntry, strRequestStart, strResponseEnd);\r\n // PerfTotal / Duration\r\n var duration = resourceEntry[STR_DURATION /* @min:%2eduration */];\r\n if (!duration) {\r\n duration = _calcPerfDuration(resourceEntry, strStartTime, strResponseEnd) || 0;\r\n }\r\n propsSet |= _setPerfValue(props, STR_DURATION, duration);\r\n propsSet |= _setPerfValue(props, \"perfTotal\", duration);\r\n var serverTiming = resourceEntry[strServerTiming];\r\n if (serverTiming) {\r\n var server_1 = {};\r\n arrForEach(serverTiming, function (value, idx) {\r\n var name = normalizeJsName(value[strName] || \"\" + idx);\r\n var newValue = server_1[name] || {};\r\n objForEachKey(value, function (key, val) {\r\n if (key !== strName && isString(val) || isNumber(val)) {\r\n if (newValue[key]) {\r\n val = newValue[key] + \";\" + val;\r\n }\r\n if (val || !isString(val)) {\r\n // Only set the value if it has a value and it's not an empty string\r\n newValue[key] = val;\r\n }\r\n }\r\n });\r\n server_1[name] = newValue;\r\n });\r\n propsSet |= _setPerfValue(props, strServerTiming, server_1);\r\n }\r\n propsSet |= _setPerfValue(props, strTransferSize, resourceEntry[strTransferSize]);\r\n propsSet |= _setPerfValue(props, strEncodedBodySize, resourceEntry[strEncodedBodySize]);\r\n propsSet |= _setPerfValue(props, strDecodedBodySize, resourceEntry[strDecodedBodySize]);\r\n }\r\n else {\r\n if (ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */]) {\r\n propsSet |= _setPerfValue(props, \"missing\", ajaxData.perfAttempts);\r\n }\r\n }\r\n if (propsSet) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = props;\r\n }\r\n}\r\nvar XHRMonitoringState = /** @class */ (function () {\r\n function XHRMonitoringState() {\r\n var self = this;\r\n self[_DYN_OPEN_DONE /* @min:%2eopenDone */] = false;\r\n self.setRequestHeaderDone = false;\r\n self[_DYN_SEND_DONE /* @min:%2esendDone */] = false;\r\n self[_DYN_ABORT_DONE /* @min:%2eabortDone */] = false;\r\n // True, if onreadyStateChangeCallback function attached to xhr, otherwise false\r\n self[_DYN_STATE_CHANGE_ATTACHE14 /* @min:%2estateChangeAttached */] = false;\r\n }\r\n return XHRMonitoringState;\r\n}());\r\nexport { XHRMonitoringState };\r\nvar ajaxRecord = /** @class */ (function () {\r\n function ajaxRecord(traceId, spanId, logger, traceCtx) {\r\n var _a;\r\n var self = this;\r\n var _logger = logger;\r\n var strResponseText = \"responseText\";\r\n // Assigning the initial/default values within the constructor to avoid typescript from creating a bunch of\r\n // this.XXXX = null\r\n self[_DYN_PERF_MARK /* @min:%2eperfMark */] = null;\r\n self.completed = false;\r\n self.requestHeadersSize = null;\r\n self[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = null;\r\n self.responseReceivingDuration = null;\r\n self.callbackDuration = null;\r\n self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */] = null;\r\n self[_DYN_ABORTED /* @min:%2eaborted */] = 0;\r\n self.pageUrl = null;\r\n self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = null;\r\n self.requestSize = 0;\r\n self[_DYN_METHOD /* @min:%2emethod */] = null;\r\n self[_DYN_STATUS /* @min:%2estatus */] = null;\r\n self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = null;\r\n self.responseStartedTime = null;\r\n self[_DYN_RESPONSE_FINISHED_TI15 /* @min:%2eresponseFinishedTime */] = null;\r\n self.callbackFinishedTime = null;\r\n self.endTime = null;\r\n self.xhrMonitoringState = new XHRMonitoringState();\r\n self.clientFailure = 0;\r\n self[_DYN_TRACE_ID /* @min:%2etraceID */] = traceId;\r\n self[_DYN_SPAN_ID /* @min:%2espanID */] = spanId;\r\n self[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = traceCtx === null || traceCtx === void 0 ? void 0 : traceCtx.getTraceFlags();\r\n if (traceCtx) {\r\n self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */] = (_a = {},\r\n _a[_DYN_TRACE_ID0 /* @min:traceId */] = traceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */](),\r\n _a[_DYN_SPAN_ID1 /* @min:spanId */] = traceCtx.getSpanId(),\r\n _a[_DYN_TRACE_FLAGS /* @min:traceFlags */] = traceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */](),\r\n _a);\r\n }\r\n else {\r\n self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */] = null;\r\n }\r\n dynamicProto(ajaxRecord, self, function (self) {\r\n self.getAbsoluteUrl = function () {\r\n return self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] ? urlGetAbsoluteUrl(self[_DYN_REQUEST_URL /* @min:%2erequestUrl */]) : null;\r\n };\r\n self.getPathName = function () {\r\n return self[_DYN_REQUEST_URL /* @min:%2erequestUrl */] ? dataSanitizeUrl(_logger, urlGetCompleteUrl(self[_DYN_METHOD /* @min:%2emethod */], self[_DYN_REQUEST_URL /* @min:%2erequestUrl */])) : null;\r\n };\r\n self[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */] = function (ajaxType, enableRequestHeaderTracking, getResponse) {\r\n var _a;\r\n // round to 3 decimal points\r\n self.ajaxTotalDuration = Math.round(dateTimeUtilsDuration(self.requestSentTime, self.responseFinishedTime) * 1000) / 1000;\r\n if (self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */] < 0) {\r\n return null;\r\n }\r\n var dependency = (_a = {\r\n id: \"|\" + self[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + self[_DYN_SPAN_ID /* @min:%2espanID */],\r\n target: self[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */]()\r\n },\r\n _a[_DYN_NAME /* @min:name */] = self.getPathName(),\r\n _a.type = ajaxType,\r\n _a[_DYN_START_TIME /* @min:startTime */] = null,\r\n _a.duration = self[_DYN_AJAX_TOTAL_DURATION /* @min:%2eajaxTotalDuration */],\r\n _a.success = (+(self[_DYN_STATUS /* @min:%2estatus */])) >= 200 && (+(self[_DYN_STATUS /* @min:%2estatus */])) < 400,\r\n _a.responseCode = (+(self[_DYN_STATUS /* @min:%2estatus */])),\r\n _a[STR_PROPERTIES] = { HttpMethod: self[_DYN_METHOD /* @min:%2emethod */] },\r\n _a);\r\n var props = dependency[STR_PROPERTIES];\r\n if (self[_DYN_ABORTED /* @min:%2eaborted */]) {\r\n props[_DYN_ABORTED /* @min:%2eaborted */] = true;\r\n }\r\n if (self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */]) {\r\n // Set the correct dependency start time\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */] = new Date();\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */].setTime(self[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */]);\r\n }\r\n // Add Ajax perf details if available\r\n _populatePerfData(self, dependency);\r\n if (enableRequestHeaderTracking) {\r\n if (objKeys(self.requestHeaders)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n props[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = self[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */];\r\n }\r\n }\r\n if (getResponse) {\r\n var response = getResponse();\r\n if (response) {\r\n // enrich dependency target with correlation context from the server\r\n var correlationContext = response[_DYN_CORRELATION_CONTEXT /* @min:%2ecorrelationContext */];\r\n if (correlationContext) {\r\n dependency.correlationContext = /* dependency.target + \" | \" + */ correlationContext;\r\n }\r\n if (response[_DYN_HEADER_MAP /* @min:%2eheaderMap */]) {\r\n if (objKeys(response.headerMap)[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n props.responseHeaders = response[_DYN_HEADER_MAP /* @min:%2eheaderMap */];\r\n }\r\n }\r\n if (self[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */]) {\r\n if (self[_DYN_STATUS /* @min:%2estatus */] >= 400) {\r\n var responseType = response.type;\r\n if (responseType === \"\" || responseType === \"text\") {\r\n props.responseText = response.responseText ? response[_DYN_STATUS_TEXT /* @min:%2estatusText */] + \" - \" + response[strResponseText] : response[_DYN_STATUS_TEXT /* @min:%2estatusText */];\r\n }\r\n if (responseType === \"json\") {\r\n props.responseText = response.response ? response[_DYN_STATUS_TEXT /* @min:%2estatusText */] + \" - \" + JSON.stringify(response[_DYN_RESPONSE /* @min:%2eresponse */]) : response[_DYN_STATUS_TEXT /* @min:%2estatusText */];\r\n }\r\n }\r\n else if (self[_DYN_STATUS /* @min:%2estatus */] === 0) {\r\n props.responseText = response[_DYN_STATUS_TEXT /* @min:%2estatusText */] || \"\";\r\n }\r\n }\r\n }\r\n }\r\n return dependency;\r\n };\r\n self[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */] = function () {\r\n var _a;\r\n var partA = null;\r\n var traceCtx = self[_DYN_EVENT_TRACE_CTX /* @min:%2eeventTraceCtx */];\r\n if (traceCtx && (traceCtx[_DYN_TRACE_ID0 /* @min:%2etraceId */] || traceCtx[_DYN_SPAN_ID1 /* @min:%2espanId */])) {\r\n partA = {};\r\n var traceExt = partA[Extensions.TraceExt] = (_a = {},\r\n _a[_DYN_TRACE_ID /* @min:traceID */] = traceCtx[_DYN_TRACE_ID0 /* @min:%2etraceId */],\r\n _a.parentID = traceCtx[_DYN_SPAN_ID1 /* @min:%2espanId */],\r\n _a);\r\n if (!isNullOrUndefined(traceCtx[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */])) {\r\n traceExt[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = traceCtx[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n }\r\n }\r\n return partA;\r\n };\r\n });\r\n }\r\n// Removed Stub for ajaxRecord.prototype.getAbsoluteUrl.\r\n// Removed Stub for ajaxRecord.prototype.getPathName.\r\n// Removed Stub for ajaxRecord.prototype.CreateTrackItem.\r\n// Removed Stub for ajaxRecord.prototype.getPartAProps.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n ajaxRecord.__ieDyn=1;\n\n return ajaxRecord;\r\n}());\r\nexport { ajaxRecord };\r\n//# sourceMappingURL=ajaxRecord.js.map","/*\n * Application Insights JavaScript SDK - Dependencies Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { __assignFn as __assign, __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { CorrelationIdHelper, DisabledPropertyName, PropertiesPluginIdentifier, RemoteDependencyData, RequestHeaders, createDistributedTraceContextFromTrace, createTelemetryItem, createTraceParent, dateTimeUtilsNow, formatTraceParent, isInternalApplicationInsightsEndpoint } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, InstrumentFunc, InstrumentProto, _throwInternal, arrForEach, createProcessTelemetryContext, createUniqueNamespace, deepFreeze, dumpObj, eventOn, generateW3CId, getExceptionName, getGlobal, getIEVersion, getLocation, getPerformance, isFunction, isNullOrUndefined, isString, isXhrSupported, mergeEvtNamespace, objForEachKey, strPrototype, strTrim } from \"@microsoft/applicationinsights-core-js\";\r\nimport { STR_PROPERTIES } from \"./InternalConstants\";\r\nimport { _DYN_ABORTED, _DYN_ABORT_DONE, _DYN_ADD_REQUEST_CONTEXT, _DYN_AJAX_PERF_LOOKUP_DEL18, _DYN_APP_ID, _DYN_CAN_INCLUDE_CORRELAT3, _DYN_CONTEXT, _DYN_CORE, _DYN_DISABLE_AJAX_TRACKIN12, _DYN_DISABLE_FETCH_TRACKI13, _DYN_DISTRIBUTED_TRACING_5, _DYN_ENABLE_AJAX_ERROR_ST7, _DYN_ENABLE_AJAX_PERF_TRA8, _DYN_ENABLE_REQUEST_HEADE6, _DYN_ENABLE_RESPONSE_HEAD10, _DYN_ERROR_STATUS_TEXT, _DYN_EXCLUDE_REQUEST_FROM11, _DYN_GET_ABSOLUTE_URL, _DYN_GET_ALL_RESPONSE_HEA16, _DYN_GET_CORRELATION_CONT17, _DYN_GET_PART_APROPS, _DYN_GET_TRACE_FLAGS, _DYN_GET_TRACE_ID, _DYN_HEADERS, _DYN_HEADER_MAP, _DYN_INCLUDE_CORRELATION_2, _DYN_INST, _DYN_LENGTH, _DYN_MAX_AJAX_CALLS_PER_V9, _DYN_METHOD, _DYN_NAME, _DYN_OPEN_DONE, _DYN_PERF_MARK, _DYN_PERF_TIMING, _DYN_REQUEST_HEADERS, _DYN_REQUEST_SENT_TIME, _DYN_REQUEST_URL, _DYN_RESPONSE, _DYN_RESPONSE_FINISHED_TI15, _DYN_RESPONSE_TEXT, _DYN_SEND_DONE, _DYN_SET_REQUEST_HEADER, _DYN_SPAN_ID, _DYN_SPAN_ID1, _DYN_START_TIME, _DYN_STATE_CHANGE_ATTACHE14, _DYN_STATUS, _DYN_STATUS_TEXT, _DYN_TO_LOWER_CASE, _DYN_TRACE_FLAGS, _DYN_TRACE_ID, _DYN_TRACE_ID0, _DYN_TRACK_DEPENDENCY_DAT4, _DYN__CREATE_TRACK_ITEM } from \"./__DynamicConstants\";\r\nimport { ajaxRecord } from \"./ajaxRecord\";\r\nvar AJAX_MONITOR_PREFIX = \"ai.ajxmn.\";\r\nvar strDiagLog = \"diagLog\";\r\nvar strAjaxData = \"ajaxData\";\r\nvar STR_FETCH = \"fetch\";\r\nvar ERROR_HEADER = \"Failed to monitor XMLHttpRequest\";\r\nvar ERROR_PREFIX = \", monitoring data for this ajax call \";\r\nvar ERROR_POSTFIX = ERROR_PREFIX + \"may be incorrect.\";\r\nvar ERROR_NOT_SENT = ERROR_PREFIX + \"won't be sent.\";\r\nvar CORRELATION_HEADER_ERROR = \"Failed to get Request-Context correlation header as it may be not included in the response or not accessible.\";\r\nvar CUSTOM_REQUEST_CONTEXT_ERROR = \"Failed to add custom defined request context as configured call back may missing a null check.\";\r\nvar FAILED_TO_CALCULATE_DURATION_ERROR = \"Failed to calculate the duration of the \";\r\n// Using a global value so that to handle same iKey with multiple app insights instances (mostly for testing)\r\nvar _markCount = 0;\r\n/** @Ignore */\r\nfunction _supportsFetch() {\r\n var _global = getGlobal();\r\n if (!_global ||\r\n isNullOrUndefined(_global.Request) ||\r\n isNullOrUndefined(_global.Request[strPrototype]) ||\r\n isNullOrUndefined(_global[STR_FETCH])) {\r\n return null;\r\n }\r\n return _global[STR_FETCH];\r\n}\r\nvar _isWebWorker = null;\r\nfunction isWebWorker() {\r\n if (_isWebWorker == null) {\r\n try {\r\n _isWebWorker = !!(self && self instanceof WorkerGlobalScope);\r\n }\r\n catch (e) {\r\n _isWebWorker = false;\r\n }\r\n }\r\n return _isWebWorker;\r\n}\r\n/**\r\n * Determines whether ajax monitoring can be enabled on this document\r\n * @returns True if Ajax monitoring is supported on this page, otherwise false\r\n * @ignore\r\n */\r\nfunction _supportsAjaxMonitoring(ajaxMonitorInstance) {\r\n var result = false;\r\n if (isXhrSupported()) {\r\n var proto = XMLHttpRequest[strPrototype];\r\n result = !isNullOrUndefined(proto) &&\r\n !isNullOrUndefined(proto.open) && // eslint-disable-line security/detect-non-literal-fs-filename -- false positive\r\n !isNullOrUndefined(proto.send) &&\r\n !isNullOrUndefined(proto.abort);\r\n }\r\n var ieVer = getIEVersion();\r\n if (ieVer && ieVer < 9) {\r\n result = false;\r\n }\r\n if (result) {\r\n // Disable if the XmlHttpRequest can't be extended or hooked\r\n try {\r\n var xhr = new XMLHttpRequest();\r\n xhr[strAjaxData] = {};\r\n // Check that we can update the prototype\r\n var theOpen = XMLHttpRequest[strPrototype].open;\r\n XMLHttpRequest[strPrototype].open = theOpen;\r\n }\r\n catch (e) {\r\n // We can't decorate the xhr object so disable monitoring\r\n result = false;\r\n _throwInternalCritical(ajaxMonitorInstance, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to enable XMLHttpRequest monitoring, extension is not supported\", {\r\n exception: dumpObj(e)\r\n });\r\n }\r\n }\r\n return result;\r\n}\r\n/** @Ignore */\r\nfunction _getFailedAjaxDiagnosticsMessage(xhr) {\r\n var result = \"\";\r\n try {\r\n if (xhr && xhr[strAjaxData] && xhr[strAjaxData][_DYN_REQUEST_URL /* @min:%2erequestUrl */]) {\r\n result += \"(url: '\" + xhr[strAjaxData][_DYN_REQUEST_URL /* @min:%2erequestUrl */] + \"')\";\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n return result;\r\n}\r\n/** @ignore */\r\nfunction _throwInternalCritical(ajaxMonitorInstance, msgId, message, properties, isUserAct) {\r\n _throwInternal(ajaxMonitorInstance[strDiagLog](), 1 /* eLoggingSeverity.CRITICAL */, msgId, message, properties, isUserAct);\r\n}\r\n/** @ignore */\r\nfunction _throwInternalWarning(ajaxMonitorInstance, msgId, message, properties, isUserAct) {\r\n _throwInternal(ajaxMonitorInstance[strDiagLog](), 2 /* eLoggingSeverity.WARNING */, msgId, message, properties, isUserAct);\r\n}\r\n/** @Ignore */\r\nfunction _createErrorCallbackFunc(ajaxMonitorInstance, internalMessage, message) {\r\n // tslint:disable-next-line\r\n return function (args) {\r\n _throwInternalCritical(ajaxMonitorInstance, internalMessage, message, {\r\n ajaxDiagnosticsMessage: _getFailedAjaxDiagnosticsMessage(args[_DYN_INST /* @min:%2einst */]),\r\n exception: dumpObj(args.err)\r\n });\r\n };\r\n}\r\nfunction _indexOf(value, match) {\r\n if (value && match) {\r\n return value.indexOf(match);\r\n }\r\n return -1;\r\n}\r\nfunction _addHandler(container, id, theFunc) {\r\n var theHandler = {\r\n id: id,\r\n fn: theFunc\r\n };\r\n container.push(theHandler);\r\n return {\r\n remove: function () {\r\n arrForEach(container, function (initializer, idx) {\r\n if (initializer.id === theHandler.id) {\r\n container.splice(idx, 1);\r\n return -1;\r\n }\r\n });\r\n }\r\n };\r\n}\r\nfunction _processDependencyContainer(core, container, details, message) {\r\n var result = true;\r\n arrForEach(container, function (theFunc, idx) {\r\n try {\r\n if (theFunc.fn.call(null, details) === false) {\r\n result = false;\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(core && core.logger, 1 /* eLoggingSeverity.CRITICAL */, 64 /* _eInternalMessageId.TelemetryInitializerFailed */, \"Dependency \" + message + \" [#\" + idx + \"] failed: \" + getExceptionName(e), { exception: dumpObj(e) }, true);\r\n }\r\n });\r\n return result;\r\n}\r\nfunction _processDependencyListeners(listeners, core, ajaxData, xhr, input, init) {\r\n var initializersCount = listeners[_DYN_LENGTH /* @min:%2elength */];\r\n if (initializersCount > 0) {\r\n var details = {\r\n core: core,\r\n xhr: xhr,\r\n input: input,\r\n init: init,\r\n traceId: ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */],\r\n spanId: ajaxData[_DYN_SPAN_ID /* @min:%2espanID */],\r\n traceFlags: ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */],\r\n context: ajaxData[_DYN_CONTEXT /* @min:%2econtext */] || {},\r\n aborted: !!ajaxData[_DYN_ABORTED /* @min:%2eaborted */]\r\n };\r\n _processDependencyContainer(core, listeners, details, \"listener\");\r\n ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] = details[_DYN_TRACE_ID0 /* @min:%2etraceId */];\r\n ajaxData[_DYN_SPAN_ID /* @min:%2espanID */] = details[_DYN_SPAN_ID1 /* @min:%2espanId */];\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = details[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n ajaxData[_DYN_CONTEXT /* @min:%2econtext */] = details[_DYN_CONTEXT /* @min:%2econtext */];\r\n }\r\n}\r\nvar BLOB_CORE = \"*.blob.core.\";\r\nexport var DfltAjaxCorrelationHeaderExDomains = deepFreeze([\r\n BLOB_CORE + \"windows.net\",\r\n BLOB_CORE + \"chinacloudapi.cn\",\r\n BLOB_CORE + \"cloudapi.de\",\r\n BLOB_CORE + \"usgovcloudapi.net\"\r\n]);\r\nvar _internalExcludeEndpoints = [\r\n /https:\\/\\/[^\\/]*(\\.pipe\\.aria|aria\\.pipe|events\\.data|collector\\.azure)\\.[^\\/]+\\/(OneCollector\\/1|Collector\\/3)\\.0/i\r\n];\r\nfunction _getDefaultConfig() {\r\n var config = {\r\n maxAjaxCallsPerView: 500,\r\n disableAjaxTracking: false,\r\n disableFetchTracking: false,\r\n excludeRequestFromAutoTrackingPatterns: undefined,\r\n disableCorrelationHeaders: false,\r\n distributedTracingMode: 1 /* eDistributedTracingModes.AI_AND_W3C */,\r\n correlationHeaderExcludedDomains: DfltAjaxCorrelationHeaderExDomains,\r\n correlationHeaderDomains: undefined,\r\n correlationHeaderExcludePatterns: undefined,\r\n appId: undefined,\r\n enableCorsCorrelation: false,\r\n enableRequestHeaderTracking: false,\r\n enableResponseHeaderTracking: false,\r\n enableAjaxErrorStatusText: false,\r\n enableAjaxPerfTracking: false,\r\n maxAjaxPerfLookupAttempts: 3,\r\n ajaxPerfLookupDelay: 25,\r\n ignoreHeaders: [\r\n \"Authorization\",\r\n \"X-API-Key\",\r\n \"WWW-Authenticate\"\r\n ],\r\n addRequestContext: undefined,\r\n addIntEndpoints: true\r\n };\r\n return config;\r\n}\r\nfunction _getEmptyConfig() {\r\n var emptyConfig = _getDefaultConfig();\r\n objForEachKey(emptyConfig, function (value) {\r\n emptyConfig[value] = undefined;\r\n });\r\n return emptyConfig;\r\n}\r\nvar AjaxMonitor = /** @class */ (function (_super) {\r\n __extends(AjaxMonitor, _super);\r\n function AjaxMonitor() {\r\n var _this = _super.call(this) || this;\r\n _this.identifier = AjaxMonitor.identifier;\r\n _this.priority = 120;\r\n var _fetchInitialized; // fetch monitoring initialized\r\n var _xhrInitialized; // XHR monitoring initialized\r\n var _currentWindowHost;\r\n var _config;\r\n var _enableRequestHeaderTracking;\r\n var _enableAjaxErrorStatusText;\r\n var _trackAjaxAttempts;\r\n var _context;\r\n var _isUsingW3CHeaders;\r\n var _isUsingAIHeaders;\r\n var _markPrefix;\r\n var _enableAjaxPerfTracking;\r\n var _maxAjaxCallsPerView;\r\n var _enableResponseHeaderTracking;\r\n var _disabledUrls;\r\n var _disableAjaxTracking;\r\n var _disableFetchTracking;\r\n var _excludeRequestFromAutoTrackingPatterns;\r\n var _addRequestContext;\r\n var _evtNamespace;\r\n var _dependencyHandlerId;\r\n var _dependencyListeners;\r\n var _dependencyInitializers;\r\n dynamicProto(AjaxMonitor, _this, function (_self, _base) {\r\n var _addHook = _base._addHook;\r\n _initDefaults();\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n if (!_self.isInitialized()) {\r\n _base.initialize(config, core, extensions, pluginChain);\r\n _evtNamespace = mergeEvtNamespace(createUniqueNamespace(\"ajax\"), core && core.evtNamespace && core.evtNamespace());\r\n _populateDefaults(config);\r\n _instrumentXhr();\r\n _instrumentFetch();\r\n _populateContext();\r\n }\r\n };\r\n _self._doTeardown = function () {\r\n _initDefaults();\r\n };\r\n _self.trackDependencyData = function (dependency, properties) {\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], null, dependency, properties);\r\n };\r\n _self[_DYN_INCLUDE_CORRELATION_2 /* @min:%2eincludeCorrelationHeaders */] = function (ajaxData, input, init, xhr) {\r\n // Test Hook to allow the overriding of the location host\r\n var currentWindowHost = _self[\"_currentWindowHost\"] || _currentWindowHost;\r\n _processDependencyListeners(_dependencyListeners, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, xhr, input, init);\r\n if (input) { // Fetch\r\n if (CorrelationIdHelper[_DYN_CAN_INCLUDE_CORRELAT3 /* @min:%2ecanIncludeCorrelationHeader */](_config, ajaxData[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */](), currentWindowHost)) {\r\n if (!init) {\r\n init = {};\r\n }\r\n // init headers override original request headers\r\n // so, if they exist use only them, otherwise use request's because they should have been applied in the first place\r\n // not using original request headers will result in them being lost\r\n var headers = new Headers(init[_DYN_HEADERS /* @min:%2eheaders */] || (input instanceof Request ? (input[_DYN_HEADERS /* @min:%2eheaders */] || {}) : {}));\r\n if (_isUsingAIHeaders) {\r\n var id = \"|\" + ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + ajaxData[_DYN_SPAN_ID /* @min:%2espanID */];\r\n headers.set(RequestHeaders[3 /* eRequestHeaders.requestIdHeader */], id);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[3 /* eRequestHeaders.requestIdHeader */]] = id;\r\n }\r\n }\r\n var appId = _config[_DYN_APP_ID /* @min:%2eappId */] || (_context && _context[_DYN_APP_ID /* @min:%2eappId */]());\r\n if (appId) {\r\n headers.set(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */], RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]] = RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId;\r\n }\r\n }\r\n if (_isUsingW3CHeaders) {\r\n var traceFlags = ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n if (isNullOrUndefined(traceFlags)) {\r\n traceFlags = 0x01;\r\n }\r\n var traceParent = formatTraceParent(createTraceParent(ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */], ajaxData[_DYN_SPAN_ID /* @min:%2espanID */], traceFlags));\r\n headers.set(RequestHeaders[4 /* eRequestHeaders.traceParentHeader */], traceParent);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[4 /* eRequestHeaders.traceParentHeader */]] = traceParent;\r\n }\r\n }\r\n init[_DYN_HEADERS /* @min:%2eheaders */] = headers;\r\n }\r\n return init;\r\n }\r\n else if (xhr) { // XHR\r\n if (CorrelationIdHelper[_DYN_CAN_INCLUDE_CORRELAT3 /* @min:%2ecanIncludeCorrelationHeader */](_config, ajaxData[_DYN_GET_ABSOLUTE_URL /* @min:%2egetAbsoluteUrl */](), currentWindowHost)) {\r\n if (_isUsingAIHeaders) {\r\n var id = \"|\" + ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */] + \".\" + ajaxData[_DYN_SPAN_ID /* @min:%2espanID */];\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[3 /* eRequestHeaders.requestIdHeader */], id);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[3 /* eRequestHeaders.requestIdHeader */]] = id;\r\n }\r\n }\r\n var appId = _config[_DYN_APP_ID /* @min:%2eappId */] || (_context && _context[_DYN_APP_ID /* @min:%2eappId */]());\r\n if (appId) {\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[0 /* eRequestHeaders.requestContextHeader */], RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]] = RequestHeaders[2 /* eRequestHeaders.requestContextAppIdFormat */] + appId;\r\n }\r\n }\r\n if (_isUsingW3CHeaders) {\r\n var traceFlags = ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */];\r\n if (isNullOrUndefined(traceFlags)) {\r\n traceFlags = 0x01;\r\n }\r\n var traceParent = formatTraceParent(createTraceParent(ajaxData[_DYN_TRACE_ID /* @min:%2etraceID */], ajaxData[_DYN_SPAN_ID /* @min:%2espanID */], traceFlags));\r\n xhr[_DYN_SET_REQUEST_HEADER /* @min:%2esetRequestHeader */](RequestHeaders[4 /* eRequestHeaders.traceParentHeader */], traceParent);\r\n if (_enableRequestHeaderTracking) {\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][RequestHeaders[4 /* eRequestHeaders.traceParentHeader */]] = traceParent;\r\n }\r\n }\r\n }\r\n return xhr;\r\n }\r\n return undefined;\r\n };\r\n _self[_DYN_TRACK_DEPENDENCY_DAT4 /* @min:%2etrackDependencyDataInternal */] = function (dependency, properties, systemProperties) {\r\n if (_maxAjaxCallsPerView === -1 || _trackAjaxAttempts < _maxAjaxCallsPerView) {\r\n // Hack since expected format in w3c mode is |abc.def.\r\n // Non-w3c format is |abc.def\r\n // @todo Remove if better solution is available, e.g. handle in portal\r\n if ((_config[_DYN_DISTRIBUTED_TRACING_5 /* @min:%2edistributedTracingMode */] === 2 /* eDistributedTracingModes.W3C */\r\n || _config[_DYN_DISTRIBUTED_TRACING_5 /* @min:%2edistributedTracingMode */] === 1 /* eDistributedTracingModes.AI_AND_W3C */)\r\n && typeof dependency.id === \"string\" && dependency.id[dependency.id[_DYN_LENGTH /* @min:%2elength */] - 1] !== \".\") {\r\n dependency.id += \".\";\r\n }\r\n if (isNullOrUndefined(dependency[_DYN_START_TIME /* @min:%2estartTime */])) {\r\n dependency[_DYN_START_TIME /* @min:%2estartTime */] = new Date();\r\n }\r\n var item = createTelemetryItem(dependency, RemoteDependencyData.dataType, RemoteDependencyData.envelopeType, _self[strDiagLog](), properties, systemProperties);\r\n _self[_DYN_CORE /* @min:%2ecore */].track(item);\r\n }\r\n else if (_trackAjaxAttempts === _maxAjaxCallsPerView) {\r\n _throwInternalCritical(_self, 55 /* _eInternalMessageId.MaxAjaxPerPVExceeded */, \"Maximum ajax per page view limit reached, ajax monitoring is paused until the next trackPageView(). In order to increase the limit set the maxAjaxCallsPerView configuration parameter.\", true);\r\n }\r\n ++_trackAjaxAttempts;\r\n };\r\n _self.addDependencyListener = function (dependencyListener) {\r\n return _addHandler(_dependencyListeners, _dependencyHandlerId++, dependencyListener);\r\n };\r\n _self.addDependencyInitializer = function (dependencyInitializer) {\r\n return _addHandler(_dependencyInitializers, _dependencyHandlerId++, dependencyInitializer);\r\n };\r\n function _initDefaults() {\r\n var location = getLocation();\r\n _fetchInitialized = false; // fetch monitoring initialized\r\n _xhrInitialized = false; // XHR monitoring initialized\r\n _currentWindowHost = location && location.host && location.host[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n _config = AjaxMonitor.getEmptyConfig();\r\n _enableRequestHeaderTracking = false;\r\n _enableAjaxErrorStatusText = false;\r\n _trackAjaxAttempts = 0;\r\n _context = null;\r\n _isUsingW3CHeaders = false;\r\n _isUsingAIHeaders = false;\r\n _markPrefix = null;\r\n _enableAjaxPerfTracking = false;\r\n _maxAjaxCallsPerView = 0;\r\n _enableResponseHeaderTracking = false;\r\n _disabledUrls = {};\r\n _disableAjaxTracking = false;\r\n _disableFetchTracking = false;\r\n _excludeRequestFromAutoTrackingPatterns = null;\r\n _addRequestContext = null;\r\n _evtNamespace = null;\r\n _dependencyHandlerId = 0;\r\n _dependencyListeners = [];\r\n _dependencyInitializers = [];\r\n }\r\n function _populateDefaults(config) {\r\n var ctx = createProcessTelemetryContext(null, config, _self[_DYN_CORE /* @min:%2ecore */]);\r\n // Reset to the empty config\r\n _config = _getEmptyConfig();\r\n var defaultConfig = _getDefaultConfig();\r\n objForEachKey(defaultConfig, function (field, value) {\r\n _config[field] = ctx.getConfig(AjaxMonitor.identifier, field, value);\r\n });\r\n var distributedTracingMode = _config[_DYN_DISTRIBUTED_TRACING_5 /* @min:%2edistributedTracingMode */];\r\n _enableRequestHeaderTracking = _config[_DYN_ENABLE_REQUEST_HEADE6 /* @min:%2eenableRequestHeaderTracking */];\r\n _enableAjaxErrorStatusText = _config[_DYN_ENABLE_AJAX_ERROR_ST7 /* @min:%2eenableAjaxErrorStatusText */];\r\n _enableAjaxPerfTracking = _config[_DYN_ENABLE_AJAX_PERF_TRA8 /* @min:%2eenableAjaxPerfTracking */];\r\n _maxAjaxCallsPerView = _config[_DYN_MAX_AJAX_CALLS_PER_V9 /* @min:%2emaxAjaxCallsPerView */];\r\n _enableResponseHeaderTracking = _config[_DYN_ENABLE_RESPONSE_HEAD10 /* @min:%2eenableResponseHeaderTracking */];\r\n _excludeRequestFromAutoTrackingPatterns = [].concat(_config[_DYN_EXCLUDE_REQUEST_FROM11 /* @min:%2eexcludeRequestFromAutoTrackingPatterns */] || [], _config.addIntEndpoints !== false ? _internalExcludeEndpoints : []);\r\n _addRequestContext = _config[_DYN_ADD_REQUEST_CONTEXT /* @min:%2eaddRequestContext */];\r\n _isUsingAIHeaders = distributedTracingMode === 0 /* eDistributedTracingModes.AI */ || distributedTracingMode === 1 /* eDistributedTracingModes.AI_AND_W3C */;\r\n _isUsingW3CHeaders = distributedTracingMode === 1 /* eDistributedTracingModes.AI_AND_W3C */ || distributedTracingMode === 2 /* eDistributedTracingModes.W3C */;\r\n if (_enableAjaxPerfTracking) {\r\n var iKey = config.instrumentationKey || \"unkwn\";\r\n if (iKey[_DYN_LENGTH /* @min:%2elength */] > 5) {\r\n _markPrefix = AJAX_MONITOR_PREFIX + iKey.substring(iKey[_DYN_LENGTH /* @min:%2elength */] - 5) + \".\";\r\n }\r\n else {\r\n _markPrefix = AJAX_MONITOR_PREFIX + iKey + \".\";\r\n }\r\n }\r\n _disableAjaxTracking = !!_config[_DYN_DISABLE_AJAX_TRACKIN12 /* @min:%2edisableAjaxTracking */];\r\n _disableFetchTracking = !!_config[_DYN_DISABLE_FETCH_TRACKI13 /* @min:%2edisableFetchTracking */];\r\n }\r\n function _populateContext() {\r\n var propExt = _self[_DYN_CORE /* @min:%2ecore */].getPlugin(PropertiesPluginIdentifier);\r\n if (propExt) {\r\n _context = propExt.plugin[_DYN_CONTEXT /* @min:%2econtext */]; // we could move IPropertiesPlugin to common as well\r\n }\r\n }\r\n // discard the header if it's defined as ignoreHeaders in ICorrelationConfig\r\n function _canIncludeHeaders(header) {\r\n var rlt = true;\r\n if (header || _config.ignoreHeaders) {\r\n arrForEach(_config.ignoreHeaders, (function (key) {\r\n if (key[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]() === header[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]()) {\r\n rlt = false;\r\n return -1;\r\n }\r\n }));\r\n }\r\n return rlt;\r\n }\r\n // Fetch Stuff\r\n function _instrumentFetch() {\r\n var fetch = _supportsFetch();\r\n if (!fetch) {\r\n return;\r\n }\r\n var global = getGlobal();\r\n var isPolyfill = fetch.polyfill;\r\n if (!_disableFetchTracking && !_fetchInitialized) {\r\n _addHook(InstrumentFunc(global, STR_FETCH, {\r\n ns: _evtNamespace,\r\n // Add request hook\r\n req: function (callDetails, input, init) {\r\n var fetchData;\r\n if (!_disableFetchTracking && _fetchInitialized &&\r\n !_isDisabledRequest(null, input, init) &&\r\n // If we have a polyfil and XHR instrumented then let XHR report otherwise we get duplicates\r\n !(isPolyfill && _xhrInitialized)) {\r\n var ctx = callDetails.ctx();\r\n fetchData = _createFetchRecord(input, init);\r\n var newInit = _self[_DYN_INCLUDE_CORRELATION_2 /* @min:%2eincludeCorrelationHeaders */](fetchData, input, init);\r\n if (newInit !== init) {\r\n callDetails.set(1, newInit);\r\n }\r\n ctx.data = fetchData;\r\n }\r\n },\r\n rsp: function (callDetails, input) {\r\n if (!_disableFetchTracking) {\r\n var fetchData_1 = callDetails.ctx().data;\r\n if (fetchData_1) {\r\n // Replace the result with the new promise from this code\r\n callDetails.rslt = callDetails.rslt.then(function (response) {\r\n _reportFetchMetrics(callDetails, (response || {})[_DYN_STATUS /* @min:%2estatus */], input, response, fetchData_1, function () {\r\n var ajaxResponse = {\r\n statusText: (response || {})[_DYN_STATUS_TEXT /* @min:%2estatusText */],\r\n headerMap: null,\r\n correlationContext: _getFetchCorrelationContext(response)\r\n };\r\n if (_enableResponseHeaderTracking && response) {\r\n var responseHeaderMap_1 = {};\r\n response.headers.forEach(function (value, name) {\r\n if (_canIncludeHeaders(name)) {\r\n responseHeaderMap_1[name] = value;\r\n }\r\n });\r\n ajaxResponse[_DYN_HEADER_MAP /* @min:%2eheaderMap */] = responseHeaderMap_1;\r\n }\r\n return ajaxResponse;\r\n });\r\n return response;\r\n })[\"catch\"](function (reason) {\r\n _reportFetchMetrics(callDetails, 0, input, null, fetchData_1, null, { error: reason.message || dumpObj(reason) });\r\n throw reason;\r\n });\r\n }\r\n }\r\n },\r\n // Create an error callback to report any hook errors\r\n hkErr: _createErrorCallbackFunc(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to monitor Window.fetch\" + ERROR_POSTFIX)\r\n }, true, isWebWorker()));\r\n _fetchInitialized = true;\r\n }\r\n else if (isPolyfill) {\r\n // If fetch is a polyfill we need to capture the request to ensure that we correctly track\r\n // disabled request URLS (i.e. internal urls) to ensure we don't end up in a constant loop\r\n // of reporting ourselves, for example React Native uses a polyfill for fetch\r\n // Note: Polyfill implementations that don't support the \"poyyfill\" tag are not supported\r\n // the workaround is to add a polyfill property to your fetch implementation before initializing\r\n // App Insights\r\n _addHook(InstrumentFunc(global, STR_FETCH, {\r\n ns: _evtNamespace,\r\n req: function (callDetails, input, init) {\r\n // Just call so that we record any disabled URL\r\n _isDisabledRequest(null, input, init);\r\n }\r\n }));\r\n }\r\n if (isPolyfill) {\r\n // retag the instrumented fetch with the same polyfill settings this is mostly for testing\r\n // But also supports multiple App Insights usages\r\n global[STR_FETCH].polyfill = isPolyfill;\r\n }\r\n }\r\n function _hookProto(target, funcName, callbacks) {\r\n _addHook(InstrumentProto(target, funcName, callbacks));\r\n }\r\n function _instrumentXhr() {\r\n if (_supportsAjaxMonitoring(_self) && !_disableAjaxTracking && !_xhrInitialized) {\r\n // Instrument open\r\n _hookProto(XMLHttpRequest, \"open\", {\r\n ns: _evtNamespace,\r\n req: function (args, method, url, async) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = args[_DYN_INST /* @min:%2einst */];\r\n var ajaxData = xhr[strAjaxData];\r\n if (!_isDisabledRequest(xhr, url) && _isMonitoredXhrInstance(xhr, true)) {\r\n if (!ajaxData || !ajaxData.xhrMonitoringState[_DYN_OPEN_DONE /* @min:%2eopenDone */]) {\r\n // Only create a single ajaxData (even when multiple AI instances are running)\r\n _openHandler(xhr, method, url, async);\r\n }\r\n // always attach to the on ready state change (required for handling multiple instances)\r\n _attachToOnReadyStateChange(xhr);\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, ERROR_HEADER + \".open\" + ERROR_POSTFIX)\r\n });\r\n // Instrument send\r\n _hookProto(XMLHttpRequest, \"send\", {\r\n ns: _evtNamespace,\r\n req: function (args, context) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = args[_DYN_INST /* @min:%2einst */];\r\n var ajaxData = xhr[strAjaxData];\r\n if (_isMonitoredXhrInstance(xhr) && !ajaxData.xhrMonitoringState[_DYN_SEND_DONE /* @min:%2esendDone */]) {\r\n _createMarkId(\"xhr\", ajaxData);\r\n ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = dateTimeUtilsNow();\r\n _self[_DYN_INCLUDE_CORRELATION_2 /* @min:%2eincludeCorrelationHeaders */](ajaxData, undefined, undefined, xhr);\r\n ajaxData.xhrMonitoringState[_DYN_SEND_DONE /* @min:%2esendDone */] = true;\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 17 /* _eInternalMessageId.FailedMonitorAjaxSend */, ERROR_HEADER + ERROR_POSTFIX)\r\n });\r\n // Instrument abort\r\n _hookProto(XMLHttpRequest, \"abort\", {\r\n ns: _evtNamespace,\r\n req: function (args) {\r\n if (!_disableAjaxTracking) {\r\n var xhr = args[_DYN_INST /* @min:%2einst */];\r\n var ajaxData = xhr[strAjaxData];\r\n if (_isMonitoredXhrInstance(xhr) && !ajaxData.xhrMonitoringState[_DYN_ABORT_DONE /* @min:%2eabortDone */]) {\r\n ajaxData[_DYN_ABORTED /* @min:%2eaborted */] = 1;\r\n ajaxData.xhrMonitoringState[_DYN_ABORT_DONE /* @min:%2eabortDone */] = true;\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 13 /* _eInternalMessageId.FailedMonitorAjaxAbort */, ERROR_HEADER + \".abort\" + ERROR_POSTFIX)\r\n });\r\n // Instrument setRequestHeader\r\n _hookProto(XMLHttpRequest, \"setRequestHeader\", {\r\n ns: _evtNamespace,\r\n req: function (args, header, value) {\r\n if (!_disableAjaxTracking && _enableRequestHeaderTracking) {\r\n var xhr = args[_DYN_INST /* @min:%2einst */];\r\n if (_isMonitoredXhrInstance(xhr) && _canIncludeHeaders(header)) {\r\n xhr[strAjaxData][_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */][header] = value;\r\n }\r\n }\r\n },\r\n hkErr: _createErrorCallbackFunc(_self, 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */, ERROR_HEADER + \".setRequestHeader\" + ERROR_POSTFIX)\r\n });\r\n _xhrInitialized = true;\r\n }\r\n }\r\n function _isDisabledRequest(xhr, request, init) {\r\n var isDisabled = false;\r\n var theUrl = ((!isString(request) ? (request || {}).url || \"\" : request) || \"\")[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */]();\r\n // check excludeRequestFromAutoTrackingPatterns before stripping off any query string\r\n arrForEach(_excludeRequestFromAutoTrackingPatterns, function (regex) {\r\n var theRegex = regex;\r\n if (isString(regex)) {\r\n theRegex = new RegExp(regex);\r\n }\r\n if (!isDisabled) {\r\n isDisabled = theRegex.test(theUrl);\r\n }\r\n });\r\n // if request url matches with exclude regex pattern, return true and no need to check for headers\r\n if (isDisabled) {\r\n return isDisabled;\r\n }\r\n var idx = _indexOf(theUrl, \"?\");\r\n var idx2 = _indexOf(theUrl, \"#\");\r\n if (idx === -1 || (idx2 !== -1 && idx2 < idx)) {\r\n idx = idx2;\r\n }\r\n if (idx !== -1) {\r\n // Strip off any Query string\r\n theUrl = theUrl.substring(0, idx);\r\n }\r\n // check that this instance is not not used by ajax call performed inside client side monitoring to send data to collector\r\n if (!isNullOrUndefined(xhr)) {\r\n // Look on the XMLHttpRequest of the URL string value\r\n isDisabled = xhr[DisabledPropertyName] === true || theUrl[DisabledPropertyName] === true;\r\n }\r\n else if (!isNullOrUndefined(request)) { // fetch\r\n // Look for DisabledPropertyName in either Request or RequestInit\r\n isDisabled = (typeof request === \"object\" ? request[DisabledPropertyName] === true : false) ||\r\n (init ? init[DisabledPropertyName] === true : false);\r\n }\r\n // Also add extra check just in case the XHR or fetch objects where not decorated with the DisableProperty due to sealing or freezing\r\n if (!isDisabled && theUrl && isInternalApplicationInsightsEndpoint(theUrl)) {\r\n isDisabled = true;\r\n }\r\n if (isDisabled) {\r\n // Add the disabled url if not present\r\n if (!_disabledUrls[theUrl]) {\r\n _disabledUrls[theUrl] = 1;\r\n }\r\n }\r\n else {\r\n // Check to see if the url is listed as disabled\r\n if (_disabledUrls[theUrl]) {\r\n isDisabled = true;\r\n }\r\n }\r\n return isDisabled;\r\n }\r\n /// Verifies that particalar instance of XMLHttpRequest needs to be monitored\r\n /// Optional parameter. True if ajaxData must be excluded from verification\r\n /// True if instance needs to be monitored, otherwise false\r\n function _isMonitoredXhrInstance(xhr, excludeAjaxDataValidation) {\r\n var ajaxValidation = true;\r\n var initialized = _xhrInitialized;\r\n if (!isNullOrUndefined(xhr)) {\r\n ajaxValidation = excludeAjaxDataValidation === true || !isNullOrUndefined(xhr[strAjaxData]);\r\n }\r\n // checking to see that all interested functions on xhr were instrumented\r\n return initialized\r\n // checking on ajaxData to see that it was not removed in user code\r\n && ajaxValidation;\r\n }\r\n function _getDistributedTraceCtx() {\r\n var distributedTraceCtx = null;\r\n if (_self[_DYN_CORE /* @min:%2ecore */] && _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx) {\r\n distributedTraceCtx = _self[_DYN_CORE /* @min:%2ecore */].getTraceCtx(false);\r\n }\r\n // Fall back\r\n if (!distributedTraceCtx && _context && _context.telemetryTrace) {\r\n distributedTraceCtx = createDistributedTraceContextFromTrace(_context.telemetryTrace);\r\n }\r\n return distributedTraceCtx;\r\n }\r\n function _openHandler(xhr, method, url, async) {\r\n var _a;\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n var traceID = (distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */]()) || generateW3CId();\r\n var spanID = generateW3CId().substr(0, 16);\r\n var ajaxData = new ajaxRecord(traceID, spanID, _self[strDiagLog](), (_a = _self.core) === null || _a === void 0 ? void 0 : _a.getTraceCtx());\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */]();\r\n ajaxData[_DYN_METHOD /* @min:%2emethod */] = method;\r\n ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = url;\r\n ajaxData.xhrMonitoringState[_DYN_OPEN_DONE /* @min:%2eopenDone */] = true;\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = {};\r\n ajaxData.async = async;\r\n ajaxData[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */] = _enableAjaxErrorStatusText;\r\n xhr[strAjaxData] = ajaxData;\r\n }\r\n function _attachToOnReadyStateChange(xhr) {\r\n xhr[strAjaxData].xhrMonitoringState[_DYN_STATE_CHANGE_ATTACHE14 /* @min:%2estateChangeAttached */] = eventOn(xhr, \"readystatechange\", function () {\r\n try {\r\n if (xhr && xhr.readyState === 4 && _isMonitoredXhrInstance(xhr)) {\r\n _onAjaxComplete(xhr);\r\n }\r\n }\r\n catch (e) {\r\n var exceptionText = dumpObj(e);\r\n // ignore messages with c00c023f, as this a known IE9 XHR abort issue\r\n if (!exceptionText || _indexOf(exceptionText[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](), \"c00c023f\") === -1) {\r\n _throwInternalCritical(_self, 16 /* _eInternalMessageId.FailedMonitorAjaxRSC */, ERROR_HEADER + \" 'readystatechange' event handler\" + ERROR_POSTFIX, {\r\n ajaxDiagnosticsMessage: _getFailedAjaxDiagnosticsMessage(xhr),\r\n exception: exceptionText\r\n });\r\n }\r\n }\r\n }, _evtNamespace);\r\n }\r\n function _getResponseText(xhr) {\r\n try {\r\n var responseType = xhr.responseType;\r\n if (responseType === \"\" || responseType === \"text\") {\r\n // As per the specification responseText is only valid if the type is an empty string or \"text\"\r\n return xhr[_DYN_RESPONSE_TEXT /* @min:%2eresponseText */];\r\n }\r\n }\r\n catch (e) {\r\n // This shouldn't happen because of the above check -- but just in case, so just ignore\r\n }\r\n return null;\r\n }\r\n function _onAjaxComplete(xhr) {\r\n var ajaxData = xhr[strAjaxData];\r\n ajaxData[_DYN_RESPONSE_FINISHED_TI15 /* @min:%2eresponseFinishedTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_STATUS /* @min:%2estatus */] = xhr[_DYN_STATUS /* @min:%2estatus */];\r\n function _reportXhrError(e, failedProps) {\r\n var errorProps = failedProps || {};\r\n errorProps[\"ajaxDiagnosticsMessage\"] = _getFailedAjaxDiagnosticsMessage(xhr);\r\n if (e) {\r\n errorProps[\"exception\"] = dumpObj(e);\r\n }\r\n _throwInternalWarning(_self, 14 /* _eInternalMessageId.FailedMonitorAjaxDur */, FAILED_TO_CALCULATE_DURATION_ERROR + \"ajax call\" + ERROR_NOT_SENT, errorProps);\r\n }\r\n _findPerfResourceEntry(\"xmlhttprequest\", ajaxData, function () {\r\n try {\r\n var dependency = ajaxData[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */](\"Ajax\", _enableRequestHeaderTracking, function () {\r\n var ajaxResponse = {\r\n statusText: xhr[_DYN_STATUS_TEXT /* @min:%2estatusText */],\r\n headerMap: null,\r\n correlationContext: _getAjaxCorrelationContext(xhr),\r\n type: xhr.responseType,\r\n responseText: _getResponseText(xhr),\r\n response: xhr[_DYN_RESPONSE /* @min:%2eresponse */]\r\n };\r\n if (_enableResponseHeaderTracking) {\r\n var headers = xhr[_DYN_GET_ALL_RESPONSE_HEA16 /* @min:%2egetAllResponseHeaders */]();\r\n if (headers) {\r\n // xhr.getAllResponseHeaders() method returns all the response headers, separated by CRLF, as a string or null\r\n // the regex converts the header string into an array of individual headers\r\n var arr = strTrim(headers).split(/[\\r\\n]+/);\r\n var responseHeaderMap_2 = {};\r\n arrForEach(arr, function (line) {\r\n var parts = line.split(\": \");\r\n var header = parts.shift();\r\n var value = parts.join(\": \");\r\n if (_canIncludeHeaders(header)) {\r\n responseHeaderMap_2[header] = value;\r\n }\r\n });\r\n ajaxResponse[_DYN_HEADER_MAP /* @min:%2eheaderMap */] = responseHeaderMap_2;\r\n }\r\n }\r\n return ajaxResponse;\r\n });\r\n var properties = void 0;\r\n try {\r\n if (!!_addRequestContext) {\r\n properties = _addRequestContext({ status: xhr[_DYN_STATUS /* @min:%2estatus */], xhr: xhr });\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 104 /* _eInternalMessageId.FailedAddingCustomDefinedRequestContext */, CUSTOM_REQUEST_CONTEXT_ERROR);\r\n }\r\n if (dependency) {\r\n if (properties !== undefined) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = __assign(__assign({}, dependency.properties), properties);\r\n }\r\n var sysProperties = ajaxData[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */]();\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, dependency, null, sysProperties);\r\n }\r\n else {\r\n _reportXhrError(null, {\r\n requestSentTime: ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */],\r\n responseFinishedTime: ajaxData[_DYN_RESPONSE_FINISHED_TI15 /* @min:%2eresponseFinishedTime */]\r\n });\r\n }\r\n }\r\n finally {\r\n // cleanup telemetry data\r\n try {\r\n xhr[strAjaxData] = null;\r\n }\r\n catch (e) {\r\n // May throw in environments that prevent extension or freeze xhr\r\n }\r\n }\r\n }, function (e) {\r\n _reportXhrError(e, null);\r\n });\r\n }\r\n function _getAjaxCorrelationContext(xhr) {\r\n try {\r\n var responseHeadersString = xhr[_DYN_GET_ALL_RESPONSE_HEA16 /* @min:%2egetAllResponseHeaders */]();\r\n if (responseHeadersString !== null) {\r\n var index = _indexOf(responseHeadersString[_DYN_TO_LOWER_CASE /* @min:%2etoLowerCase */](), RequestHeaders[8 /* eRequestHeaders.requestContextHeaderLowerCase */]);\r\n if (index !== -1) {\r\n var responseHeader = xhr.getResponseHeader(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]);\r\n return CorrelationIdHelper[_DYN_GET_CORRELATION_CONT17 /* @min:%2egetCorrelationContext */](responseHeader);\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, CORRELATION_HEADER_ERROR, {\r\n ajaxDiagnosticsMessage: _getFailedAjaxDiagnosticsMessage(xhr),\r\n exception: dumpObj(e)\r\n });\r\n }\r\n }\r\n function _createMarkId(type, ajaxData) {\r\n if (ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] && _markPrefix && _enableAjaxPerfTracking) {\r\n var performance_1 = getPerformance();\r\n if (performance_1 && isFunction(performance_1.mark)) {\r\n _markCount++;\r\n var markId = _markPrefix + type + \"#\" + _markCount;\r\n performance_1.mark(markId);\r\n var entries = performance_1.getEntriesByName(markId);\r\n if (entries && entries[_DYN_LENGTH /* @min:%2elength */] === 1) {\r\n ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */] = entries[0];\r\n }\r\n }\r\n }\r\n }\r\n function _findPerfResourceEntry(initiatorType, ajaxData, trackCallback, reportError) {\r\n var perfMark = ajaxData[_DYN_PERF_MARK /* @min:%2eperfMark */];\r\n var performance = getPerformance();\r\n var maxAttempts = _config.maxAjaxPerfLookupAttempts;\r\n var retryDelay = _config[_DYN_AJAX_PERF_LOOKUP_DEL18 /* @min:%2eajaxPerfLookupDelay */];\r\n var requestUrl = ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */];\r\n var attempt = 0;\r\n (function locateResourceTiming() {\r\n try {\r\n if (performance && perfMark) {\r\n attempt++;\r\n var perfTiming = null;\r\n var entries = performance.getEntries();\r\n for (var lp = entries[_DYN_LENGTH /* @min:%2elength */] - 1; lp >= 0; lp--) {\r\n var entry = entries[lp];\r\n if (entry) {\r\n if (entry.entryType === \"resource\") {\r\n if (entry.initiatorType === initiatorType &&\r\n (_indexOf(entry[_DYN_NAME /* @min:%2ename */], requestUrl) !== -1 || _indexOf(requestUrl, entry[_DYN_NAME /* @min:%2ename */]) !== -1)) {\r\n perfTiming = entry;\r\n }\r\n }\r\n else if (entry.entryType === \"mark\" && entry[_DYN_NAME /* @min:%2ename */] === perfMark[_DYN_NAME /* @min:%2ename */]) {\r\n // We hit the start event\r\n ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */] = perfTiming;\r\n break;\r\n }\r\n if (entry[_DYN_START_TIME /* @min:%2estartTime */] < perfMark[_DYN_START_TIME /* @min:%2estartTime */] - 1000) {\r\n // Fallback to try and reduce the time spent looking for the perf entry\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n if (!perfMark || // - we don't have a perfMark or\r\n ajaxData[_DYN_PERF_TIMING /* @min:%2eperfTiming */] || // - we have not found the perf entry or\r\n attempt >= maxAttempts || // - we have tried too many attempts or\r\n ajaxData.async === false) { // - this is a sync request\r\n if (perfMark && isFunction(performance.clearMarks)) {\r\n // Remove the mark so we don't fill up the performance resources too much\r\n performance.clearMarks(perfMark[_DYN_NAME /* @min:%2ename */]);\r\n }\r\n ajaxData.perfAttempts = attempt;\r\n // just continue and report the track event\r\n trackCallback();\r\n }\r\n else {\r\n // We need to wait for the browser to populate the window.performance entry\r\n // This needs to be at least 1ms as waiting <= 1 (on firefox) is not enough time for fetch or xhr,\r\n // this is a scheduling issue for the browser implementation\r\n setTimeout(locateResourceTiming, retryDelay);\r\n }\r\n }\r\n catch (e) {\r\n reportError(e);\r\n }\r\n })();\r\n }\r\n function _createFetchRecord(input, init) {\r\n var _a;\r\n var distributedTraceCtx = _getDistributedTraceCtx();\r\n var traceID = (distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_ID /* @min:%2egetTraceId */]()) || generateW3CId();\r\n var spanID = generateW3CId().substr(0, 16);\r\n var ajaxData = new ajaxRecord(traceID, spanID, _self[strDiagLog](), (_a = _self.core) === null || _a === void 0 ? void 0 : _a.getTraceCtx());\r\n ajaxData[_DYN_TRACE_FLAGS /* @min:%2etraceFlags */] = distributedTraceCtx && distributedTraceCtx[_DYN_GET_TRACE_FLAGS /* @min:%2egetTraceFlags */]();\r\n ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_ERROR_STATUS_TEXT /* @min:%2eerrorStatusText */] = _enableAjaxErrorStatusText;\r\n if (input instanceof Request) {\r\n ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = input ? input.url : \"\";\r\n }\r\n else {\r\n ajaxData[_DYN_REQUEST_URL /* @min:%2erequestUrl */] = input;\r\n }\r\n var method = \"GET\";\r\n if (init && init[_DYN_METHOD /* @min:%2emethod */]) {\r\n method = init[_DYN_METHOD /* @min:%2emethod */];\r\n }\r\n else if (input && input instanceof Request) {\r\n method = input[_DYN_METHOD /* @min:%2emethod */];\r\n }\r\n ajaxData[_DYN_METHOD /* @min:%2emethod */] = method;\r\n var requestHeaders = {};\r\n if (_enableRequestHeaderTracking) {\r\n var headers = new Headers((init ? init[_DYN_HEADERS /* @min:%2eheaders */] : 0) || (input instanceof Request ? (input[_DYN_HEADERS /* @min:%2eheaders */] || {}) : {}));\r\n headers.forEach(function (value, key) {\r\n if (_canIncludeHeaders(key)) {\r\n requestHeaders[key] = value;\r\n }\r\n });\r\n }\r\n ajaxData[_DYN_REQUEST_HEADERS /* @min:%2erequestHeaders */] = requestHeaders;\r\n _createMarkId(STR_FETCH, ajaxData);\r\n return ajaxData;\r\n }\r\n function _getFailedFetchDiagnosticsMessage(input) {\r\n var result = \"\";\r\n try {\r\n if (!isNullOrUndefined(input)) {\r\n if (typeof (input) === \"string\") {\r\n result += \"(url: '\".concat(input, \"')\");\r\n }\r\n else {\r\n result += \"(url: '\".concat(input.url, \"')\");\r\n }\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalCritical(_self, 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */, \"Failed to grab failed fetch diagnostics message\", { exception: dumpObj(e) });\r\n }\r\n return result;\r\n }\r\n function _reportFetchMetrics(callDetails, status, input, response, ajaxData, getResponse, properties) {\r\n if (!ajaxData) {\r\n return;\r\n }\r\n function _reportFetchError(msgId, e, failedProps) {\r\n var errorProps = failedProps || {};\r\n errorProps[\"fetchDiagnosticsMessage\"] = _getFailedFetchDiagnosticsMessage(input);\r\n if (e) {\r\n errorProps[\"exception\"] = dumpObj(e);\r\n }\r\n _throwInternalWarning(_self, msgId, FAILED_TO_CALCULATE_DURATION_ERROR + \"fetch call\" + ERROR_NOT_SENT, errorProps);\r\n }\r\n ajaxData[_DYN_RESPONSE_FINISHED_TI15 /* @min:%2eresponseFinishedTime */] = dateTimeUtilsNow();\r\n ajaxData[_DYN_STATUS /* @min:%2estatus */] = status;\r\n _findPerfResourceEntry(STR_FETCH, ajaxData, function () {\r\n var dependency = ajaxData[_DYN__CREATE_TRACK_ITEM /* @min:%2eCreateTrackItem */](\"Fetch\", _enableRequestHeaderTracking, getResponse);\r\n var properties;\r\n try {\r\n if (!!_addRequestContext) {\r\n properties = _addRequestContext({ status: status, request: input, response: response });\r\n }\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 104 /* _eInternalMessageId.FailedAddingCustomDefinedRequestContext */, CUSTOM_REQUEST_CONTEXT_ERROR);\r\n }\r\n if (dependency) {\r\n if (properties !== undefined) {\r\n dependency[STR_PROPERTIES /* @min:%2eproperties */] = __assign(__assign({}, dependency.properties), properties);\r\n }\r\n var sysProperties = ajaxData[_DYN_GET_PART_APROPS /* @min:%2egetPartAProps */]();\r\n _reportDependencyInternal(_dependencyInitializers, _self[_DYN_CORE /* @min:%2ecore */], ajaxData, dependency, null, sysProperties);\r\n }\r\n else {\r\n _reportFetchError(14 /* _eInternalMessageId.FailedMonitorAjaxDur */, null, {\r\n requestSentTime: ajaxData[_DYN_REQUEST_SENT_TIME /* @min:%2erequestSentTime */],\r\n responseFinishedTime: ajaxData[_DYN_RESPONSE_FINISHED_TI15 /* @min:%2eresponseFinishedTime */]\r\n });\r\n }\r\n }, function (e) {\r\n _reportFetchError(18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, e, null);\r\n });\r\n }\r\n function _getFetchCorrelationContext(response) {\r\n if (response && response[_DYN_HEADERS /* @min:%2eheaders */]) {\r\n try {\r\n var responseHeader = response[_DYN_HEADERS /* @min:%2eheaders */].get(RequestHeaders[0 /* eRequestHeaders.requestContextHeader */]);\r\n return CorrelationIdHelper[_DYN_GET_CORRELATION_CONT17 /* @min:%2egetCorrelationContext */](responseHeader);\r\n }\r\n catch (e) {\r\n _throwInternalWarning(_self, 18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */, CORRELATION_HEADER_ERROR, {\r\n fetchDiagnosticsMessage: _getFailedFetchDiagnosticsMessage(response),\r\n exception: dumpObj(e)\r\n });\r\n }\r\n }\r\n }\r\n function _reportDependencyInternal(initializers, core, ajaxData, dependency, properties, systemProperties) {\r\n var result = true;\r\n var initializersCount = initializers[_DYN_LENGTH /* @min:%2elength */];\r\n if (initializersCount > 0) {\r\n var details = {\r\n item: dependency,\r\n properties: properties,\r\n sysProperties: systemProperties,\r\n context: ajaxData ? ajaxData[_DYN_CONTEXT /* @min:%2econtext */] : null,\r\n aborted: ajaxData ? !!ajaxData[_DYN_ABORTED /* @min:%2eaborted */] : false\r\n };\r\n result = _processDependencyContainer(core, initializers, details, \"initializer\");\r\n }\r\n if (result) {\r\n _self[_DYN_TRACK_DEPENDENCY_DAT4 /* @min:%2etrackDependencyDataInternal */](dependency, properties, systemProperties);\r\n }\r\n }\r\n });\r\n return _this;\r\n }\r\n// Removed Stub for AjaxMonitor.prototype.initialize.\r\n AjaxMonitor.prototype.processTelemetry = function (item, itemCtx) {\r\n this.processNext(item, itemCtx);\r\n };\r\n// Removed Stub for AjaxMonitor.prototype.trackDependencyData.\r\n// Removed Stub for AjaxMonitor.prototype.includeCorrelationHeaders.\r\n// Removed Stub for AjaxMonitor.prototype.addDependencyListener.\r\n /**\r\n * Add an dependency telemetry initializer callback function to allow populating additional properties or drop the request.\r\n * It is called after the dependency call has completed and any available performance details are available. A dependency\r\n * initializer is similar to the TelemetryInitializer function but it allows you to block the reporting of the dependency\r\n * request so that it doesn't count against the `maxAjaxCallsPerView`.\r\n * @param dependencyInitializer - The Dependency Telemetry Initializer function\r\n * @returns - A IDependencyInitializerHandler to enable the initializer to be removed\r\n */\r\n AjaxMonitor.prototype.addDependencyInitializer = function (dependencyInitializer) {\r\n return null;\r\n };\r\n// Removed Stub for AjaxMonitor.prototype.trackDependencyDataInternal.\r\n AjaxMonitor.identifier = \"AjaxDependencyPlugin\";\r\n AjaxMonitor.getDefaultConfig = _getDefaultConfig;\r\n AjaxMonitor.getEmptyConfig = _getEmptyConfig;\r\n return AjaxMonitor;\r\n}(BaseTelemetryPlugin));\r\nexport { AjaxMonitor };\r\n//# sourceMappingURL=ajax.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nexport var strShimFunction = \"function\";\r\nexport var strShimObject = \"object\";\r\nexport var strShimUndefined = \"undefined\";\r\nexport var strShimPrototype = \"prototype\";\r\nexport var strShimHasOwnProperty = \"hasOwnProperty\";\r\nexport var strDefault = \"default\";\r\nexport var ObjClass = Object;\r\nexport var ObjProto = ObjClass[strShimPrototype];\r\nexport var ObjAssign = ObjClass[\"assign\"];\r\nexport var ObjCreate = ObjClass[\"create\"];\r\nexport var ObjDefineProperty = ObjClass[\"defineProperty\"];\r\nexport var ObjHasOwnProperty = ObjProto[strShimHasOwnProperty];\r\n//# sourceMappingURL=Constants.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjCreate, strShimFunction, strShimObject, strShimPrototype, strShimUndefined } from \"./Constants\";\r\nvar _cachedGlobal = null;\r\n/**\r\n * Returns the current global scope object, for a normal web page this will be the current\r\n * window, for a Web Worker this will be current worker global scope via \"self\". The internal\r\n * implementation returns the first available instance object in the following order\r\n * - globalThis (New standard)\r\n * - self (Will return the current window instance for supported browsers)\r\n * - window (fallback for older browser implementations)\r\n * - global (NodeJS standard)\r\n * - (When all else fails)\r\n * While the return type is a Window for the normal case, not all environments will support all\r\n * of the properties or functions.\r\n */\r\nexport function getGlobal(useCached) {\r\n if (useCached === void 0) { useCached = true; }\r\n var result = useCached === false ? null : _cachedGlobal;\r\n if (!result) {\r\n if (typeof globalThis !== strShimUndefined) {\r\n result = globalThis;\r\n }\r\n if (!result && typeof self !== strShimUndefined) {\r\n result = self;\r\n }\r\n if (!result && typeof window !== strShimUndefined) {\r\n result = window;\r\n }\r\n if (!result && typeof global !== strShimUndefined) {\r\n result = global;\r\n }\r\n _cachedGlobal = result;\r\n }\r\n return result;\r\n}\r\nexport function throwTypeError(message) {\r\n throw new TypeError(message);\r\n}\r\n/**\r\n * Creates an object that has the specified prototype, and that optionally contains specified properties. This helper exists to avoid adding a polyfil\r\n * for older browsers that do not define Object.create eg. ES3 only, IE8 just in case any page checks for presence/absence of the prototype implementation.\r\n * Note: For consistency this will not use the Object.create implementation if it exists as this would cause a testing requirement to test with and without the implementations\r\n * @param obj Object to use as a prototype. May be null\r\n */\r\nexport function objCreateFn(obj) {\r\n var func = ObjCreate;\r\n // Use build in Object.create\r\n if (func) {\r\n // Use Object create method if it exists\r\n return func(obj);\r\n }\r\n if (obj == null) {\r\n return {};\r\n }\r\n var type = typeof obj;\r\n if (type !== strShimObject && type !== strShimFunction) {\r\n throwTypeError(\"Object prototype may only be an Object:\" + obj);\r\n }\r\n function tmpFunc() { }\r\n tmpFunc[strShimPrototype] = obj;\r\n return new tmpFunc();\r\n}\r\n//# sourceMappingURL=Helpers.js.map","// Copyright (c) Microsoft Corporation. All rights reserved.\r\n// Licensed under the MIT License.\r\nimport { ObjAssign, ObjClass, ObjCreate, ObjDefineProperty, ObjHasOwnProperty, ObjProto, strDefault, strShimFunction, strShimHasOwnProperty, strShimPrototype } from \"./Constants\";\r\nimport { getGlobal, objCreateFn, throwTypeError } from \"./Helpers\";\r\n// Most of these functions have been directly shamelessly \"lifted\" from the https://github.com/@microsoft/tslib and\r\n// modified to be ES3 compatible and applying several minification and tree-shaking techniques so that Application Insights\r\n// can successfully use TypeScript \"importHelpers\" which imports tslib during compilation but it will use these at runtime\r\n// Which is also why all of the functions have not been included as Application Insights currently doesn't use or require\r\n// them.\r\nexport var SymbolObj = (getGlobal() || {})[\"Symbol\"];\r\nexport var ReflectObj = (getGlobal() || {})[\"Reflect\"];\r\nexport var __hasSymbol = !!SymbolObj;\r\nexport var __hasReflect = !!ReflectObj;\r\nvar strDecorate = \"decorate\";\r\nvar strMetadata = \"metadata\";\r\nvar strGetOwnPropertySymbols = \"getOwnPropertySymbols\";\r\nvar strIterator = \"iterator\";\r\nexport var __objAssignFnImpl = function (t) {\r\n // tslint:disable-next-line: ban-comma-operator\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) {\r\n if (ObjProto[strShimHasOwnProperty].call(s, p)) {\r\n t[p] = s[p];\r\n }\r\n }\r\n }\r\n return t;\r\n};\r\nexport var __assignFn = ObjAssign || __objAssignFnImpl;\r\n// tslint:disable-next-line: only-arrow-functions\r\nvar extendStaticsFn = function (d, b) {\r\n extendStaticsFn = ObjClass[\"setPrototypeOf\"] ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n ({ __proto__: [] } instanceof Array && function (d, b) {\r\n d.__proto__ = b;\r\n }) ||\r\n // tslint:disable-next-line: only-arrow-functions\r\n function (d, b) {\r\n for (var p in b) {\r\n if (b[strShimHasOwnProperty](p)) {\r\n d[p] = b[p];\r\n }\r\n }\r\n };\r\n return extendStaticsFn(d, b);\r\n};\r\nexport function __extendsFn(d, b) {\r\n if (typeof b !== strShimFunction && b !== null) {\r\n throwTypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n }\r\n extendStaticsFn(d, b);\r\n function __() {\r\n this.constructor = d;\r\n }\r\n // tslint:disable-next-line: ban-comma-operator\r\n d[strShimPrototype] = b === null ? objCreateFn(b) : (__[strShimPrototype] = b[strShimPrototype], new __());\r\n}\r\nexport function __restFn(s, e) {\r\n var t = {};\r\n for (var k in s) {\r\n if (ObjHasOwnProperty.call(s, k) && e.indexOf(k) < 0) {\r\n t[k] = s[k];\r\n }\r\n }\r\n if (s != null && typeof ObjClass[strGetOwnPropertySymbols] === strShimFunction) {\r\n for (var i = 0, p = ObjClass[strGetOwnPropertySymbols](s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && ObjProto[\"propertyIsEnumerable\"].call(s, p[i])) {\r\n t[p[i]] = s[p[i]];\r\n }\r\n }\r\n }\r\n return t;\r\n}\r\nexport function __decorateFn(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = ObjClass[\"getOwnPropertyDescriptor\"](target, key) : desc, d;\r\n if (__hasReflect && typeof ReflectObj[strDecorate] === strShimFunction) {\r\n r = ReflectObj[strDecorate](decorators, target, key, desc);\r\n }\r\n else {\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n // eslint-disable-next-line no-cond-assign\r\n if (d = decorators[i]) {\r\n r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n }\r\n }\r\n }\r\n // tslint:disable-next-line:ban-comma-operator\r\n return c > 3 && r && ObjDefineProperty(target, key, r), r;\r\n}\r\nexport function __paramFn(paramIndex, decorator) {\r\n return function (target, key) {\r\n decorator(target, key, paramIndex);\r\n };\r\n}\r\nexport function __metadataFn(metadataKey, metadataValue) {\r\n if (__hasReflect && ReflectObj[strMetadata] === strShimFunction) {\r\n return ReflectObj[strMetadata](metadataKey, metadataValue);\r\n }\r\n}\r\nexport function __exportStarFn(m, o) {\r\n for (var p in m) {\r\n if (p !== strDefault && !ObjHasOwnProperty.call(o, p)) {\r\n __createBindingFn(o, m, p);\r\n }\r\n }\r\n}\r\nexport function __createBindingFn(o, m, k, k2) {\r\n if (k2 === undefined) {\r\n k2 = k;\r\n }\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(o, k2, {\r\n enumerable: true,\r\n get: function () {\r\n return m[k];\r\n }\r\n });\r\n }\r\n else {\r\n o[k2] = m[k];\r\n }\r\n}\r\nexport function __valuesFn(o) {\r\n var s = typeof SymbolObj === strShimFunction && SymbolObj[strIterator], m = s && o[s], i = 0;\r\n if (m) {\r\n return m.call(o);\r\n }\r\n if (o && typeof o.length === \"number\") {\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) {\r\n o = void 0;\r\n }\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n }\r\n throwTypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\nexport function __readFn(o, n) {\r\n var m = typeof SymbolObj === strShimFunction && o[SymbolObj[strIterator]];\r\n if (!m) {\r\n return o;\r\n }\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) {\r\n ar.push(r.value);\r\n }\r\n }\r\n catch (error) {\r\n e = {\r\n error: error\r\n };\r\n }\r\n finally {\r\n try {\r\n // tslint:disable-next-line:no-conditional-assignment\r\n if (r && !r.done && (m = i[\"return\"])) {\r\n m.call(i);\r\n }\r\n }\r\n finally {\r\n if (e) {\r\n // eslint-disable-next-line no-unsafe-finally\r\n throw e.error;\r\n }\r\n }\r\n }\r\n return ar;\r\n}\r\n/** @deprecated */\r\nexport function __spreadArraysFn() {\r\n var theArgs = arguments;\r\n // Calculate new total size\r\n for (var s = 0, i = 0, il = theArgs.length; i < il; i++) {\r\n s += theArgs[i].length;\r\n }\r\n // Create new full array\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++) {\r\n for (var a = theArgs[i], j = 0, jl = a.length; j < jl; j++, k++) {\r\n r[k] = a[j];\r\n }\r\n }\r\n return r;\r\n}\r\nexport function __spreadArrayFn(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\r\n to[j] = from[i];\r\n }\r\n return to;\r\n}\r\nexport function __makeTemplateObjectFn(cooked, raw) {\r\n if (ObjDefineProperty) {\r\n ObjDefineProperty(cooked, \"raw\", { value: raw });\r\n }\r\n else {\r\n cooked.raw = raw;\r\n }\r\n return cooked;\r\n}\r\nexport function __importStarFn(mod) {\r\n if (mod && mod.__esModule) {\r\n return mod;\r\n }\r\n var result = {};\r\n if (mod != null) {\r\n for (var k in mod) {\r\n if (k !== strDefault && Object.prototype.hasOwnProperty.call(mod, k)) {\r\n __createBindingFn(result, mod, k);\r\n }\r\n }\r\n }\r\n // Set default module\r\n if (!!ObjCreate) {\r\n ObjDefineProperty(result, strDefault, { enumerable: true, value: mod });\r\n }\r\n else {\r\n result[strDefault] = mod;\r\n }\r\n return result;\r\n}\r\nexport function __importDefaultFn(mod) {\r\n return (mod && mod.__esModule) ? mod : { strDefault: mod };\r\n}\r\n//# sourceMappingURL=TsLibShims.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Application = /** @class */ (function () {\r\n function Application() {\r\n }\r\n return Application;\r\n}());\r\nexport { Application };\r\n//# sourceMappingURL=Application.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Device = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the Device class\r\n */\r\n function Device() {\r\n // don't attempt to fingerprint browsers\r\n this.id = \"browser\";\r\n // Device type is a dimension in our data platform\r\n // Setting it to 'Browser' allows to separate client and server dependencies/exceptions\r\n this.deviceClass = \"Browser\";\r\n }\r\n return Device;\r\n}());\r\nexport { Device };\r\n//# sourceMappingURL=Device.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_SESSION_MANAGER = \"sessionManager\"; // Count: 3\r\nexport var _DYN_UPDATE = \"update\"; // Count: 4\r\nexport var _DYN_IS_USER_COOKIE_SET = \"isUserCookieSet\"; // Count: 4\r\nexport var _DYN_IS_NEW_USER = \"isNewUser\"; // Count: 4\r\nexport var _DYN_GET_TRACE_CTX = \"getTraceCtx\"; // Count: 3\r\nexport var _DYN_TELEMETRY_TRACE = \"telemetryTrace\"; // Count: 3\r\nexport var _DYN_APPLY_SESSION_CONTEX0 = \"applySessionContext\"; // Count: 2\r\nexport var _DYN_APPLY_APPLICATION_CO1 = \"applyApplicationContext\"; // Count: 2\r\nexport var _DYN_APPLY_DEVICE_CONTEXT = \"applyDeviceContext\"; // Count: 2\r\nexport var _DYN_APPLY_OPERATION_CONT2 = \"applyOperationContext\"; // Count: 2\r\nexport var _DYN_APPLY_USER_CONTEXT = \"applyUserContext\"; // Count: 2\r\nexport var _DYN_APPLY_OPERATING_SYST3 = \"applyOperatingSystemContxt\"; // Count: 2\r\nexport var _DYN_APPLY_LOCATION_CONTE4 = \"applyLocationContext\"; // Count: 2\r\nexport var _DYN_APPLY_INTERNAL_CONTE5 = \"applyInternalContext\"; // Count: 2\r\nexport var _DYN_ACCOUNT_ID = \"accountId\"; // Count: 8\r\nexport var _DYN_SDK_EXTENSION = \"sdkExtension\"; // Count: 4\r\nexport var _DYN_GET_SESSION_ID = \"getSessionId\"; // Count: 4\r\nexport var _DYN_NAME_PREFIX = \"namePrefix\"; // Count: 7\r\nexport var _DYN_SESSION_COOKIE_POSTF6 = \"sessionCookiePostfix\"; // Count: 4\r\nexport var _DYN_USER_COOKIE_POSTFIX = \"userCookiePostfix\"; // Count: 4\r\nexport var _DYN_ID_LENGTH = \"idLength\"; // Count: 5\r\nexport var _DYN_GET_NEW_ID = \"getNewId\"; // Count: 6\r\nexport var _DYN_LENGTH = \"length\"; // Count: 4\r\nexport var _DYN_AUTOMATIC_SESSION = \"automaticSession\"; // Count: 5\r\nexport var _DYN_AUTHENTICATED_ID = \"authenticatedId\"; // Count: 6\r\nexport var _DYN_SESSION_EXPIRATION_M7 = \"sessionExpirationMs\"; // Count: 5\r\nexport var _DYN_SESSION_RENEWAL_MS = \"sessionRenewalMs\"; // Count: 4\r\nexport var _DYN_CONFIG = \"config\"; // Count: 4\r\nexport var _DYN_ACQUISITION_DATE = \"acquisitionDate\"; // Count: 5\r\nexport var _DYN_RENEWAL_DATE = \"renewalDate\"; // Count: 4\r\nexport var _DYN_COOKIE_DOMAIN = \"cookieDomain\"; // Count: 3\r\nexport var _DYN_JOIN = \"join\"; // Count: 5\r\nexport var _DYN_COOKIE_SEPARATOR = \"cookieSeparator\"; // Count: 5\r\nexport var _DYN_AUTH_USER_COOKIE_NAM8 = \"authUserCookieName\"; // Count: 3\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { _DYN_SDK_EXTENSION } from \"../__DynamicConstants\";\r\nvar Version = '2.8.14';\r\nvar Internal = /** @class */ (function () {\r\n /**\r\n * Constructs a new instance of the internal telemetry data class.\r\n */\r\n function Internal(config) {\r\n this.sdkVersion = (config[_DYN_SDK_EXTENSION /* @min:%2esdkExtension */] && config[_DYN_SDK_EXTENSION /* @min:%2esdkExtension */]() ? config[_DYN_SDK_EXTENSION /* @min:%2esdkExtension */]() + \"_\" : \"\") + \"javascript:\" + Version;\r\n }\r\n return Internal;\r\n}());\r\nexport { Internal };\r\n//# sourceMappingURL=Internal.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nvar Location = /** @class */ (function () {\r\n function Location() {\r\n }\r\n return Location;\r\n}());\r\nexport { Location };\r\n//# sourceMappingURL=Location.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlCanUseLocalStorage, utlGetLocalStorage, utlSetLocalStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, dateNow, dumpObj, getExceptionName, isFunction, newId, safeGetCookieMgr, safeGetLogger } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_ACQUISITION_DATE, _DYN_AUTOMATIC_SESSION, _DYN_CONFIG, _DYN_COOKIE_DOMAIN, _DYN_GET_NEW_ID, _DYN_ID_LENGTH, _DYN_JOIN, _DYN_LENGTH, _DYN_NAME_PREFIX, _DYN_RENEWAL_DATE, _DYN_SESSION_COOKIE_POSTF6, _DYN_SESSION_EXPIRATION_M7, _DYN_SESSION_RENEWAL_MS, _DYN_UPDATE } from \"../__DynamicConstants\";\r\nvar cookieNameConst = \"ai_session\";\r\nvar Session = /** @class */ (function () {\r\n function Session() {\r\n }\r\n return Session;\r\n}());\r\nexport { Session };\r\nvar _SessionManager = /** @class */ (function () {\r\n function _SessionManager(config, core) {\r\n var self = this;\r\n var _storageNamePrefix;\r\n var _cookieUpdatedTimestamp;\r\n var _logger = safeGetLogger(core);\r\n var _cookieManager = safeGetCookieMgr(core);\r\n dynamicProto(_SessionManager, self, function (_self) {\r\n if (!config) {\r\n config = {};\r\n }\r\n if (!isFunction(config[_DYN_SESSION_EXPIRATION_M7 /* @min:%2esessionExpirationMs */])) {\r\n config[_DYN_SESSION_EXPIRATION_M7 /* @min:%2esessionExpirationMs */] = function () { return _SessionManager.acquisitionSpan; };\r\n }\r\n if (!isFunction(config[_DYN_SESSION_RENEWAL_MS /* @min:%2esessionRenewalMs */])) {\r\n config[_DYN_SESSION_RENEWAL_MS /* @min:%2esessionRenewalMs */] = function () { return _SessionManager.renewalSpan; };\r\n }\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = config;\r\n // sessionCookiePostfix takes the preference if it is configured, otherwise takes namePrefix if configured.\r\n var sessionCookiePostfix = (_self.config[_DYN_SESSION_COOKIE_POSTF6 /* @min:%2esessionCookiePostfix */] && _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_SESSION_COOKIE_POSTF6 /* @min:%2esessionCookiePostfix */]()) ?\r\n _self.config[_DYN_SESSION_COOKIE_POSTF6 /* @min:%2esessionCookiePostfix */]() :\r\n ((_self.config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] && _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_NAME_PREFIX /* @min:%2enamePrefix */]()) ? _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() : \"\");\r\n _storageNamePrefix = function () { return cookieNameConst + sessionCookiePostfix; };\r\n _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */] = new Session();\r\n _self[_DYN_UPDATE /* @min:%2eupdate */] = function () {\r\n // Always using Date getTime() as there is a bug in older IE instances that causes the performance timings to have the hi-bit set eg 0x800000000 causing\r\n // the number to be incorrect.\r\n var nowMs = dateNow();\r\n var isExpired = false;\r\n var session = _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n if (!session.id) {\r\n isExpired = !_initializeAutomaticSession(session, nowMs);\r\n }\r\n var sessionExpirationMs = _self.config[_DYN_SESSION_EXPIRATION_M7 /* @min:%2esessionExpirationMs */]();\r\n if (!isExpired && sessionExpirationMs > 0) {\r\n var sessionRenewalMs = _self.config[_DYN_SESSION_RENEWAL_MS /* @min:%2esessionRenewalMs */]();\r\n var timeSinceAcqMs = nowMs - session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */];\r\n var timeSinceRenewalMs = nowMs - session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */];\r\n isExpired = timeSinceAcqMs < 0 || timeSinceRenewalMs < 0; // expired if the acquisition or last renewal are in the future\r\n isExpired = isExpired || timeSinceAcqMs > sessionExpirationMs; // expired if the time since acquisition is more than session Expiration\r\n isExpired = isExpired || timeSinceRenewalMs > sessionRenewalMs; // expired if the time since last renewal is more than renewal period\r\n }\r\n // renew if acquisitionSpan or renewalSpan has elapsed\r\n if (isExpired) {\r\n // update automaticSession so session state has correct id\r\n _renew(nowMs);\r\n }\r\n else {\r\n // do not update the cookie more often than cookieUpdateInterval\r\n if (!_cookieUpdatedTimestamp || nowMs - _cookieUpdatedTimestamp > _SessionManager.cookieUpdateInterval) {\r\n _setCookie(session, nowMs);\r\n }\r\n }\r\n };\r\n /**\r\n * Record the current state of the automatic session and store it in our cookie string format\r\n * into the browser's local storage. This is used to restore the session data when the cookie\r\n * expires.\r\n */\r\n _self.backup = function () {\r\n var session = _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n _setStorage(session.id, session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */], session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */]);\r\n };\r\n /**\r\n * Use config.namePrefix + ai_session cookie data or local storage data (when the cookie is unavailable) to\r\n * initialize the automatic session.\r\n * @returns true if values set otherwise false\r\n */\r\n function _initializeAutomaticSession(session, now) {\r\n var isValid = false;\r\n var cookieValue = _cookieManager.get(_storageNamePrefix());\r\n if (cookieValue && isFunction(cookieValue.split)) {\r\n isValid = _initializeAutomaticSessionWithData(session, cookieValue);\r\n }\r\n else {\r\n // There's no cookie, but we might have session data in local storage\r\n // This can happen if the session expired or the user actively deleted the cookie\r\n // We only want to recover data if the cookie is missing from expiry. We should respect the user's wishes if the cookie was deleted actively.\r\n // The User class handles this for us and deletes our local storage object if the persistent user cookie was removed.\r\n var storageValue = utlGetLocalStorage(_logger, _storageNamePrefix());\r\n if (storageValue) {\r\n isValid = _initializeAutomaticSessionWithData(session, storageValue);\r\n }\r\n }\r\n return isValid || !!session.id;\r\n }\r\n /**\r\n * Extract id, acquisitionDate, and renewalDate from an ai_session payload string and\r\n * use this data to initialize automaticSession.\r\n *\r\n * @param {string} sessionData - The string stored in an ai_session cookie or local storage backup\r\n * @returns true if values set otherwise false\r\n */\r\n function _initializeAutomaticSessionWithData(session, sessionData) {\r\n var isValid = false;\r\n var sessionReset = \", session will be reset\";\r\n var tokens = sessionData.split(\"|\");\r\n if (tokens[_DYN_LENGTH /* @min:%2elength */] >= 2) {\r\n try {\r\n var acqMs = +tokens[1] || 0;\r\n var renewalMs = +tokens[2] || 0;\r\n if (isNaN(acqMs) || acqMs <= 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 27 /* _eInternalMessageId.SessionRenewalDateIsZero */, \"AI session acquisition date is 0\" + sessionReset);\r\n }\r\n else if (isNaN(renewalMs) || renewalMs <= 0) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 27 /* _eInternalMessageId.SessionRenewalDateIsZero */, \"AI session renewal date is 0\" + sessionReset);\r\n }\r\n else if (tokens[0]) {\r\n // Everything looks valid so set the values\r\n session.id = tokens[0];\r\n session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */] = acqMs;\r\n session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */] = renewalMs;\r\n isValid = true;\r\n }\r\n }\r\n catch (e) {\r\n _throwInternal(_logger, 1 /* eLoggingSeverity.CRITICAL */, 9 /* _eInternalMessageId.ErrorParsingAISessionCookie */, \"Error parsing ai_session value [\" + (sessionData || \"\") + \"]\" + sessionReset + \" - \" + getExceptionName(e), { exception: dumpObj(e) });\r\n }\r\n }\r\n return isValid;\r\n }\r\n function _renew(nowMs) {\r\n var theConfig = (_self[_DYN_CONFIG /* @min:%2econfig */] || {});\r\n var getNewId = (theConfig[_DYN_GET_NEW_ID /* @min:%2egetNewId */] ? theConfig[_DYN_GET_NEW_ID /* @min:%2egetNewId */]() : null) || newId;\r\n _self.automaticSession.id = getNewId(theConfig[_DYN_ID_LENGTH /* @min:%2eidLength */] ? theConfig[_DYN_ID_LENGTH /* @min:%2eidLength */]() : 22);\r\n _self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */][_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */] = nowMs;\r\n _setCookie(_self[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */], nowMs);\r\n // If this browser does not support local storage, fire an internal log to keep track of it at this point\r\n if (!utlCanUseLocalStorage()) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 0 /* _eInternalMessageId.BrowserDoesNotSupportLocalStorage */, \"Browser does not support local storage. Session durations will be inaccurate.\");\r\n }\r\n }\r\n function _setCookie(session, nowMs) {\r\n var acq = session[_DYN_ACQUISITION_DATE /* @min:%2eacquisitionDate */];\r\n session[_DYN_RENEWAL_DATE /* @min:%2erenewalDate */] = nowMs;\r\n var config = _self[_DYN_CONFIG /* @min:%2econfig */];\r\n var renewalPeriodMs = config[_DYN_SESSION_RENEWAL_MS /* @min:%2esessionRenewalMs */]();\r\n // Set cookie to expire after the session expiry time passes or the session renewal deadline, whichever is sooner\r\n // Expiring the cookie will cause the session to expire even if the user isn't on the page\r\n var acqTimeLeftMs = (acq + config[_DYN_SESSION_EXPIRATION_M7 /* @min:%2esessionExpirationMs */]()) - nowMs;\r\n var cookie = [session.id, acq, nowMs];\r\n var maxAgeSec = 0;\r\n if (acqTimeLeftMs < renewalPeriodMs) {\r\n maxAgeSec = acqTimeLeftMs / 1000;\r\n }\r\n else {\r\n maxAgeSec = renewalPeriodMs / 1000;\r\n }\r\n var cookieDomain = config[_DYN_COOKIE_DOMAIN /* @min:%2ecookieDomain */] ? config[_DYN_COOKIE_DOMAIN /* @min:%2ecookieDomain */]() : null;\r\n // if sessionExpirationMs is set to 0, it means the expiry is set to 0 for this session cookie\r\n // A cookie with 0 expiry in the session cookie will never expire for that browser session. If the browser is closed the cookie expires.\r\n // Depending on the browser, another instance does not inherit this cookie, however, another tab will\r\n _cookieManager.set(_storageNamePrefix(), cookie.join(\"|\"), config[_DYN_SESSION_EXPIRATION_M7 /* @min:%2esessionExpirationMs */]() > 0 ? maxAgeSec : null, cookieDomain);\r\n _cookieUpdatedTimestamp = nowMs;\r\n }\r\n function _setStorage(guid, acq, renewal) {\r\n // Keep data in local storage to retain the last session id, allowing us to cleanly end the session when it expires\r\n // Browsers that don't support local storage won't be able to end sessions cleanly from the client\r\n // The server will notice this and end the sessions itself, with loss of accurate session duration\r\n utlSetLocalStorage(_logger, _storageNamePrefix(), [guid, acq, renewal][_DYN_JOIN /* @min:%2ejoin */](\"|\"));\r\n }\r\n });\r\n }\r\n// Removed Stub for _SessionManager.prototype.update.\r\n// Removed Stub for _SessionManager.prototype.backup.\r\n _SessionManager.acquisitionSpan = 86400000; // 24 hours in ms\r\n _SessionManager.renewalSpan = 1800000; // 30 minutes in ms\r\n _SessionManager.cookieUpdateInterval = 60000; // 1 minute in ms\r\n return _SessionManager;\r\n}());\r\nexport { _SessionManager };\r\n//# sourceMappingURL=Session.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport { dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { generateW3CId, getLocation } from \"@microsoft/applicationinsights-core-js\";\r\nvar TelemetryTrace = /** @class */ (function () {\r\n function TelemetryTrace(id, parentId, name, logger) {\r\n var _self = this;\r\n _self.traceID = id || generateW3CId();\r\n _self.parentID = parentId;\r\n var location = getLocation();\r\n if (!name && location && location.pathname) {\r\n name = location.pathname;\r\n }\r\n _self.name = dataSanitizeString(logger, name);\r\n }\r\n return TelemetryTrace;\r\n}());\r\nexport { TelemetryTrace };\r\n//# sourceMappingURL=TelemetryTrace.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { utlRemoveStorage } from \"@microsoft/applicationinsights-common\";\r\nimport { _throwInternal, newId, safeGetCookieMgr, safeGetLogger, toISOString } from \"@microsoft/applicationinsights-core-js\";\r\nimport { _DYN_ACCOUNT_ID, _DYN_AUTHENTICATED_ID, _DYN_AUTH_USER_COOKIE_NAM8, _DYN_CONFIG, _DYN_COOKIE_SEPARATOR, _DYN_GET_NEW_ID, _DYN_ID_LENGTH, _DYN_IS_NEW_USER, _DYN_IS_USER_COOKIE_SET, _DYN_JOIN, _DYN_LENGTH, _DYN_NAME_PREFIX, _DYN_UPDATE, _DYN_USER_COOKIE_POSTFIX } from \"../__DynamicConstants\";\r\nfunction _validateUserInput(id) {\r\n // Validate:\r\n // 1. Id is a non-empty string.\r\n // 2. It does not contain special characters for cookies.\r\n if (typeof id !== \"string\" ||\r\n !id ||\r\n id.match(/,|;|=| |\\|/)) {\r\n return false;\r\n }\r\n return true;\r\n}\r\nvar User = /** @class */ (function () {\r\n function User(config, core) {\r\n /**\r\n * A flag indicating whether this represents a new user\r\n */\r\n this.isNewUser = false;\r\n /**\r\n * A flag indicating whether the user cookie has been set\r\n */\r\n this.isUserCookieSet = false;\r\n var _logger = safeGetLogger(core);\r\n var _cookieManager = safeGetCookieMgr(core);\r\n var _storageNamePrefix;\r\n dynamicProto(User, this, function (_self) {\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = config;\r\n var userCookiePostfix = (_self.config[_DYN_USER_COOKIE_POSTFIX /* @min:%2euserCookiePostfix */] && _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_USER_COOKIE_POSTFIX /* @min:%2euserCookiePostfix */]()) ? _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_USER_COOKIE_POSTFIX /* @min:%2euserCookiePostfix */]() : \"\";\r\n _storageNamePrefix = function () { return User.userCookieName + userCookiePostfix; };\r\n // get userId or create new one if none exists\r\n var cookie = _cookieManager.get(_storageNamePrefix());\r\n if (cookie) {\r\n _self[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = false;\r\n var params = cookie.split(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n if (params[_DYN_LENGTH /* @min:%2elength */] > 0) {\r\n _self.id = params[0];\r\n // we already have a cookie\r\n _self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */] = !!_self.id;\r\n }\r\n }\r\n function _generateNewId() {\r\n var theConfig = (config || {});\r\n var getNewId = (theConfig[_DYN_GET_NEW_ID /* @min:%2egetNewId */] ? theConfig[_DYN_GET_NEW_ID /* @min:%2egetNewId */]() : null) || newId;\r\n var id = getNewId(theConfig[_DYN_ID_LENGTH /* @min:%2eidLength */] ? config[_DYN_ID_LENGTH /* @min:%2eidLength */]() : 22);\r\n return id;\r\n }\r\n function _generateNewCookie(userId) {\r\n var acqStr = toISOString(new Date());\r\n _self.accountAcquisitionDate = acqStr;\r\n _self[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = true;\r\n var newCookie = [userId, acqStr];\r\n return newCookie;\r\n }\r\n function _setUserCookie(cookie) {\r\n // without expiration, cookies expire at the end of the session\r\n // set it to 365 days from now\r\n // 365 * 24 * 60 * 60 = 31536000\r\n var oneYear = 31536000;\r\n _self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */] = _cookieManager.set(_storageNamePrefix(), cookie, oneYear);\r\n }\r\n if (!_self.id) {\r\n _self.id = _generateNewId();\r\n var newCookie = _generateNewCookie(_self.id);\r\n _setUserCookie(newCookie[_DYN_JOIN /* @min:%2ejoin */](User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]));\r\n // If we have an config.namePrefix() + ai_session in local storage this means the user actively removed our cookies.\r\n // We should respect their wishes and clear ourselves from local storage\r\n var name_1 = config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */] && config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() ? config[_DYN_NAME_PREFIX /* @min:%2enamePrefix */]() + \"ai_session\" : \"ai_session\";\r\n utlRemoveStorage(_logger, name_1);\r\n }\r\n // We still take the account id from the ctor param for backward compatibility.\r\n // But if the the customer set the accountId through the newer setAuthenticatedUserContext API, we will override it.\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = config[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] ? config[_DYN_ACCOUNT_ID /* @min:%2eaccountId */]() : undefined;\r\n // Get the auth user id and account id from the cookie if exists\r\n // Cookie is in the pattern: |\r\n var authCookie = _cookieManager.get(User[_DYN_AUTH_USER_COOKIE_NAM8 /* @min:%2eauthUserCookieName */]);\r\n if (authCookie) {\r\n authCookie = decodeURI(authCookie);\r\n var authCookieString = authCookie.split(User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n if (authCookieString[0]) {\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = authCookieString[0];\r\n }\r\n if (authCookieString[_DYN_LENGTH /* @min:%2elength */] > 1 && authCookieString[1]) {\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = authCookieString[1];\r\n }\r\n }\r\n _self.setAuthenticatedUserContext = function (authenticatedUserId, accountId, storeInCookie) {\r\n if (storeInCookie === void 0) { storeInCookie = false; }\r\n // Validate inputs to ensure no cookie control characters.\r\n var isInvalidInput = !_validateUserInput(authenticatedUserId) || (accountId && !_validateUserInput(accountId));\r\n if (isInvalidInput) {\r\n _throwInternal(_logger, 2 /* eLoggingSeverity.WARNING */, 60 /* _eInternalMessageId.SetAuthContextFailedAccountName */, \"Setting auth user context failed. \" +\r\n \"User auth/account id should be of type string, and not contain commas, semi-colons, equal signs, spaces, or vertical-bars.\", true);\r\n return;\r\n }\r\n // Create cookie string.\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = authenticatedUserId;\r\n var authCookie = _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */];\r\n if (accountId) {\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = accountId;\r\n authCookie = [_self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */], _self.accountId][_DYN_JOIN /* @min:%2ejoin */](User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]);\r\n }\r\n if (storeInCookie) {\r\n // Set the cookie. No expiration date because this is a session cookie (expires when browser closed).\r\n // Encoding the cookie to handle unexpected unicode characters.\r\n _cookieManager.set(User[_DYN_AUTH_USER_COOKIE_NAM8 /* @min:%2eauthUserCookieName */], encodeURI(authCookie));\r\n }\r\n };\r\n /**\r\n * Clears the authenticated user id and the account id from the user context.\r\n * @returns {}\r\n */\r\n _self.clearAuthenticatedUserContext = function () {\r\n _self[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */] = null;\r\n _self[_DYN_ACCOUNT_ID /* @min:%2eaccountId */] = null;\r\n _cookieManager.del(User[_DYN_AUTH_USER_COOKIE_NAM8 /* @min:%2eauthUserCookieName */]);\r\n };\r\n _self[_DYN_UPDATE /* @min:%2eupdate */] = function (userId) {\r\n // Optimizations to avoid setting and processing the cookie when not needed\r\n if (_self.id !== userId || !_self[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */]) {\r\n var user_id = userId ? userId : _generateNewId();\r\n var user_cookie = _generateNewCookie(user_id);\r\n _setUserCookie(user_cookie[_DYN_JOIN /* @min:%2ejoin */](User[_DYN_COOKIE_SEPARATOR /* @min:%2ecookieSeparator */]));\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for User.prototype.setAuthenticatedUserContext.\r\n// Removed Stub for User.prototype.clearAuthenticatedUserContext.\r\n// Removed Stub for User.prototype.update.\r\n User.cookieSeparator = \"|\";\r\n User.userCookieName = \"ai_user\";\r\n User.authUserCookieName = \"ai_authUser\";\r\n return User;\r\n}());\r\nexport { User };\r\n//# sourceMappingURL=User.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* TelemetryContext.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { CtxTagKeys, Extensions, PageView, dataSanitizeString } from \"@microsoft/applicationinsights-common\";\r\nimport { _InternalLogMessage, getSetValue, hasWindow, isNullOrUndefined, isString, objKeys, setValue } from \"@microsoft/applicationinsights-core-js\";\r\nimport { Application } from \"./Context/Application\";\r\nimport { Device } from \"./Context/Device\";\r\nimport { Internal } from \"./Context/Internal\";\r\nimport { Location } from \"./Context/Location\";\r\nimport { Session, _SessionManager } from \"./Context/Session\";\r\nimport { TelemetryTrace } from \"./Context/TelemetryTrace\";\r\nimport { User } from \"./Context/User\";\r\nimport { _DYN_ACCOUNT_ID, _DYN_APPLY_APPLICATION_CO1, _DYN_APPLY_DEVICE_CONTEXT, _DYN_APPLY_INTERNAL_CONTE5, _DYN_APPLY_LOCATION_CONTE4, _DYN_APPLY_OPERATING_SYST3, _DYN_APPLY_OPERATION_CONT2, _DYN_APPLY_SESSION_CONTEX0, _DYN_APPLY_USER_CONTEXT, _DYN_AUTHENTICATED_ID, _DYN_AUTOMATIC_SESSION, _DYN_GET_SESSION_ID, _DYN_LENGTH, _DYN_SESSION_MANAGER, _DYN_TELEMETRY_TRACE } from \"./__DynamicConstants\";\r\nvar strExt = \"ext\";\r\nvar strTags = \"tags\";\r\nfunction _removeEmpty(target, name) {\r\n if (target && target[name] && objKeys(target[name])[_DYN_LENGTH /* @min:%2elength */] === 0) {\r\n delete target[name];\r\n }\r\n}\r\nvar TelemetryContext = /** @class */ (function () {\r\n function TelemetryContext(core, defaultConfig, previousTraceCtx) {\r\n var _this = this;\r\n var logger = core.logger;\r\n this.appId = function () { return null; };\r\n this[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */] = function () { return null; };\r\n dynamicProto(TelemetryContext, this, function (_self) {\r\n _self.application = new Application();\r\n _self.internal = new Internal(defaultConfig);\r\n if (hasWindow()) {\r\n _self[_DYN_SESSION_MANAGER /* @min:%2esessionManager */] = new _SessionManager(defaultConfig, core);\r\n _self.device = new Device();\r\n _self.location = new Location();\r\n _self.user = new User(defaultConfig, core);\r\n var traceId = void 0;\r\n var parentId = void 0;\r\n var name_1;\r\n if (previousTraceCtx) {\r\n traceId = previousTraceCtx.getTraceId();\r\n parentId = previousTraceCtx.getSpanId();\r\n name_1 = previousTraceCtx.getName();\r\n }\r\n _self[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */] = new TelemetryTrace(traceId, parentId, name_1, logger);\r\n _self.session = new Session();\r\n }\r\n _self[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */] = function () {\r\n var session = _self.session;\r\n var sesId = null;\r\n // If customer set session info, apply their context; otherwise apply context automatically generated\r\n if (session && isString(session.id)) {\r\n sesId = session.id;\r\n }\r\n else {\r\n // Gets the automatic session if it exists or an empty object\r\n var autoSession = (_self[_DYN_SESSION_MANAGER /* @min:%2esessionManager */] || {})[_DYN_AUTOMATIC_SESSION /* @min:%2eautomaticSession */];\r\n sesId = autoSession && isString(autoSession.id) ? autoSession.id : null;\r\n }\r\n return sesId;\r\n };\r\n _self[_DYN_APPLY_SESSION_CONTEX0 /* @min:%2eapplySessionContext */] = function (evt, itemCtx) {\r\n setValue(getSetValue(evt.ext, Extensions.AppExt), \"sesId\", _self[_DYN_GET_SESSION_ID /* @min:%2egetSessionId */](), isString);\r\n };\r\n _self[_DYN_APPLY_OPERATING_SYST3 /* @min:%2eapplyOperatingSystemContxt */] = function (evt, itemCtx) {\r\n setValue(evt.ext, Extensions.OSExt, _self.os);\r\n };\r\n _self[_DYN_APPLY_APPLICATION_CO1 /* @min:%2eapplyApplicationContext */] = function (evt, itemCtx) {\r\n var application = _self.application;\r\n if (application) {\r\n // evt.ext.app\r\n var tags = getSetValue(evt, strTags);\r\n setValue(tags, CtxTagKeys.applicationVersion, application.ver, isString);\r\n setValue(tags, CtxTagKeys.applicationBuild, application.build, isString);\r\n }\r\n };\r\n _self[_DYN_APPLY_DEVICE_CONTEXT /* @min:%2eapplyDeviceContext */] = function (evt, itemCtx) {\r\n var device = _self.device;\r\n if (device) {\r\n // evt.ext.device\r\n var extDevice = getSetValue(getSetValue(evt, strExt), Extensions.DeviceExt);\r\n setValue(extDevice, \"localId\", device.id, isString);\r\n setValue(extDevice, \"ip\", device.ip, isString);\r\n setValue(extDevice, \"model\", device.model, isString);\r\n setValue(extDevice, \"deviceClass\", device.deviceClass, isString);\r\n }\r\n };\r\n _self[_DYN_APPLY_INTERNAL_CONTE5 /* @min:%2eapplyInternalContext */] = function (evt, itemCtx) {\r\n var internal = _self.internal;\r\n if (internal) {\r\n var tags = getSetValue(evt, strTags);\r\n setValue(tags, CtxTagKeys.internalAgentVersion, internal.agentVersion, isString); // not mapped in CS 4.0\r\n setValue(tags, CtxTagKeys.internalSdkVersion, dataSanitizeString(logger, internal.sdkVersion, 64), isString);\r\n if (evt.baseType === _InternalLogMessage.dataType || evt.baseType === PageView.dataType) {\r\n setValue(tags, CtxTagKeys.internalSnippet, internal.snippetVer, isString);\r\n setValue(tags, CtxTagKeys.internalSdkSrc, internal.sdkSrc, isString);\r\n }\r\n }\r\n };\r\n _self[_DYN_APPLY_LOCATION_CONTE4 /* @min:%2eapplyLocationContext */] = function (evt, itemCtx) {\r\n var location = _this.location;\r\n if (location) {\r\n setValue(getSetValue(evt, strTags, []), CtxTagKeys.locationIp, location.ip, isString);\r\n }\r\n };\r\n _self[_DYN_APPLY_OPERATION_CONT2 /* @min:%2eapplyOperationContext */] = function (evt, itemCtx) {\r\n var telemetryTrace = _self[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */];\r\n if (telemetryTrace) {\r\n var extTrace = getSetValue(getSetValue(evt, strExt), Extensions.TraceExt, { traceID: undefined, parentID: undefined });\r\n setValue(extTrace, \"traceID\", telemetryTrace.traceID, isString, isNullOrUndefined);\r\n setValue(extTrace, \"name\", telemetryTrace.name, isString, isNullOrUndefined);\r\n setValue(extTrace, \"parentID\", telemetryTrace.parentID, isString, isNullOrUndefined);\r\n }\r\n };\r\n _self.applyWebContext = function (evt, itemCtx) {\r\n var web = _this.web;\r\n if (web) {\r\n setValue(getSetValue(evt, strExt), Extensions.WebExt, web);\r\n }\r\n };\r\n _self[_DYN_APPLY_USER_CONTEXT /* @min:%2eapplyUserContext */] = function (evt, itemCtx) {\r\n var user = _self.user;\r\n if (user) {\r\n var tags = getSetValue(evt, strTags, []);\r\n // stays in tags\r\n setValue(tags, CtxTagKeys.userAccountId, user[_DYN_ACCOUNT_ID /* @min:%2eaccountId */], isString);\r\n // CS 4.0\r\n var extUser = getSetValue(getSetValue(evt, strExt), Extensions.UserExt);\r\n setValue(extUser, \"id\", user.id, isString);\r\n setValue(extUser, \"authId\", user[_DYN_AUTHENTICATED_ID /* @min:%2eauthenticatedId */], isString);\r\n }\r\n };\r\n _self.cleanUp = function (evt, itemCtx) {\r\n var ext = evt.ext;\r\n if (ext) {\r\n _removeEmpty(ext, Extensions.DeviceExt);\r\n _removeEmpty(ext, Extensions.UserExt);\r\n _removeEmpty(ext, Extensions.WebExt);\r\n _removeEmpty(ext, Extensions.OSExt);\r\n _removeEmpty(ext, Extensions.AppExt);\r\n _removeEmpty(ext, Extensions.TraceExt);\r\n }\r\n };\r\n });\r\n }\r\n// Removed Stub for TelemetryContext.prototype.applySessionContext.\r\n// Removed Stub for TelemetryContext.prototype.applyOperatingSystemContxt.\r\n// Removed Stub for TelemetryContext.prototype.applyApplicationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyDeviceContext.\r\n// Removed Stub for TelemetryContext.prototype.applyInternalContext.\r\n// Removed Stub for TelemetryContext.prototype.applyLocationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyOperationContext.\r\n// Removed Stub for TelemetryContext.prototype.applyWebContext.\r\n// Removed Stub for TelemetryContext.prototype.applyUserContext.\r\n// Removed Stub for TelemetryContext.prototype.cleanUp.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n TelemetryContext.__ieDyn=1;\n\n return TelemetryContext;\r\n}());\r\nexport { TelemetryContext };\r\n//# sourceMappingURL=TelemetryContext.js.map","/*\n * Application Insights JavaScript SDK - Properties Plugin, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n/**\r\n* PropertiesPlugin.ts\r\n* @copyright Microsoft 2018\r\n*/\r\nimport { __extendsFn as __extends } from \"@microsoft/applicationinsights-shims\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { BreezeChannelIdentifier, PageView, PropertiesPluginIdentifier, createDistributedTraceContextFromTrace } from \"@microsoft/applicationinsights-common\";\r\nimport { BaseTelemetryPlugin, _InternalLogMessage, _logInternalMessage, createProcessTelemetryContext, getNavigator, getSetValue, isNullOrUndefined, objForEachKey } from \"@microsoft/applicationinsights-core-js\";\r\nimport { TelemetryContext } from \"./TelemetryContext\";\r\nimport { _DYN_ACCOUNT_ID, _DYN_APPLY_APPLICATION_CO1, _DYN_APPLY_DEVICE_CONTEXT, _DYN_APPLY_INTERNAL_CONTE5, _DYN_APPLY_LOCATION_CONTE4, _DYN_APPLY_OPERATING_SYST3, _DYN_APPLY_OPERATION_CONT2, _DYN_APPLY_SESSION_CONTEX0, _DYN_APPLY_USER_CONTEXT, _DYN_COOKIE_DOMAIN, _DYN_GET_NEW_ID, _DYN_GET_SESSION_ID, _DYN_GET_TRACE_CTX, _DYN_ID_LENGTH, _DYN_IS_NEW_USER, _DYN_IS_USER_COOKIE_SET, _DYN_NAME_PREFIX, _DYN_SDK_EXTENSION, _DYN_SESSION_COOKIE_POSTF6, _DYN_SESSION_MANAGER, _DYN_TELEMETRY_TRACE, _DYN_UPDATE, _DYN_USER_COOKIE_POSTFIX } from \"./__DynamicConstants\";\r\nvar PropertiesPlugin = /** @class */ (function (_super) {\r\n __extends(PropertiesPlugin, _super);\r\n function PropertiesPlugin() {\r\n var _this = _super.call(this) || this;\r\n _this.priority = 110;\r\n _this.identifier = PropertiesPluginIdentifier;\r\n var _extensionConfig;\r\n var _distributedTraceCtx;\r\n var _previousTraceCtx;\r\n dynamicProto(PropertiesPlugin, _this, function (_self, _base) {\r\n _initDefaults();\r\n _self.initialize = function (config, core, extensions, pluginChain) {\r\n _base.initialize(config, core, extensions, pluginChain);\r\n _populateDefaults(config);\r\n };\r\n /**\r\n * Add Part A fields to the event\r\n * @param event The event that needs to be processed\r\n */\r\n _self.processTelemetry = function (event, itemCtx) {\r\n if (isNullOrUndefined(event)) {\r\n // TODO(barustum): throw an internal event once we have support for internal logging\r\n }\r\n else {\r\n itemCtx = _self._getTelCtx(itemCtx);\r\n // If the envelope is PageView, reset the internal message count so that we can send internal telemetry for the new page.\r\n if (event.name === PageView.envelopeType) {\r\n itemCtx.diagLog().resetInternalMessageCount();\r\n }\r\n var theContext = (_self.context || {});\r\n if (theContext.session) {\r\n // If customer did not provide custom session id update the session manager\r\n if (typeof _self.context.session.id !== \"string\" && theContext[_DYN_SESSION_MANAGER /* @min:%2esessionManager */]) {\r\n theContext[_DYN_SESSION_MANAGER /* @min:%2esessionManager */][_DYN_UPDATE /* @min:%2eupdate */]();\r\n }\r\n }\r\n var userCtx = theContext.user;\r\n if (userCtx && !userCtx[_DYN_IS_USER_COOKIE_SET /* @min:%2eisUserCookieSet */]) {\r\n userCtx[_DYN_UPDATE /* @min:%2eupdate */](theContext.user.id);\r\n }\r\n _processTelemetryInternal(event, itemCtx);\r\n if (userCtx && userCtx[_DYN_IS_NEW_USER /* @min:%2eisNewUser */]) {\r\n userCtx[_DYN_IS_NEW_USER /* @min:%2eisNewUser */] = false;\r\n var message = new _InternalLogMessage(72 /* _eInternalMessageId.SendBrowserInfoOnUserInit */, ((getNavigator() || {}).userAgent || \"\"));\r\n _logInternalMessage(itemCtx.diagLog(), 1 /* eLoggingSeverity.CRITICAL */, message);\r\n }\r\n _self.processNext(event, itemCtx);\r\n }\r\n };\r\n _self._doTeardown = function (unloadCtx, unloadState) {\r\n var core = (unloadCtx || {}).core();\r\n if (core && core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */]) {\r\n var traceCtx = core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */](false);\r\n if (traceCtx === _distributedTraceCtx) {\r\n core.setTraceCtx(_previousTraceCtx);\r\n }\r\n }\r\n _initDefaults();\r\n };\r\n function _initDefaults() {\r\n _extensionConfig = null;\r\n _distributedTraceCtx = null;\r\n _previousTraceCtx = null;\r\n }\r\n function _populateDefaults(config) {\r\n var identifier = _self.identifier;\r\n var core = _self.core;\r\n var ctx = createProcessTelemetryContext(null, config, core);\r\n var defaultConfig = PropertiesPlugin.getDefaultConfig();\r\n _extensionConfig = _extensionConfig || {};\r\n objForEachKey(defaultConfig, function (field, value) {\r\n _extensionConfig[field] = function () { return ctx.getConfig(identifier, field, value()); };\r\n });\r\n _previousTraceCtx = core[_DYN_GET_TRACE_CTX /* @min:%2egetTraceCtx */](false);\r\n _self.context = new TelemetryContext(core, _extensionConfig, _previousTraceCtx);\r\n _distributedTraceCtx = createDistributedTraceContextFromTrace(_self.context[_DYN_TELEMETRY_TRACE /* @min:%2etelemetryTrace */], _previousTraceCtx);\r\n core.setTraceCtx(_distributedTraceCtx);\r\n _self.context.appId = function () {\r\n var breezeChannel = core.getPlugin(BreezeChannelIdentifier);\r\n return breezeChannel ? breezeChannel.plugin[\"_appId\"] : null;\r\n };\r\n // Test hook to allow accessing the internal values -- explicitly not defined as an available property on the class\r\n _self[\"_extConfig\"] = _extensionConfig;\r\n }\r\n function _processTelemetryInternal(evt, itemCtx) {\r\n // Set Part A fields\r\n getSetValue(evt, \"tags\", []);\r\n getSetValue(evt, \"ext\", {});\r\n var ctx = _self.context;\r\n ctx[_DYN_APPLY_SESSION_CONTEX0 /* @min:%2eapplySessionContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_APPLICATION_CO1 /* @min:%2eapplyApplicationContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_DEVICE_CONTEXT /* @min:%2eapplyDeviceContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_OPERATION_CONT2 /* @min:%2eapplyOperationContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_USER_CONTEXT /* @min:%2eapplyUserContext */](evt, itemCtx);\r\n ctx[_DYN_APPLY_OPERATING_SYST3 /* @min:%2eapplyOperatingSystemContxt */](evt, itemCtx);\r\n ctx.applyWebContext(evt, itemCtx);\r\n ctx[_DYN_APPLY_LOCATION_CONTE4 /* @min:%2eapplyLocationContext */](evt, itemCtx); // legacy tags\r\n ctx[_DYN_APPLY_INTERNAL_CONTE5 /* @min:%2eapplyInternalContext */](evt, itemCtx); // legacy tags\r\n ctx.cleanUp(evt, itemCtx);\r\n }\r\n });\r\n return _this;\r\n }\r\n PropertiesPlugin.getDefaultConfig = function () {\r\n var _a;\r\n var defaultValue;\r\n var nullValue = null;\r\n var defaultConfig = (_a = {\r\n instrumentationKey: function () { return defaultValue; }\r\n },\r\n _a[_DYN_ACCOUNT_ID /* @min:accountId */] = function () { return nullValue; },\r\n _a.sessionRenewalMs = function () { return 30 * 60 * 1000; },\r\n _a.samplingPercentage = function () { return 100; },\r\n _a.sessionExpirationMs = function () { return 24 * 60 * 60 * 1000; },\r\n _a[_DYN_COOKIE_DOMAIN /* @min:cookieDomain */] = function () { return nullValue; },\r\n _a[_DYN_SDK_EXTENSION /* @min:sdkExtension */] = function () { return nullValue; },\r\n _a.isBrowserLinkTrackingEnabled = function () { return false; },\r\n _a.appId = function () { return nullValue; },\r\n _a[_DYN_GET_SESSION_ID /* @min:getSessionId */] = function () { return nullValue; },\r\n _a[_DYN_NAME_PREFIX /* @min:namePrefix */] = function () { return defaultValue; },\r\n _a[_DYN_SESSION_COOKIE_POSTF6 /* @min:sessionCookiePostfix */] = function () { return defaultValue; },\r\n _a[_DYN_USER_COOKIE_POSTFIX /* @min:userCookiePostfix */] = function () { return defaultValue; },\r\n _a[_DYN_ID_LENGTH /* @min:idLength */] = function () { return 22; },\r\n _a[_DYN_GET_NEW_ID /* @min:getNewId */] = function () { return nullValue; },\r\n _a);\r\n return defaultConfig;\r\n };\r\n// Removed Stub for PropertiesPlugin.prototype.initialize.\r\n// Removed Stub for PropertiesPlugin.prototype.processTelemetry.\r\n return PropertiesPlugin;\r\n}(BaseTelemetryPlugin));\r\nexport default PropertiesPlugin;\r\n//# sourceMappingURL=PropertiesPlugin.js.map","/*\n * Application Insights JavaScript SDK - Web, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Generally you should only put values that are used more than 2 times and then only if not already exposed as a constant (such as SdkCoreNames)\r\n// as when using \"short\" named values from here they will be will be minified smaller than the SdkCoreNames[eSdkCoreNames.xxxx] value.\r\nvar _AUTHENTICATED_USER_CONTEXT = \"AuthenticatedUserContext\";\r\nvar _TRACK = \"track\";\r\nexport var STR_EMPTY = \"\";\r\nexport var STR_SNIPPET = \"snippet\";\r\nexport var STR_GET_COOKIE_MGR = \"getCookieMgr\";\r\nexport var STR_START_TRACK_PAGE = \"startTrackPage\";\r\nexport var STR_STOP_TRACK_PAGE = \"stopTrackPage\";\r\nexport var STR_FLUSH = \"flush\";\r\nexport var STR_START_TRACK_EVENT = \"startTrackEvent\";\r\nexport var STR_STOP_TRACK_EVENT = \"stopTrackEvent\";\r\nexport var STR_ADD_TELEMETRY_INITIALIZER = \"addTelemetryInitializer\";\r\nexport var STR_ADD_TELEMETRY_INITIALIZERS = STR_ADD_TELEMETRY_INITIALIZER + \"s\";\r\nexport var STR_POLL_INTERNAL_LOGS = \"pollInternalLogs\";\r\nexport var STR_GET_PLUGIN = \"getPlugin\";\r\nexport var STR_EVT_NAMESPACE = \"evtNamespace\";\r\nexport var STR_TRACK_EVENT = _TRACK + \"Event\";\r\nexport var STR_TRACK_TRACE = _TRACK + \"Trace\";\r\nexport var STR_TRACK_METRIC = _TRACK + \"Metric\";\r\nexport var STR_TRACK_PAGE_VIEW = _TRACK + \"PageView\";\r\nexport var STR_TRACK_EXCEPTION = _TRACK + \"Exception\";\r\nexport var STR_TRACK_DEPENDENCY_DATA = _TRACK + \"DependencyData\";\r\nexport var STR_SET_AUTHENTICATED_USER_CONTEXT = \"set\" + _AUTHENTICATED_USER_CONTEXT;\r\nexport var STR_CLEAR_AUTHENTICATED_USER_CONTEXT = \"clear\" + _AUTHENTICATED_USER_CONTEXT;\r\n//# sourceMappingURL=InternalConstants.js.map","/*\n * Application Insights JavaScript SDK - Web, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n\"use strict\";\r\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { AnalyticsPlugin } from \"@microsoft/applicationinsights-analytics-js\";\r\nimport { Sender } from \"@microsoft/applicationinsights-channel-js\";\r\nimport { AnalyticsPluginIdentifier, BreezeChannelIdentifier, ConfigurationManager, ConnectionStringParser, ContextTagKeys, CorrelationIdHelper, CtxTagKeys, DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, Data, DataSanitizer, DateTimeUtils, DisabledPropertyName, DistributedTracingModes, Envelope, Event, Exception, Extensions, HttpMethod, Metric, PageView, PageViewPerformance, ProcessLegacy, PropertiesPluginIdentifier, RemoteDependencyData, RequestHeaders, SampleRate, SeverityLevel, TelemetryItemCreator, Trace, UrlHelper, Util, parseConnectionString } from \"@microsoft/applicationinsights-common\";\r\nimport { AppInsightsCore, _throwInternal, addPageHideEventListener, addPageUnloadEventListener, arrForEach, arrIndexOf, createUniqueNamespace, doPerf, hasDocument, hasWindow, isArray, isFunction, isNullOrUndefined, isReactNative, isString, mergeEvtNamespace, objForEachKey, proxyAssign, proxyFunctions, removePageHideEventListener, removePageUnloadEventListener, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { AjaxPlugin as DependenciesPlugin } from \"@microsoft/applicationinsights-dependencies-js\";\r\nimport { PropertiesPlugin } from \"@microsoft/applicationinsights-properties-js\";\r\nimport { STR_ADD_TELEMETRY_INITIALIZER, STR_CLEAR_AUTHENTICATED_USER_CONTEXT, STR_EVT_NAMESPACE, STR_FLUSH, STR_GET_COOKIE_MGR, STR_GET_PLUGIN, STR_POLL_INTERNAL_LOGS, STR_SET_AUTHENTICATED_USER_CONTEXT, STR_SNIPPET, STR_START_TRACK_EVENT, STR_START_TRACK_PAGE, STR_STOP_TRACK_EVENT, STR_STOP_TRACK_PAGE, STR_TRACK_DEPENDENCY_DATA, STR_TRACK_EVENT, STR_TRACK_EXCEPTION, STR_TRACK_METRIC, STR_TRACK_PAGE_VIEW, STR_TRACK_TRACE } from \"./InternalConstants\";\r\nimport { _DYN_ADD_HOUSEKEEPING_BEF20, _DYN_APP_INSIGHTS, _DYN_CONFIG, _DYN_CONNECTION_STRING, _DYN_CONTEXT, _DYN_DIAGNOSTIC_LOG_INTER4, _DYN_DISABLE_FLUSH_ON_BEF11, _DYN_DISABLE_FLUSH_ON_UNL12, _DYN_DISABLE_IKEY_DEPRECA18, _DYN_ENDPOINT_URL, _DYN_GET_TRANSMISSION_CON19, _DYN_INDEX_OF, _DYN_INSTRUMENTATION_KEY, _DYN_LOAD_APP_INSIGHTS, _DYN_ONUNLOAD_FLUSH, _DYN_PUSH, _DYN_QUEUE, _DYN_UPDATE_SNIPPET_DEFIN0, _DYN_VERSION } from \"./__DynamicConstants\";\r\nvar _internalSdkSrc;\r\n// This is an exclude list of properties that should not be updated during initialization\r\n// They include a combination of private and internal property names\r\nvar _ignoreUpdateSnippetProperties = [\r\n STR_SNIPPET, \"dependencies\", \"properties\", \"_snippetVersion\", \"appInsightsNew\", \"getSKUDefaults\"\r\n];\r\n// Re-exposing the Common classes as Telemetry, the list was taken by reviewing the generated code for the build while using\r\n// the previous configuration :-\r\n// import * as Common from \"@microsoft/applicationinsights-common\"\r\n// export const Telemetry = Common;\r\nvar fieldType = {\r\n Default: 0 /* FieldType.Default */,\r\n Required: 1 /* FieldType.Required */,\r\n Array: 2 /* FieldType.Array */,\r\n Hidden: 4 /* FieldType.Hidden */\r\n};\r\n/**\r\n * Telemetry type classes, e.g. PageView, Exception, etc\r\n */\r\nexport var Telemetry = {\r\n __proto__: null,\r\n PropertiesPluginIdentifier: PropertiesPluginIdentifier,\r\n BreezeChannelIdentifier: BreezeChannelIdentifier,\r\n AnalyticsPluginIdentifier: AnalyticsPluginIdentifier,\r\n Util: Util,\r\n CorrelationIdHelper: CorrelationIdHelper,\r\n UrlHelper: UrlHelper,\r\n DateTimeUtils: DateTimeUtils,\r\n ConnectionStringParser: ConnectionStringParser,\r\n FieldType: fieldType,\r\n RequestHeaders: RequestHeaders,\r\n DisabledPropertyName: DisabledPropertyName,\r\n ProcessLegacy: ProcessLegacy,\r\n SampleRate: SampleRate,\r\n HttpMethod: HttpMethod,\r\n DEFAULT_BREEZE_ENDPOINT: DEFAULT_BREEZE_ENDPOINT,\r\n Envelope: Envelope,\r\n Event: Event,\r\n Exception: Exception,\r\n Metric: Metric,\r\n PageView: PageView,\r\n RemoteDependencyData: RemoteDependencyData,\r\n Trace: Trace,\r\n PageViewPerformance: PageViewPerformance,\r\n Data: Data,\r\n SeverityLevel: SeverityLevel,\r\n ConfigurationManager: ConfigurationManager,\r\n ContextTagKeys: ContextTagKeys,\r\n DataSanitizer: DataSanitizer,\r\n TelemetryItemCreator: TelemetryItemCreator,\r\n CtxTagKeys: CtxTagKeys,\r\n Extensions: Extensions,\r\n DistributedTracingModes: DistributedTracingModes\r\n};\r\n/**\r\n * Application Insights API\r\n * @class Initialization\r\n * @implements {IApplicationInsights}\r\n */\r\nvar Initialization = /** @class */ (function () {\r\n function Initialization(snippet) {\r\n var _this = this;\r\n // NOTE!: DON'T set default values here, instead set them in the _initDefaults() function as it is also called during teardown()\r\n var dependencies;\r\n var properties;\r\n var _sender;\r\n var _snippetVersion;\r\n var _evtNamespace;\r\n var _houseKeepingNamespace;\r\n var _core;\r\n dynamicProto(Initialization, this, function (_self) {\r\n _initDefaults();\r\n // initialize the queue and config in case they are undefined\r\n _snippetVersion = \"\" + (snippet.sv || snippet[_DYN_VERSION /* @min:%2eversion */] || \"\");\r\n snippet[_DYN_QUEUE /* @min:%2equeue */] = snippet[_DYN_QUEUE /* @min:%2equeue */] || [];\r\n snippet[_DYN_VERSION /* @min:%2eversion */] = snippet[_DYN_VERSION /* @min:%2eversion */] || 2.0; // Default to new version\r\n var config = snippet[_DYN_CONFIG /* @min:%2econfig */] || {};\r\n if (config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */]) {\r\n var cs = parseConnectionString(config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */]);\r\n var ingest = cs.ingestionendpoint;\r\n config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] = ingest ? (ingest + DEFAULT_BREEZE_PATH) : config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */]; // only add /v2/track when from connectionstring\r\n config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */] = cs.instrumentationkey || config[_DYN_INSTRUMENTATION_KEY /* @min:%2einstrumentationKey */];\r\n }\r\n _self[_DYN_APP_INSIGHTS /* @min:%2eappInsights */] = new AnalyticsPlugin();\r\n properties = new PropertiesPlugin();\r\n dependencies = new DependenciesPlugin();\r\n _sender = new Sender();\r\n _core = new AppInsightsCore();\r\n _self.core = _core;\r\n var isErrMessageDisabled = isNullOrUndefined(config[_DYN_DISABLE_IKEY_DEPRECA18 /* @min:%2edisableIkeyDeprecationMessage */]) ? true : config[_DYN_DISABLE_IKEY_DEPRECA18 /* @min:%2edisableIkeyDeprecationMessage */];\r\n if (!config[_DYN_CONNECTION_STRING /* @min:%2econnectionString */] && !isErrMessageDisabled) {\r\n _throwInternal(_core.logger, 1 /* eLoggingSeverity.CRITICAL */, 106 /* _eInternalMessageId.InstrumentationKeyDeprecation */, \"Instrumentation key support will end soon, see aka.ms/IkeyMigrate\");\r\n }\r\n _self[STR_SNIPPET /* @min:%2esnippet */] = snippet;\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = config;\r\n _getSKUDefaults();\r\n _self[STR_FLUSH /* @min:%2eflush */] = function (async) {\r\n if (async === void 0) { async = true; }\r\n doPerf(_core, function () { return \"AISKU.flush\"; }, function () {\r\n arrForEach(_core[_DYN_GET_TRANSMISSION_CON19 /* @min:%2egetTransmissionControls */](), function (channels) {\r\n arrForEach(channels, function (channel) {\r\n channel[STR_FLUSH /* @min:%2eflush */](async);\r\n });\r\n });\r\n }, null, async);\r\n };\r\n _self[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */] = function (async) {\r\n if (async === void 0) { async = true; }\r\n arrForEach(_core[_DYN_GET_TRANSMISSION_CON19 /* @min:%2egetTransmissionControls */](), function (channels) {\r\n arrForEach(channels, function (channel) {\r\n if (channel[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */]) {\r\n channel[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */]();\r\n }\r\n else {\r\n channel[STR_FLUSH /* @min:%2eflush */](async);\r\n }\r\n });\r\n });\r\n };\r\n _self[_DYN_LOAD_APP_INSIGHTS /* @min:%2eloadAppInsights */] = function (legacyMode, logger, notificationManager) {\r\n if (legacyMode === void 0) { legacyMode = false; }\r\n function _updateSnippetProperties(snippet) {\r\n if (snippet) {\r\n var snippetVer = \"\";\r\n if (!isNullOrUndefined(_snippetVersion)) {\r\n snippetVer += _snippetVersion;\r\n }\r\n if (legacyMode) {\r\n snippetVer += \".lg\";\r\n }\r\n if (_self[_DYN_CONTEXT /* @min:%2econtext */] && _self[_DYN_CONTEXT /* @min:%2econtext */].internal) {\r\n _self[_DYN_CONTEXT /* @min:%2econtext */].internal.snippetVer = snippetVer || \"-\";\r\n }\r\n // apply updated properties to the global instance (snippet)\r\n objForEachKey(_self, function (field, value) {\r\n if (isString(field) &&\r\n !isFunction(value) &&\r\n field && field[0] !== \"_\" && // Don't copy \"internal\" values\r\n arrIndexOf(_ignoreUpdateSnippetProperties, field) === -1) {\r\n snippet[field] = value;\r\n }\r\n });\r\n }\r\n }\r\n // dont allow additional channels/other extensions for legacy mode; legacy mode is only to allow users to switch with no code changes!\r\n if (legacyMode && _self[_DYN_CONFIG /* @min:%2econfig */].extensions && _self[_DYN_CONFIG /* @min:%2econfig */].extensions.length > 0) {\r\n throwError(\"Extensions not allowed in legacy mode\");\r\n }\r\n doPerf(_self.core, function () { return \"AISKU.loadAppInsights\"; }, function () {\r\n var extensions = [];\r\n extensions[_DYN_PUSH /* @min:%2epush */](_sender);\r\n extensions[_DYN_PUSH /* @min:%2epush */](properties);\r\n extensions[_DYN_PUSH /* @min:%2epush */](dependencies);\r\n extensions[_DYN_PUSH /* @min:%2epush */](_self[_DYN_APP_INSIGHTS /* @min:%2eappInsights */]);\r\n // initialize core\r\n _core.initialize(_self[_DYN_CONFIG /* @min:%2econfig */], extensions, logger, notificationManager);\r\n _self[_DYN_CONTEXT /* @min:%2econtext */] = properties[_DYN_CONTEXT /* @min:%2econtext */];\r\n if (_internalSdkSrc && _self[_DYN_CONTEXT /* @min:%2econtext */]) {\r\n _self[_DYN_CONTEXT /* @min:%2econtext */].internal.sdkSrc = _internalSdkSrc;\r\n }\r\n _updateSnippetProperties(_self[STR_SNIPPET /* @min:%2esnippet */]);\r\n // Empty queue of all api calls logged prior to sdk download\r\n _self.emptyQueue();\r\n _self[STR_POLL_INTERNAL_LOGS /* @min:%2epollInternalLogs */]();\r\n _self[_DYN_ADD_HOUSEKEEPING_BEF20 /* @min:%2eaddHousekeepingBeforeUnload */](_self);\r\n });\r\n return _self;\r\n };\r\n _self[_DYN_UPDATE_SNIPPET_DEFIN0 /* @min:%2eupdateSnippetDefinitions */] = function (snippet) {\r\n // apply full appInsights to the global instance\r\n // Note: This must be called before loadAppInsights is called\r\n proxyAssign(snippet, _self, function (name) {\r\n // Not excluding names prefixed with \"_\" as we need to proxy some functions like _onError\r\n return name && arrIndexOf(_ignoreUpdateSnippetProperties, name) === -1;\r\n });\r\n };\r\n _self.emptyQueue = function () {\r\n // call functions that were queued before the main script was loaded\r\n try {\r\n if (isArray(_self.snippet[_DYN_QUEUE /* @min:%2equeue */])) {\r\n // note: do not check length in the for-loop conditional in case something goes wrong and the stub methods are not overridden.\r\n var length_1 = _self.snippet[_DYN_QUEUE /* @min:%2equeue */].length;\r\n for (var i = 0; i < length_1; i++) {\r\n var call = _self.snippet[_DYN_QUEUE /* @min:%2equeue */][i];\r\n call();\r\n }\r\n _self.snippet[_DYN_QUEUE /* @min:%2equeue */] = undefined;\r\n delete _self.snippet[_DYN_QUEUE /* @min:%2equeue */];\r\n }\r\n }\r\n catch (exception) {\r\n var properties_1 = {};\r\n if (exception && isFunction(exception.toString)) {\r\n properties_1.exception = exception.toString();\r\n }\r\n // need from core\r\n // Microsoft.ApplicationInsights._InternalLogging.throwInternal(\r\n // eLoggingSeverity.WARNING,\r\n // _eInternalMessageId.FailedToSendQueuedTelemetry,\r\n // \"Failed to send queued telemetry\",\r\n // properties);\r\n }\r\n };\r\n _self[_DYN_ADD_HOUSEKEEPING_BEF20 /* @min:%2eaddHousekeepingBeforeUnload */] = function (appInsightsInstance) {\r\n // Add callback to push events when the user navigates away\r\n if (hasWindow() || hasDocument()) {\r\n var performHousekeeping = function () {\r\n // Adds the ability to flush all data before the page unloads.\r\n // Note: This approach tries to push a sync request with all the pending events onbeforeunload.\r\n // Firefox does not respect this.Other browsers DO push out the call with < 100% hit rate.\r\n // Telemetry here will help us analyze how effective this approach is.\r\n // Another approach would be to make this call sync with a acceptable timeout to reduce the\r\n // impact on user experience.\r\n // appInsightsInstance.context._sender.triggerSend();\r\n appInsightsInstance[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */](false);\r\n // Back up the current session to local storage\r\n // This lets us close expired sessions after the cookies themselves expire\r\n if (isFunction(_this.core[STR_GET_PLUGIN /* @min:%2egetPlugin */])) {\r\n var loadedPlugin = _this.core[STR_GET_PLUGIN /* @min:%2egetPlugin */](PropertiesPluginIdentifier);\r\n if (loadedPlugin) {\r\n var propertiesPlugin = loadedPlugin.plugin;\r\n if (propertiesPlugin && propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */] && propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */]._sessionManager) {\r\n propertiesPlugin[_DYN_CONTEXT /* @min:%2econtext */]._sessionManager.backup();\r\n }\r\n }\r\n }\r\n };\r\n var added = false;\r\n var excludePageUnloadEvents = appInsightsInstance.appInsights[_DYN_CONFIG /* @min:%2econfig */].disablePageUnloadEvents;\r\n if (!_houseKeepingNamespace) {\r\n _houseKeepingNamespace = mergeEvtNamespace(_evtNamespace, _core[STR_EVT_NAMESPACE /* @min:%2eevtNamespace */] && _core[STR_EVT_NAMESPACE /* @min:%2eevtNamespace */]());\r\n }\r\n if (!appInsightsInstance.appInsights.config[_DYN_DISABLE_FLUSH_ON_BEF11 /* @min:%2edisableFlushOnBeforeUnload */]) {\r\n // Hook the unload event for the document, window and body to ensure that the client events are flushed to the server\r\n // As just hooking the window does not always fire (on chrome) for page navigation's.\r\n if (addPageUnloadEventListener(performHousekeeping, excludePageUnloadEvents, _houseKeepingNamespace)) {\r\n added = true;\r\n }\r\n // We also need to hook the pagehide and visibilitychange events as not all versions of Safari support load/unload events.\r\n if (addPageHideEventListener(performHousekeeping, excludePageUnloadEvents, _houseKeepingNamespace)) {\r\n added = true;\r\n }\r\n // A reactNative app may not have a window and therefore the beforeunload/pagehide events -- so don't\r\n // log the failure in this case\r\n if (!added && !isReactNative()) {\r\n _throwInternal(appInsightsInstance[_DYN_APP_INSIGHTS /* @min:%2eappInsights */].core.logger, 1 /* eLoggingSeverity.CRITICAL */, 19 /* _eInternalMessageId.FailedToAddHandlerForOnBeforeUnload */, \"Could not add handler for beforeunload and pagehide\");\r\n }\r\n }\r\n if (!added && !appInsightsInstance.appInsights.config[_DYN_DISABLE_FLUSH_ON_UNL12 /* @min:%2edisableFlushOnUnload */]) {\r\n // If we didn't add the normal set then attempt to add the pagehide and visibilitychange only\r\n addPageHideEventListener(performHousekeeping, excludePageUnloadEvents, _houseKeepingNamespace);\r\n }\r\n }\r\n };\r\n _self.getSender = function () {\r\n return _sender;\r\n };\r\n _self.unload = function (isAsync, unloadComplete, cbTimeout) {\r\n _self[_DYN_ONUNLOAD_FLUSH /* @min:%2eonunloadFlush */](isAsync);\r\n // Remove any registered event handlers\r\n if (_houseKeepingNamespace) {\r\n removePageUnloadEventListener(null, _houseKeepingNamespace);\r\n removePageHideEventListener(null, _houseKeepingNamespace);\r\n }\r\n _core.unload && _core.unload(isAsync, unloadComplete, cbTimeout);\r\n };\r\n proxyFunctions(_self, _self[_DYN_APP_INSIGHTS /* @min:%2eappInsights */], [\r\n STR_GET_COOKIE_MGR,\r\n STR_TRACK_EVENT,\r\n STR_TRACK_PAGE_VIEW,\r\n \"trackPageViewPerformance\",\r\n STR_TRACK_EXCEPTION,\r\n \"_onerror\",\r\n STR_TRACK_TRACE,\r\n STR_TRACK_METRIC,\r\n STR_START_TRACK_PAGE,\r\n STR_STOP_TRACK_PAGE,\r\n STR_START_TRACK_EVENT,\r\n STR_STOP_TRACK_EVENT\r\n ]);\r\n proxyFunctions(_self, _getCurrentDependencies, [\r\n STR_TRACK_DEPENDENCY_DATA,\r\n \"addDependencyListener\",\r\n \"addDependencyInitializer\"\r\n ]);\r\n proxyFunctions(_self, _core, [\r\n STR_ADD_TELEMETRY_INITIALIZER,\r\n STR_POLL_INTERNAL_LOGS,\r\n \"stopPollingInternalLogs\",\r\n STR_GET_PLUGIN,\r\n \"addPlugin\",\r\n STR_EVT_NAMESPACE,\r\n \"addUnloadCb\",\r\n \"getTraceCtx\"\r\n ]);\r\n proxyFunctions(_self, function () {\r\n var context = properties[_DYN_CONTEXT /* @min:%2econtext */];\r\n return context ? context.user : null;\r\n }, [\r\n STR_SET_AUTHENTICATED_USER_CONTEXT,\r\n STR_CLEAR_AUTHENTICATED_USER_CONTEXT\r\n ]);\r\n function _getSKUDefaults() {\r\n _self.config[_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] =\r\n _self.config[_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] && _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] > 0 ? _self[_DYN_CONFIG /* @min:%2econfig */][_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] : 10000;\r\n }\r\n // Using a function to support the dynamic adding / removal of plugins, so this will always return the current value\r\n function _getCurrentDependencies() {\r\n return dependencies;\r\n }\r\n function _initDefaults() {\r\n _evtNamespace = createUniqueNamespace(\"AISKU\");\r\n _houseKeepingNamespace = null;\r\n dependencies = null;\r\n properties = null;\r\n _sender = null;\r\n _snippetVersion = null;\r\n }\r\n });\r\n }\r\n // Analytics Plugin\r\n// Removed Stub for Initialization.prototype.getCookieMgr.\r\n// Removed Stub for Initialization.prototype.trackEvent.\r\n// Removed Stub for Initialization.prototype.trackPageView.\r\n// Removed Stub for Initialization.prototype.trackPageViewPerformance.\r\n// Removed Stub for Initialization.prototype.trackException.\r\n// Removed Stub for Initialization.prototype._onerror.\r\n// Removed Stub for Initialization.prototype.trackTrace.\r\n// Removed Stub for Initialization.prototype.trackMetric.\r\n// Removed Stub for Initialization.prototype.startTrackPage.\r\n// Removed Stub for Initialization.prototype.stopTrackPage.\r\n// Removed Stub for Initialization.prototype.startTrackEvent.\r\n// Removed Stub for Initialization.prototype.stopTrackEvent.\r\n// Removed Stub for Initialization.prototype.addTelemetryInitializer.\r\n // Properties Plugin\r\n// Removed Stub for Initialization.prototype.setAuthenticatedUserContext.\r\n// Removed Stub for Initialization.prototype.clearAuthenticatedUserContext.\r\n // Dependencies Plugin\r\n// Removed Stub for Initialization.prototype.trackDependencyData.\r\n // Misc\r\n// Removed Stub for Initialization.prototype.flush.\r\n// Removed Stub for Initialization.prototype.onunloadFlush.\r\n// Removed Stub for Initialization.prototype.loadAppInsights.\r\n// Removed Stub for Initialization.prototype.updateSnippetDefinitions.\r\n// Removed Stub for Initialization.prototype.emptyQueue.\r\n// Removed Stub for Initialization.prototype.pollInternalLogs.\r\n// Removed Stub for Initialization.prototype.stopPollingInternalLogs.\r\n// Removed Stub for Initialization.prototype.addHousekeepingBeforeUnload.\r\n// Removed Stub for Initialization.prototype.getSender.\r\n// Removed Stub for Initialization.prototype.unload.\r\n// Removed Stub for Initialization.prototype.getPlugin.\r\n// Removed Stub for Initialization.prototype.addPlugin.\r\n// Removed Stub for Initialization.prototype.evtNamespace.\r\n// Removed Stub for Initialization.prototype.addUnloadCb.\r\n// Removed Stub for Initialization.prototype.addDependencyListener.\r\n /**\r\n * Add an dependency telemetry initializer callback function to allow populating additional properties or drop the request.\r\n * It is called after the dependency call has completed and any available performance details are available. A dependency\r\n * initializer is similar to the TelemetryInitializer function but it allows you to block the reporting of the dependency\r\n * request so that it doesn't count against the `maxAjaxCallsPerView`.\r\n * @param dependencyInitializer - The Dependency Telemetry Initializer function\r\n * @returns - A IDependencyInitializerHandler to enable the initializer to be removed\r\n */\r\n Initialization.prototype.addDependencyInitializer = function (dependencyInitializer) {\r\n return null;\r\n };\r\n// Removed Stub for Initialization.prototype.getTraceCtx.\r\n return Initialization;\r\n}());\r\nexport { Initialization };\r\n// tslint:disable-next-line\r\n(function () {\r\n var sdkSrc = null;\r\n var isModule = false;\r\n var cdns = [\r\n \"://js.monitor.azure.com/\",\r\n \"://az416426.vo.msecnd.net/\"\r\n ];\r\n try {\r\n // Try and determine whether the sdk is being loaded from the CDN\r\n // currentScript is only valid during initial processing\r\n var scrpt = (document || {}).currentScript;\r\n if (scrpt) {\r\n sdkSrc = scrpt.src;\r\n // } else {\r\n // // We need to update to at least typescript 2.9 for this to work :-(\r\n // // Leaving as a stub for now so after we upgrade this breadcrumb is available\r\n // let meta = import.meta;\r\n // sdkSrc = (meta || {}).url;\r\n // isModule = true;\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n if (sdkSrc) {\r\n try {\r\n var url = sdkSrc.toLowerCase();\r\n if (url) {\r\n var src = \"\";\r\n for (var idx = 0; idx < cdns.length; idx++) {\r\n if (url[_DYN_INDEX_OF /* @min:%2eindexOf */](cdns[idx]) !== -1) {\r\n src = \"cdn\" + (idx + 1);\r\n if (url[_DYN_INDEX_OF /* @min:%2eindexOf */](\"/scripts/\") === -1) {\r\n if (url[_DYN_INDEX_OF /* @min:%2eindexOf */](\"/next/\") !== -1) {\r\n src += \"-next\";\r\n }\r\n else if (url[_DYN_INDEX_OF /* @min:%2eindexOf */](\"/beta/\") !== -1) {\r\n src += \"-beta\";\r\n }\r\n }\r\n _internalSdkSrc = src + (isModule ? \".mod\" : \"\");\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // eslint-disable-next-line no-empty\r\n }\r\n }\r\n})();\r\n//# sourceMappingURL=Initialization.js.map","/*\n * Application Insights JavaScript SDK - Web, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\n// ##############################################################\r\n// AUTO GENERATED FILE: This file is Auto Generated during build.\r\n// ##############################################################\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n// Note: DON'T Export these const from the package as we are still targeting ES3 this will export a mutable variables that someone could change!!!\r\n// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\nexport var _DYN_UPDATE_SNIPPET_DEFIN0 = \"updateSnippetDefinitions\"; // Count: 4\r\nexport var _DYN_LOAD_APP_INSIGHTS = \"loadAppInsights\"; // Count: 4\r\nexport var _DYN_ENDPOINT_URL = \"endpointUrl\"; // Count: 4\r\nexport var _DYN_MAX_BATCH_SIZE_IN_BY1 = \"maxBatchSizeInBytes\"; // Count: 3\r\nexport var _DYN_MAX_BATCH_INTERVAL = \"maxBatchInterval\"; // Count: 3\r\nexport var _DYN_DISABLE_EXCEPTION_TR2 = \"disableExceptionTracking\"; // Count: 2\r\nexport var _DYN_DISABLE_TELEMETRY = \"disableTelemetry\"; // Count: 2\r\nexport var _DYN_EMIT_LINE_DELIMITED_3 = \"emitLineDelimitedJson\"; // Count: 2\r\nexport var _DYN_DIAGNOSTIC_LOG_INTER4 = \"diagnosticLogInterval\"; // Count: 6\r\nexport var _DYN_AUTO_TRACK_PAGE_VISI5 = \"autoTrackPageVisitTime\"; // Count: 2\r\nexport var _DYN_SAMPLING_PERCENTAGE = \"samplingPercentage\"; // Count: 4\r\nexport var _DYN_DISABLE_AJAX_TRACKIN6 = \"disableAjaxTracking\"; // Count: 2\r\nexport var _DYN_MAX_AJAX_CALLS_PER_V7 = \"maxAjaxCallsPerView\"; // Count: 3\r\nexport var _DYN_IS_BEACON_API_DISABL8 = \"isBeaconApiDisabled\"; // Count: 2\r\nexport var _DYN_DISABLE_CORRELATION_9 = \"disableCorrelationHeaders\"; // Count: 2\r\nexport var _DYN_CORRELATION_HEADER_E10 = \"correlationHeaderExcludedDomains\"; // Count: 2\r\nexport var _DYN_DISABLE_FLUSH_ON_BEF11 = \"disableFlushOnBeforeUnload\"; // Count: 4\r\nexport var _DYN_DISABLE_FLUSH_ON_UNL12 = \"disableFlushOnUnload\"; // Count: 3\r\nexport var _DYN_ENABLE_SESSION_STORA13 = \"enableSessionStorageBuffer\"; // Count: 2\r\nexport var _DYN_IS_COOKIE_USE_DISABL14 = \"isCookieUseDisabled\"; // Count: 2\r\nexport var _DYN_IS_STORAGE_USE_DISAB15 = \"isStorageUseDisabled\"; // Count: 2\r\nexport var _DYN_IS_BROWSER_LINK_TRAC16 = \"isBrowserLinkTrackingEnabled\"; // Count: 2\r\nexport var _DYN_ENABLE_CORS_CORRELAT17 = \"enableCorsCorrelation\"; // Count: 2\r\nexport var _DYN_CONFIG = \"config\"; // Count: 6\r\nexport var _DYN_CONTEXT = \"context\"; // Count: 8\r\nexport var _DYN_PUSH = \"push\"; // Count: 5\r\nexport var _DYN_VERSION = \"version\"; // Count: 6\r\nexport var _DYN_QUEUE = \"queue\"; // Count: 6\r\nexport var _DYN_CONNECTION_STRING = \"connectionString\"; // Count: 3\r\nexport var _DYN_INSTRUMENTATION_KEY = \"instrumentationKey\"; // Count: 2\r\nexport var _DYN_APP_INSIGHTS = \"appInsights\"; // Count: 3\r\nexport var _DYN_DISABLE_IKEY_DEPRECA18 = \"disableIkeyDeprecationMessage\"; // Count: 2\r\nexport var _DYN_GET_TRANSMISSION_CON19 = \"getTransmissionControls\"; // Count: 2\r\nexport var _DYN_ONUNLOAD_FLUSH = \"onunloadFlush\"; // Count: 6\r\nexport var _DYN_ADD_HOUSEKEEPING_BEF20 = \"addHousekeepingBeforeUnload\"; // Count: 2\r\nexport var _DYN_INDEX_OF = \"indexOf\"; // Count: 4\r\n//# sourceMappingURL=__DynamicConstants.js.map","/*\n * Application Insights JavaScript SDK - Web, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport dynamicProto from \"@microsoft/dynamicproto-js\";\r\nimport { DEFAULT_BREEZE_ENDPOINT, DEFAULT_BREEZE_PATH, ProcessLegacy, stringToBoolOrDefault } from \"@microsoft/applicationinsights-common\";\r\nimport { arrIndexOf, isFunction, proxyAssign, proxyFunctions, throwError } from \"@microsoft/applicationinsights-core-js\";\r\nimport { DfltAjaxCorrelationHeaderExDomains } from \"@microsoft/applicationinsights-dependencies-js\";\r\nimport { STR_ADD_TELEMETRY_INITIALIZER, STR_ADD_TELEMETRY_INITIALIZERS, STR_CLEAR_AUTHENTICATED_USER_CONTEXT, STR_FLUSH, STR_GET_COOKIE_MGR, STR_SET_AUTHENTICATED_USER_CONTEXT, STR_SNIPPET, STR_START_TRACK_EVENT, STR_START_TRACK_PAGE, STR_STOP_TRACK_EVENT, STR_STOP_TRACK_PAGE, STR_TRACK_DEPENDENCY_DATA, STR_TRACK_EVENT, STR_TRACK_EXCEPTION, STR_TRACK_METRIC, STR_TRACK_PAGE_VIEW, STR_TRACK_TRACE } from \"./InternalConstants\";\r\nimport { _DYN_AUTO_TRACK_PAGE_VISI5, _DYN_CONFIG, _DYN_CONTEXT, _DYN_CORRELATION_HEADER_E10, _DYN_DIAGNOSTIC_LOG_INTER4, _DYN_DISABLE_AJAX_TRACKIN6, _DYN_DISABLE_CORRELATION_9, _DYN_DISABLE_EXCEPTION_TR2, _DYN_DISABLE_FLUSH_ON_BEF11, _DYN_DISABLE_TELEMETRY, _DYN_EMIT_LINE_DELIMITED_3, _DYN_ENABLE_CORS_CORRELAT17, _DYN_ENABLE_SESSION_STORA13, _DYN_ENDPOINT_URL, _DYN_IS_BEACON_API_DISABL8, _DYN_IS_BROWSER_LINK_TRAC16, _DYN_IS_COOKIE_USE_DISABL14, _DYN_IS_STORAGE_USE_DISAB15, _DYN_LOAD_APP_INSIGHTS, _DYN_MAX_AJAX_CALLS_PER_V7, _DYN_MAX_BATCH_INTERVAL, _DYN_MAX_BATCH_SIZE_IN_BY1, _DYN_PUSH, _DYN_QUEUE, _DYN_SAMPLING_PERCENTAGE, _DYN_UPDATE_SNIPPET_DEFIN0 } from \"./__DynamicConstants\";\r\n// This is an exclude list of properties that should not be updated during initialization\r\n// They include a combination of private and internal property names\r\nvar _ignoreUpdateSnippetProperties = [\r\n STR_SNIPPET, \"getDefaultConfig\", \"_hasLegacyInitializers\", \"_queue\", \"_processLegacyInitializers\"\r\n];\r\nfunction getDefaultConfig(config) {\r\n if (!config) {\r\n config = {};\r\n }\r\n // set default values\r\n config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] = config[_DYN_ENDPOINT_URL /* @min:%2eendpointUrl */] || DEFAULT_BREEZE_ENDPOINT + DEFAULT_BREEZE_PATH;\r\n config.sessionRenewalMs = 30 * 60 * 1000;\r\n config.sessionExpirationMs = 24 * 60 * 60 * 1000;\r\n config[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */] = config[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */] > 0 ? config[_DYN_MAX_BATCH_SIZE_IN_BY1 /* @min:%2emaxBatchSizeInBytes */] : 102400; // 100kb\r\n config[_DYN_MAX_BATCH_INTERVAL /* @min:%2emaxBatchInterval */] = !isNaN(config[_DYN_MAX_BATCH_INTERVAL /* @min:%2emaxBatchInterval */]) ? config[_DYN_MAX_BATCH_INTERVAL /* @min:%2emaxBatchInterval */] : 15000;\r\n config.enableDebug = stringToBoolOrDefault(config.enableDebug);\r\n config[_DYN_DISABLE_EXCEPTION_TR2 /* @min:%2edisableExceptionTracking */] = stringToBoolOrDefault(config[_DYN_DISABLE_EXCEPTION_TR2 /* @min:%2edisableExceptionTracking */]);\r\n config[_DYN_DISABLE_TELEMETRY /* @min:%2edisableTelemetry */] = stringToBoolOrDefault(config[_DYN_DISABLE_TELEMETRY /* @min:%2edisableTelemetry */]);\r\n config.verboseLogging = stringToBoolOrDefault(config.verboseLogging);\r\n config[_DYN_EMIT_LINE_DELIMITED_3 /* @min:%2eemitLineDelimitedJson */] = stringToBoolOrDefault(config[_DYN_EMIT_LINE_DELIMITED_3 /* @min:%2eemitLineDelimitedJson */]);\r\n config[_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] = config[_DYN_DIAGNOSTIC_LOG_INTER4 /* @min:%2ediagnosticLogInterval */] || 10000;\r\n config[_DYN_AUTO_TRACK_PAGE_VISI5 /* @min:%2eautoTrackPageVisitTime */] = stringToBoolOrDefault(config[_DYN_AUTO_TRACK_PAGE_VISI5 /* @min:%2eautoTrackPageVisitTime */]);\r\n if (isNaN(config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */]) || config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] <= 0 || config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] >= 100) {\r\n config[_DYN_SAMPLING_PERCENTAGE /* @min:%2esamplingPercentage */] = 100;\r\n }\r\n config[_DYN_DISABLE_AJAX_TRACKIN6 /* @min:%2edisableAjaxTracking */] = stringToBoolOrDefault(config[_DYN_DISABLE_AJAX_TRACKIN6 /* @min:%2edisableAjaxTracking */]);\r\n config[_DYN_MAX_AJAX_CALLS_PER_V7 /* @min:%2emaxAjaxCallsPerView */] = !isNaN(config[_DYN_MAX_AJAX_CALLS_PER_V7 /* @min:%2emaxAjaxCallsPerView */]) ? config[_DYN_MAX_AJAX_CALLS_PER_V7 /* @min:%2emaxAjaxCallsPerView */] : 500;\r\n config[_DYN_IS_BEACON_API_DISABL8 /* @min:%2eisBeaconApiDisabled */] = stringToBoolOrDefault(config[_DYN_IS_BEACON_API_DISABL8 /* @min:%2eisBeaconApiDisabled */], true);\r\n config[_DYN_DISABLE_CORRELATION_9 /* @min:%2edisableCorrelationHeaders */] = stringToBoolOrDefault(config[_DYN_DISABLE_CORRELATION_9 /* @min:%2edisableCorrelationHeaders */]);\r\n config[_DYN_CORRELATION_HEADER_E10 /* @min:%2ecorrelationHeaderExcludedDomains */] = config[_DYN_CORRELATION_HEADER_E10 /* @min:%2ecorrelationHeaderExcludedDomains */] || DfltAjaxCorrelationHeaderExDomains;\r\n config[_DYN_DISABLE_FLUSH_ON_BEF11 /* @min:%2edisableFlushOnBeforeUnload */] = stringToBoolOrDefault(config[_DYN_DISABLE_FLUSH_ON_BEF11 /* @min:%2edisableFlushOnBeforeUnload */]);\r\n config.disableFlushOnUnload = stringToBoolOrDefault(config.disableFlushOnUnload, config[_DYN_DISABLE_FLUSH_ON_BEF11 /* @min:%2edisableFlushOnBeforeUnload */]);\r\n config[_DYN_ENABLE_SESSION_STORA13 /* @min:%2eenableSessionStorageBuffer */] = stringToBoolOrDefault(config[_DYN_ENABLE_SESSION_STORA13 /* @min:%2eenableSessionStorageBuffer */], true);\r\n config.isRetryDisabled = stringToBoolOrDefault(config.isRetryDisabled);\r\n config[_DYN_IS_COOKIE_USE_DISABL14 /* @min:%2eisCookieUseDisabled */] = stringToBoolOrDefault(config[_DYN_IS_COOKIE_USE_DISABL14 /* @min:%2eisCookieUseDisabled */]);\r\n config[_DYN_IS_STORAGE_USE_DISAB15 /* @min:%2eisStorageUseDisabled */] = stringToBoolOrDefault(config[_DYN_IS_STORAGE_USE_DISAB15 /* @min:%2eisStorageUseDisabled */]);\r\n config[_DYN_IS_BROWSER_LINK_TRAC16 /* @min:%2eisBrowserLinkTrackingEnabled */] = stringToBoolOrDefault(config[_DYN_IS_BROWSER_LINK_TRAC16 /* @min:%2eisBrowserLinkTrackingEnabled */]);\r\n config[_DYN_ENABLE_CORS_CORRELAT17 /* @min:%2eenableCorsCorrelation */] = stringToBoolOrDefault(config[_DYN_ENABLE_CORS_CORRELAT17 /* @min:%2eenableCorsCorrelation */]);\r\n return config;\r\n}\r\nvar AppInsightsDeprecated = /** @class */ (function () {\r\n function AppInsightsDeprecated(snippet, appInsightsNew) {\r\n var _this = this;\r\n var _hasLegacyInitializers = false;\r\n var _queue = [];\r\n var _config;\r\n dynamicProto(AppInsightsDeprecated, this, function (_self) {\r\n _config = getDefaultConfig(snippet[_DYN_CONFIG /* @min:%2econfig */]);\r\n _self[_DYN_CONFIG /* @min:%2econfig */] = _config;\r\n _self[STR_SNIPPET /* @min:%2esnippet */] = snippet;\r\n _self.appInsightsNew = appInsightsNew;\r\n _self[_DYN_CONTEXT /* @min:%2econtext */] = { addTelemetryInitializer: _addTelemetryInitializers.bind(_self) };\r\n _self[STR_ADD_TELEMETRY_INITIALIZERS /* @min:%2eaddTelemetryInitializers */] = _addTelemetryInitializers;\r\n function _addTelemetryInitializers(callBack) {\r\n // Add initializer to current processing only if there is any old telemetry initializer\r\n if (!_hasLegacyInitializers) {\r\n appInsightsNew[STR_ADD_TELEMETRY_INITIALIZER /* @min:%2eaddTelemetryInitializer */](function (item) {\r\n _processLegacyInitializers(item); // setup call back for each legacy processor\r\n });\r\n _hasLegacyInitializers = true;\r\n }\r\n _queue[_DYN_PUSH /* @min:%2epush */](callBack);\r\n }\r\n proxyFunctions(_self, appInsightsNew, [\r\n STR_GET_COOKIE_MGR,\r\n STR_START_TRACK_PAGE,\r\n STR_STOP_TRACK_PAGE,\r\n STR_FLUSH,\r\n STR_START_TRACK_EVENT,\r\n STR_STOP_TRACK_EVENT\r\n ]);\r\n _self[STR_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (name, url, properties, measurements, duration) {\r\n var telemetry = {\r\n name: name,\r\n uri: url,\r\n properties: properties,\r\n measurements: measurements\r\n };\r\n // fix for props, measurements, duration\r\n appInsightsNew[STR_TRACK_PAGE_VIEW /* @min:%2etrackPageView */](telemetry);\r\n };\r\n _self[STR_TRACK_EVENT /* @min:%2etrackEvent */] = function (name, properties, measurements) {\r\n appInsightsNew[STR_TRACK_EVENT /* @min:%2etrackEvent */]({ name: name });\r\n };\r\n _self.trackDependency = function (id, method, absoluteUrl, pathName, totalTime, success, resultCode) {\r\n appInsightsNew[STR_TRACK_DEPENDENCY_DATA /* @min:%2etrackDependencyData */]({\r\n id: id,\r\n target: absoluteUrl,\r\n type: pathName,\r\n duration: totalTime,\r\n properties: { HttpMethod: method },\r\n success: success,\r\n responseCode: resultCode\r\n });\r\n };\r\n _self[STR_TRACK_EXCEPTION /* @min:%2etrackException */] = function (exception, handledAt, properties, measurements, severityLevel) {\r\n appInsightsNew[STR_TRACK_EXCEPTION /* @min:%2etrackException */]({\r\n exception: exception\r\n });\r\n };\r\n _self[STR_TRACK_METRIC /* @min:%2etrackMetric */] = function (name, average, sampleCount, min, max, properties) {\r\n appInsightsNew[STR_TRACK_METRIC /* @min:%2etrackMetric */]({ name: name, average: average, sampleCount: sampleCount, min: min, max: max });\r\n };\r\n _self[STR_TRACK_TRACE /* @min:%2etrackTrace */] = function (message, properties, severityLevel) {\r\n appInsightsNew[STR_TRACK_TRACE /* @min:%2etrackTrace */]({ message: message, severityLevel: severityLevel });\r\n };\r\n _self[STR_SET_AUTHENTICATED_USER_CONTEXT /* @min:%2esetAuthenticatedUserContext */] = function (authenticatedUserId, accountId, storeInCookie) {\r\n appInsightsNew[_DYN_CONTEXT /* @min:%2econtext */].user[STR_SET_AUTHENTICATED_USER_CONTEXT /* @min:%2esetAuthenticatedUserContext */](authenticatedUserId, accountId, storeInCookie);\r\n };\r\n _self[STR_CLEAR_AUTHENTICATED_USER_CONTEXT /* @min:%2eclearAuthenticatedUserContext */] = function () {\r\n appInsightsNew[_DYN_CONTEXT /* @min:%2econtext */].user[STR_CLEAR_AUTHENTICATED_USER_CONTEXT /* @min:%2eclearAuthenticatedUserContext */]();\r\n };\r\n _self._onerror = function (message, url, lineNumber, columnNumber, error) {\r\n appInsightsNew._onerror({ message: message, url: url, lineNumber: lineNumber, columnNumber: columnNumber, error: error });\r\n };\r\n _self.downloadAndSetup = function (config) {\r\n throwError(\"downloadAndSetup not implemented in web SKU\");\r\n };\r\n _self[_DYN_UPDATE_SNIPPET_DEFIN0 /* @min:%2eupdateSnippetDefinitions */] = function (snippet) {\r\n // apply full appInsights to the global instance\r\n // Note: This must be called before loadAppInsights is called\r\n proxyAssign(snippet, _this, function (name) {\r\n // Not excluding names prefixed with \"_\" as we need to proxy some functions like _onError\r\n return name && arrIndexOf(_ignoreUpdateSnippetProperties, name) === -1;\r\n });\r\n };\r\n // note: these are split into methods to enable unit tests\r\n _self[_DYN_LOAD_APP_INSIGHTS /* @min:%2eloadAppInsights */] = function () {\r\n // initialize global instance of appInsights\r\n // var appInsights = new Microsoft.ApplicationInsights.AppInsights(_self.config);\r\n // implement legacy version of trackPageView for 0.10<\r\n if (_self[_DYN_CONFIG /* @min:%2econfig */][\"iKey\"]) {\r\n var originalTrackPageView_1 = _self[STR_TRACK_PAGE_VIEW /* @min:%2etrackPageView */];\r\n _self[STR_TRACK_PAGE_VIEW /* @min:%2etrackPageView */] = function (pagePath, properties, measurements) {\r\n originalTrackPageView_1.apply(_self, [null, pagePath, properties, measurements]);\r\n };\r\n }\r\n // implement legacy pageView interface if it is present in the snippet\r\n var legacyPageView = \"logPageView\";\r\n if (isFunction(_self[STR_SNIPPET /* @min:%2esnippet */][legacyPageView])) {\r\n _this[legacyPageView] = function (pagePath, properties, measurements) {\r\n _self[STR_TRACK_PAGE_VIEW /* @min:%2etrackPageView */](null, pagePath, properties, measurements);\r\n };\r\n }\r\n // implement legacy event interface if it is present in the snippet\r\n var legacyEvent = \"logEvent\";\r\n if (isFunction(_self[STR_SNIPPET /* @min:%2esnippet */][legacyEvent])) {\r\n _this[legacyEvent] = function (name, props, measurements) {\r\n _self[STR_TRACK_EVENT /* @min:%2etrackEvent */](name, props, measurements);\r\n };\r\n }\r\n return _this;\r\n };\r\n function _processLegacyInitializers(item) {\r\n // instead of mapping new to legacy and then back again and repeating in channel, attach callback for channel to call\r\n item.tags[ProcessLegacy] = _queue;\r\n return item;\r\n }\r\n });\r\n }\r\n// Removed Stub for AppInsightsDeprecated.prototype.addTelemetryInitializers.\r\n// Removed Stub for AppInsightsDeprecated.prototype.getCookieMgr.\r\n// Removed Stub for AppInsightsDeprecated.prototype.startTrackPage.\r\n// Removed Stub for AppInsightsDeprecated.prototype.stopTrackPage.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackPageView.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackEvent.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackDependency.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackException.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackMetric.\r\n// Removed Stub for AppInsightsDeprecated.prototype.trackTrace.\r\n// Removed Stub for AppInsightsDeprecated.prototype.flush.\r\n// Removed Stub for AppInsightsDeprecated.prototype.setAuthenticatedUserContext.\r\n// Removed Stub for AppInsightsDeprecated.prototype.clearAuthenticatedUserContext.\r\n// Removed Stub for AppInsightsDeprecated.prototype._onerror.\r\n// Removed Stub for AppInsightsDeprecated.prototype.startTrackEvent.\r\n// Removed Stub for AppInsightsDeprecated.prototype.stopTrackEvent.\r\n// Removed Stub for AppInsightsDeprecated.prototype.downloadAndSetup.\r\n// Removed Stub for AppInsightsDeprecated.prototype.updateSnippetDefinitions.\r\n // note: these are split into methods to enable unit tests\r\n// Removed Stub for AppInsightsDeprecated.prototype.loadAppInsights.\r\n // This is a workaround for an IE8 bug when using dynamicProto() with classes that don't have any\n // non-dynamic functions or static properties/functions when using uglify-js to minify the resulting code.\n // this will be removed when ES3 support is dropped.\n AppInsightsDeprecated.__ieDyn=1;\n\n return AppInsightsDeprecated;\r\n}());\r\nexport { AppInsightsDeprecated };\r\n//# sourceMappingURL=ApplicationInsightsDeprecated.js.map","/*\n * Application Insights JavaScript SDK - Core, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\n\r\n\r\n// @skip-file-minify\r\nvar _a;\r\nimport { createEnumStyle } from \"../JavaScriptSDK.Enums/EnumHelperFuncs\";\r\nvar FAILED = \"Failed\";\r\nvar FAILED_MONITOR_AJAX = FAILED + \"MonitorAjax\";\r\nvar TRACK = \"Track\";\r\nvar START = \"Start\";\r\nvar STOP = \"Stop\";\r\nvar EVENT = \"Event\";\r\nvar AUTH_CONTEXT = \"AuthContext\";\r\nvar EXCEPTION = \"Exception\";\r\nvar LOCAL = \"Local\";\r\nvar SESSION = \"Session\";\r\nvar STORAGE = \"Storage\";\r\nvar BROWSER = \"Browser\";\r\nvar CANNOT = \"Cannot\";\r\nvar BUFFER = \"Buffer\";\r\nvar INSTRUMENTATION_KEY = \"InstrumentationKey\";\r\nexport var LoggingSeverity = createEnumStyle({\r\n CRITICAL: 1 /* eLoggingSeverity.CRITICAL */,\r\n WARNING: 2 /* eLoggingSeverity.WARNING */\r\n});\r\n/**\r\n * Internal message ID. Please create a new one for every conceptually different message. Please keep alphabetically ordered\r\n */\r\nexport var _InternalMessageId = createEnumStyle((_a = {},\r\n // Non user actionable\r\n _a[BROWSER + \"DoesNotSupport\" + LOCAL + STORAGE] = 0 /* _eInternalMessageId.BrowserDoesNotSupportLocalStorage */,\r\n _a[BROWSER + CANNOT + \"Read\" + LOCAL + STORAGE] = 1 /* _eInternalMessageId.BrowserCannotReadLocalStorage */,\r\n _a[BROWSER + CANNOT + \"Read\" + SESSION + STORAGE] = 2 /* _eInternalMessageId.BrowserCannotReadSessionStorage */,\r\n _a[BROWSER + CANNOT + \"Write\" + LOCAL + STORAGE] = 3 /* _eInternalMessageId.BrowserCannotWriteLocalStorage */,\r\n _a[BROWSER + CANNOT + \"Write\" + SESSION + STORAGE] = 4 /* _eInternalMessageId.BrowserCannotWriteSessionStorage */,\r\n _a[BROWSER + FAILED + \"RemovalFrom\" + LOCAL + STORAGE] = 5 /* _eInternalMessageId.BrowserFailedRemovalFromLocalStorage */,\r\n _a[BROWSER + FAILED + \"RemovalFrom\" + SESSION + STORAGE] = 6 /* _eInternalMessageId.BrowserFailedRemovalFromSessionStorage */,\r\n _a[CANNOT + \"SendEmptyTelemetry\"] = 7 /* _eInternalMessageId.CannotSendEmptyTelemetry */,\r\n _a.ClientPerformanceMathError = 8 /* _eInternalMessageId.ClientPerformanceMathError */,\r\n _a[\"ErrorParsingAI\" + SESSION + \"Cookie\"] = 9 /* _eInternalMessageId.ErrorParsingAISessionCookie */,\r\n _a.ErrorPVCalc = 10 /* _eInternalMessageId.ErrorPVCalc */,\r\n _a[EXCEPTION + \"WhileLoggingError\"] = 11 /* _eInternalMessageId.ExceptionWhileLoggingError */,\r\n _a[FAILED + \"AddingTelemetryTo\" + BUFFER] = 12 /* _eInternalMessageId.FailedAddingTelemetryToBuffer */,\r\n _a[FAILED_MONITOR_AJAX + \"Abort\"] = 13 /* _eInternalMessageId.FailedMonitorAjaxAbort */,\r\n _a[FAILED_MONITOR_AJAX + \"Dur\"] = 14 /* _eInternalMessageId.FailedMonitorAjaxDur */,\r\n _a[FAILED_MONITOR_AJAX + \"Open\"] = 15 /* _eInternalMessageId.FailedMonitorAjaxOpen */,\r\n _a[FAILED_MONITOR_AJAX + \"RSC\"] = 16 /* _eInternalMessageId.FailedMonitorAjaxRSC */,\r\n _a[FAILED_MONITOR_AJAX + \"Send\"] = 17 /* _eInternalMessageId.FailedMonitorAjaxSend */,\r\n _a[FAILED_MONITOR_AJAX + \"GetCorrelationHeader\"] = 18 /* _eInternalMessageId.FailedMonitorAjaxGetCorrelationHeader */,\r\n _a[FAILED + \"ToAddHandlerForOnBeforeUnload\"] = 19 /* _eInternalMessageId.FailedToAddHandlerForOnBeforeUnload */,\r\n _a[FAILED + \"ToSendQueuedTelemetry\"] = 20 /* _eInternalMessageId.FailedToSendQueuedTelemetry */,\r\n _a[FAILED + \"ToReportDataLoss\"] = 21 /* _eInternalMessageId.FailedToReportDataLoss */,\r\n _a[\"Flush\" + FAILED] = 22 /* _eInternalMessageId.FlushFailed */,\r\n _a.MessageLimitPerPVExceeded = 23 /* _eInternalMessageId.MessageLimitPerPVExceeded */,\r\n _a.MissingRequiredFieldSpecification = 24 /* _eInternalMessageId.MissingRequiredFieldSpecification */,\r\n _a.NavigationTimingNotSupported = 25 /* _eInternalMessageId.NavigationTimingNotSupported */,\r\n _a.OnError = 26 /* _eInternalMessageId.OnError */,\r\n _a[SESSION + \"RenewalDateIsZero\"] = 27 /* _eInternalMessageId.SessionRenewalDateIsZero */,\r\n _a.SenderNotInitialized = 28 /* _eInternalMessageId.SenderNotInitialized */,\r\n _a[START + TRACK + EVENT + FAILED] = 29 /* _eInternalMessageId.StartTrackEventFailed */,\r\n _a[STOP + TRACK + EVENT + FAILED] = 30 /* _eInternalMessageId.StopTrackEventFailed */,\r\n _a[START + TRACK + FAILED] = 31 /* _eInternalMessageId.StartTrackFailed */,\r\n _a[STOP + TRACK + FAILED] = 32 /* _eInternalMessageId.StopTrackFailed */,\r\n _a.TelemetrySampledAndNotSent = 33 /* _eInternalMessageId.TelemetrySampledAndNotSent */,\r\n _a[TRACK + EVENT + FAILED] = 34 /* _eInternalMessageId.TrackEventFailed */,\r\n _a[TRACK + EXCEPTION + FAILED] = 35 /* _eInternalMessageId.TrackExceptionFailed */,\r\n _a[TRACK + \"Metric\" + FAILED] = 36 /* _eInternalMessageId.TrackMetricFailed */,\r\n _a[TRACK + \"PV\" + FAILED] = 37 /* _eInternalMessageId.TrackPVFailed */,\r\n _a[TRACK + \"PV\" + FAILED + \"Calc\"] = 38 /* _eInternalMessageId.TrackPVFailedCalc */,\r\n _a[TRACK + \"Trace\" + FAILED] = 39 /* _eInternalMessageId.TrackTraceFailed */,\r\n _a[\"Transmission\" + FAILED] = 40 /* _eInternalMessageId.TransmissionFailed */,\r\n _a[FAILED + \"ToSet\" + STORAGE + BUFFER] = 41 /* _eInternalMessageId.FailedToSetStorageBuffer */,\r\n _a[FAILED + \"ToRestore\" + STORAGE + BUFFER] = 42 /* _eInternalMessageId.FailedToRestoreStorageBuffer */,\r\n _a.InvalidBackendResponse = 43 /* _eInternalMessageId.InvalidBackendResponse */,\r\n _a[FAILED + \"ToFixDepricatedValues\"] = 44 /* _eInternalMessageId.FailedToFixDepricatedValues */,\r\n _a.InvalidDurationValue = 45 /* _eInternalMessageId.InvalidDurationValue */,\r\n _a.TelemetryEnvelopeInvalid = 46 /* _eInternalMessageId.TelemetryEnvelopeInvalid */,\r\n _a.CreateEnvelopeError = 47 /* _eInternalMessageId.CreateEnvelopeError */,\r\n // User actionable\r\n _a[CANNOT + \"SerializeObject\"] = 48 /* _eInternalMessageId.CannotSerializeObject */,\r\n _a[CANNOT + \"SerializeObjectNonSerializable\"] = 49 /* _eInternalMessageId.CannotSerializeObjectNonSerializable */,\r\n _a.CircularReferenceDetected = 50 /* _eInternalMessageId.CircularReferenceDetected */,\r\n _a[\"Clear\" + AUTH_CONTEXT + FAILED] = 51 /* _eInternalMessageId.ClearAuthContextFailed */,\r\n _a[EXCEPTION + \"Truncated\"] = 52 /* _eInternalMessageId.ExceptionTruncated */,\r\n _a.IllegalCharsInName = 53 /* _eInternalMessageId.IllegalCharsInName */,\r\n _a.ItemNotInArray = 54 /* _eInternalMessageId.ItemNotInArray */,\r\n _a.MaxAjaxPerPVExceeded = 55 /* _eInternalMessageId.MaxAjaxPerPVExceeded */,\r\n _a.MessageTruncated = 56 /* _eInternalMessageId.MessageTruncated */,\r\n _a.NameTooLong = 57 /* _eInternalMessageId.NameTooLong */,\r\n _a.SampleRateOutOfRange = 58 /* _eInternalMessageId.SampleRateOutOfRange */,\r\n _a[\"Set\" + AUTH_CONTEXT + FAILED] = 59 /* _eInternalMessageId.SetAuthContextFailed */,\r\n _a[\"Set\" + AUTH_CONTEXT + FAILED + \"AccountName\"] = 60 /* _eInternalMessageId.SetAuthContextFailedAccountName */,\r\n _a.StringValueTooLong = 61 /* _eInternalMessageId.StringValueTooLong */,\r\n _a.StartCalledMoreThanOnce = 62 /* _eInternalMessageId.StartCalledMoreThanOnce */,\r\n _a.StopCalledWithoutStart = 63 /* _eInternalMessageId.StopCalledWithoutStart */,\r\n _a[\"TelemetryInitializer\" + FAILED] = 64 /* _eInternalMessageId.TelemetryInitializerFailed */,\r\n _a.TrackArgumentsNotSpecified = 65 /* _eInternalMessageId.TrackArgumentsNotSpecified */,\r\n _a.UrlTooLong = 66 /* _eInternalMessageId.UrlTooLong */,\r\n _a[SESSION + STORAGE + BUFFER + \"Full\"] = 67 /* _eInternalMessageId.SessionStorageBufferFull */,\r\n _a[CANNOT + \"AccessCookie\"] = 68 /* _eInternalMessageId.CannotAccessCookie */,\r\n _a.IdTooLong = 69 /* _eInternalMessageId.IdTooLong */,\r\n _a.InvalidEvent = 70 /* _eInternalMessageId.InvalidEvent */,\r\n _a[FAILED_MONITOR_AJAX + \"SetRequestHeader\"] = 71 /* _eInternalMessageId.FailedMonitorAjaxSetRequestHeader */,\r\n _a[\"Send\" + BROWSER + \"InfoOnUserInit\"] = 72 /* _eInternalMessageId.SendBrowserInfoOnUserInit */,\r\n _a[\"Plugin\" + EXCEPTION] = 73 /* _eInternalMessageId.PluginException */,\r\n _a[\"Notification\" + EXCEPTION] = 74 /* _eInternalMessageId.NotificationException */,\r\n _a.SnippetScriptLoadFailure = 99 /* _eInternalMessageId.SnippetScriptLoadFailure */,\r\n _a[\"Invalid\" + INSTRUMENTATION_KEY] = 100 /* _eInternalMessageId.InvalidInstrumentationKey */,\r\n _a[CANNOT + \"ParseAiBlobValue\"] = 101 /* _eInternalMessageId.CannotParseAiBlobValue */,\r\n _a.InvalidContentBlob = 102 /* _eInternalMessageId.InvalidContentBlob */,\r\n _a[TRACK + \"PageAction\" + EVENT + FAILED] = 103 /* _eInternalMessageId.TrackPageActionEventFailed */,\r\n _a[FAILED + \"AddingCustomDefinedRequestContext\"] = 104 /* _eInternalMessageId.FailedAddingCustomDefinedRequestContext */,\r\n _a[\"InMemory\" + STORAGE + BUFFER + \"Full\"] = 105 /* _eInternalMessageId.InMemoryStorageBufferFull */,\r\n _a[INSTRUMENTATION_KEY + \"Deprecation\"] = 106 /* _eInternalMessageId.InstrumentationKeyDeprecation */,\r\n _a));\r\n//# sourceMappingURL=LoggingEnums.js.map","/*\n * Application Insights JavaScript SDK - Web, 2.8.14\n * Copyright (c) Microsoft and contributors. All rights reserved.\n */\nimport { _legacyCookieMgr } from \"@microsoft/applicationinsights-core-js\";\r\nimport { AppInsightsDeprecated } from \"./ApplicationInsightsDeprecated\";\r\nimport { Initialization as ApplicationInsights } from \"./Initialization\";\r\nimport { _DYN_LOAD_APP_INSIGHTS, _DYN_UPDATE_SNIPPET_DEFIN0 } from \"./__DynamicConstants\";\r\nvar ApplicationInsightsContainer = /** @class */ (function () {\r\n function ApplicationInsightsContainer() {\r\n }\r\n ApplicationInsightsContainer.getAppInsights = function (snippet, version) {\r\n var initialization = new ApplicationInsights(snippet);\r\n var legacyMode = version >= 2 ? false : true;\r\n // Side effect is to create, initialize and listen to the CoreUtils._canUseCookies changes\r\n // Called here to support backward compatibility\r\n _legacyCookieMgr();\r\n // Two target scenarios:\r\n // 1. Customer runs v1 snippet + runtime. If customer updates just cdn location to new SDK, it will run in compat mode so old apis work\r\n // 2. Customer updates to new snippet (that uses cdn location to new SDK. This is same as a new customer onboarding\r\n // and all api signatures are expected to map to new SDK. Note new snippet specifies version\r\n if (!legacyMode) {\r\n initialization[_DYN_UPDATE_SNIPPET_DEFIN0 /* @min:%2eupdateSnippetDefinitions */](snippet);\r\n initialization[_DYN_LOAD_APP_INSIGHTS /* @min:%2eloadAppInsights */](legacyMode);\r\n return initialization; // default behavior with new snippet\r\n }\r\n else {\r\n var legacy = new AppInsightsDeprecated(snippet, initialization); // target scenario old snippet + updated endpoint\r\n legacy[_DYN_UPDATE_SNIPPET_DEFIN0 /* @min:%2eupdateSnippetDefinitions */](snippet);\r\n initialization[_DYN_LOAD_APP_INSIGHTS /* @min:%2eloadAppInsights */](legacyMode);\r\n return legacy;\r\n }\r\n };\r\n return ApplicationInsightsContainer;\r\n}());\r\nexport { ApplicationInsightsContainer };\r\n//# sourceMappingURL=ApplicationInsightsContainer.js.map"],"names":["strShimUndefined","Object","_cachedGlobal","getGlobal","useCached","result","globalThis","self","window","g","message","TypeError","__assignFn","t","s","i","n","arguments","length","p","call","extendStaticsFn","d","b","__proto__","Array","_DYN_SPLIT","_DYN_LENGTH","_DYN_TO_LOWER_CASE","_DYN_INGESTIONENDPOINT","_DYN_TO_STRING","_DYN_REMOVE_ITEM","_DYN_NAME","_DYN_MESSAGE","_DYN_STRINGIFY","_DYN_PATHNAME","_DYN_CORRELATION_HEADER_E0","_DYN_INDEX_OF","_DYN_EXTENSION_CONFIG","_DYN_EXCEPTIONS","_DYN_PARSED_STACK","_DYN_PROPERTIES","_DYN_MEASUREMENTS","_DYN_SIZE_IN_BYTES","_DYN_TYPE_NAME","_DYN_SEVERITY_LEVEL","_DYN_PROBLEM_GROUP","_DYN_IS_MANUAL","_DYN__CREATE_FROM_INTERFA1","_DYN_ASSEMBLY","_DYN_HAS_FULL_STACK","_DYN_LEVEL","_DYN_METHOD","_DYN_FILE_NAME","_DYN_LINE","_DYN_DURATION","_DYN_RECEIVED_RESPONSE","_DYN_SUBSTRING","strEmpty","stringToBoolOrDefault","str","defaultValue","toString","msToTimeSpan","totalms","isNaN","Math","round","ms","sec","floor","min","hour","days","isCrossOriginError","url","lineNumber","columnNumber","error","StorageType","LocalStorage","SessionStorage","DistributedTracingModes","AI","AI_AND_W3C","W3C","_canUseLocalStorage","undefined","_canUseSessionStorage","_getLocalStorageObject","utlCanUseLocalStorage","_getVerifiedStorageObject","storageType","uid","Date","storage","setItem","fail","getItem","exception","_getSessionStorageObject","utlCanUseSessionStorage","utlDisableStorage","reset","utlGetLocalStorage","logger","name","e","utlSetLocalStorage","data","utlRemoveStorage","utlGetSessionStorage","utlSetSessionStorage","utlRemoveSessionStorage","_a","PropertiesPluginIdentifier","BreezeChannelIdentifier","AnalyticsPluginIdentifier","DisabledPropertyName","SampleRate","ProcessLegacy","HttpMethod","DEFAULT_BREEZE_ENDPOINT","DEFAULT_BREEZE_PATH","strNotSpecified","strIkey","dataSanitizeKeyAndAddUniqueness","key","map","origLength","field","dataSanitizeKey","uniqueField","dsPadNumber","nameTrunc","dataSanitizeString","value","maxLength","valueTrunc","dataSanitizeUrl","dataSanitizeInput","dataSanitizeMessage","messageTrunc","dataSanitizeException","exceptionTrunc","dataSanitizeProperties","properties","tempProps_1","prop","dataSanitizeMeasurements","measurements","tempMeasurements_1","measure","dataSanitizeId","id","input","_msgId","inputTrunc","num","substr","DataSanitizer","MAX_NAME_LENGTH","MAX_ID_LENGTH","MAX_PROPERTY_LENGTH","MAX_STRING_LENGTH","MAX_URL_LENGTH","MAX_MESSAGE_LENGTH","MAX_EXCEPTION_LENGTH","sanitizeKey","sanitizeString","sanitizeUrl","sanitizeMessage","sanitizeId","sanitizeInput","padNumber","trim","createTelemetryItem","item","baseType","envelopeName","customProperties","systemProperties","iKey","telemetryItem","time","ext","tags","baseData","TelemetryItemCreator","create","Event","this","aiDataContract","ver","_self","envelopeType","dataType","Trace","severityLevel","DataPoint","kind","count","max","stdDev","Metric","metrics","dataPoint","PageView","durationMs","duration","PageViewPerformance","unused","cs4BaseData","perfTotal","networkConnect","sentRequest","receivedResponse","domProcessing","strError","strStack","strStackDetails","strErrorSrc","strMessage","strDescription","_stringify","convertToString","JSON","_formatMessage","theEvent","errorType","evtMessage","_isStackDetails","details","src","obj","_convertStackObj","errorStack","items","_getStackFromErrorObj","errorObj","errorMessage","stack","lines","lp","entry","push","_getOperaStack","reason","_getErrorType","typeName","results","exec","constructor","_formatErrorCode","Exception","exceptions","_isExceptionInternal","_ExceptionDetails","CreateAutoException","evt","errorSrc","stackDetails","CreateFromInterface","ex","prototype","toInterface","_b","problemGroup","isManual","exceptionDetailsInterface","CreateSimpleException","assembly","fileName","line","formatError","outerId","hasFullStack","parsedStack","_isExceptionDetailsInternal","frames","level_1","totalSizeInBytes_1","frame","theFrame","_StackFrame","regex","test","parsedFrame","left","right","size","acceptedLeft","acceptedRight","howMany","splice","_parseStack","_formatStackTrace","sourceFrame","level","method","matches","match","parseInt","sizeInBytes","baseSize","createDomEvent","eventName","event","doc","createEvent","initEvent","RequestHeaders","requestContextHeader","requestContextTargetKey","requestContextAppIdFormat","requestIdHeader","traceParentHeader","traceStateHeader","sdkContextHeader","sdkContextHeaderAppIdRequest","requestContextHeaderLowerCase","_document","_htmlAnchorIdx","_htmlAnchorElement","urlParseUrl","anchorIdx","anchorCache","tempAnchor","createElement","host","urlParseHost","href","urlGetAbsoluteUrl","a","urlGetCompleteUrl","absoluteUrl","toUpperCase","inclPort","fullHost","urlParseFullHost","protocol","port","_internalEndpoints","isInternalApplicationInsightsEndpoint","endpointUrl","Util","NotSpecified","disableStorage","canUseLocalStorage","getStorage","setStorage","removeStorage","canUseSessionStorage","getSessionStorageKeys","keys","getSessionStorage","setSessionStorage","removeSessionStorage","disableCookies","canUseCookies","disallowsSameSiteNone","setCookie","getCookie","deleteCookie","newId","random32","generateW3CId","isArray","isError","isDate","toISOStringForIE8","getIEVersion","dump","getExceptionName","addEventHandler","IsBeaconApiSupported","getExtension","extensions","identifier","extension","UrlHelper","parseUrl","getAbsoluteUrl","getPathName","getCompleteUrl","parseHost","parseFullHost","CorrelationIdHelper","correlationIdPrefix","canIncludeCorrelationHeader","config","requestUrl","currentHost","disableCorrelationHeaders","correlationHeaderExcludePatterns","requestHost","enableCorsCorrelation","matchExists_1","includedDomains","correlationHeaderDomains","domain","RegExp","toLowerCase","replace","excludedDomains","correlationHeaderExcludedDomains","getCorrelationContext","responseHeader","correlationId","getCorrelationContextValue","keyValues","keyValue","dateTimeUtilsNow","perf","now","timing","navigationStart","dateTimeUtilsDuration","start","end","DateTimeUtils","Now","GetDuration","createDistributedTraceContextFromTrace","telemetryTrace","parentCtx","trace","getName","setName","newValue","getTraceId","traceID","setTraceId","getSpanId","parentID","setSpanId","getTraceFlags","traceFlags","setTraceFlags","newTraceFlags","RemoteDependencyData","commandName","success","resultCode","requestAPI","correlationContext","target","type","dependencyKind","dependencySource","dependencyTypeName","dependencyFields","parsedUrl","pathName","pathname","charAt","AjaxHelperParseDependencyPath","concat","aiInstrumentHooks","cbNames","_arrLoop","arr","fn","_doCallbacks","hooks","callDetails","cbArgs","hookCtx","hook","idx","cbks","cb","ctx","inst","err","orgEx","hookErrorCb","_getOwner","checkPrototype","checkParentProto","owner","_createInstrumentHook","funcName","callbacks","aiHook","newFunc","orgArgs","h","funcArgs","set","_createArgs","theArgs","arg","theFunc","f","rslt","_createFunctionHook","theHook","rm","InstrumentFunc","InstrumentEvent","evtName","_DYN_DISABLE_EXCEPTION_TR0","_DYN_AUTO_TRACK_PAGE_VISI1","_DYN_OVERRIDE_PAGE_VIEW_D2","_DYN_ENABLE_UNHANDLED_PRO3","_DYN_SAMPLING_PERCENTAGE","_DYN_IS_STORAGE_USE_DISAB4","_DYN_IS_BROWSER_LINK_TRAC5","_DYN_ENABLE_AUTO_ROUTE_TR6","_DYN_NAME_PREFIX","_DYN_DISABLE_FLUSH_ON_BEF7","_DYN_CORE","_DYN_DATA_TYPE","_DYN_ENVELOPE_TYPE","_DYN_DIAG_LOG","_DYN_TRACK","_DYN_TRACK_PAGE_VIEW","_DYN_TRACK_PREVIOUS_PAGE_9","_DYN_SEND_PAGE_VIEW_INTER10","_DYN_SEND_PAGE_VIEW_PERFO11","_DYN_POPULATE_PAGE_VIEW_P12","_DYN_HREF","_DYN_SEND_EXCEPTION_INTER13","_DYN_EXCEPTION","_DYN_ERROR","_DYN__ONERROR","_DYN_ERROR_SRC","_DYN_LINE_NUMBER","_DYN_COLUMN_NUMBER","_DYN__CREATE_AUTO_EXCEPTI14","_DYN_ADD_TELEMETRY_INITIA15","_DYN_IS_PERFORMANCE_TIMIN16","_DYN_GET_PERFORMANCE_TIMI17","_DYN_NAVIGATION_START","_DYN_SHOULD_COLLECT_DURAT18","_DYN_IS_PERFORMANCE_TIMIN19","_DYN_RESPONSE_START","_DYN_LOAD_EVENT_END","_DYN_RESPONSE_END","_DYN_CONNECT_END","_DYN_PAGE_VISIT_START_TIM20","_isWebWorker","PageViewManager","appInsights","overridePageViewDuration","core","pageViewPerformanceManager","_logger","queueTimer","itemQueue","pageViewPerformanceSent","_flushChannels","isAsync","flush","_startTimer","setTimeout","allItems","slice","doFlush","_addQueue","pageView","title","uri","location_1","WorkerGlobalScope","isWebWorker","customDuration","pageViewSent","processed","pageViewPerformance","isValid","teardown","unloadCtx","unloadState","clearTimeout","__ieDyn","botAgentNames","_isPerformanceTimingSupported","_isPerformanceTimingDataReady","domainLookupStart","domLoading","_getPerformanceTiming","_shouldCollectDuration","durations","_i","userAgent","isGoogleBot","indexOf","PageViewPerformanceManager","navigationTiming","getEntriesByType","total","network","request","response","dom","startTime","requestStart","responseEnd","PageVisitTimeManager","pageVisitTimeTrackingHandler","prevPageVisitDataKeyName","currentPageName","currentPageUrl","prevPageVisitTimeData","pageName","pageUrl","prevPageVisitData","pageVisitEndTime","pageVisitDataJsonStr","parse","pageVisitTime","stopPageVisitTimer","currPageVisitData","PageVisitData","currPageVisitDataStr","stringify","startPageVisitTimer","restartPageVisitTimer","Timing","_events","stop","action","_dispatchEvent","evnt","dispatchEvent","MinMilliSeconds","_configMilliseconds","defValue","_getDefaultConfig","sessionRenewalMs","sessionExpirationMs","enableDebug","disableFlushOnUnload","AnalyticsPlugin","_super","_eventTracking","_pageTracking","_pageViewManager","_pageViewPerformanceManager","_pageVisitTimeManager","_preInitTelemetryInitializers","_isBrowserLinkTrackingEnabled","_browserLinkInitializerAdded","_enableAutoRouteTracking","_historyListenerAdded","_disableExceptionTracking","_autoExceptionInstrumented","_enableUnhandledPromiseRejectionTracking","_autoUnhandledPromiseInstrumented","_prevUri","_currUri","_evtNamespace","_this","priority","autoRoutePVDelay","_base","_addHook","_throwInternal","severity","msgId","msg","isUserAct","throwInternal","_initDefaults","location","getCookieMgr","processTelemetry","env","itemCtx","processNext","trackEvent","startTrackEvent","stopTrackEvent","trackTrace","trackMetric","metric","inPv","refUri","referrer","trackPageViewPerformance","inPvp","startTrackPage","stopTrackPage","measurement","loc","theError","trackException","_window","URL","_sendCORSException","errorString","telemetryInitializer","initialize","pluginChain","isInitialized","evtNamespace","initializer","extConfig","defaults","getExtCfg","getConfig","_populateDefaults","_updateStorageUsage","PageName","PageUrl","average","sampleCount","trackPageVisitTime","browserLinkPaths_1","envelope","remoteData","_addDefaultTelemetryInitializers","_updateBrowserLinkTracking","pageViewItem","locn","autoExceptionInstrumented","ns","rsp","_location","_getReason","autoUnhandledPromiseInstrumented","_addUnhandledPromiseRejectionTracking","_updateExceptionTracking","win","_history","pushState","replaceState","history","namePrefix","distributedTraceCtx","getTraceCtx","getPlugin","context","plugin","_getDistributedTraceCtx","traceLocationName","hash","bind","_addHistoryListener","_updateLocationChange","setInitialized","_doTeardown","__","String","tmpFunc","objCreateFn","Version","getDefaultConfig","BaseTelemetryPlugin","_aiNameFunc","baseName","aiName","_aiApplication","_aiDevice","_aiLocation","_aiOperation","_aiSession","_aiUser","_aiCloud","_aiInternal","ContextTagKeys","applicationVersion","applicationBuild","applicationTypeId","applicationId","applicationLayer","deviceId","deviceIp","deviceLanguage","deviceLocale","deviceModel","deviceFriendlyName","deviceNetwork","deviceNetworkName","deviceOEMName","deviceOS","deviceOSVersion","deviceRoleInstance","deviceRoleName","deviceScreenResolution","deviceType","deviceMachineName","deviceVMName","deviceBrowser","deviceBrowserVersion","locationIp","locationCountry","locationProvince","locationCity","operationId","operationName","operationParentId","operationRootId","operationSyntheticSource","operationCorrelationVector","sessionId","sessionIsFirst","sessionIsNew","userAccountAcquisitionDate","userAccountId","userId","userStoreRegion","userAuthUserId","userAnonymousUserAcquisitionDate","userAuthenticatedUserAcquisitionDate","cloudName","cloudRole","cloudRoleVer","cloudRoleInstance","cloudEnvironment","cloudLocation","cloudDeploymentUnit","internalNodeName","internalSdkVersion","internalAgentVersion","internalSnippet","internalSdkSrc","Extensions","UserExt","DeviceExt","TraceExt","WebExt","AppExt","OSExt","SessionExt","SDKExt","CtxTagKeys","Envelope","sampleRate","Data","STR_DURATION","_DYN_TAGS","_DYN_DEVICE_TYPE","_DYN_DATA","_DYN_TRACE_ID","_DYN_ON_LINE","_DYN_IS_ONLINE","_DYN_ENQUEUE","_DYN_EMIT_LINE_DELIMITED_0","_DYN_CLEAR","_DYN_BATCH_PAYLOADS","_DYN_MARK_AS_SENT","_DYN_CLEAR_SENT","_DYN_BUFFER_OVERRIDE","_DYN__BUFFER__KEY","_DYN__SENT__BUFFER__KEY","_DYN__MAX__BUFFER__SIZE","_DYN_MAX_BATCH_SIZE_IN_BY1","_DYN_TRIGGER_SEND","_DYN_ONUNLOAD_DISABLE_BEA2","_DYN_IS_BEACON_API_DISABL3","_DYN__SENDER","_DYN__SENDER_CONFIG","_DYN_ENABLE_SESSION_STORA4","_DYN__BUFFER","_DYN_INSTRUMENTATION_KEY","_DYN_ENDPOINT_URL","_DYN_CUSTOM_HEADERS","_DYN_DISABLE_XHR","_DYN_ONUNLOAD_DISABLE_FET5","_DYN_DISABLE_TELEMETRY","_DYN_BASE_TYPE","_DYN_SAMPLE_RATE","_DYN_CONVERT_UNDEFINED","_DYN__ON_ERROR","_DYN__ON_PARTIAL_SUCCESS","_DYN__ON_SUCCESS","_DYN_ITEMS_ACCEPTED","_DYN_IS_RETRY_DISABLED","_DYN_SET_REQUEST_HEADER","_DYN_MAX_BATCH_INTERVAL","_DYN_EVENTS_SEND_REQUEST","_DYN_DISABLE_INSTRUMENTAT7","_DYN_GET_SAMPLING_SCORE","strBaseType","strBaseData","strProperties","strTrue","_setValueIf","_extractPropsAndMeasurements","_convertPropsUndefinedToCustomDefinedValue","customUndefinedValue","_createEnvelope","iKeyNoDashes","envTags","itmExt","itmTags","extUser","user","authId","localId","extApp","app","sesId","extDevice","device","deviceClass","ip","model","web","browserLang","browserVer","browser","envData","envBaseData","envProps","screenRes","userConsent","extOs","os","extTrace","tgs","tg","theTags","EnvelopeCreator","_extractPartAExtensions","EnvelopeCreatorInit","EventEnvelopeCreator","customMeasurements","eventData","_disableEvents","BaseSendBuffer","_buffer","_bufferFullMessageSent","_get","_set","buffer","payload","eventsLimitInMem","getItems","join","ArraySendBuffer","SessionStorageSendBuffer","bufferItems","_getBuffer","notDeliveredItems","_removePayloadsFromBuffer","payloads","remaining","prefixedKey","bufferJson","buffer_1","_setBuffer","sentElements","BUFFER_KEY","SENT_BUFFER_KEY","MAX_BUFFER_SIZE","Serializer","_serializeObject","source","circularReferenceCheck","output","_serializeStringMap","_serializeArray","contract","isRequired","isHidden","isPresent","isObj","sources","expectedType","parseFloat","serialize","HashCodeScoreGenerator","getHashCodeScore","getHashCode","INT_MAX_VALUE","charCodeAt","abs","SamplingScoreGenerator","hashCodeGenerator","random","Sample","samplingRate","samplingScoreGenerator","isSampledIn","samplingPercentage","_getResponseText","xhr","responseText","_getDefaultAppInsightsChannelConfig","EnvelopeTypeCreator","props","currentContextId","bd","pageType","isLoggedIn","pageTags","pageViewData","exData","baseMetricData","remoteDepData","responseCode","Sender","_consecutiveErrors","_retryAt","_paused","_timeoutHandle","_serializer","_stamp_specific_redirects","_headers","_senderConfig","_fallbackSender","_syncUnloadSender","_offlineListener","_syncFetchPayload","_checkResponsStatus","status","responseUrl","countOfItemsInPayload","res","_appId","_parseResponse","appId","_checkAndUpdateEndPointUrl","_isRetriable","_resendPayload","isOnline","_doUnloadSend","_beaconSender","_doBeaconSend","nav","batch","plainTextBatch","Blob","queued","sendBeacon","_onSuccess","droppedPayload","thePayload","_xhrSender","XMLHttpRequest","endPointUrl","open","headerName","onreadystatechange","_xhrReadyStateChange","onerror","_formatErrorMessageXhr","send","_fetchKeepAliveSender","payloadSize","_doFetchSender","_fetchSender","requestHeaders","Headers","batchLength","ignoreResponse","responseHandled","append","init","headers","body","keepalive","Request","fetch","then","ok","text","statusText","itemsReceived","itemsAccepted","errors","linearFactor","payload_1","delayInSeconds","backOffSlot","pow","backOffDelay","retryAfterTimeSpan","_setRetryTime","_setupTimer","retryInterval","timerValue","_clearScheduledTimer","statusCode","_xdrSender","xdr","XDomainRequest","onload","_xdrOnLoad","_formatErrorMessageXdr","hostingProtocol","lastIndexOf","_sample","pause","resume","callBack","sendReason","onunloadFlush","addHeader","_getTelCtx","diagLog","parentEvtNamespace","_navigator","_isListening","_onlineStatus","_enableEvents","ononline","enabled","_setOnline","_setOffline","isListening","unload","createOfflineListener","defaultConfig","theValue","useSessionStorage","_validateInstrumentationKey","customHeaders","customHeader","header","senderConfig","sendPostFunc","diagLogger","convertUndefined","defaultEnvelopeIkey","aiEnvelope_1","constructEnvelope","doNotSendItem_1","readyState","responseURL","async","forcedSender","sendRequest","func","manager","_notifySendRequest","ieVer","failed","retry","errors_1","reverse","extracted","index","orig","parseConnectionString","connectionString","kvPairs","fields","kv","kvParts","endpointsuffix","locationPrefix","ConnectionStringParser","ConfigurationManager","configValue","to","from","il","j","ChannelControllerPriority","_addChannelQueue","channelQueue","queue","sort","queueItem","chain","TelemetryInitializerPlugin","_id","_initializers","addTelemetryInitializer","theInitializer","remove","doNotSendItem","telemetryInitializersCount","strValidationError","strNotificationManager","strSdkUnloadingError","defaultInitConfig","loggingLevelConsole","_createPerfManager","notificationMgr","PerfManager","_isPluginPresent","thePlugin","plugins","exists","BaseCore","_config","_isInitialized","_eventQueue","_notificationManager","_perfManager","_cfgPerfManager","_cookieManager","_pluginChain","_configExtensions","_coreExtensions","_channelControl","_channelConfig","_channelQueue","_isUnloading","_telemetryInitializerPlugin","_internalLogsEventName","_unloadHandlers","_debugListener","_traceCtx","_internalLogPoller","_forceStopInternalLogPoller","_startInternalLogTimer","alwaysStart","interval","diagnosticLogInterval","setInterval","clearInterval","_flushInternalLogs","DiagnosticLogger","_createTelCtx","theCtx","_getPluginChain","_initPluginChain","updateState","theExtensions","channelPriority","allExtensions","coreExtensions","extPriorities","extPriority","all","_validateExtensions","channels","extensionQueue_1","createChannelQueues","_setQueue","_processChannelQueue","theChannels","processFn","onComplete","waiting","_runChainOnComplete","channelChain","chainCtx","channelController","update","updateCtx","theUpdateState","iterate","theUnloadState","getChannel","pluginIdentifier","cbTimeout","doneIterating","cbTimer","doCallback","handled_1","createChannelControllerPlugin","initCtx","_updateHook","_doUpdate","_getPlugin","theExt","isEnabled","pluginState","removeCb","pluginsToRemove","_removePlugins","removed","thePlugins","removeComplete","unloadChain","newConfigExtensions","newChannelConfig","newQueue","channel","logMessage","track","_logOrThrowError","notificationManager","enablePerfMgr","disableDbgExt","NotificationManager","cfgExtensions","apply","releaseQueue","getTransmissionControls","controls","listener","events","_createDummyNotificationManager","setCookieMgr","cookieMgr","createPerfMgr","setPerfMgr","perfMgr","eventCnt","eventQueue","pollInternalLogs","unloadComplete","flushComplete","processUnloadCtx","_doUnload","run","addPlugin","replaceExisting","addCb","existingPlugin","_addPlugin","added","removedPlugins_1","createNew","setTraceCtx","traceCtx","_runListeners","listeners","callback","perfEvtsSendAll","perfEvent","AppInsightsCore","_notifyInvalidEvent","_validateTelemetryItem","STR_PROPERTIES","_DYN_REQUEST_URL","_DYN_INST","_DYN_SPAN_ID","_DYN_TRACE_FLAGS","_DYN_CONTEXT","_DYN_ABORTED","_DYN_TRACE_ID0","_DYN_SPAN_ID1","_DYN_INCLUDE_CORRELATION_2","_DYN_CAN_INCLUDE_CORRELAT3","_DYN_GET_ABSOLUTE_URL","_DYN_HEADERS","_DYN_REQUEST_HEADERS","_DYN_APP_ID","_DYN_TRACK_DEPENDENCY_DAT4","_DYN_DISTRIBUTED_TRACING_5","_DYN_START_TIME","_DYN_STATUS","_DYN_STATUS_TEXT","_DYN_HEADER_MAP","_DYN_OPEN_DONE","_DYN_SEND_DONE","_DYN_REQUEST_SENT_TIME","_DYN_ABORT_DONE","_DYN_GET_TRACE_ID","_DYN_GET_TRACE_FLAGS","_DYN_ERROR_STATUS_TEXT","_DYN_STATE_CHANGE_ATTACHE14","_DYN_RESPONSE_FINISHED_TI15","_DYN__CREATE_TRACK_ITEM","_DYN_RESPONSE","_DYN_GET_ALL_RESPONSE_HEA16","_DYN_GET_PART_APROPS","_DYN_GET_CORRELATION_CONT17","_DYN_PERF_MARK","_DYN_PERF_TIMING","_DYN_AJAX_TOTAL_DURATION","_DYN_EVENT_TRACE_CTX","_calcPerfDuration","resourceEntry","_setPerfDuration","_setPerfValue","strPerf","XHRMonitoringState","setRequestHeaderDone","ajaxRecord","traceId","spanId","completed","requestHeadersSize","responseReceivingDuration","callbackDuration","requestSize","responseStartedTime","callbackFinishedTime","endTime","xhrMonitoringState","clientFailure","ajaxType","enableRequestHeaderTracking","getResponse","ajaxTotalDuration","requestSentTime","responseFinishedTime","dependency","setTime","ajaxData","propsSet","strName","strStart","strEnd","strDomainLookup","strConnect","strRedirect","strRequest","strResponse","strStartTime","strDomainLookupStart","strDomainLookupEnd","strConnectStart","strConnectEnd","strRequestStart","strRequestEnd","strResponseStart","strResponseEnd","strRedirectStart","strRedirectEnd","strTransferSize","strEncodedBodySize","strDecodedBodySize","strServerTiming","serverTiming","server_1","val","perfAttempts","_populatePerfData","headerMap","responseHeaders","responseType","partA","traceExt","AJAX_MONITOR_PREFIX","strDiagLog","strAjaxData","STR_FETCH","ERROR_HEADER","ERROR_PREFIX","ERROR_POSTFIX","ERROR_NOT_SENT","CORRELATION_HEADER_ERROR","CUSTOM_REQUEST_CONTEXT_ERROR","FAILED_TO_CALCULATE_DURATION_ERROR","_markCount","_getFailedAjaxDiagnosticsMessage","_throwInternalCritical","ajaxMonitorInstance","_throwInternalWarning","_createErrorCallbackFunc","internalMessage","args","ajaxDiagnosticsMessage","_indexOf","_addHandler","container","theHandler","_processDependencyContainer","BLOB_CORE","DfltAjaxCorrelationHeaderExDomains","_internalExcludeEndpoints","maxAjaxCallsPerView","disableAjaxTracking","disableFetchTracking","excludeRequestFromAutoTrackingPatterns","distributedTracingMode","enableResponseHeaderTracking","enableAjaxErrorStatusText","enableAjaxPerfTracking","maxAjaxPerfLookupAttempts","ajaxPerfLookupDelay","ignoreHeaders","addRequestContext","addIntEndpoints","_getEmptyConfig","emptyConfig","AjaxMonitor","_fetchInitialized","_xhrInitialized","_currentWindowHost","_enableRequestHeaderTracking","_enableAjaxErrorStatusText","_trackAjaxAttempts","_context","_isUsingW3CHeaders","_isUsingAIHeaders","_markPrefix","_enableAjaxPerfTracking","_maxAjaxCallsPerView","_enableResponseHeaderTracking","_disabledUrls","_disableAjaxTracking","_disableFetchTracking","_excludeRequestFromAutoTrackingPatterns","_addRequestContext","_dependencyHandlerId","_dependencyListeners","_dependencyInitializers","getEmptyConfig","_canIncludeHeaders","rlt","_hookProto","InstrumentProto","_isDisabledRequest","isDisabled","theUrl","theRegex","idx2","substring","_isMonitoredXhrInstance","excludeAjaxDataValidation","ajaxValidation","initialized","_getAjaxCorrelationContext","responseHeadersString","getResponseHeader","_createMarkId","performance_1","mark","markId","entries","getEntriesByName","_findPerfResourceEntry","initiatorType","trackCallback","reportError","perfMark","performance","maxAttempts","retryDelay","attempt","locateResourceTiming","perfTiming","getEntries","entryType","clearMarks","_getFailedFetchDiagnosticsMessage","_reportFetchMetrics","_reportFetchError","failedProps","errorProps","sysProperties","_reportDependencyInternal","_getFetchCorrelationContext","get","fetchDiagnosticsMessage","initializers","aborted","propExt","instrumentationKey","proto","abort","theOpen","_supportsAjaxMonitoring","req","spanID","_openHandler","_reportXhrError","ajaxResponse","split","responseHeaderMap_2","parts","shift","_onAjaxComplete","exceptionText","_attachToOnReadyStateChange","hkErr","_global","global","isPolyfill","polyfill","fetchData","forEach","_createFetchRecord","newInit","fetchData_1","responseHeaderMap_1","_instrumentFetch","trackDependencyData","currentWindowHost","_processDependencyListeners","traceParent","addDependencyListener","dependencyListener","addDependencyInitializer","dependencyInitializer","Application","Device","_DYN_SESSION_MANAGER","_DYN_UPDATE","_DYN_IS_USER_COOKIE_SET","_DYN_IS_NEW_USER","_DYN_GET_TRACE_CTX","_DYN_TELEMETRY_TRACE","_DYN_APPLY_SESSION_CONTEX0","_DYN_APPLY_APPLICATION_CO1","_DYN_APPLY_DEVICE_CONTEXT","_DYN_APPLY_OPERATION_CONT2","_DYN_APPLY_USER_CONTEXT","_DYN_APPLY_OPERATING_SYST3","_DYN_APPLY_LOCATION_CONTE4","_DYN_APPLY_INTERNAL_CONTE5","_DYN_ACCOUNT_ID","_DYN_SDK_EXTENSION","_DYN_GET_SESSION_ID","_DYN_SESSION_COOKIE_POSTF6","_DYN_USER_COOKIE_POSTFIX","_DYN_ID_LENGTH","_DYN_GET_NEW_ID","_DYN_AUTOMATIC_SESSION","_DYN_AUTHENTICATED_ID","_DYN_SESSION_EXPIRATION_M7","_DYN_SESSION_RENEWAL_MS","_DYN_CONFIG","_DYN_ACQUISITION_DATE","_DYN_RENEWAL_DATE","_DYN_COOKIE_DOMAIN","_DYN_JOIN","_DYN_COOKIE_SEPARATOR","_DYN_AUTH_USER_COOKIE_NAM8","Internal","sdkVersion","Location","Session","_SessionManager","_storageNamePrefix","_cookieUpdatedTimestamp","acquisitionSpan","renewalSpan","sessionCookiePostfix","_initializeAutomaticSessionWithData","session","sessionData","sessionReset","tokens","acqMs","renewalMs","_setCookie","nowMs","acq","maxAgeSec","renewalPeriodMs","acqTimeLeftMs","cookie","cookieDomain","isExpired","cookieValue","storageValue","_initializeAutomaticSession","timeSinceAcqMs","timeSinceRenewalMs","theConfig","getNewId","automaticSession","_renew","cookieUpdateInterval","backup","guid","renewal","TelemetryTrace","parentId","_validateUserInput","User","isNewUser","isUserCookieSet","userCookiePostfix","userCookieName","params","_generateNewId","_generateNewCookie","acqStr","accountAcquisitionDate","_setUserCookie","name_1","authCookie","authCookieString","decodeURI","setAuthenticatedUserContext","authenticatedUserId","accountId","storeInCookie","encodeURI","clearAuthenticatedUserContext","del","cookieSeparator","authUserCookieName","strExt","strTags","_removeEmpty","TelemetryContext","previousTraceCtx","application","internal","autoSession","build","agentVersion","snippetVer","sdkSrc","applyWebContext","cleanUp","PropertiesPlugin","_extensionConfig","_distributedTraceCtx","_previousTraceCtx","breezeChannel","resetInternalMessageCount","theContext","userCtx","_processTelemetryInternal","nullValue","isBrowserLinkTrackingEnabled","_internalSdkSrc","_AUTHENTICATED_USER_CONTEXT","_TRACK","STR_SNIPPET","STR_GET_COOKIE_MGR","STR_START_TRACK_PAGE","STR_STOP_TRACK_PAGE","STR_FLUSH","STR_START_TRACK_EVENT","STR_STOP_TRACK_EVENT","STR_ADD_TELEMETRY_INITIALIZER","STR_ADD_TELEMETRY_INITIALIZERS","STR_POLL_INTERNAL_LOGS","STR_GET_PLUGIN","STR_EVT_NAMESPACE","STR_TRACK_EVENT","STR_TRACK_TRACE","STR_TRACK_METRIC","STR_TRACK_PAGE_VIEW","STR_TRACK_EXCEPTION","STR_TRACK_DEPENDENCY_DATA","STR_SET_AUTHENTICATED_USER_CONTEXT","STR_CLEAR_AUTHENTICATED_USER_CONTEXT","_DYN_UPDATE_SNIPPET_DEFIN0","_DYN_LOAD_APP_INSIGHTS","_DYN_DISABLE_EXCEPTION_TR2","_DYN_EMIT_LINE_DELIMITED_3","_DYN_DIAGNOSTIC_LOG_INTER4","_DYN_AUTO_TRACK_PAGE_VISI5","_DYN_DISABLE_AJAX_TRACKIN6","_DYN_MAX_AJAX_CALLS_PER_V7","_DYN_IS_BEACON_API_DISABL8","_DYN_DISABLE_CORRELATION_9","_DYN_CORRELATION_HEADER_E10","_DYN_DISABLE_FLUSH_ON_BEF11","_DYN_ENABLE_SESSION_STORA13","_DYN_IS_COOKIE_USE_DISABL14","_DYN_IS_STORAGE_USE_DISAB15","_DYN_IS_BROWSER_LINK_TRAC16","_DYN_ENABLE_CORS_CORRELAT17","_DYN_VERSION","_DYN_QUEUE","_DYN_CONNECTION_STRING","_DYN_APP_INSIGHTS","_DYN_DISABLE_IKEY_DEPRECA18","_DYN_GET_TRANSMISSION_CON19","_DYN_ONUNLOAD_FLUSH","_DYN_ADD_HOUSEKEEPING_BEF20","_ignoreUpdateSnippetProperties","Telemetry","FieldType","Default","Required","Hidden","SeverityLevel","Initialization","snippet","dependencies","_sender","_snippetVersion","_houseKeepingNamespace","_core","sv","cs","ingest","ingestionendpoint","instrumentationkey","isErrMessageDisabled","legacyMode","_updateSnippetProperties","emptyQueue","length_1","appInsightsInstance","performHousekeeping","loadedPlugin","propertiesPlugin","_sessionManager","excludePageUnloadEvents","disablePageUnloadEvents","getSender","cdns","scrpt","document","currentScript","AppInsightsDeprecated","appInsightsNew","_hasLegacyInitializers","_queue","_addTelemetryInitializers","_processLegacyInitializers","verboseLogging","isRetryDisabled","telemetry","trackDependency","totalTime","handledAt","_onerror","downloadAndSetup","originalTrackPageView_1","pagePath","legacyPageView","legacyEvent","ApplicationInsightsContainer","getAppInsights","version","initialization","legacy","FAILED","FAILED_MONITOR_AJAX","TRACK","START","STOP","EVENT","AUTH_CONTEXT","EXCEPTION","LOCAL","SESSION","STORAGE","BROWSER","CANNOT","BUFFER","INSTRUMENTATION_KEY","LoggingSeverity","CRITICAL","WARNING","_InternalMessageId","ClientPerformanceMathError","ErrorPVCalc","MessageLimitPerPVExceeded","MissingRequiredFieldSpecification","NavigationTimingNotSupported","OnError","SenderNotInitialized","TelemetrySampledAndNotSent","InvalidBackendResponse","InvalidDurationValue","TelemetryEnvelopeInvalid","CreateEnvelopeError","CircularReferenceDetected","IllegalCharsInName","ItemNotInArray","MaxAjaxPerPVExceeded","MessageTruncated","NameTooLong","SampleRateOutOfRange","StringValueTooLong","StartCalledMoreThanOnce","StopCalledWithoutStart","TrackArgumentsNotSpecified","UrlTooLong","IdTooLong","InvalidEvent","SnippetScriptLoadFailure","InvalidContentBlob"],"sourceRoot":""}