@microsoft/applicationinsights-teechannel-js 3.0.2-nightly3.2305-03 → 3.0.2-nightly3.2305-04

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.cjs.js → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.cjs.js} +4 -3
  2. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.gbl.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.cjs.js.map} +1 -1
  3. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.cjs.min.js → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.cjs.min.js} +3 -3
  4. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.cjs.min.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.cjs.min.js.map} +1 -1
  5. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.gbl.js +3241 -0
  6. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.cjs.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.gbl.js.map} +1 -1
  7. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.gbl.min.js +6 -0
  8. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.gbl.min.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.gbl.min.js.map} +1 -1
  9. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.integrity.json +66 -0
  10. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.js +3245 -0
  11. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.js.map} +1 -1
  12. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.min.js +6 -0
  13. package/browser/es5/{applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.min.js.map → applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.min.js.map} +1 -1
  14. package/browser/es5/applicationinsights-teechannel-js.3.cjs.js +3 -2
  15. package/browser/es5/applicationinsights-teechannel-js.3.cjs.js.map +1 -1
  16. package/browser/es5/applicationinsights-teechannel-js.3.cjs.min.js +2 -2
  17. package/browser/es5/applicationinsights-teechannel-js.3.cjs.min.js.map +1 -1
  18. package/browser/es5/applicationinsights-teechannel-js.3.gbl.js +2917 -2897
  19. package/browser/es5/applicationinsights-teechannel-js.3.gbl.js.map +1 -1
  20. package/browser/es5/applicationinsights-teechannel-js.3.gbl.min.js +2 -2
  21. package/browser/es5/applicationinsights-teechannel-js.3.gbl.min.js.map +1 -1
  22. package/browser/es5/applicationinsights-teechannel-js.3.js +2919 -2897
  23. package/browser/es5/applicationinsights-teechannel-js.3.js.map +1 -1
  24. package/browser/es5/applicationinsights-teechannel-js.3.min.js +2 -2
  25. package/browser/es5/applicationinsights-teechannel-js.3.min.js.map +1 -1
  26. package/dist/es5/applicationinsights-teechannel-js.js +3 -3
  27. package/dist/es5/applicationinsights-teechannel-js.js.map +1 -1
  28. package/dist/es5/applicationinsights-teechannel-js.min.js +2 -2
  29. package/dist/es5/applicationinsights-teechannel-js.min.js.map +1 -1
  30. package/dist-es5/ChannelController.js +1 -1
  31. package/dist-es5/Interfaces/ITeeChannelConfig.js +1 -1
  32. package/dist-es5/TeeChannel.js +1 -1
  33. package/dist-es5/__DynamicConstants.js +1 -1
  34. package/dist-es5/applicationinsights-teechannel-js.js +1 -1
  35. package/package.json +3 -3
  36. package/types/applicationinsights-teechannel-js.d.ts +1 -1
  37. package/types/applicationinsights-teechannel-js.namespaced.d.ts +1 -1
  38. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.gbl.js +0 -3221
  39. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.gbl.min.js +0 -6
  40. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.integrity.json +0 -66
  41. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.js +0 -3223
  42. package/browser/es5/applicationinsights-teechannel-js.3.0.2-nightly3.2305-03.min.js +0 -6
@@ -0,0 +1,3241 @@
1
+ /*!
2
+ * Application Insights JavaScript SDK - Tee Channel, 3.0.2-nightly3.2305-04
3
+ * Copyright (c) Microsoft and contributors. All rights reserved.
4
+ */
5
+ (function (global, factory) {
6
+ var undef = "undefined";
7
+ var nsKey, key, nm, theExports = {}, modName = "es5_applicationinsights_teechannel_js_3_0_2_nightly3_2305_04", msMod="__ms$mod__";
8
+ var mods={}, modDetail=mods[modName]={}, ver="3.0.2-nightly3.2305-04";
9
+ var baseNs=global, nsKey="Microsoft", baseNs=baseNs[nsKey]=(baseNs[nsKey]||{});
10
+ // Versioned namespace "Microsoft.ApplicationInsights3"
11
+ var exportNs=baseNs, nsKey="ApplicationInsights3", exportNs=exportNs[nsKey]=(exportNs[nsKey]||{});
12
+ // Global namespace "Microsoft.ApplicationInsights"
13
+ var destNs=baseNs, nsKey="ApplicationInsights", destNs=destNs[nsKey]=(destNs[nsKey]||{});
14
+ var expNsDetail=(exportNs[msMod]=(exportNs[msMod] || {})), expNameVer=(expNsDetail["v"]=(expNsDetail["v"] || []));
15
+ var destNsDetail=(destNs[msMod]=(destNs[msMod] || {})), destNameVer=(destNsDetail["v"]=(destNsDetail["v"] || []));
16
+ (destNsDetail["o"]=(destNsDetail["o"] || [])).push(mods);
17
+ factory(theExports);
18
+ for(var key in theExports) {
19
+ // Always set the imported value into the "export" versioned namespace (last-write wins)
20
+ nm="x", exportNs[key]=theExports[key], expNameVer[key]=ver;
21
+ // Copy over any named element that is not already present (first-write wins)
22
+ typeof destNs[key]===undef ? (nm="n", destNs[key]=theExports[key]) && (destNameVer[key]=ver) : !destNameVer[key] && (destNameVer[key]="---");
23
+ (modDetail[nm] = (modDetail[nm] || [])).push(key);
24
+ }
25
+ })(this, (function (exports) {
26
+ 'use strict';
27
+
28
+
29
+ var strShimFunction = "function";
30
+ var strShimObject = "object";
31
+ var strShimUndefined = "undefined";
32
+ var strShimPrototype = "prototype";
33
+ var ObjClass$1 = Object;
34
+
35
+ var UNDEF_VALUE = undefined;
36
+ var EMPTY = "";
37
+ var BOOLEAN = "boolean";
38
+ var FUNCTION = "function";
39
+ var NUMBER = "number";
40
+ var OBJECT = "object";
41
+ var PROTOTYPE = "prototype";
42
+ var STRING = "string";
43
+ var UNDEFINED = "undefined";
44
+ var CONSTRUCTOR = "constructor";
45
+ var SYMBOL = "Symbol";
46
+ var POLYFILL_TAG = "_polyfill";
47
+ var INDEX_OF = "indexOf";
48
+ var LENGTH = "length";
49
+ var DONE = "done";
50
+ var VALUE = "value";
51
+ var NAME = "name";
52
+ var SLICE = "slice";
53
+ var ObjClass = Object;
54
+ var ObjProto = ObjClass[PROTOTYPE];
55
+ var StrCls = String;
56
+ var StrProto = StrCls[PROTOTYPE];
57
+ var ArrCls = Array;
58
+ var ArrProto = ArrCls[PROTOTYPE];
59
+
60
+ function safeGet(cb, defValue) {
61
+ var result = defValue;
62
+ try {
63
+ result = cb();
64
+ }
65
+ catch (e) {
66
+ }
67
+ return result;
68
+ }
69
+
70
+ function _createIs(theType) {
71
+ return function (value) {
72
+ return typeof value === theType;
73
+ };
74
+ }
75
+ function _createObjIs(theName) {
76
+ var theType = "[object " + theName + "]";
77
+ return function (value) {
78
+ return !!(value && objToString(value) === theType);
79
+ };
80
+ }
81
+ function objToString(value) {
82
+ return ObjProto.toString.call(value);
83
+ }
84
+ function isUndefined(value) {
85
+ return typeof value === UNDEFINED || value === UNDEFINED;
86
+ }
87
+ function isNullOrUndefined(value) {
88
+ return value === null || isUndefined(value);
89
+ }
90
+ function isStrictNullOrUndefined(value) {
91
+ return value === null || !isDefined(value);
92
+ }
93
+ function isDefined(arg) {
94
+ return !!arg || arg !== UNDEF_VALUE;
95
+ }
96
+ var isString = _createIs(STRING);
97
+ var isFunction = _createIs(FUNCTION);
98
+ function isObject(value) {
99
+ if (!value && isNullOrUndefined(value)) {
100
+ return false;
101
+ }
102
+ return !!value && typeof value === OBJECT;
103
+ }
104
+ var isArray = ArrCls.isArray;
105
+ var isNumber = _createIs(NUMBER);
106
+ var isBoolean = _createIs(BOOLEAN);
107
+ var isError = _createObjIs("Error");
108
+ function isPromiseLike(value) {
109
+ return !!value && isFunction(value.then);
110
+ }
111
+
112
+ var objGetOwnPropertyDescriptor = ObjClass.getOwnPropertyDescriptor;
113
+
114
+ function objHasOwnProperty(obj, prop) {
115
+ return obj && ObjProto.hasOwnProperty.call(obj, prop);
116
+ }
117
+
118
+ var objHasOwn = ObjClass["hasOwn"] || polyObjHasOwn;
119
+ function polyObjHasOwn(obj, prop) {
120
+ return objHasOwnProperty(obj, prop) || !!objGetOwnPropertyDescriptor(obj, prop);
121
+ }
122
+
123
+ function objForEachKey(theObject, callbackfn, thisArg) {
124
+ if (theObject && isObject(theObject)) {
125
+ for (var prop in theObject) {
126
+ if (objHasOwn(theObject, prop)) {
127
+ if (callbackfn.call(thisArg || theObject, prop, theObject[prop]) === -1) {
128
+ break;
129
+ }
130
+ }
131
+ }
132
+ }
133
+ }
134
+
135
+ function _createKeyValueMap(values, keyType, valueType, completeFn) {
136
+ var theMap = {};
137
+ objForEachKey(values, function (key, value) {
138
+ theMap[key] = keyType ? value : key;
139
+ theMap[value] = valueType ? value : key;
140
+ });
141
+ return completeFn(theMap);
142
+ }
143
+
144
+ function throwError(message) {
145
+ throw new Error(message);
146
+ }
147
+ function throwTypeError(message) {
148
+ throw new TypeError(message);
149
+ }
150
+
151
+ var _objFreeze = ObjClass["freeze"];
152
+ var _doNothing = function (value) { return value; };
153
+ function objDeepFreeze(value) {
154
+ if (_objFreeze) {
155
+ objForEachKey(value, function (key, value) {
156
+ if (isArray(value) || isObject(value)) {
157
+ _objFreeze(value);
158
+ }
159
+ });
160
+ }
161
+ return objFreeze(value);
162
+ }
163
+ var objFreeze = _objFreeze || _doNothing;
164
+ var objGetPrototypeOf = ObjClass["getPrototypeOf"] || _doNothing;
165
+
166
+ function createEnumKeyMap(values) {
167
+ return _createKeyValueMap(values, 0 , 0 , objDeepFreeze);
168
+ }
169
+
170
+ var _wellKnownSymbolMap = createEnumKeyMap({
171
+ asyncIterator: 0 ,
172
+ hasInstance: 1 ,
173
+ isConcatSpreadable: 2 ,
174
+ iterator: 3 ,
175
+ match: 4 ,
176
+ matchAll: 5 ,
177
+ replace: 6 ,
178
+ search: 7 ,
179
+ species: 8 ,
180
+ split: 9 ,
181
+ toPrimitive: 10 ,
182
+ toStringTag: 11 ,
183
+ unscopables: 12
184
+ });
185
+
186
+ var asString = StrCls;
187
+
188
+ var GLOBAL_CONFIG_KEY = "__tsUtils$gblCfg";
189
+ var _globalCfg;
190
+ function _getGlobalValue() {
191
+ var result;
192
+ if (typeof globalThis !== UNDEFINED) {
193
+ result = globalThis;
194
+ }
195
+ if (!result && typeof self !== UNDEFINED) {
196
+ result = self;
197
+ }
198
+ if (!result && typeof window !== UNDEFINED) {
199
+ result = window;
200
+ }
201
+ if (!result && typeof global !== UNDEFINED) {
202
+ result = global;
203
+ }
204
+ return result;
205
+ }
206
+ function _getGlobalConfig() {
207
+ if (!_globalCfg) {
208
+ var gbl = _getGlobalValue() || {};
209
+ _globalCfg = gbl[GLOBAL_CONFIG_KEY] = gbl[GLOBAL_CONFIG_KEY] || {};
210
+ }
211
+ return _globalCfg;
212
+ }
213
+
214
+ function dumpObj(object, format) {
215
+ var propertyValueDump = EMPTY;
216
+ if (isError(object)) {
217
+ propertyValueDump = "{ stack: '" + object.stack + "', message: '" + object.message + "', name: '" + object.name + "'";
218
+ }
219
+ else {
220
+ try {
221
+ propertyValueDump = JSON.stringify(object, null, format ? (isNumber(format) ? format : 4) : UNDEF_VALUE);
222
+ }
223
+ catch (e) {
224
+ propertyValueDump = " - " + dumpObj(e, format);
225
+ }
226
+ }
227
+ return objToString(object) + ": " + propertyValueDump;
228
+ }
229
+
230
+ function _unwrapFunction(funcName, target, polyFunc) {
231
+ return function (thisArg) {
232
+ var theFunc = (thisArg && thisArg[funcName]) || (target && target[funcName]);
233
+ if (theFunc || polyFunc) {
234
+ var theArgs = arguments;
235
+ return (theFunc || polyFunc).apply(thisArg, theFunc ? ArrProto[SLICE].call(theArgs, 1) : theArgs);
236
+ }
237
+ throwTypeError("'" + asString(funcName) + "' not defined for " + dumpObj(thisArg));
238
+ };
239
+ }
240
+
241
+ var _polySymbols;
242
+ function _globalSymbolRegistry() {
243
+ if (!_polySymbols) {
244
+ var gblCfg = _getGlobalConfig();
245
+ _polySymbols = gblCfg.gblSym = gblCfg.gblSym || { k: {}, s: {} };
246
+ }
247
+ return _polySymbols;
248
+ }
249
+ var _wellKnownSymbolCache = {};
250
+ function polyNewSymbol(description) {
251
+ var theSymbol = {
252
+ description: asString(description),
253
+ toString: function () { return SYMBOL + "(" + description + ")"; }
254
+ };
255
+ theSymbol[POLYFILL_TAG] = true;
256
+ return theSymbol;
257
+ }
258
+ function polySymbolFor(key) {
259
+ var registry = _globalSymbolRegistry();
260
+ if (!objHasOwn(registry, key)) {
261
+ var newSymbol = polyNewSymbol(key);
262
+ registry.k[key] = newSymbol;
263
+ registry.s[newSymbol] = asString(key);
264
+ }
265
+ return registry.k[key];
266
+ }
267
+ function polyGetKnownSymbol(name) {
268
+ var result;
269
+ var knownName = _wellKnownSymbolMap[name];
270
+ if (knownName) {
271
+ result = _wellKnownSymbolCache[knownName] = _wellKnownSymbolCache[knownName] || polyNewSymbol(SYMBOL + "." + knownName);
272
+ }
273
+ return result;
274
+ }
275
+
276
+ var propMap = {
277
+ e: "enumerable",
278
+ c: "configurable",
279
+ v: VALUE,
280
+ w: "writable",
281
+ g: "get",
282
+ s: "set"
283
+ };
284
+ function _createProp(value) {
285
+ var prop = {};
286
+ prop[propMap["c"]] = true;
287
+ prop[propMap["e"]] = true;
288
+ if (value.l) {
289
+ prop.get = function () { return value.l.v; };
290
+ var desc = objGetOwnPropertyDescriptor(value.l, "v");
291
+ if (desc && desc.set) {
292
+ prop.set = function (newValue) {
293
+ value.l.v = newValue;
294
+ };
295
+ }
296
+ }
297
+ objForEachKey(value, function (key, value) {
298
+ prop[propMap[key]] = isUndefined(value) ? prop[propMap[key]] : value;
299
+ });
300
+ return prop;
301
+ }
302
+ var objDefineProp = ObjClass["defineProperty"];
303
+ function objDefine(target, key, propDesc) {
304
+ return objDefineProp(target, key, _createProp(propDesc));
305
+ }
306
+
307
+ var _globalLazyTestHooks;
308
+ var _fetchLazyTestHooks = function () {
309
+ _globalLazyTestHooks = _getGlobalConfig();
310
+ _fetchLazyTestHooks = null;
311
+ };
312
+ function getLazy(cb) {
313
+ var lazyValue = {};
314
+ _fetchLazyTestHooks && _fetchLazyTestHooks();
315
+ lazyValue.b = _globalLazyTestHooks.lzy;
316
+ objDefineProp(lazyValue, "v", {
317
+ configurable: true,
318
+ get: function () {
319
+ var result = cb();
320
+ if (!_globalLazyTestHooks.lzy) {
321
+ objDefineProp(lazyValue, "v", {
322
+ value: result
323
+ });
324
+ if (lazyValue.b) {
325
+ delete lazyValue.b;
326
+ }
327
+ }
328
+ if (_globalLazyTestHooks.lzy && lazyValue.b !== _globalLazyTestHooks.lzy) {
329
+ lazyValue.b = _globalLazyTestHooks.lzy;
330
+ }
331
+ return result;
332
+ }
333
+ });
334
+ return lazyValue;
335
+ }
336
+
337
+ function safeGetLazy(cb, defValue) {
338
+ return getLazy(function () { return safeGet(cb, defValue); });
339
+ }
340
+
341
+ var WINDOW = "window";
342
+ var _cachedGlobal;
343
+ var _cachedWindow;
344
+ var _cachedDocument;
345
+ var _cachedNavigator;
346
+ var _isNode;
347
+ function lazySafeGetInst(name) {
348
+ return safeGetLazy(function () { return getInst(name) || UNDEF_VALUE; }, UNDEF_VALUE);
349
+ }
350
+ function getGlobal(useCached) {
351
+ (!_cachedGlobal || useCached === false || (_globalLazyTestHooks.lzy && !_cachedGlobal.b)) && (_cachedGlobal = safeGetLazy(_getGlobalValue, null));
352
+ return _cachedGlobal.v;
353
+ }
354
+ function getInst(name, useCached) {
355
+ var gbl = getGlobal(useCached);
356
+ if (gbl && gbl[name]) {
357
+ return gbl[name];
358
+ }
359
+ if (name === WINDOW && _cachedWindow) {
360
+ return _cachedWindow.v;
361
+ }
362
+ return null;
363
+ }
364
+ function getDocument() {
365
+ (!_cachedDocument || (_globalLazyTestHooks.lzy && !_cachedDocument.b)) && (_cachedDocument = lazySafeGetInst("document"));
366
+ return _cachedDocument.v;
367
+ }
368
+ function hasWindow() {
369
+ return !!getWindow();
370
+ }
371
+ function getWindow() {
372
+ (!_cachedWindow || (_globalLazyTestHooks.lzy && !_cachedWindow.b)) && (_cachedWindow = lazySafeGetInst(WINDOW));
373
+ return _cachedWindow.v;
374
+ }
375
+ function getNavigator() {
376
+ (!_cachedNavigator || (_globalLazyTestHooks.lzy && !_cachedNavigator.b)) && (_cachedNavigator = lazySafeGetInst("navigator"));
377
+ return _cachedNavigator.v;
378
+ }
379
+ function isNode() {
380
+ !_isNode && (_isNode = safeGetLazy(function () { return !!(process && (process.versions || {}).node); }, false));
381
+ return _isNode.v;
382
+ }
383
+
384
+ var _symbol;
385
+ var _symbolFor;
386
+ var _symbolKeyFor;
387
+ function _getSymbolValue(name) {
388
+ return safeGetLazy(function () {
389
+ return (_symbol.v ? _symbol[name] : UNDEF_VALUE);
390
+ }, UNDEF_VALUE);
391
+ }
392
+ function hasSymbol() {
393
+ return !!getSymbol();
394
+ }
395
+ function getSymbol() {
396
+ var resetCache = !_symbol || (_globalLazyTestHooks && _globalLazyTestHooks.lzy && !_symbol.b);
397
+ resetCache && (_symbol = lazySafeGetInst(SYMBOL));
398
+ (!_symbolFor || resetCache) && (_symbolFor = _getSymbolValue("for"));
399
+ (!_symbolKeyFor || resetCache) && (_symbolKeyFor = _getSymbolValue("keyFor"));
400
+ return _symbol.v;
401
+ }
402
+ function getKnownSymbol(name, noPoly) {
403
+ var knownName = _wellKnownSymbolMap[name];
404
+ (!_symbol || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
405
+ return _symbol.v ? _symbol.v[knownName || name] : (!noPoly ? polyGetKnownSymbol(name) : UNDEF_VALUE);
406
+ }
407
+ function newSymbol(description, noPoly) {
408
+ (!_symbol || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
409
+ return _symbol.v ? _symbol.v(description) : (!noPoly ? polyNewSymbol(description) : null);
410
+ }
411
+ function symbolFor(key) {
412
+ (!_symbolFor || (_globalLazyTestHooks.lzy && !_symbol.b)) && getSymbol();
413
+ return (_symbolFor.v || polySymbolFor)(key);
414
+ }
415
+
416
+ function isIterator(value) {
417
+ return !!value && isFunction(value.next);
418
+ }
419
+ function isIterable(value) {
420
+ return !isStrictNullOrUndefined(value) && isFunction(value[getKnownSymbol(3 )]);
421
+ }
422
+
423
+ function iterForOf(iter, callbackfn, thisArg) {
424
+ if (iter) {
425
+ if (!isIterator(iter)) {
426
+ var itSymbol = getKnownSymbol(3 );
427
+ iter = iter[itSymbol] ? iter[itSymbol]() : null;
428
+ }
429
+ if (isIterator(iter)) {
430
+ try {
431
+ var count = 0;
432
+ var value = iter.next();
433
+ while (!value[DONE]) {
434
+ if (callbackfn.call(thisArg || iter, value[VALUE], count, iter) === -1) {
435
+ break;
436
+ }
437
+ count++;
438
+ value = iter.next();
439
+ }
440
+ iter.return && iter.return(value);
441
+ }
442
+ catch (e) {
443
+ iter.throw && iter.throw(e);
444
+ }
445
+ }
446
+ }
447
+ }
448
+
449
+ function arrAppend(target, elms) {
450
+ if (!isUndefined(elms) && target) {
451
+ if (isArray(elms)) {
452
+ target.push.apply(target, elms);
453
+ }
454
+ else if (isIterator(elms) || isIterable(elms)) {
455
+ iterForOf(elms, function (elm) {
456
+ target.push(elm);
457
+ });
458
+ }
459
+ else {
460
+ target.push(elms);
461
+ }
462
+ }
463
+ return target;
464
+ }
465
+
466
+ function arrForEach(theArray, callbackfn, thisArg) {
467
+ if (theArray) {
468
+ var len = theArray[LENGTH] >>> 0;
469
+ for (var idx = 0; idx < len; idx++) {
470
+ if (idx in theArray) {
471
+ if (callbackfn.call(thisArg || theArray, theArray[idx], idx, theArray) === -1) {
472
+ break;
473
+ }
474
+ }
475
+ }
476
+ }
477
+ }
478
+
479
+ var arrIndexOf = _unwrapFunction(INDEX_OF, ArrProto);
480
+
481
+ var arrSlice = _unwrapFunction(SLICE, ArrProto);
482
+
483
+ function objSetPrototypeOf(obj, proto) {
484
+ var fn = ObjClass["setPrototypeOf"] ||
485
+ ({ __proto__: [] } instanceof Array && function (d, b) {
486
+ d.__proto__ = b;
487
+ }) ||
488
+ function (d, b) {
489
+ objForEachKey(b, function (key, value) { return d[key] = value; });
490
+ };
491
+ return fn(obj, proto);
492
+ }
493
+
494
+ function _createCustomError(name, d, baseClass) {
495
+ objSetPrototypeOf(d, baseClass);
496
+ function __() {
497
+ this.constructor = d;
498
+ this[NAME] = name;
499
+ }
500
+ __[PROTOTYPE] = baseClass[PROTOTYPE];
501
+ d[PROTOTYPE] = new __();
502
+ return d;
503
+ }
504
+ var _safeSetName = function (baseClass, name) {
505
+ try {
506
+ baseClass[PROTOTYPE][NAME] = name;
507
+ }
508
+ catch (e) {
509
+ }
510
+ };
511
+ function createCustomError(name, constructCb) {
512
+ var baseClass = Error;
513
+ var orgName = baseClass[PROTOTYPE][NAME];
514
+ var customError = _createCustomError(name, function () {
515
+ var _this = this;
516
+ try {
517
+ _safeSetName(baseClass, name);
518
+ _this = baseClass.apply(_this, arguments) || _this;
519
+ _this[NAME] = name;
520
+ constructCb && constructCb(_this, arguments);
521
+ }
522
+ finally {
523
+ _safeSetName(baseClass, orgName);
524
+ }
525
+ return _this;
526
+ }, baseClass);
527
+ return customError;
528
+ }
529
+
530
+ function utcNow() {
531
+ return (Date.now || polyUtcNow)();
532
+ }
533
+ function polyUtcNow() {
534
+ return new Date().getTime();
535
+ }
536
+
537
+ var _fnToString;
538
+ var _objCtrFnString;
539
+ var _gblWindow;
540
+ function isPlainObject(value) {
541
+ if (!value || typeof value !== OBJECT) {
542
+ return false;
543
+ }
544
+ if (!_gblWindow) {
545
+ _gblWindow = hasWindow() ? getWindow() : true;
546
+ }
547
+ var result = false;
548
+ if (value !== _gblWindow) {
549
+ if (!_objCtrFnString) {
550
+ _fnToString = Function[PROTOTYPE].toString;
551
+ _objCtrFnString = _fnToString.call(ObjClass);
552
+ }
553
+ try {
554
+ var proto = objGetPrototypeOf(value);
555
+ result = !proto;
556
+ if (!result) {
557
+ if (objHasOwnProperty(proto, CONSTRUCTOR)) {
558
+ proto = proto[CONSTRUCTOR];
559
+ }
560
+ result = proto && typeof proto === FUNCTION && _fnToString.call(proto) === _objCtrFnString;
561
+ }
562
+ }
563
+ catch (ex) {
564
+ }
565
+ }
566
+ return result;
567
+ }
568
+
569
+ var _objCreate = ObjClass["create"];
570
+ var objCreate = _objCreate || polyObjCreate;
571
+ function polyObjCreate(obj) {
572
+ if (!obj) {
573
+ return {};
574
+ }
575
+ var type = typeof obj;
576
+ if (type !== OBJECT && type !== FUNCTION) {
577
+ throw new TypeError("Prototype must be an Object or function: " + dumpObj(obj));
578
+ }
579
+ function tempFunc() { }
580
+ tempFunc[PROTOTYPE] = obj;
581
+ return new tempFunc();
582
+ }
583
+
584
+ var strIndexOf = _unwrapFunction(INDEX_OF, StrProto);
585
+
586
+ var REF = "ref";
587
+ var UNREF = "un" + REF;
588
+ var HAS_REF = "hasRef";
589
+ var ENABLED = "enabled";
590
+ function _createTimerHandler(startTimer, refreshFn, cancelFn) {
591
+ var _a;
592
+ var ref = true;
593
+ var timerId = startTimer ? refreshFn(null) : null;
594
+ var theTimerHandler;
595
+ var _unref = function () {
596
+ ref = false;
597
+ timerId && timerId[UNREF] && timerId[UNREF]();
598
+ return theTimerHandler;
599
+ };
600
+ var _ref = function () {
601
+ ref = true;
602
+ timerId && timerId[REF] && timerId[REF]();
603
+ return theTimerHandler;
604
+ };
605
+ var _hasRef = function () {
606
+ if (timerId && timerId[HAS_REF]) {
607
+ return timerId[HAS_REF]();
608
+ }
609
+ return ref;
610
+ };
611
+ var _refresh = function () {
612
+ timerId = refreshFn(timerId);
613
+ if (!ref) {
614
+ _unref();
615
+ }
616
+ return theTimerHandler;
617
+ };
618
+ var _cancel = function () {
619
+ timerId && cancelFn(timerId);
620
+ timerId = null;
621
+ };
622
+ var _setEnabled = function (value) {
623
+ !value && timerId && _cancel();
624
+ value && !timerId && _refresh();
625
+ };
626
+ theTimerHandler = (_a = {
627
+ cancel: _cancel,
628
+ refresh: _refresh
629
+ },
630
+ _a[HAS_REF] = _hasRef,
631
+ _a[REF] = _ref,
632
+ _a[UNREF] = _unref,
633
+ _a[ENABLED] = false,
634
+ _a);
635
+ objDefineProp(theTimerHandler, ENABLED, {
636
+ get: function () { return !!timerId; },
637
+ set: _setEnabled
638
+ });
639
+ return {
640
+ h: theTimerHandler,
641
+ dn: function () {
642
+ timerId = null;
643
+ }
644
+ };
645
+ }
646
+
647
+ function _createTimeoutWith(self, startTimer, overrideFn, theArgs) {
648
+ var isArr = isArray(overrideFn);
649
+ var len = isArr ? overrideFn.length : 0;
650
+ var setFn = (len > 0 ? overrideFn[0] : (!isArr ? overrideFn : UNDEF_VALUE)) || setTimeout;
651
+ var clearFn = (len > 1 ? overrideFn[1] : UNDEF_VALUE) || clearTimeout;
652
+ var timerFn = theArgs[0];
653
+ theArgs[0] = function () {
654
+ handler.dn();
655
+ timerFn.apply(self, arguments);
656
+ };
657
+ var handler = _createTimerHandler(startTimer, function (timerId) {
658
+ if (timerId) {
659
+ if (timerId.refresh) {
660
+ timerId.refresh();
661
+ return timerId;
662
+ }
663
+ clearFn.call(self, timerId);
664
+ }
665
+ return setFn.apply(self, theArgs);
666
+ }, function (timerId) {
667
+ clearFn.call(self, timerId);
668
+ });
669
+ return handler.h;
670
+ }
671
+ function scheduleTimeout(callback, timeout) {
672
+ return _createTimeoutWith(this, true, UNDEF_VALUE, arrSlice(arguments));
673
+ }
674
+
675
+ (getGlobal() || {})["Symbol"];
676
+ (getGlobal() || {})["Reflect"];
677
+ var strHasOwnProperty = "hasOwnProperty";
678
+ var extendStaticsFn = function (d, b) {
679
+ extendStaticsFn = ObjClass$1["setPrototypeOf"] ||
680
+ ({ __proto__: [] } instanceof Array && function (d, b) {
681
+ d.__proto__ = b;
682
+ }) ||
683
+ function (d, b) {
684
+ for (var p in b) {
685
+ if (b[strHasOwnProperty](p)) {
686
+ d[p] = b[p];
687
+ }
688
+ }
689
+ };
690
+ return extendStaticsFn(d, b);
691
+ };
692
+ function __extendsFn(d, b) {
693
+ if (typeof b !== strShimFunction && b !== null) {
694
+ throwTypeError("Class extends value " + String(b) + " is not a constructor or null");
695
+ }
696
+ extendStaticsFn(d, b);
697
+ function __() {
698
+ this.constructor = d;
699
+ }
700
+ d[strShimPrototype] = b === null ? objCreate(b) : (__[strShimPrototype] = b[strShimPrototype], new __());
701
+ }
702
+
703
+ var _a$2;
704
+ var Constructor = 'constructor';
705
+ var Prototype = 'prototype';
706
+ var strFunction = 'function';
707
+ var DynInstFuncTable = '_dynInstFuncs';
708
+ var DynProxyTag = '_isDynProxy';
709
+ var DynClassName = '_dynClass';
710
+ var DynClassNamePrefix = '_dynCls$';
711
+ var DynInstChkTag = '_dynInstChk';
712
+ var DynAllowInstChkTag = DynInstChkTag;
713
+ var DynProtoDefaultOptions = '_dfOpts';
714
+ var UnknownValue = '_unknown_';
715
+ var str__Proto = "__proto__";
716
+ var DynProtoBaseProto = "_dyn" + str__Proto;
717
+ var DynProtoGlobalSettings = "__dynProto$Gbl";
718
+ var DynProtoCurrent = "_dynInstProto";
719
+ var strUseBaseInst = 'useBaseInst';
720
+ var strSetInstFuncs = 'setInstFuncs';
721
+ var Obj = Object;
722
+ var _objGetPrototypeOf = Obj["getPrototypeOf"];
723
+ var _objGetOwnProps = Obj["getOwnPropertyNames"];
724
+ var _gbl = getGlobal();
725
+ var _gblInst = _gbl[DynProtoGlobalSettings] || (_gbl[DynProtoGlobalSettings] = {
726
+ o: (_a$2 = {},
727
+ _a$2[strSetInstFuncs] = true,
728
+ _a$2[strUseBaseInst] = true,
729
+ _a$2),
730
+ n: 1000
731
+ });
732
+ function _isObjectOrArrayPrototype(target) {
733
+ return target && (target === Obj[Prototype] || target === Array[Prototype]);
734
+ }
735
+ function _isObjectArrayOrFunctionPrototype(target) {
736
+ return _isObjectOrArrayPrototype(target) || target === Function[Prototype];
737
+ }
738
+ function _getObjProto(target) {
739
+ var newProto;
740
+ if (target) {
741
+ if (_objGetPrototypeOf) {
742
+ return _objGetPrototypeOf(target);
743
+ }
744
+ var curProto = target[str__Proto] || target[Prototype] || (target[Constructor] ? target[Constructor][Prototype] : null);
745
+ newProto = target[DynProtoBaseProto] || curProto;
746
+ if (!objHasOwnProperty(target, DynProtoBaseProto)) {
747
+ delete target[DynProtoCurrent];
748
+ newProto = target[DynProtoBaseProto] = target[DynProtoCurrent] || target[DynProtoBaseProto];
749
+ target[DynProtoCurrent] = curProto;
750
+ }
751
+ }
752
+ return newProto;
753
+ }
754
+ function _forEachProp(target, func) {
755
+ var props = [];
756
+ if (_objGetOwnProps) {
757
+ props = _objGetOwnProps(target);
758
+ }
759
+ else {
760
+ for (var name_1 in target) {
761
+ if (typeof name_1 === "string" && objHasOwnProperty(target, name_1)) {
762
+ props.push(name_1);
763
+ }
764
+ }
765
+ }
766
+ if (props && props.length > 0) {
767
+ for (var lp = 0; lp < props.length; lp++) {
768
+ func(props[lp]);
769
+ }
770
+ }
771
+ }
772
+ function _isDynamicCandidate(target, funcName, skipOwn) {
773
+ return (funcName !== Constructor && typeof target[funcName] === strFunction && (skipOwn || objHasOwnProperty(target, funcName)));
774
+ }
775
+ function _throwTypeError(message) {
776
+ throwTypeError("DynamicProto: " + message);
777
+ }
778
+ function _getInstanceFuncs(thisTarget) {
779
+ var instFuncs = {};
780
+ _forEachProp(thisTarget, function (name) {
781
+ if (!instFuncs[name] && _isDynamicCandidate(thisTarget, name, false)) {
782
+ instFuncs[name] = thisTarget[name];
783
+ }
784
+ });
785
+ return instFuncs;
786
+ }
787
+ function _hasVisited(values, value) {
788
+ for (var lp = values.length - 1; lp >= 0; lp--) {
789
+ if (values[lp] === value) {
790
+ return true;
791
+ }
792
+ }
793
+ return false;
794
+ }
795
+ function _getBaseFuncs(classProto, thisTarget, instFuncs, useBaseInst) {
796
+ function _instFuncProxy(target, funcHost, funcName) {
797
+ var theFunc = funcHost[funcName];
798
+ if (theFunc[DynProxyTag] && useBaseInst) {
799
+ var instFuncTable = target[DynInstFuncTable] || {};
800
+ if (instFuncTable[DynAllowInstChkTag] !== false) {
801
+ theFunc = (instFuncTable[funcHost[DynClassName]] || {})[funcName] || theFunc;
802
+ }
803
+ }
804
+ return function () {
805
+ return theFunc.apply(target, arguments);
806
+ };
807
+ }
808
+ var baseFuncs = {};
809
+ _forEachProp(instFuncs, function (name) {
810
+ baseFuncs[name] = _instFuncProxy(thisTarget, instFuncs, name);
811
+ });
812
+ var baseProto = _getObjProto(classProto);
813
+ var visited = [];
814
+ while (baseProto && !_isObjectArrayOrFunctionPrototype(baseProto) && !_hasVisited(visited, baseProto)) {
815
+ _forEachProp(baseProto, function (name) {
816
+ if (!baseFuncs[name] && _isDynamicCandidate(baseProto, name, !_objGetPrototypeOf)) {
817
+ baseFuncs[name] = _instFuncProxy(thisTarget, baseProto, name);
818
+ }
819
+ });
820
+ visited.push(baseProto);
821
+ baseProto = _getObjProto(baseProto);
822
+ }
823
+ return baseFuncs;
824
+ }
825
+ function _getInstFunc(target, funcName, proto, currentDynProtoProxy) {
826
+ var instFunc = null;
827
+ if (target && objHasOwnProperty(proto, DynClassName)) {
828
+ var instFuncTable = target[DynInstFuncTable] || {};
829
+ instFunc = (instFuncTable[proto[DynClassName]] || {})[funcName];
830
+ if (!instFunc) {
831
+ _throwTypeError("Missing [" + funcName + "] " + strFunction);
832
+ }
833
+ if (!instFunc[DynInstChkTag] && instFuncTable[DynAllowInstChkTag] !== false) {
834
+ var canAddInst = !objHasOwnProperty(target, funcName);
835
+ var objProto = _getObjProto(target);
836
+ var visited = [];
837
+ while (canAddInst && objProto && !_isObjectArrayOrFunctionPrototype(objProto) && !_hasVisited(visited, objProto)) {
838
+ var protoFunc = objProto[funcName];
839
+ if (protoFunc) {
840
+ canAddInst = (protoFunc === currentDynProtoProxy);
841
+ break;
842
+ }
843
+ visited.push(objProto);
844
+ objProto = _getObjProto(objProto);
845
+ }
846
+ try {
847
+ if (canAddInst) {
848
+ target[funcName] = instFunc;
849
+ }
850
+ instFunc[DynInstChkTag] = 1;
851
+ }
852
+ catch (e) {
853
+ instFuncTable[DynAllowInstChkTag] = false;
854
+ }
855
+ }
856
+ }
857
+ return instFunc;
858
+ }
859
+ function _getProtoFunc(funcName, proto, currentDynProtoProxy) {
860
+ var protoFunc = proto[funcName];
861
+ if (protoFunc === currentDynProtoProxy) {
862
+ protoFunc = _getObjProto(proto)[funcName];
863
+ }
864
+ if (typeof protoFunc !== strFunction) {
865
+ _throwTypeError("[" + funcName + "] is not a " + strFunction);
866
+ }
867
+ return protoFunc;
868
+ }
869
+ function _populatePrototype(proto, className, target, baseInstFuncs, setInstanceFunc) {
870
+ function _createDynamicPrototype(proto, funcName) {
871
+ var dynProtoProxy = function () {
872
+ var instFunc = _getInstFunc(this, funcName, proto, dynProtoProxy) || _getProtoFunc(funcName, proto, dynProtoProxy);
873
+ return instFunc.apply(this, arguments);
874
+ };
875
+ dynProtoProxy[DynProxyTag] = 1;
876
+ return dynProtoProxy;
877
+ }
878
+ if (!_isObjectOrArrayPrototype(proto)) {
879
+ var instFuncTable = target[DynInstFuncTable] = target[DynInstFuncTable] || {};
880
+ var instFuncs_1 = instFuncTable[className] = (instFuncTable[className] || {});
881
+ if (instFuncTable[DynAllowInstChkTag] !== false) {
882
+ instFuncTable[DynAllowInstChkTag] = !!setInstanceFunc;
883
+ }
884
+ _forEachProp(target, function (name) {
885
+ if (_isDynamicCandidate(target, name, false) && target[name] !== baseInstFuncs[name]) {
886
+ instFuncs_1[name] = target[name];
887
+ delete target[name];
888
+ if (!objHasOwnProperty(proto, name) || (proto[name] && !proto[name][DynProxyTag])) {
889
+ proto[name] = _createDynamicPrototype(proto, name);
890
+ }
891
+ }
892
+ });
893
+ }
894
+ }
895
+ function _checkPrototype(classProto, thisTarget) {
896
+ if (_objGetPrototypeOf) {
897
+ var visited = [];
898
+ var thisProto = _getObjProto(thisTarget);
899
+ while (thisProto && !_isObjectArrayOrFunctionPrototype(thisProto) && !_hasVisited(visited, thisProto)) {
900
+ if (thisProto === classProto) {
901
+ return true;
902
+ }
903
+ visited.push(thisProto);
904
+ thisProto = _getObjProto(thisProto);
905
+ }
906
+ return false;
907
+ }
908
+ return true;
909
+ }
910
+ function _getObjName(target, unknownValue) {
911
+ if (objHasOwnProperty(target, Prototype)) {
912
+ return target.name || unknownValue || UnknownValue;
913
+ }
914
+ return (((target || {})[Constructor]) || {}).name || unknownValue || UnknownValue;
915
+ }
916
+ function dynamicProto(theClass, target, delegateFunc, options) {
917
+ if (!objHasOwnProperty(theClass, Prototype)) {
918
+ _throwTypeError("theClass is an invalid class definition.");
919
+ }
920
+ var classProto = theClass[Prototype];
921
+ if (!_checkPrototype(classProto, target)) {
922
+ _throwTypeError("[" + _getObjName(theClass) + "] not in hierarchy of [" + _getObjName(target) + "]");
923
+ }
924
+ var className = null;
925
+ if (objHasOwnProperty(classProto, DynClassName)) {
926
+ className = classProto[DynClassName];
927
+ }
928
+ else {
929
+ className = DynClassNamePrefix + _getObjName(theClass, "_") + "$" + _gblInst.n;
930
+ _gblInst.n++;
931
+ classProto[DynClassName] = className;
932
+ }
933
+ var perfOptions = dynamicProto[DynProtoDefaultOptions];
934
+ var useBaseInst = !!perfOptions[strUseBaseInst];
935
+ if (useBaseInst && options && options[strUseBaseInst] !== undefined) {
936
+ useBaseInst = !!options[strUseBaseInst];
937
+ }
938
+ var instFuncs = _getInstanceFuncs(target);
939
+ var baseFuncs = _getBaseFuncs(classProto, target, instFuncs, useBaseInst);
940
+ delegateFunc(target, baseFuncs);
941
+ var setInstanceFunc = !!_objGetPrototypeOf && !!perfOptions[strSetInstFuncs];
942
+ if (setInstanceFunc && options) {
943
+ setInstanceFunc = !!options[strSetInstFuncs];
944
+ }
945
+ _populatePrototype(classProto, className, target, instFuncs, setInstanceFunc !== false);
946
+ }
947
+ dynamicProto[DynProtoDefaultOptions] = _gblInst.o;
948
+
949
+ var _DYN_TO_LOWER_CASE = "toLowerCase";
950
+ var _DYN_LENGTH$1 = "length";
951
+ var _DYN_RD_ONLY = "rdOnly";
952
+ var _DYN_NOTIFY = "notify";
953
+ var _DYN_THROW_INTERNAL = "throwInternal";
954
+ var _DYN_SET_DF = "setDf";
955
+ var _DYN_WATCH = "watch";
956
+ var _DYN_LOGGER = "logger";
957
+ var _DYN_APPLY = "apply";
958
+ var _DYN_PUSH = "push";
959
+ var _DYN_SPLICE = "splice";
960
+ var _DYN_CANCEL = "cancel";
961
+ var _DYN_INITIALIZE = "initialize";
962
+ var _DYN_IDENTIFIER$1 = "identifier";
963
+ var _DYN_IS_INITIALIZED = "isInitialized";
964
+ var _DYN_GET_PLUGIN = "getPlugin";
965
+ var _DYN_NAME = "name";
966
+ var _DYN_TIME = "time";
967
+ var _DYN_PROCESS_NEXT$1 = "processNext";
968
+ var _DYN_GET_PROCESS_TEL_CONT0 = "getProcessTelContext";
969
+ var _DYN_UNLOAD = "unload";
970
+ var _DYN_LOGGING_LEVEL_CONSOL4 = "loggingLevelConsole";
971
+ var _DYN_CREATE_NEW = "createNew";
972
+ var _DYN_TEARDOWN$1 = "teardown";
973
+ var _DYN_MESSAGE_ID = "messageId";
974
+ var _DYN_MESSAGE = "message";
975
+ var _DYN_IS_ASYNC = "isAsync";
976
+ var _DYN_DIAG_LOG = "diagLog";
977
+ var _DYN__DO_TEARDOWN = "_doTeardown";
978
+ var _DYN_UPDATE = "update";
979
+ var _DYN_GET_NEXT = "getNext";
980
+ var _DYN_SET_NEXT_PLUGIN = "setNextPlugin";
981
+ var _DYN_USER_AGENT = "userAgent";
982
+ var _DYN_NODE_TYPE = "nodeType";
983
+ var _DYN_REPLACE = "replace";
984
+ var _DYN_LOG_INTERNAL_MESSAGE = "logInternalMessage";
985
+ var _DYN_IS_CHILD_EVT = "isChildEvt";
986
+ var _DYN_GET_CTX = "getCtx";
987
+ var _DYN_SET_CTX = "setCtx";
988
+ var _DYN_COMPLETE = "complete";
989
+
990
+ var aggregationErrorType;
991
+ function throwAggregationError(message, sourceErrors) {
992
+ if (!aggregationErrorType) {
993
+ aggregationErrorType = createCustomError("AggregationError", function (self, args) {
994
+ if (args[_DYN_LENGTH$1 ] > 1) {
995
+ self.errors = args[1];
996
+ }
997
+ });
998
+ }
999
+ var theMessage = message || "One or more errors occurred.";
1000
+ arrForEach(sourceErrors, function (srcError, idx) {
1001
+ theMessage += "\n".concat(idx, " > ").concat(dumpObj(srcError));
1002
+ });
1003
+ throw new aggregationErrorType(theMessage, sourceErrors || []);
1004
+ }
1005
+
1006
+ var _theLogger = null;
1007
+ function _debugLog(id, message) {
1008
+ if (_theLogger) {
1009
+ _theLogger(id, message);
1010
+ }
1011
+ }
1012
+
1013
+ var STRING_STATES = [
1014
+ "pending", "resolving", "resolved", "rejected"
1015
+ ];
1016
+
1017
+ var DISPATCH_EVENT = "dispatchEvent";
1018
+ var _hasInitEvent;
1019
+ function emitEvent(target, evtName, populateEvent, useNewEvent) {
1020
+ var doc = getDocument();
1021
+ !_hasInitEvent && (_hasInitEvent = safeGetLazy(function () {
1022
+ var evt;
1023
+ if (doc && doc.createEvent) {
1024
+ evt = doc.createEvent("Event");
1025
+ }
1026
+ return (!!evt && evt.initEvent);
1027
+ }, null));
1028
+ var theEvt = _hasInitEvent.v ? doc.createEvent("Event") : (useNewEvent ? new Event(evtName) : {});
1029
+ populateEvent && populateEvent(theEvt);
1030
+ if (_hasInitEvent.v) {
1031
+ theEvt.initEvent(evtName, false, true);
1032
+ }
1033
+ if (theEvt && target[DISPATCH_EVENT]) {
1034
+ target[DISPATCH_EVENT](theEvt);
1035
+ }
1036
+ else {
1037
+ var handler = target["on" + evtName];
1038
+ if (handler) {
1039
+ handler(theEvt);
1040
+ }
1041
+ else {
1042
+ var theConsole = getInst("console");
1043
+ theConsole && (theConsole["error"] || theConsole["log"])(evtName, dumpObj(theEvt));
1044
+ }
1045
+ }
1046
+ }
1047
+
1048
+ var STR_PROMISE = "Promise";
1049
+
1050
+ var NODE_UNHANDLED_REJECTION = "unhandledRejection";
1051
+ var UNHANDLED_REJECTION = NODE_UNHANDLED_REJECTION.toLowerCase();
1052
+ var _unhandledRejectionTimeout = 10;
1053
+ var _hasPromiseRejectionEvent;
1054
+ function dumpFnObj(value) {
1055
+ if (isFunction(value)) {
1056
+ return value.toString();
1057
+ }
1058
+ return dumpObj(value);
1059
+ }
1060
+ function _createPromise(newPromise, processor, executor) {
1061
+ var additionalArgs = arrSlice(arguments, 3);
1062
+ var _state = 0 ;
1063
+ var _hasResolved = false;
1064
+ var _settledValue;
1065
+ var _queue = [];
1066
+ var _handled = false;
1067
+ var _unHandledRejectionHandler = null;
1068
+ var _thePromise;
1069
+ !_hasPromiseRejectionEvent && (_hasPromiseRejectionEvent = lazySafeGetInst(STR_PROMISE + "RejectionEvent"));
1070
+ var _then = function (onResolved, onRejected) {
1071
+ try {
1072
+ _handled = true;
1073
+ _unHandledRejectionHandler && _unHandledRejectionHandler.cancel();
1074
+ _unHandledRejectionHandler = null;
1075
+ _debugLog(_toString(), "then(" + dumpFnObj(onResolved) + ", " + dumpFnObj(onResolved) + ")");
1076
+ var thenPromise = newPromise(function (resolve, reject) {
1077
+ _queue.push(function () {
1078
+ try {
1079
+ _debugLog(_toString(), "Handling settled value " + dumpFnObj(_settledValue));
1080
+ var handler = _state === 2 ? onResolved : onRejected;
1081
+ var value = isUndefined(handler) ? _settledValue : (isFunction(handler) ? handler(_settledValue) : handler);
1082
+ _debugLog(_toString(), "Handling Result " + dumpFnObj(value));
1083
+ if (isPromiseLike(value)) {
1084
+ value.then(resolve, reject);
1085
+ }
1086
+ else if (handler) {
1087
+ resolve(value);
1088
+ }
1089
+ else if (_state === 3 ) {
1090
+ reject(value);
1091
+ }
1092
+ else {
1093
+ resolve(value);
1094
+ }
1095
+ }
1096
+ catch (e) {
1097
+ reject(e);
1098
+ }
1099
+ });
1100
+ _debugLog(_toString(), "Added to Queue " + _queue.length);
1101
+ if (_hasResolved) {
1102
+ _processQueue();
1103
+ }
1104
+ }, additionalArgs);
1105
+ _debugLog(_toString(), "Created -> " + thenPromise.toString());
1106
+ return thenPromise;
1107
+ }
1108
+ finally {
1109
+ }
1110
+ };
1111
+ var _catch = function (onRejected) {
1112
+ return _then(undefined, onRejected);
1113
+ };
1114
+ var _finally = function (onFinally) {
1115
+ var thenFinally = onFinally;
1116
+ var catchFinally = onFinally;
1117
+ if (isFunction(onFinally)) {
1118
+ thenFinally = function (value) {
1119
+ onFinally && onFinally();
1120
+ return value;
1121
+ };
1122
+ catchFinally = function (reason) {
1123
+ onFinally && onFinally();
1124
+ throw reason;
1125
+ };
1126
+ }
1127
+ return _then(thenFinally, catchFinally);
1128
+ };
1129
+ var _strState = function () {
1130
+ return STRING_STATES[_state];
1131
+ };
1132
+ var _processQueue = function () {
1133
+ if (_queue.length > 0) {
1134
+ var pending = _queue.slice();
1135
+ _queue = [];
1136
+ _debugLog(_toString(), "Processing queue " + pending.length);
1137
+ _handled = true;
1138
+ processor(pending);
1139
+ _debugLog(_toString(), "Processing done");
1140
+ _unHandledRejectionHandler && _unHandledRejectionHandler.cancel();
1141
+ _unHandledRejectionHandler = null;
1142
+ }
1143
+ else {
1144
+ _debugLog(_toString(), "Empty Processing queue ");
1145
+ }
1146
+ };
1147
+ var _createSettleIfFn = function (newState, allowState) {
1148
+ return function (theValue) {
1149
+ if (_state === allowState) {
1150
+ if (newState === 2 && isPromiseLike(theValue)) {
1151
+ _state = 1 ;
1152
+ _debugLog(_toString(), "Resolving");
1153
+ theValue.then(_createSettleIfFn(2 , 1 ), _createSettleIfFn(3 , 1 ));
1154
+ return;
1155
+ }
1156
+ _state = newState;
1157
+ _hasResolved = true;
1158
+ _settledValue = theValue;
1159
+ _debugLog(_toString(), _strState());
1160
+ _processQueue();
1161
+ if (!_handled && newState === 3 && !_unHandledRejectionHandler) {
1162
+ _unHandledRejectionHandler = scheduleTimeout(_notifyUnhandledRejection, _unhandledRejectionTimeout);
1163
+ }
1164
+ }
1165
+ else {
1166
+ _debugLog(_toString(), "Already " + _strState());
1167
+ }
1168
+ };
1169
+ };
1170
+ var _notifyUnhandledRejection = function () {
1171
+ if (!_handled) {
1172
+ if (isNode()) {
1173
+ _debugLog(_toString(), "Emitting " + NODE_UNHANDLED_REJECTION);
1174
+ process.emit(NODE_UNHANDLED_REJECTION, _settledValue, _thePromise);
1175
+ }
1176
+ else {
1177
+ var gbl = getWindow() || getGlobal();
1178
+ _debugLog(_toString(), "Emitting " + UNHANDLED_REJECTION);
1179
+ emitEvent(gbl, UNHANDLED_REJECTION, function (theEvt) {
1180
+ objDefine(theEvt, "promise", { g: function () { return _thePromise; } });
1181
+ theEvt.reason = _settledValue;
1182
+ return theEvt;
1183
+ }, !!_hasPromiseRejectionEvent.v);
1184
+ }
1185
+ }
1186
+ };
1187
+ _thePromise = {
1188
+ then: _then,
1189
+ "catch": _catch,
1190
+ finally: _finally
1191
+ };
1192
+ objDefineProp(_thePromise, "state", {
1193
+ get: _strState
1194
+ });
1195
+ if (hasSymbol()) {
1196
+ _thePromise[getKnownSymbol(11 )] = "IPromise";
1197
+ }
1198
+ var _toString = function () {
1199
+ return "IPromise" + ("") + " " + _strState() + (_hasResolved ? (" - " + dumpFnObj(_settledValue)) : "");
1200
+ };
1201
+ _thePromise.toString = _toString;
1202
+ (function _initialize() {
1203
+ if (!isFunction(executor)) {
1204
+ throwTypeError(STR_PROMISE + ": executor is not a function - " + dumpFnObj(executor));
1205
+ }
1206
+ var _rejectFn = _createSettleIfFn(3 , 0 );
1207
+ try {
1208
+ _debugLog(_toString(), "Executing");
1209
+ executor.call(_thePromise, _createSettleIfFn(2 , 0 ), _rejectFn);
1210
+ }
1211
+ catch (e) {
1212
+ _rejectFn(e);
1213
+ }
1214
+ })();
1215
+ _debugLog(_toString(), "Returning");
1216
+ return _thePromise;
1217
+ }
1218
+
1219
+ var _processPendingItems = function (pending) {
1220
+ arrForEach(pending, function (fn) {
1221
+ try {
1222
+ fn();
1223
+ }
1224
+ catch (e) {
1225
+ }
1226
+ });
1227
+ };
1228
+ function timeoutItemProcessor(timeout) {
1229
+ var callbackTimeout = isNumber(timeout) ? timeout : 0;
1230
+ return function (pending) {
1231
+ scheduleTimeout(function () {
1232
+ _processPendingItems(pending);
1233
+ }, callbackTimeout);
1234
+ };
1235
+ }
1236
+
1237
+ function createAsyncPromise(executor, timeout) {
1238
+ return _createPromise(createAsyncPromise, timeoutItemProcessor(timeout), executor, timeout);
1239
+ }
1240
+
1241
+ var _isPromiseSupported;
1242
+ function createNativePromise(executor, timeout) {
1243
+ !_isPromiseSupported && (_isPromiseSupported = lazySafeGetInst(STR_PROMISE));
1244
+ var PrmCls = _isPromiseSupported.v;
1245
+ if (!PrmCls) {
1246
+ return createAsyncPromise(executor);
1247
+ }
1248
+ if (!isFunction(executor)) {
1249
+ throwTypeError(STR_PROMISE + ": executor is not a function - " + dumpObj(executor));
1250
+ }
1251
+ var _state = 0 ;
1252
+ function _strState() {
1253
+ return STRING_STATES[_state];
1254
+ }
1255
+ var thePromise = new PrmCls(function (resolve, reject) {
1256
+ function _resolve(value) {
1257
+ _state = 2 ;
1258
+ resolve(value);
1259
+ }
1260
+ function _reject(reason) {
1261
+ _state = 3 ;
1262
+ reject(reason);
1263
+ }
1264
+ executor(_resolve, _reject);
1265
+ });
1266
+ objDefineProp(thePromise, "state", {
1267
+ get: _strState
1268
+ });
1269
+ return thePromise;
1270
+ }
1271
+
1272
+ var _promiseCreator;
1273
+ function createPromise(executor, timeout) {
1274
+ !_promiseCreator && (_promiseCreator = getLazy(function () { return createNativePromise; }));
1275
+ return _promiseCreator.v.call(this, executor, timeout);
1276
+ }
1277
+
1278
+ var UNDEFINED_VALUE = undefined;
1279
+ var STR_EMPTY = "";
1280
+ var STR_CORE = "core";
1281
+ var STR_DISABLED = "disabled";
1282
+ var STR_EXTENSION_CONFIG = "extensionConfig";
1283
+ var STR_PROCESS_TELEMETRY = "processTelemetry";
1284
+ var STR_PRIORITY = "priority";
1285
+ var STR_ERROR_TO_CONSOLE = "errorToConsole";
1286
+ var STR_WARN_TO_CONSOLE = "warnToConsole";
1287
+ var STR_GET_PERF_MGR = "getPerfMgr";
1288
+ var STR_NOT_DYNAMIC_ERROR = "Not dynamic - ";
1289
+
1290
+ var rCamelCase = /-([a-z])/g;
1291
+ var rNormalizeInvalid = /([^\w\d_$])/g;
1292
+ var rLeadingNumeric = /^(\d+[\w\d_$])/;
1293
+ function isNotNullOrUndefined(value) {
1294
+ return !isNullOrUndefined(value);
1295
+ }
1296
+ function normalizeJsName(name) {
1297
+ var value = name;
1298
+ if (value && isString(value)) {
1299
+ value = value[_DYN_REPLACE ](rCamelCase, function (_all, letter) {
1300
+ return letter.toUpperCase();
1301
+ });
1302
+ value = value[_DYN_REPLACE ](rNormalizeInvalid, "_");
1303
+ value = value[_DYN_REPLACE ](rLeadingNumeric, function (_all, match) {
1304
+ return "_" + match;
1305
+ });
1306
+ }
1307
+ return value;
1308
+ }
1309
+ function strContains(value, search) {
1310
+ if (value && search) {
1311
+ return strIndexOf(value, search) !== -1;
1312
+ }
1313
+ return false;
1314
+ }
1315
+ function _createProxyFunction(source, funcName) {
1316
+ var srcFunc = null;
1317
+ var src = null;
1318
+ if (isFunction(source)) {
1319
+ srcFunc = source;
1320
+ }
1321
+ else {
1322
+ src = source;
1323
+ }
1324
+ return function () {
1325
+ var originalArguments = arguments;
1326
+ if (srcFunc) {
1327
+ src = srcFunc();
1328
+ }
1329
+ if (src) {
1330
+ return src[funcName][_DYN_APPLY ](src, originalArguments);
1331
+ }
1332
+ };
1333
+ }
1334
+ function proxyFunctionAs(target, name, source, theFunc, overwriteTarget) {
1335
+ if (target && name && source) {
1336
+ if (overwriteTarget !== false || isUndefined(target[name])) {
1337
+ target[name] = _createProxyFunction(source, theFunc);
1338
+ }
1339
+ }
1340
+ }
1341
+ function proxyFunctions(target, source, functionsToProxy, overwriteTarget) {
1342
+ if (target && source && isObject(target) && isArray(functionsToProxy)) {
1343
+ arrForEach(functionsToProxy, function (theFuncName) {
1344
+ if (isString(theFuncName)) {
1345
+ proxyFunctionAs(target, theFuncName, source, theFuncName, overwriteTarget);
1346
+ }
1347
+ });
1348
+ }
1349
+ return target;
1350
+ }
1351
+
1352
+ var strConsole = "console";
1353
+ var strJSON = "JSON";
1354
+ var strCrypto = "crypto";
1355
+ var strMsCrypto = "msCrypto";
1356
+ var strMsie = "msie";
1357
+ var strTrident = "trident/";
1358
+ var _isTrident = null;
1359
+ var _navUserAgentCheck = null;
1360
+ function getConsole() {
1361
+ if (typeof console !== strShimUndefined) {
1362
+ return console;
1363
+ }
1364
+ return getInst(strConsole);
1365
+ }
1366
+ function hasJSON() {
1367
+ return Boolean((typeof JSON === strShimObject && JSON) || getInst(strJSON) !== null);
1368
+ }
1369
+ function getJSON() {
1370
+ if (hasJSON()) {
1371
+ return JSON || getInst(strJSON);
1372
+ }
1373
+ return null;
1374
+ }
1375
+ function getCrypto() {
1376
+ return getInst(strCrypto);
1377
+ }
1378
+ function getMsCrypto() {
1379
+ return getInst(strMsCrypto);
1380
+ }
1381
+ function isIE() {
1382
+ var nav = getNavigator();
1383
+ if (nav && (nav[_DYN_USER_AGENT ] !== _navUserAgentCheck || _isTrident === null)) {
1384
+ _navUserAgentCheck = nav[_DYN_USER_AGENT ];
1385
+ var userAgent = (_navUserAgentCheck || STR_EMPTY)[_DYN_TO_LOWER_CASE ]();
1386
+ _isTrident = (strContains(userAgent, strMsie) || strContains(userAgent, strTrident));
1387
+ }
1388
+ return _isTrident;
1389
+ }
1390
+
1391
+ var UInt32Mask = 0x100000000;
1392
+ var MaxUInt32 = 0xffffffff;
1393
+ var SEED1 = 123456789;
1394
+ var SEED2 = 987654321;
1395
+ var _mwcSeeded = false;
1396
+ var _mwcW = SEED1;
1397
+ var _mwcZ = SEED2;
1398
+ function _mwcSeed(seedValue) {
1399
+ if (seedValue < 0) {
1400
+ seedValue >>>= 0;
1401
+ }
1402
+ _mwcW = (SEED1 + seedValue) & MaxUInt32;
1403
+ _mwcZ = (SEED2 - seedValue) & MaxUInt32;
1404
+ _mwcSeeded = true;
1405
+ }
1406
+ function _autoSeedMwc() {
1407
+ try {
1408
+ var now = utcNow() & 0x7fffffff;
1409
+ _mwcSeed(((Math.random() * UInt32Mask) ^ now) + now);
1410
+ }
1411
+ catch (e) {
1412
+ }
1413
+ }
1414
+ function random32(signed) {
1415
+ var value = 0;
1416
+ var c = getCrypto() || getMsCrypto();
1417
+ if (c && c.getRandomValues) {
1418
+ value = c.getRandomValues(new Uint32Array(1))[0] & MaxUInt32;
1419
+ }
1420
+ if (value === 0 && isIE()) {
1421
+ if (!_mwcSeeded) {
1422
+ _autoSeedMwc();
1423
+ }
1424
+ value = mwcRandom32() & MaxUInt32;
1425
+ }
1426
+ if (value === 0) {
1427
+ value = Math.floor((UInt32Mask * Math.random()) | 0);
1428
+ }
1429
+ if (!signed) {
1430
+ value >>>= 0;
1431
+ }
1432
+ return value;
1433
+ }
1434
+ function mwcRandom32(signed) {
1435
+ _mwcZ = (36969 * (_mwcZ & 0xFFFF) + (_mwcZ >> 16)) & MaxUInt32;
1436
+ _mwcW = (18000 * (_mwcW & 0xFFFF) + (_mwcW >> 16)) & MaxUInt32;
1437
+ var value = (((_mwcZ << 16) + (_mwcW & 0xFFFF)) >>> 0) & MaxUInt32 | 0;
1438
+ if (!signed) {
1439
+ value >>>= 0;
1440
+ }
1441
+ return value;
1442
+ }
1443
+ function newId(maxLength) {
1444
+ if (maxLength === void 0) { maxLength = 22; }
1445
+ var base64chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
1446
+ var number = random32() >>> 0;
1447
+ var chars = 0;
1448
+ var result = STR_EMPTY;
1449
+ while (result[_DYN_LENGTH$1 ] < maxLength) {
1450
+ chars++;
1451
+ result += base64chars.charAt(number & 0x3F);
1452
+ number >>>= 6;
1453
+ if (chars === 5) {
1454
+ number = (((random32() << 2) & 0xFFFFFFFF) | (number & 0x03)) >>> 0;
1455
+ chars = 0;
1456
+ }
1457
+ }
1458
+ return result;
1459
+ }
1460
+
1461
+ var version = "3.0.2-nightly3.2305-04";
1462
+ var instanceName = "." + newId(6);
1463
+ var _dataUid = 0;
1464
+ function _canAcceptData(target) {
1465
+ return target[_DYN_NODE_TYPE ] === 1 || target[_DYN_NODE_TYPE ] === 9 || !(+target[_DYN_NODE_TYPE ]);
1466
+ }
1467
+ function _getCache(data, target) {
1468
+ var theCache = target[data.id];
1469
+ if (!theCache) {
1470
+ theCache = {};
1471
+ try {
1472
+ if (_canAcceptData(target)) {
1473
+ objDefine(target, data.id, {
1474
+ e: false,
1475
+ v: theCache
1476
+ });
1477
+ }
1478
+ }
1479
+ catch (e) {
1480
+ }
1481
+ }
1482
+ return theCache;
1483
+ }
1484
+ function createUniqueNamespace(name, includeVersion) {
1485
+ if (includeVersion === void 0) { includeVersion = false; }
1486
+ return normalizeJsName(name + (_dataUid++) + (includeVersion ? "." + version : STR_EMPTY) + instanceName);
1487
+ }
1488
+ function createElmNodeData(name) {
1489
+ var data = {
1490
+ id: createUniqueNamespace("_aiData-" + (name || STR_EMPTY) + "." + version),
1491
+ accept: function (target) {
1492
+ return _canAcceptData(target);
1493
+ },
1494
+ get: function (target, name, defValue, addDefault) {
1495
+ var theCache = target[data.id];
1496
+ if (!theCache) {
1497
+ if (addDefault) {
1498
+ theCache = _getCache(data, target);
1499
+ theCache[normalizeJsName(name)] = defValue;
1500
+ }
1501
+ return defValue;
1502
+ }
1503
+ return theCache[normalizeJsName(name)];
1504
+ },
1505
+ kill: function (target, name) {
1506
+ if (target && target[name]) {
1507
+ try {
1508
+ delete target[name];
1509
+ }
1510
+ catch (e) {
1511
+ }
1512
+ }
1513
+ }
1514
+ };
1515
+ return data;
1516
+ }
1517
+
1518
+ function _isConfigDefaults(value) {
1519
+ return (value && isObject(value) && (value.isVal || value.fb || objHasOwn(value, "v") || objHasOwn(value, "mrg") || objHasOwn(value, "ref") || value.set));
1520
+ }
1521
+ function _getDefault(dynamicHandler, theConfig, cfgDefaults) {
1522
+ var defValue;
1523
+ var isDefaultValid = cfgDefaults.dfVal || isDefined;
1524
+ if (theConfig && cfgDefaults.fb) {
1525
+ var fallbacks = cfgDefaults.fb;
1526
+ if (!isArray(fallbacks)) {
1527
+ fallbacks = [fallbacks];
1528
+ }
1529
+ for (var lp = 0; lp < fallbacks[_DYN_LENGTH$1 ]; lp++) {
1530
+ var fallback = fallbacks[lp];
1531
+ var fbValue = theConfig[fallback];
1532
+ if (isDefaultValid(fbValue)) {
1533
+ defValue = fbValue;
1534
+ }
1535
+ else if (dynamicHandler) {
1536
+ fbValue = dynamicHandler.cfg[fallback];
1537
+ if (isDefaultValid(fbValue)) {
1538
+ defValue = fbValue;
1539
+ }
1540
+ dynamicHandler.set(dynamicHandler.cfg, asString(fallback), fbValue);
1541
+ }
1542
+ if (isDefaultValid(defValue)) {
1543
+ break;
1544
+ }
1545
+ }
1546
+ }
1547
+ if (!isDefaultValid(defValue) && isDefaultValid(cfgDefaults.v)) {
1548
+ defValue = cfgDefaults.v;
1549
+ }
1550
+ return defValue;
1551
+ }
1552
+ function _resolveDefaultValue(dynamicHandler, theConfig, cfgDefaults) {
1553
+ var theValue = cfgDefaults;
1554
+ if (cfgDefaults && _isConfigDefaults(cfgDefaults)) {
1555
+ theValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);
1556
+ }
1557
+ if (theValue) {
1558
+ if (_isConfigDefaults(theValue)) {
1559
+ theValue = _resolveDefaultValue(dynamicHandler, theConfig, theValue);
1560
+ }
1561
+ var newValue_1;
1562
+ if (isArray(theValue)) {
1563
+ newValue_1 = [];
1564
+ newValue_1[_DYN_LENGTH$1 ] = theValue[_DYN_LENGTH$1 ];
1565
+ }
1566
+ else if (isPlainObject(theValue)) {
1567
+ newValue_1 = {};
1568
+ }
1569
+ if (newValue_1) {
1570
+ objForEachKey(theValue, function (key, value) {
1571
+ if (value && _isConfigDefaults(value)) {
1572
+ value = _resolveDefaultValue(dynamicHandler, theConfig, value);
1573
+ }
1574
+ newValue_1[key] = value;
1575
+ });
1576
+ theValue = newValue_1;
1577
+ }
1578
+ }
1579
+ return theValue;
1580
+ }
1581
+ function _applyDefaultValue(dynamicHandler, theConfig, name, defaultValue) {
1582
+ var isValid;
1583
+ var setFn;
1584
+ var defValue;
1585
+ var cfgDefaults = defaultValue;
1586
+ var mergeDf;
1587
+ var reference;
1588
+ var readOnly;
1589
+ if (_isConfigDefaults(cfgDefaults)) {
1590
+ isValid = cfgDefaults.isVal;
1591
+ setFn = cfgDefaults.set;
1592
+ readOnly = cfgDefaults[_DYN_RD_ONLY ];
1593
+ mergeDf = cfgDefaults.mrg;
1594
+ reference = cfgDefaults.ref;
1595
+ if (!reference && isUndefined(reference)) {
1596
+ reference = !!mergeDf;
1597
+ }
1598
+ defValue = _getDefault(dynamicHandler, theConfig, cfgDefaults);
1599
+ }
1600
+ else {
1601
+ defValue = defaultValue;
1602
+ }
1603
+ var theValue;
1604
+ var usingDefault = true;
1605
+ var cfgValue = theConfig[name];
1606
+ if (cfgValue || !isNullOrUndefined(cfgValue)) {
1607
+ theValue = cfgValue;
1608
+ usingDefault = false;
1609
+ if (isValid && theValue !== defValue && !isValid(theValue)) {
1610
+ theValue = defValue;
1611
+ usingDefault = true;
1612
+ }
1613
+ if (setFn) {
1614
+ theValue = setFn(theValue, defValue, theConfig);
1615
+ usingDefault = theValue === defValue;
1616
+ }
1617
+ }
1618
+ if (!usingDefault) {
1619
+ if (isPlainObject(theValue) || isArray(defValue)) {
1620
+ if (mergeDf && defValue && (isPlainObject(defValue) || isArray(defValue))) {
1621
+ objForEachKey(defValue, function (dfName, dfValue) {
1622
+ _applyDefaultValue(dynamicHandler, theValue, dfName, dfValue);
1623
+ });
1624
+ }
1625
+ }
1626
+ }
1627
+ else if (defValue) {
1628
+ theValue = _resolveDefaultValue(dynamicHandler, theConfig, defValue);
1629
+ }
1630
+ else {
1631
+ theValue = defValue;
1632
+ }
1633
+ dynamicHandler.set(theConfig, name, theValue);
1634
+ if (reference) {
1635
+ dynamicHandler.ref(theConfig, name);
1636
+ }
1637
+ if (readOnly) {
1638
+ dynamicHandler[_DYN_RD_ONLY ](theConfig, name);
1639
+ }
1640
+ }
1641
+
1642
+ var CFG_HANDLER_LINK = symbolFor("[[ai_dynCfg_1]]");
1643
+ var BLOCK_DYNAMIC = symbolFor("[[ai_blkDynCfg_1]]");
1644
+ var FORCE_DYNAMIC = symbolFor("[[ai_frcDynCfg_1]]");
1645
+ function _cfgDeepCopy(source) {
1646
+ if (source) {
1647
+ var target_1;
1648
+ if (isArray(source)) {
1649
+ target_1 = [];
1650
+ target_1[_DYN_LENGTH$1 ] = source[_DYN_LENGTH$1 ];
1651
+ }
1652
+ else if (isPlainObject(source)) {
1653
+ target_1 = {};
1654
+ }
1655
+ if (target_1) {
1656
+ objForEachKey(source, function (key, value) {
1657
+ target_1[key] = _cfgDeepCopy(value);
1658
+ });
1659
+ return target_1;
1660
+ }
1661
+ }
1662
+ return source;
1663
+ }
1664
+ function getDynamicConfigHandler(value) {
1665
+ if (value) {
1666
+ var handler = value[CFG_HANDLER_LINK] || value;
1667
+ if (handler.cfg && (handler.cfg === value || handler.cfg[CFG_HANDLER_LINK] === handler)) {
1668
+ return handler;
1669
+ }
1670
+ }
1671
+ return null;
1672
+ }
1673
+ function _canMakeDynamic(value) {
1674
+ var result = false;
1675
+ if (value) {
1676
+ result = value[FORCE_DYNAMIC];
1677
+ if (!result && !value[BLOCK_DYNAMIC]) {
1678
+ result = isPlainObject(value) || isArray(value);
1679
+ }
1680
+ }
1681
+ return result;
1682
+ }
1683
+ function throwInvalidAccess(message) {
1684
+ throwTypeError("InvalidAccess:" + message);
1685
+ }
1686
+
1687
+ var arrayMethodsToPatch = [
1688
+ "push",
1689
+ "pop",
1690
+ "shift",
1691
+ "unshift",
1692
+ "splice"
1693
+ ];
1694
+ function _patchArray(state, target) {
1695
+ if (isArray(target)) {
1696
+ arrForEach(arrayMethodsToPatch, function (method) {
1697
+ var orgMethod = target[method];
1698
+ target[method] = function () {
1699
+ var args = [];
1700
+ for (var _i = 0; _i < arguments.length; _i++) {
1701
+ args[_i] = arguments[_i];
1702
+ }
1703
+ var result = orgMethod[_DYN_APPLY ](this, args);
1704
+ _makeDynamicObject(state, target);
1705
+ return result;
1706
+ };
1707
+ });
1708
+ }
1709
+ }
1710
+ function _getOwnPropGetter(target, name) {
1711
+ var propDesc = objGetOwnPropertyDescriptor(target, name);
1712
+ return propDesc && propDesc.get;
1713
+ }
1714
+ function _makeDynamicProperty(state, theConfig, name, value) {
1715
+ var detail = {
1716
+ n: name,
1717
+ h: [],
1718
+ trk: function (handler) {
1719
+ if (handler && handler.fn) {
1720
+ if (arrIndexOf(detail.h, handler) === -1) {
1721
+ detail.h[_DYN_PUSH ](handler);
1722
+ }
1723
+ state.trk(handler, detail);
1724
+ }
1725
+ },
1726
+ clr: function (handler) {
1727
+ var idx = arrIndexOf(detail.h, handler);
1728
+ if (idx !== -1) {
1729
+ detail.h[_DYN_SPLICE ](idx, 1);
1730
+ }
1731
+ }
1732
+ };
1733
+ var checkDynamic = true;
1734
+ var isObjectOrArray = false;
1735
+ function _getProperty() {
1736
+ if (checkDynamic) {
1737
+ isObjectOrArray = isObjectOrArray || _canMakeDynamic(value);
1738
+ if (value && !value[CFG_HANDLER_LINK] && isObjectOrArray) {
1739
+ value = _makeDynamicObject(state, value);
1740
+ }
1741
+ checkDynamic = false;
1742
+ }
1743
+ var activeHandler = state.act;
1744
+ if (activeHandler) {
1745
+ detail.trk(activeHandler);
1746
+ }
1747
+ return value;
1748
+ }
1749
+ _getProperty[state.prop] = {
1750
+ chng: function () {
1751
+ state.add(detail);
1752
+ }
1753
+ };
1754
+ function _setProperty(newValue) {
1755
+ if (value !== newValue) {
1756
+ if (!!_getProperty[state.ro] && !state.upd) {
1757
+ throwInvalidAccess("[" + name + "] is read-only:" + dumpObj(theConfig));
1758
+ }
1759
+ if (checkDynamic) {
1760
+ isObjectOrArray = isObjectOrArray || _canMakeDynamic(value);
1761
+ checkDynamic = false;
1762
+ }
1763
+ var isReferenced = isObjectOrArray && _getProperty[state.rf];
1764
+ if (isObjectOrArray) {
1765
+ if (isReferenced) {
1766
+ objForEachKey(value, function (key) {
1767
+ value[key] = newValue ? newValue[key] : UNDEFINED_VALUE;
1768
+ });
1769
+ objForEachKey(newValue, function (key, theValue) {
1770
+ _setDynamicProperty(state, value, key, theValue);
1771
+ });
1772
+ newValue = value;
1773
+ }
1774
+ else if (value && value[CFG_HANDLER_LINK]) {
1775
+ objForEachKey(value, function (key) {
1776
+ var getter = _getOwnPropGetter(value, key);
1777
+ if (getter) {
1778
+ var valueState = getter[state.prop];
1779
+ valueState && valueState.chng();
1780
+ }
1781
+ });
1782
+ }
1783
+ }
1784
+ if (newValue !== value) {
1785
+ var newIsObjectOrArray = newValue && _canMakeDynamic(newValue);
1786
+ if (!isReferenced && newIsObjectOrArray) {
1787
+ _makeDynamicObject(state, newValue);
1788
+ }
1789
+ value = newValue;
1790
+ isObjectOrArray = newIsObjectOrArray;
1791
+ }
1792
+ state.add(detail);
1793
+ }
1794
+ }
1795
+ objDefine(theConfig, detail.n, { g: _getProperty, s: _setProperty });
1796
+ }
1797
+ function _setDynamicProperty(state, target, name, value, inPlace, rdOnly) {
1798
+ if (target) {
1799
+ var getter = _getOwnPropGetter(target, name);
1800
+ var isDynamic = getter && !!getter[state.prop];
1801
+ if (!isDynamic) {
1802
+ _makeDynamicProperty(state, target, name, value);
1803
+ if (inPlace || rdOnly) {
1804
+ getter = _getOwnPropGetter(target, name);
1805
+ }
1806
+ }
1807
+ else {
1808
+ target[name] = value;
1809
+ }
1810
+ if (inPlace) {
1811
+ getter[state.rf] = inPlace;
1812
+ }
1813
+ if (rdOnly) {
1814
+ getter[state.ro] = rdOnly;
1815
+ }
1816
+ }
1817
+ return target;
1818
+ }
1819
+ function _makeDynamicObject(state, target) {
1820
+ objForEachKey(target, function (key, value) {
1821
+ _setDynamicProperty(state, target, key, value);
1822
+ });
1823
+ if (!target[CFG_HANDLER_LINK]) {
1824
+ objDefineProp(target, CFG_HANDLER_LINK, {
1825
+ get: function () {
1826
+ return state.hdlr;
1827
+ }
1828
+ });
1829
+ _patchArray(state, target);
1830
+ }
1831
+ return target;
1832
+ }
1833
+
1834
+ var symPrefix = "[[ai_";
1835
+ var symPostfix = "]]";
1836
+ function _createState(cfgHandler) {
1837
+ var _a;
1838
+ var dynamicPropertySymbol = newSymbol(symPrefix + "get" + cfgHandler.uid + symPostfix);
1839
+ var dynamicPropertyReadOnly = newSymbol(symPrefix + "ro" + cfgHandler.uid + symPostfix);
1840
+ var dynamicPropertyReferenced = newSymbol(symPrefix + "rf" + cfgHandler.uid + symPostfix);
1841
+ var dynamicPropertyDetail = newSymbol(symPrefix + "dtl" + cfgHandler.uid + symPostfix);
1842
+ var _waitingHandlers = null;
1843
+ var _watcherTimer = null;
1844
+ var theState;
1845
+ function _useHandler(activeHandler, callback) {
1846
+ var prevWatcher = theState.act;
1847
+ try {
1848
+ theState.act = activeHandler;
1849
+ if (activeHandler && activeHandler[dynamicPropertyDetail]) {
1850
+ arrForEach(activeHandler[dynamicPropertyDetail], function (detail) {
1851
+ detail.clr(activeHandler);
1852
+ });
1853
+ activeHandler[dynamicPropertyDetail] = [];
1854
+ }
1855
+ callback({
1856
+ cfg: cfgHandler.cfg,
1857
+ set: cfgHandler.set.bind(cfgHandler),
1858
+ setDf: cfgHandler[_DYN_SET_DF ].bind(cfgHandler),
1859
+ ref: cfgHandler.ref.bind(cfgHandler),
1860
+ rdOnly: cfgHandler[_DYN_RD_ONLY ].bind(cfgHandler)
1861
+ });
1862
+ }
1863
+ catch (e) {
1864
+ var logger = cfgHandler[_DYN_LOGGER ];
1865
+ if (logger) {
1866
+ logger[_DYN_THROW_INTERNAL ](1 , 107 , dumpObj(e));
1867
+ }
1868
+ throw e;
1869
+ }
1870
+ finally {
1871
+ theState.act = prevWatcher || null;
1872
+ }
1873
+ }
1874
+ function _notifyWatchers() {
1875
+ if (_waitingHandlers) {
1876
+ var notifyHandlers = _waitingHandlers;
1877
+ _waitingHandlers = null;
1878
+ _watcherTimer && _watcherTimer[_DYN_CANCEL ]();
1879
+ _watcherTimer = null;
1880
+ var watcherFailures_1 = [];
1881
+ arrForEach(notifyHandlers, function (handler) {
1882
+ if (handler) {
1883
+ if (handler[dynamicPropertyDetail]) {
1884
+ arrForEach(handler[dynamicPropertyDetail], function (detail) {
1885
+ detail.clr(handler);
1886
+ });
1887
+ handler[dynamicPropertyDetail] = null;
1888
+ }
1889
+ if (handler.fn) {
1890
+ try {
1891
+ _useHandler(handler, handler.fn);
1892
+ }
1893
+ catch (e) {
1894
+ watcherFailures_1[_DYN_PUSH ](e);
1895
+ }
1896
+ }
1897
+ }
1898
+ });
1899
+ if (_waitingHandlers) {
1900
+ try {
1901
+ _notifyWatchers();
1902
+ }
1903
+ catch (e) {
1904
+ watcherFailures_1[_DYN_PUSH ](e);
1905
+ }
1906
+ }
1907
+ if (watcherFailures_1[_DYN_LENGTH$1 ] > 0) {
1908
+ throwAggregationError("Watcher error(s): ", watcherFailures_1);
1909
+ }
1910
+ }
1911
+ }
1912
+ function _addWatcher(detail) {
1913
+ if (detail && detail.h[_DYN_LENGTH$1 ] > 0) {
1914
+ if (!_waitingHandlers) {
1915
+ _waitingHandlers = [];
1916
+ }
1917
+ if (!_watcherTimer) {
1918
+ _watcherTimer = scheduleTimeout(function () {
1919
+ _watcherTimer = null;
1920
+ _notifyWatchers();
1921
+ }, 0);
1922
+ }
1923
+ for (var idx = 0; idx < detail.h[_DYN_LENGTH$1 ]; idx++) {
1924
+ var handler = detail.h[idx];
1925
+ if (handler && arrIndexOf(_waitingHandlers, handler) === -1) {
1926
+ _waitingHandlers[_DYN_PUSH ](handler);
1927
+ }
1928
+ }
1929
+ }
1930
+ }
1931
+ function _trackHandler(handler, detail) {
1932
+ if (handler) {
1933
+ var details = handler[dynamicPropertyDetail] = handler[dynamicPropertyDetail] || [];
1934
+ if (arrIndexOf(details, detail) === -1) {
1935
+ details[_DYN_PUSH ](detail);
1936
+ }
1937
+ }
1938
+ }
1939
+ theState = (_a = {
1940
+ prop: dynamicPropertySymbol,
1941
+ ro: dynamicPropertyReadOnly,
1942
+ rf: dynamicPropertyReferenced,
1943
+ hdlr: cfgHandler,
1944
+ add: _addWatcher
1945
+ },
1946
+ _a[_DYN_NOTIFY ] = _notifyWatchers,
1947
+ _a.use = _useHandler,
1948
+ _a.trk = _trackHandler,
1949
+ _a);
1950
+ return theState;
1951
+ }
1952
+
1953
+ function _createAndUseHandler(state, configHandler) {
1954
+ var handler = {
1955
+ fn: configHandler,
1956
+ rm: function () {
1957
+ handler.fn = null;
1958
+ state = null;
1959
+ configHandler = null;
1960
+ }
1961
+ };
1962
+ state.use(handler, configHandler);
1963
+ return handler;
1964
+ }
1965
+ function _createDynamicHandler(logger, target, inPlace) {
1966
+ var _a;
1967
+ var dynamicHandler = getDynamicConfigHandler(target);
1968
+ if (dynamicHandler) {
1969
+ return dynamicHandler;
1970
+ }
1971
+ var uid = createUniqueNamespace("dyncfg", true);
1972
+ var newTarget = (target && inPlace !== false) ? target : _cfgDeepCopy(target);
1973
+ var theState;
1974
+ function _notifyWatchers() {
1975
+ theState[_DYN_NOTIFY ]();
1976
+ }
1977
+ function _setValue(target, name, value) {
1978
+ return _setDynamicProperty(theState, target, name, value)[name];
1979
+ }
1980
+ function _watch(configHandler) {
1981
+ return _createAndUseHandler(theState, configHandler);
1982
+ }
1983
+ function _block(configHandler, allowUpdate) {
1984
+ theState.use(null, function (details) {
1985
+ var prevUpd = theState.upd;
1986
+ try {
1987
+ if (!isUndefined(allowUpdate)) {
1988
+ theState.upd = allowUpdate;
1989
+ }
1990
+ configHandler(details);
1991
+ }
1992
+ finally {
1993
+ theState.upd = prevUpd;
1994
+ }
1995
+ });
1996
+ }
1997
+ function _ref(target, name) {
1998
+ return _setDynamicProperty(theState, target, name, target[name], true)[name];
1999
+ }
2000
+ function _rdOnly(target, name) {
2001
+ return _setDynamicProperty(theState, target, name, target[name], false, true)[name];
2002
+ }
2003
+ function _applyDefaults(theConfig, defaultValues) {
2004
+ if (defaultValues) {
2005
+ objForEachKey(defaultValues, function (name, value) {
2006
+ _applyDefaultValue(cfgHandler, theConfig, name, value);
2007
+ });
2008
+ }
2009
+ return theConfig;
2010
+ }
2011
+ var cfgHandler = (_a = {
2012
+ uid: null,
2013
+ cfg: newTarget
2014
+ },
2015
+ _a[_DYN_LOGGER ] = logger,
2016
+ _a[_DYN_NOTIFY ] = _notifyWatchers,
2017
+ _a.set = _setValue,
2018
+ _a[_DYN_SET_DF ] = _applyDefaults,
2019
+ _a[_DYN_WATCH ] = _watch,
2020
+ _a.ref = _ref,
2021
+ _a[_DYN_RD_ONLY ] = _rdOnly,
2022
+ _a._block = _block,
2023
+ _a);
2024
+ objDefine(cfgHandler, "uid", {
2025
+ c: false,
2026
+ e: false,
2027
+ w: false,
2028
+ v: uid
2029
+ });
2030
+ theState = _createState(cfgHandler);
2031
+ _makeDynamicObject(theState, newTarget);
2032
+ return cfgHandler;
2033
+ }
2034
+ function _logInvalidAccess(logger, message) {
2035
+ if (logger) {
2036
+ logger[STR_WARN_TO_CONSOLE ](message);
2037
+ logger[_DYN_THROW_INTERNAL ](2 , 108 , message);
2038
+ }
2039
+ else {
2040
+ throwInvalidAccess(message);
2041
+ }
2042
+ }
2043
+ function createDynamicConfig(config, defaultConfig, logger, inPlace) {
2044
+ var dynamicHandler = _createDynamicHandler(logger, config || {}, inPlace);
2045
+ if (defaultConfig) {
2046
+ dynamicHandler[_DYN_SET_DF ](dynamicHandler.cfg, defaultConfig);
2047
+ }
2048
+ return dynamicHandler;
2049
+ }
2050
+ function onConfigChange(config, configHandler, logger) {
2051
+ var handler = config[CFG_HANDLER_LINK] || config;
2052
+ if (handler.cfg && (handler.cfg === config || handler.cfg[CFG_HANDLER_LINK] === handler)) {
2053
+ return handler[_DYN_WATCH ](configHandler);
2054
+ }
2055
+ _logInvalidAccess(logger, STR_NOT_DYNAMIC_ERROR + dumpObj(config));
2056
+ return createDynamicConfig(config, null, logger)[_DYN_WATCH ](configHandler);
2057
+ }
2058
+
2059
+ function _stringToBoolOrDefault(theValue, defaultValue, theConfig) {
2060
+ if (!theValue && isNullOrUndefined(theValue)) {
2061
+ return defaultValue;
2062
+ }
2063
+ if (isBoolean(theValue)) {
2064
+ return theValue;
2065
+ }
2066
+ return asString(theValue)[_DYN_TO_LOWER_CASE ]() === "true";
2067
+ }
2068
+ function cfgDfBoolean(defaultValue, fallBackName) {
2069
+ return {
2070
+ fb: fallBackName,
2071
+ set: _stringToBoolOrDefault,
2072
+ v: !!defaultValue
2073
+ };
2074
+ }
2075
+
2076
+ var _aiNamespace = null;
2077
+ function _getExtensionNamespace() {
2078
+ var target = getInst("Microsoft");
2079
+ if (target) {
2080
+ _aiNamespace = target["ApplicationInsights"];
2081
+ }
2082
+ return _aiNamespace;
2083
+ }
2084
+ function getDebugExt(config) {
2085
+ var ns = _aiNamespace;
2086
+ if (!ns && config.disableDbgExt !== true) {
2087
+ ns = _aiNamespace || _getExtensionNamespace();
2088
+ }
2089
+ return ns ? ns["ChromeDbgExt"] : null;
2090
+ }
2091
+
2092
+ var AiNonUserActionablePrefix = "AI (Internal): ";
2093
+ var AiUserActionablePrefix = "AI: ";
2094
+ var AIInternalMessagePrefix = "AITR_";
2095
+ var defaultValues$1 = {
2096
+ loggingLevelConsole: 0,
2097
+ loggingLevelTelemetry: 1,
2098
+ maxMessageLimit: 25,
2099
+ enableDebug: false
2100
+ };
2101
+ function _sanitizeDiagnosticText(text) {
2102
+ if (text) {
2103
+ return "\"" + text[_DYN_REPLACE ](/\"/g, STR_EMPTY) + "\"";
2104
+ }
2105
+ return STR_EMPTY;
2106
+ }
2107
+ function _logToConsole(func, message) {
2108
+ var theConsole = getConsole();
2109
+ if (!!theConsole) {
2110
+ var logFunc = "log";
2111
+ if (theConsole[func]) {
2112
+ logFunc = func;
2113
+ }
2114
+ if (isFunction(theConsole[logFunc])) {
2115
+ theConsole[logFunc](message);
2116
+ }
2117
+ }
2118
+ }
2119
+ var _InternalLogMessage = /** @class */ (function () {
2120
+ function _InternalLogMessage(msgId, msg, isUserAct, properties) {
2121
+ if (isUserAct === void 0) { isUserAct = false; }
2122
+ var _self = this;
2123
+ _self[_DYN_MESSAGE_ID ] = msgId;
2124
+ _self[_DYN_MESSAGE ] =
2125
+ (isUserAct ? AiUserActionablePrefix : AiNonUserActionablePrefix) +
2126
+ msgId;
2127
+ var strProps = STR_EMPTY;
2128
+ if (hasJSON()) {
2129
+ strProps = getJSON().stringify(properties);
2130
+ }
2131
+ var diagnosticText = (msg ? " message:" + _sanitizeDiagnosticText(msg) : STR_EMPTY) +
2132
+ (properties ? " props:" + _sanitizeDiagnosticText(strProps) : STR_EMPTY);
2133
+ _self[_DYN_MESSAGE ] += diagnosticText;
2134
+ }
2135
+ _InternalLogMessage.dataType = "MessageData";
2136
+ return _InternalLogMessage;
2137
+ }());
2138
+ function safeGetLogger(core, config) {
2139
+ return (core || {})[_DYN_LOGGER ] || new DiagnosticLogger(config);
2140
+ }
2141
+ var DiagnosticLogger = /** @class */ (function () {
2142
+ function DiagnosticLogger(config) {
2143
+ this.identifier = "DiagnosticLogger";
2144
+ this.queue = [];
2145
+ var _messageCount = 0;
2146
+ var _messageLogged = {};
2147
+ var _loggingLevelConsole;
2148
+ var _loggingLevelTelemetry;
2149
+ var _maxInternalMessageLimit;
2150
+ var _enableDebug;
2151
+ var _unloadHandler;
2152
+ dynamicProto(DiagnosticLogger, this, function (_self) {
2153
+ _unloadHandler = _setDefaultsFromConfig(config || {});
2154
+ _self.consoleLoggingLevel = function () { return _loggingLevelConsole; };
2155
+ _self[_DYN_THROW_INTERNAL ] = function (severity, msgId, msg, properties, isUserAct) {
2156
+ if (isUserAct === void 0) { isUserAct = false; }
2157
+ var message = new _InternalLogMessage(msgId, msg, isUserAct, properties);
2158
+ if (_enableDebug) {
2159
+ throw dumpObj(message);
2160
+ }
2161
+ else {
2162
+ var logFunc = severity === 1 ? STR_ERROR_TO_CONSOLE : STR_WARN_TO_CONSOLE;
2163
+ if (!isUndefined(message[_DYN_MESSAGE ])) {
2164
+ if (isUserAct) {
2165
+ var messageKey = +message[_DYN_MESSAGE_ID ];
2166
+ if (!_messageLogged[messageKey] && _loggingLevelConsole >= severity) {
2167
+ _self[logFunc](message[_DYN_MESSAGE ]);
2168
+ _messageLogged[messageKey] = true;
2169
+ }
2170
+ }
2171
+ else {
2172
+ if (_loggingLevelConsole >= severity) {
2173
+ _self[logFunc](message[_DYN_MESSAGE ]);
2174
+ }
2175
+ }
2176
+ _logInternalMessage(severity, message);
2177
+ }
2178
+ else {
2179
+ _debugExtMsg("throw" + (severity === 1 ? "Critical" : "Warning"), message);
2180
+ }
2181
+ }
2182
+ };
2183
+ _self[STR_WARN_TO_CONSOLE ] = function (message) {
2184
+ _logToConsole("warn", message);
2185
+ _debugExtMsg("warning", message);
2186
+ };
2187
+ _self[STR_ERROR_TO_CONSOLE ] = function (message) {
2188
+ _logToConsole("error", message);
2189
+ _debugExtMsg("error", message);
2190
+ };
2191
+ _self.resetInternalMessageCount = function () {
2192
+ _messageCount = 0;
2193
+ _messageLogged = {};
2194
+ };
2195
+ _self[_DYN_LOG_INTERNAL_MESSAGE ] = _logInternalMessage;
2196
+ _self[_DYN_UNLOAD ] = function (isAsync) {
2197
+ _unloadHandler && _unloadHandler.rm();
2198
+ _unloadHandler = null;
2199
+ };
2200
+ function _logInternalMessage(severity, message) {
2201
+ if (_areInternalMessagesThrottled()) {
2202
+ return;
2203
+ }
2204
+ var logMessage = true;
2205
+ var messageKey = AIInternalMessagePrefix + message[_DYN_MESSAGE_ID ];
2206
+ if (_messageLogged[messageKey]) {
2207
+ logMessage = false;
2208
+ }
2209
+ else {
2210
+ _messageLogged[messageKey] = true;
2211
+ }
2212
+ if (logMessage) {
2213
+ if (severity <= _loggingLevelTelemetry) {
2214
+ _self.queue[_DYN_PUSH ](message);
2215
+ _messageCount++;
2216
+ _debugExtMsg((severity === 1 ? "error" : "warn"), message);
2217
+ }
2218
+ if (_messageCount === _maxInternalMessageLimit) {
2219
+ var throttleLimitMessage = "Internal events throttle limit per PageView reached for this app.";
2220
+ var throttleMessage = new _InternalLogMessage(23 , throttleLimitMessage, false);
2221
+ _self.queue[_DYN_PUSH ](throttleMessage);
2222
+ if (severity === 1 ) {
2223
+ _self[STR_ERROR_TO_CONSOLE ](throttleLimitMessage);
2224
+ }
2225
+ else {
2226
+ _self[STR_WARN_TO_CONSOLE ](throttleLimitMessage);
2227
+ }
2228
+ }
2229
+ }
2230
+ }
2231
+ function _setDefaultsFromConfig(config) {
2232
+ return onConfigChange(createDynamicConfig(config, defaultValues$1, _self).cfg, function (details) {
2233
+ var config = details.cfg;
2234
+ _loggingLevelConsole = config[_DYN_LOGGING_LEVEL_CONSOL4 ];
2235
+ _loggingLevelTelemetry = config.loggingLevelTelemetry;
2236
+ _maxInternalMessageLimit = config.maxMessageLimit;
2237
+ _enableDebug = config.enableDebug;
2238
+ });
2239
+ }
2240
+ function _areInternalMessagesThrottled() {
2241
+ return _messageCount >= _maxInternalMessageLimit;
2242
+ }
2243
+ function _debugExtMsg(name, data) {
2244
+ var dbgExt = getDebugExt(config || {});
2245
+ if (dbgExt && dbgExt[_DYN_DIAG_LOG ]) {
2246
+ dbgExt[_DYN_DIAG_LOG ](name, data);
2247
+ }
2248
+ }
2249
+ });
2250
+ }
2251
+ DiagnosticLogger.__ieDyn=1;
2252
+ return DiagnosticLogger;
2253
+ }());
2254
+ function _getLogger(logger) {
2255
+ return (logger || new DiagnosticLogger());
2256
+ }
2257
+ function _throwInternal(logger, severity, msgId, msg, properties, isUserAct) {
2258
+ if (isUserAct === void 0) { isUserAct = false; }
2259
+ _getLogger(logger)[_DYN_THROW_INTERNAL ](severity, msgId, msg, properties, isUserAct);
2260
+ }
2261
+
2262
+ var strExecutionContextKey = "ctx";
2263
+ var strParentContextKey = "ParentContextKey";
2264
+ var strChildrenContextKey = "ChildrenContextKey";
2265
+ var PerfEvent = /** @class */ (function () {
2266
+ function PerfEvent(name, payloadDetails, isAsync) {
2267
+ var _self = this;
2268
+ _self.start = utcNow();
2269
+ _self[_DYN_NAME ] = name;
2270
+ _self[_DYN_IS_ASYNC ] = isAsync;
2271
+ _self[_DYN_IS_CHILD_EVT ] = function () { return false; };
2272
+ if (isFunction(payloadDetails)) {
2273
+ var theDetails_1;
2274
+ objDefine(_self, "payload", {
2275
+ g: function () {
2276
+ if (!theDetails_1 && isFunction(payloadDetails)) {
2277
+ theDetails_1 = payloadDetails();
2278
+ payloadDetails = null;
2279
+ }
2280
+ return theDetails_1;
2281
+ }
2282
+ });
2283
+ }
2284
+ _self[_DYN_GET_CTX ] = function (key) {
2285
+ if (key) {
2286
+ if (key === PerfEvent[strParentContextKey] || key === PerfEvent[strChildrenContextKey]) {
2287
+ return _self[key];
2288
+ }
2289
+ return (_self[strExecutionContextKey] || {})[key];
2290
+ }
2291
+ return null;
2292
+ };
2293
+ _self[_DYN_SET_CTX ] = function (key, value) {
2294
+ if (key) {
2295
+ if (key === PerfEvent[strParentContextKey]) {
2296
+ if (!_self[key]) {
2297
+ _self[_DYN_IS_CHILD_EVT ] = function () { return true; };
2298
+ }
2299
+ _self[key] = value;
2300
+ }
2301
+ else if (key === PerfEvent[strChildrenContextKey]) {
2302
+ _self[key] = value;
2303
+ }
2304
+ else {
2305
+ var ctx = _self[strExecutionContextKey] = _self[strExecutionContextKey] || {};
2306
+ ctx[key] = value;
2307
+ }
2308
+ }
2309
+ };
2310
+ _self[_DYN_COMPLETE ] = function () {
2311
+ var childTime = 0;
2312
+ var childEvts = _self[_DYN_GET_CTX ](PerfEvent[strChildrenContextKey]);
2313
+ if (isArray(childEvts)) {
2314
+ for (var lp = 0; lp < childEvts[_DYN_LENGTH$1 ]; lp++) {
2315
+ var childEvt = childEvts[lp];
2316
+ if (childEvt) {
2317
+ childTime += childEvt[_DYN_TIME ];
2318
+ }
2319
+ }
2320
+ }
2321
+ _self[_DYN_TIME ] = utcNow() - _self.start;
2322
+ _self.exTime = _self[_DYN_TIME ] - childTime;
2323
+ _self[_DYN_COMPLETE ] = function () { };
2324
+ };
2325
+ }
2326
+ PerfEvent.ParentContextKey = "parent";
2327
+ PerfEvent.ChildrenContextKey = "childEvts";
2328
+ return PerfEvent;
2329
+ }());
2330
+ var doPerfActiveKey = "CoreUtils.doPerf";
2331
+ function doPerf(mgrSource, getSource, func, details, isAsync) {
2332
+ if (mgrSource) {
2333
+ var perfMgr = mgrSource;
2334
+ if (perfMgr[STR_GET_PERF_MGR]) {
2335
+ perfMgr = perfMgr[STR_GET_PERF_MGR]();
2336
+ }
2337
+ if (perfMgr) {
2338
+ var perfEvt = void 0;
2339
+ var currentActive = perfMgr[_DYN_GET_CTX ](doPerfActiveKey);
2340
+ try {
2341
+ perfEvt = perfMgr.create(getSource(), details, isAsync);
2342
+ if (perfEvt) {
2343
+ if (currentActive && perfEvt[_DYN_SET_CTX ]) {
2344
+ perfEvt[_DYN_SET_CTX ](PerfEvent[strParentContextKey], currentActive);
2345
+ if (currentActive[_DYN_GET_CTX ] && currentActive[_DYN_SET_CTX ]) {
2346
+ var children = currentActive[_DYN_GET_CTX ](PerfEvent[strChildrenContextKey]);
2347
+ if (!children) {
2348
+ children = [];
2349
+ currentActive[_DYN_SET_CTX ](PerfEvent[strChildrenContextKey], children);
2350
+ }
2351
+ children[_DYN_PUSH ](perfEvt);
2352
+ }
2353
+ }
2354
+ perfMgr[_DYN_SET_CTX ](doPerfActiveKey, perfEvt);
2355
+ return func(perfEvt);
2356
+ }
2357
+ }
2358
+ catch (ex) {
2359
+ if (perfEvt && perfEvt[_DYN_SET_CTX ]) {
2360
+ perfEvt[_DYN_SET_CTX ]("exception", ex);
2361
+ }
2362
+ }
2363
+ finally {
2364
+ if (perfEvt) {
2365
+ perfMgr.fire(perfEvt);
2366
+ }
2367
+ perfMgr[_DYN_SET_CTX ](doPerfActiveKey, currentActive);
2368
+ }
2369
+ }
2370
+ }
2371
+ return func();
2372
+ }
2373
+
2374
+ var pluginStateData = createElmNodeData("plugin");
2375
+ function _getPluginState(plugin) {
2376
+ return pluginStateData.get(plugin, "state", {}, true);
2377
+ }
2378
+ function initializePlugins(processContext, extensions) {
2379
+ var initPlugins = [];
2380
+ var lastPlugin = null;
2381
+ var proxy = processContext[_DYN_GET_NEXT ]();
2382
+ var pluginState;
2383
+ while (proxy) {
2384
+ var thePlugin = proxy[_DYN_GET_PLUGIN ]();
2385
+ if (thePlugin) {
2386
+ if (lastPlugin && lastPlugin[_DYN_SET_NEXT_PLUGIN ] && thePlugin[STR_PROCESS_TELEMETRY ]) {
2387
+ lastPlugin[_DYN_SET_NEXT_PLUGIN ](thePlugin);
2388
+ }
2389
+ pluginState = _getPluginState(thePlugin);
2390
+ var isInitialized = !!pluginState[_DYN_IS_INITIALIZED ];
2391
+ if (thePlugin[_DYN_IS_INITIALIZED ]) {
2392
+ isInitialized = thePlugin[_DYN_IS_INITIALIZED ]();
2393
+ }
2394
+ if (!isInitialized) {
2395
+ initPlugins[_DYN_PUSH ](thePlugin);
2396
+ }
2397
+ lastPlugin = thePlugin;
2398
+ proxy = proxy[_DYN_GET_NEXT ]();
2399
+ }
2400
+ }
2401
+ arrForEach(initPlugins, function (thePlugin) {
2402
+ var core = processContext[STR_CORE ]();
2403
+ thePlugin[_DYN_INITIALIZE ](processContext.getCfg(), core, extensions, processContext[_DYN_GET_NEXT ]());
2404
+ pluginState = _getPluginState(thePlugin);
2405
+ if (!thePlugin[STR_CORE] && !pluginState[STR_CORE]) {
2406
+ pluginState[STR_CORE] = core;
2407
+ }
2408
+ pluginState[_DYN_IS_INITIALIZED ] = true;
2409
+ delete pluginState[_DYN_TEARDOWN$1 ];
2410
+ });
2411
+ }
2412
+
2413
+ var strTelemetryPluginChain = "TelemetryPluginChain";
2414
+ var strHasRunFlags = "_hasRun";
2415
+ var strGetTelCtx = "_getTelCtx";
2416
+ var _chainId = 0;
2417
+ function _getNextProxyStart(proxy, core, startAt) {
2418
+ while (proxy) {
2419
+ if (proxy[_DYN_GET_PLUGIN ]() === startAt) {
2420
+ return proxy;
2421
+ }
2422
+ proxy = proxy[_DYN_GET_NEXT ]();
2423
+ }
2424
+ return createTelemetryProxyChain([startAt], core.config || {}, core);
2425
+ }
2426
+ function _createInternalContext(telemetryChain, dynamicHandler, core, startAt) {
2427
+ var _nextProxy = null;
2428
+ var _onComplete = [];
2429
+ if (!dynamicHandler) {
2430
+ dynamicHandler = createDynamicConfig({}, null, core[_DYN_LOGGER ]);
2431
+ }
2432
+ if (startAt !== null) {
2433
+ _nextProxy = startAt ? _getNextProxyStart(telemetryChain, core, startAt) : telemetryChain;
2434
+ }
2435
+ var context = {
2436
+ _next: _moveNext,
2437
+ ctx: {
2438
+ core: function () {
2439
+ return core;
2440
+ },
2441
+ diagLog: function () {
2442
+ return safeGetLogger(core, dynamicHandler.cfg);
2443
+ },
2444
+ getCfg: function () {
2445
+ return dynamicHandler.cfg;
2446
+ },
2447
+ getExtCfg: _resolveExtCfg,
2448
+ getConfig: _getConfig,
2449
+ hasNext: function () {
2450
+ return !!_nextProxy;
2451
+ },
2452
+ getNext: function () {
2453
+ return _nextProxy;
2454
+ },
2455
+ setNext: function (nextPlugin) {
2456
+ _nextProxy = nextPlugin;
2457
+ },
2458
+ iterate: _iterateChain,
2459
+ onComplete: _addOnComplete
2460
+ }
2461
+ };
2462
+ function _addOnComplete(onComplete, that) {
2463
+ var args = [];
2464
+ for (var _i = 2; _i < arguments.length; _i++) {
2465
+ args[_i - 2] = arguments[_i];
2466
+ }
2467
+ if (onComplete) {
2468
+ _onComplete[_DYN_PUSH ]({
2469
+ func: onComplete,
2470
+ self: !isUndefined(that) ? that : context.ctx,
2471
+ args: args
2472
+ });
2473
+ }
2474
+ }
2475
+ function _moveNext() {
2476
+ var nextProxy = _nextProxy;
2477
+ _nextProxy = nextProxy ? nextProxy[_DYN_GET_NEXT ]() : null;
2478
+ if (!nextProxy) {
2479
+ var onComplete = _onComplete;
2480
+ if (onComplete && onComplete[_DYN_LENGTH$1 ] > 0) {
2481
+ arrForEach(onComplete, function (completeDetails) {
2482
+ try {
2483
+ completeDetails.func.call(completeDetails.self, completeDetails.args);
2484
+ }
2485
+ catch (e) {
2486
+ _throwInternal(core[_DYN_LOGGER ], 2 , 73 , "Unexpected Exception during onComplete - " + dumpObj(e));
2487
+ }
2488
+ });
2489
+ _onComplete = [];
2490
+ }
2491
+ }
2492
+ return nextProxy;
2493
+ }
2494
+ function _getExtCfg(identifier, createIfMissing) {
2495
+ var idCfg = null;
2496
+ var cfg = dynamicHandler.cfg;
2497
+ if (cfg && identifier) {
2498
+ var extCfg = cfg[STR_EXTENSION_CONFIG ];
2499
+ if (!extCfg && createIfMissing) {
2500
+ extCfg = {};
2501
+ }
2502
+ cfg[STR_EXTENSION_CONFIG] = extCfg;
2503
+ extCfg = dynamicHandler.ref(cfg, STR_EXTENSION_CONFIG);
2504
+ if (extCfg) {
2505
+ idCfg = extCfg[identifier];
2506
+ if (!idCfg && createIfMissing) {
2507
+ idCfg = {};
2508
+ }
2509
+ extCfg[identifier] = idCfg;
2510
+ idCfg = dynamicHandler.ref(extCfg, identifier);
2511
+ }
2512
+ }
2513
+ return idCfg;
2514
+ }
2515
+ function _resolveExtCfg(identifier, defaultValues) {
2516
+ var newConfig = _getExtCfg(identifier, true);
2517
+ if (defaultValues) {
2518
+ objForEachKey(defaultValues, function (field, defaultValue) {
2519
+ if (isNullOrUndefined(newConfig[field])) {
2520
+ var cfgValue = dynamicHandler.cfg[field];
2521
+ if (cfgValue || !isNullOrUndefined(cfgValue)) {
2522
+ newConfig[field] = cfgValue;
2523
+ }
2524
+ }
2525
+ _applyDefaultValue(dynamicHandler, newConfig, field, defaultValue);
2526
+ });
2527
+ }
2528
+ return dynamicHandler[_DYN_SET_DF ](newConfig, defaultValues);
2529
+ }
2530
+ function _getConfig(identifier, field, defaultValue) {
2531
+ if (defaultValue === void 0) { defaultValue = false; }
2532
+ var theValue;
2533
+ var extConfig = _getExtCfg(identifier, false);
2534
+ var rootConfig = dynamicHandler.cfg;
2535
+ if (extConfig && (extConfig[field] || !isNullOrUndefined(extConfig[field]))) {
2536
+ theValue = extConfig[field];
2537
+ }
2538
+ else if (rootConfig[field] || !isNullOrUndefined(rootConfig[field])) {
2539
+ theValue = rootConfig[field];
2540
+ }
2541
+ return (theValue || !isNullOrUndefined(theValue)) ? theValue : defaultValue;
2542
+ }
2543
+ function _iterateChain(cb) {
2544
+ var nextPlugin;
2545
+ while (!!(nextPlugin = context._next())) {
2546
+ var plugin = nextPlugin[_DYN_GET_PLUGIN ]();
2547
+ if (plugin) {
2548
+ cb(plugin);
2549
+ }
2550
+ }
2551
+ }
2552
+ return context;
2553
+ }
2554
+ function createProcessTelemetryContext(telemetryChain, cfg, core, startAt) {
2555
+ var config = createDynamicConfig(cfg);
2556
+ var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
2557
+ var context = internalContext.ctx;
2558
+ function _processNext(env) {
2559
+ var nextPlugin = internalContext._next();
2560
+ if (nextPlugin) {
2561
+ nextPlugin[STR_PROCESS_TELEMETRY ](env, context);
2562
+ }
2563
+ return !nextPlugin;
2564
+ }
2565
+ function _createNew(plugins, startAt) {
2566
+ if (plugins === void 0) { plugins = null; }
2567
+ if (isArray(plugins)) {
2568
+ plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
2569
+ }
2570
+ return createProcessTelemetryContext(plugins || context[_DYN_GET_NEXT ](), config.cfg, core, startAt);
2571
+ }
2572
+ context[_DYN_PROCESS_NEXT$1 ] = _processNext;
2573
+ context[_DYN_CREATE_NEW ] = _createNew;
2574
+ return context;
2575
+ }
2576
+ function createProcessTelemetryUnloadContext(telemetryChain, core, startAt) {
2577
+ var config = createDynamicConfig(core.config);
2578
+ var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
2579
+ var context = internalContext.ctx;
2580
+ function _processNext(unloadState) {
2581
+ var nextPlugin = internalContext._next();
2582
+ nextPlugin && nextPlugin[_DYN_UNLOAD ](context, unloadState);
2583
+ return !nextPlugin;
2584
+ }
2585
+ function _createNew(plugins, startAt) {
2586
+ if (plugins === void 0) { plugins = null; }
2587
+ if (isArray(plugins)) {
2588
+ plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
2589
+ }
2590
+ return createProcessTelemetryUnloadContext(plugins || context[_DYN_GET_NEXT ](), core, startAt);
2591
+ }
2592
+ context[_DYN_PROCESS_NEXT$1 ] = _processNext;
2593
+ context[_DYN_CREATE_NEW ] = _createNew;
2594
+ return context;
2595
+ }
2596
+ function createProcessTelemetryUpdateContext(telemetryChain, core, startAt) {
2597
+ var config = createDynamicConfig(core.config);
2598
+ var internalContext = _createInternalContext(telemetryChain, config, core, startAt);
2599
+ var context = internalContext.ctx;
2600
+ function _processNext(updateState) {
2601
+ return context.iterate(function (plugin) {
2602
+ if (isFunction(plugin[_DYN_UPDATE ])) {
2603
+ plugin[_DYN_UPDATE ](context, updateState);
2604
+ }
2605
+ });
2606
+ }
2607
+ function _createNew(plugins, startAt) {
2608
+ if (plugins === void 0) { plugins = null; }
2609
+ if (isArray(plugins)) {
2610
+ plugins = createTelemetryProxyChain(plugins, config.cfg, core, startAt);
2611
+ }
2612
+ return createProcessTelemetryUpdateContext(plugins || context[_DYN_GET_NEXT ](), core, startAt);
2613
+ }
2614
+ context[_DYN_PROCESS_NEXT$1 ] = _processNext;
2615
+ context[_DYN_CREATE_NEW ] = _createNew;
2616
+ return context;
2617
+ }
2618
+ function createTelemetryProxyChain(plugins, config, core, startAt) {
2619
+ var firstProxy = null;
2620
+ var add = startAt ? false : true;
2621
+ if (isArray(plugins) && plugins[_DYN_LENGTH$1 ] > 0) {
2622
+ var lastProxy_1 = null;
2623
+ arrForEach(plugins, function (thePlugin) {
2624
+ if (!add && startAt === thePlugin) {
2625
+ add = true;
2626
+ }
2627
+ if (add && thePlugin && isFunction(thePlugin[STR_PROCESS_TELEMETRY ])) {
2628
+ var newProxy = createTelemetryPluginProxy(thePlugin, config, core);
2629
+ if (!firstProxy) {
2630
+ firstProxy = newProxy;
2631
+ }
2632
+ if (lastProxy_1) {
2633
+ lastProxy_1._setNext(newProxy);
2634
+ }
2635
+ lastProxy_1 = newProxy;
2636
+ }
2637
+ });
2638
+ }
2639
+ if (startAt && !firstProxy) {
2640
+ return createTelemetryProxyChain([startAt], config, core);
2641
+ }
2642
+ return firstProxy;
2643
+ }
2644
+ function createTelemetryPluginProxy(plugin, config, core) {
2645
+ var nextProxy = null;
2646
+ var hasProcessTelemetry = isFunction(plugin[STR_PROCESS_TELEMETRY ]);
2647
+ var hasSetNext = isFunction(plugin[_DYN_SET_NEXT_PLUGIN ]);
2648
+ var chainId;
2649
+ if (plugin) {
2650
+ chainId = plugin[_DYN_IDENTIFIER$1 ] + "-" + plugin[STR_PRIORITY ] + "-" + _chainId++;
2651
+ }
2652
+ else {
2653
+ chainId = "Unknown-0-" + _chainId++;
2654
+ }
2655
+ var proxyChain = {
2656
+ getPlugin: function () {
2657
+ return plugin;
2658
+ },
2659
+ getNext: function () {
2660
+ return nextProxy;
2661
+ },
2662
+ processTelemetry: _processTelemetry,
2663
+ unload: _unloadPlugin,
2664
+ update: _updatePlugin,
2665
+ _id: chainId,
2666
+ _setNext: function (nextPlugin) {
2667
+ nextProxy = nextPlugin;
2668
+ }
2669
+ };
2670
+ function _getTelCtx() {
2671
+ var itemCtx;
2672
+ if (plugin && isFunction(plugin[strGetTelCtx])) {
2673
+ itemCtx = plugin[strGetTelCtx]();
2674
+ }
2675
+ if (!itemCtx) {
2676
+ itemCtx = createProcessTelemetryContext(proxyChain, config, core);
2677
+ }
2678
+ return itemCtx;
2679
+ }
2680
+ function _processChain(itemCtx, processPluginFn, name, details, isAsync) {
2681
+ var hasRun = false;
2682
+ var identifier = plugin ? plugin[_DYN_IDENTIFIER$1 ] : strTelemetryPluginChain;
2683
+ var hasRunContext = itemCtx[strHasRunFlags];
2684
+ if (!hasRunContext) {
2685
+ hasRunContext = itemCtx[strHasRunFlags] = {};
2686
+ }
2687
+ itemCtx.setNext(nextProxy);
2688
+ if (plugin) {
2689
+ doPerf(itemCtx[STR_CORE ](), function () { return identifier + ":" + name; }, function () {
2690
+ hasRunContext[chainId] = true;
2691
+ try {
2692
+ var nextId = nextProxy ? nextProxy._id : STR_EMPTY;
2693
+ if (nextId) {
2694
+ hasRunContext[nextId] = false;
2695
+ }
2696
+ hasRun = processPluginFn(itemCtx);
2697
+ }
2698
+ catch (error) {
2699
+ var hasNextRun = nextProxy ? hasRunContext[nextProxy._id] : true;
2700
+ if (hasNextRun) {
2701
+ hasRun = true;
2702
+ }
2703
+ if (!nextProxy || !hasNextRun) {
2704
+ _throwInternal(itemCtx[_DYN_DIAG_LOG ](), 1 , 73 , "Plugin [" + identifier + "] failed during " + name + " - " + dumpObj(error) + ", run flags: " + dumpObj(hasRunContext));
2705
+ }
2706
+ }
2707
+ }, details, isAsync);
2708
+ }
2709
+ return hasRun;
2710
+ }
2711
+ function _processTelemetry(env, itemCtx) {
2712
+ itemCtx = itemCtx || _getTelCtx();
2713
+ function _callProcessTelemetry(itemCtx) {
2714
+ if (!plugin || !hasProcessTelemetry) {
2715
+ return false;
2716
+ }
2717
+ var pluginState = _getPluginState(plugin);
2718
+ if (pluginState[_DYN_TEARDOWN$1 ] || pluginState[STR_DISABLED]) {
2719
+ return false;
2720
+ }
2721
+ if (hasSetNext) {
2722
+ plugin[_DYN_SET_NEXT_PLUGIN ](nextProxy);
2723
+ }
2724
+ plugin[STR_PROCESS_TELEMETRY ](env, itemCtx);
2725
+ return true;
2726
+ }
2727
+ if (!_processChain(itemCtx, _callProcessTelemetry, "processTelemetry", function () { return ({ item: env }); }, !(env.sync))) {
2728
+ itemCtx[_DYN_PROCESS_NEXT$1 ](env);
2729
+ }
2730
+ }
2731
+ function _unloadPlugin(unloadCtx, unloadState) {
2732
+ function _callTeardown() {
2733
+ var hasRun = false;
2734
+ if (plugin) {
2735
+ var pluginState = _getPluginState(plugin);
2736
+ var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE ];
2737
+ if (plugin && (!pluginCore || pluginCore === unloadCtx.core()) && !pluginState[_DYN_TEARDOWN$1 ]) {
2738
+ pluginState[STR_CORE ] = null;
2739
+ pluginState[_DYN_TEARDOWN$1 ] = true;
2740
+ pluginState[_DYN_IS_INITIALIZED ] = false;
2741
+ if (plugin[_DYN_TEARDOWN$1 ] && plugin[_DYN_TEARDOWN$1 ](unloadCtx, unloadState) === true) {
2742
+ hasRun = true;
2743
+ }
2744
+ }
2745
+ }
2746
+ return hasRun;
2747
+ }
2748
+ if (!_processChain(unloadCtx, _callTeardown, "unload", function () { }, unloadState[_DYN_IS_ASYNC ])) {
2749
+ unloadCtx[_DYN_PROCESS_NEXT$1 ](unloadState);
2750
+ }
2751
+ }
2752
+ function _updatePlugin(updateCtx, updateState) {
2753
+ function _callUpdate() {
2754
+ var hasRun = false;
2755
+ if (plugin) {
2756
+ var pluginState = _getPluginState(plugin);
2757
+ var pluginCore = plugin[STR_CORE] || pluginState[STR_CORE ];
2758
+ if (plugin && (!pluginCore || pluginCore === updateCtx.core()) && !pluginState[_DYN_TEARDOWN$1 ]) {
2759
+ if (plugin[_DYN_UPDATE ] && plugin[_DYN_UPDATE ](updateCtx, updateState) === true) {
2760
+ hasRun = true;
2761
+ }
2762
+ }
2763
+ }
2764
+ return hasRun;
2765
+ }
2766
+ if (!_processChain(updateCtx, _callUpdate, "update", function () { }, false)) {
2767
+ updateCtx[_DYN_PROCESS_NEXT$1 ](updateState);
2768
+ }
2769
+ }
2770
+ return objFreeze(proxyChain);
2771
+ }
2772
+
2773
+ function createUnloadHandlerContainer() {
2774
+ var handlers = [];
2775
+ function _addHandler(handler) {
2776
+ if (handler) {
2777
+ handlers[_DYN_PUSH ](handler);
2778
+ }
2779
+ }
2780
+ function _runHandlers(unloadCtx, unloadState) {
2781
+ arrForEach(handlers, function (handler) {
2782
+ try {
2783
+ handler(unloadCtx, unloadState);
2784
+ }
2785
+ catch (e) {
2786
+ _throwInternal(unloadCtx[_DYN_DIAG_LOG ](), 2 , 73 , "Unexpected error calling unload handler - " + dumpObj(e));
2787
+ }
2788
+ });
2789
+ handlers = [];
2790
+ }
2791
+ return {
2792
+ add: _addHandler,
2793
+ run: _runHandlers
2794
+ };
2795
+ }
2796
+
2797
+ function createUnloadHookContainer() {
2798
+ var _hooks = [];
2799
+ function _doUnload(logger) {
2800
+ var oldHooks = _hooks;
2801
+ _hooks = [];
2802
+ arrForEach(oldHooks, function (fn) {
2803
+ try {
2804
+ (fn.rm || fn.remove).call(fn);
2805
+ }
2806
+ catch (e) {
2807
+ _throwInternal(logger, 2 , 73 , "Unloading:" + dumpObj(e));
2808
+ }
2809
+ });
2810
+ }
2811
+ function _addHook(hooks) {
2812
+ if (hooks) {
2813
+ arrAppend(_hooks, hooks);
2814
+ }
2815
+ }
2816
+ return {
2817
+ run: _doUnload,
2818
+ add: _addHook
2819
+ };
2820
+ }
2821
+
2822
+ var _a$1;
2823
+ var strGetPlugin = "getPlugin";
2824
+ var defaultValues = (_a$1 = {},
2825
+ _a$1[STR_EXTENSION_CONFIG] = { isVal: isNotNullOrUndefined, v: {} },
2826
+ _a$1);
2827
+ var BaseTelemetryPlugin = /** @class */ (function () {
2828
+ function BaseTelemetryPlugin() {
2829
+ var _self = this;
2830
+ var _isinitialized;
2831
+ var _rootCtx;
2832
+ var _nextPlugin;
2833
+ var _unloadHandlerContainer;
2834
+ var _hookContainer;
2835
+ _initDefaults();
2836
+ dynamicProto(BaseTelemetryPlugin, _self, function (_self) {
2837
+ _self[_DYN_INITIALIZE ] = function (config, core, extensions, pluginChain) {
2838
+ _setDefaults(config, core, pluginChain);
2839
+ _isinitialized = true;
2840
+ };
2841
+ _self[_DYN_TEARDOWN$1 ] = function (unloadCtx, unloadState) {
2842
+ var _a;
2843
+ var core = _self[STR_CORE ];
2844
+ if (!core || (unloadCtx && core !== unloadCtx[STR_CORE ]())) {
2845
+ return;
2846
+ }
2847
+ var result;
2848
+ var unloadDone = false;
2849
+ var theUnloadCtx = unloadCtx || createProcessTelemetryUnloadContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);
2850
+ var theUnloadState = unloadState || (_a = {
2851
+ reason: 0
2852
+ },
2853
+ _a[_DYN_IS_ASYNC ] = false,
2854
+ _a);
2855
+ function _unloadCallback() {
2856
+ if (!unloadDone) {
2857
+ unloadDone = true;
2858
+ _unloadHandlerContainer.run(theUnloadCtx, unloadState);
2859
+ _hookContainer.run(theUnloadCtx[_DYN_DIAG_LOG ]());
2860
+ if (result === true) {
2861
+ theUnloadCtx[_DYN_PROCESS_NEXT$1 ](theUnloadState);
2862
+ }
2863
+ _initDefaults();
2864
+ }
2865
+ }
2866
+ if (!_self[_DYN__DO_TEARDOWN ] || _self[_DYN__DO_TEARDOWN ](theUnloadCtx, theUnloadState, _unloadCallback) !== true) {
2867
+ _unloadCallback();
2868
+ }
2869
+ else {
2870
+ result = true;
2871
+ }
2872
+ return result;
2873
+ };
2874
+ _self[_DYN_UPDATE ] = function (updateCtx, updateState) {
2875
+ var core = _self[STR_CORE ];
2876
+ if (!core || (updateCtx && core !== updateCtx[STR_CORE ]())) {
2877
+ return;
2878
+ }
2879
+ var result;
2880
+ var updateDone = false;
2881
+ var theUpdateCtx = updateCtx || createProcessTelemetryUpdateContext(null, core, _nextPlugin && _nextPlugin[strGetPlugin] ? _nextPlugin[strGetPlugin]() : _nextPlugin);
2882
+ var theUpdateState = updateState || {
2883
+ reason: 0
2884
+ };
2885
+ function _updateCallback() {
2886
+ if (!updateDone) {
2887
+ updateDone = true;
2888
+ _setDefaults(theUpdateCtx.getCfg(), theUpdateCtx.core(), theUpdateCtx[_DYN_GET_NEXT ]());
2889
+ }
2890
+ }
2891
+ if (!_self._doUpdate || _self._doUpdate(theUpdateCtx, theUpdateState, _updateCallback) !== true) {
2892
+ _updateCallback();
2893
+ }
2894
+ else {
2895
+ result = true;
2896
+ }
2897
+ return result;
2898
+ };
2899
+ proxyFunctionAs(_self, "_addUnloadCb", function () { return _unloadHandlerContainer; }, "add");
2900
+ proxyFunctionAs(_self, "_addHook", function () { return _hookContainer; }, "add");
2901
+ objDefine(_self, "_unloadHooks", { g: function () { return _hookContainer; } });
2902
+ });
2903
+ _self[_DYN_DIAG_LOG ] = function (itemCtx) {
2904
+ return _getTelCtx(itemCtx)[_DYN_DIAG_LOG ]();
2905
+ };
2906
+ _self[_DYN_IS_INITIALIZED ] = function () {
2907
+ return _isinitialized;
2908
+ };
2909
+ _self.setInitialized = function (isInitialized) {
2910
+ _isinitialized = isInitialized;
2911
+ };
2912
+ _self[_DYN_SET_NEXT_PLUGIN ] = function (next) {
2913
+ _nextPlugin = next;
2914
+ };
2915
+ _self[_DYN_PROCESS_NEXT$1 ] = function (env, itemCtx) {
2916
+ if (itemCtx) {
2917
+ itemCtx[_DYN_PROCESS_NEXT$1 ](env);
2918
+ }
2919
+ else if (_nextPlugin && isFunction(_nextPlugin[STR_PROCESS_TELEMETRY ])) {
2920
+ _nextPlugin[STR_PROCESS_TELEMETRY ](env, null);
2921
+ }
2922
+ };
2923
+ _self._getTelCtx = _getTelCtx;
2924
+ function _getTelCtx(currentCtx) {
2925
+ if (currentCtx === void 0) { currentCtx = null; }
2926
+ var itemCtx = currentCtx;
2927
+ if (!itemCtx) {
2928
+ var rootCtx = _rootCtx || createProcessTelemetryContext(null, {}, _self[STR_CORE ]);
2929
+ if (_nextPlugin && _nextPlugin[strGetPlugin]) {
2930
+ itemCtx = rootCtx[_DYN_CREATE_NEW ](null, _nextPlugin[strGetPlugin]);
2931
+ }
2932
+ else {
2933
+ itemCtx = rootCtx[_DYN_CREATE_NEW ](null, _nextPlugin);
2934
+ }
2935
+ }
2936
+ return itemCtx;
2937
+ }
2938
+ function _setDefaults(config, core, pluginChain) {
2939
+ createDynamicConfig(config, defaultValues, safeGetLogger(core));
2940
+ if (!pluginChain && core) {
2941
+ pluginChain = core[_DYN_GET_PROCESS_TEL_CONT0 ]()[_DYN_GET_NEXT ]();
2942
+ }
2943
+ var nextPlugin = _nextPlugin;
2944
+ if (_nextPlugin && _nextPlugin[strGetPlugin]) {
2945
+ nextPlugin = _nextPlugin[strGetPlugin]();
2946
+ }
2947
+ _self[STR_CORE ] = core;
2948
+ _rootCtx = createProcessTelemetryContext(pluginChain, config, core, nextPlugin);
2949
+ }
2950
+ function _initDefaults() {
2951
+ _isinitialized = false;
2952
+ _self[STR_CORE ] = null;
2953
+ _rootCtx = null;
2954
+ _nextPlugin = null;
2955
+ _hookContainer = createUnloadHookContainer();
2956
+ _unloadHandlerContainer = createUnloadHandlerContainer();
2957
+ }
2958
+ }
2959
+ BaseTelemetryPlugin.__ieDyn=1;
2960
+ return BaseTelemetryPlugin;
2961
+ }());
2962
+
2963
+ var _DYN_LENGTH = "length";
2964
+ var _DYN_QUEUE = "queue";
2965
+ var _DYN_PROCESS_NEXT = "processNext";
2966
+ var _DYN_IDENTIFIER = "identifier";
2967
+ var _DYN_GET_QUEUES = "getQueues";
2968
+ var _DYN_TEARDOWN = "teardown";
2969
+ var _DYN_PRIORITY = "priority";
2970
+ var _DYN_IGNORE_CORE_CHANNELS = "ignoreCoreChannels";
2971
+ var _DYN_TEE_CHANNELS = "teeChannels";
2972
+
2973
+ var ChannelControllerPriority = 500;
2974
+ function _getTelCtx(core) {
2975
+ return createProcessTelemetryContext(null, core.config, core, null);
2976
+ }
2977
+ function _processChannelQueue(theChannels, itemCtx, processFn, onComplete) {
2978
+ var waiting = theChannels ? (theChannels[_DYN_LENGTH ] + 1) : 1;
2979
+ function _runChainOnComplete() {
2980
+ waiting--;
2981
+ if (waiting === 0) {
2982
+ onComplete && onComplete();
2983
+ onComplete = null;
2984
+ }
2985
+ }
2986
+ if (waiting > 0) {
2987
+ arrForEach(theChannels, function (channels) {
2988
+ if (channels && channels.queue[_DYN_LENGTH ] > 0) {
2989
+ var chainCtx = itemCtx.createNew(channels[_DYN_QUEUE ]);
2990
+ chainCtx.onComplete(_runChainOnComplete);
2991
+ processFn(chainCtx);
2992
+ }
2993
+ else {
2994
+ waiting--;
2995
+ }
2996
+ });
2997
+ }
2998
+ _runChainOnComplete();
2999
+ }
3000
+ function createChannelControllerPlugin() {
3001
+ var _channelQueue = [];
3002
+ var _core = null;
3003
+ function _doUpdate(updateCtx, updateState) {
3004
+ var theUpdateState = updateState || {
3005
+ reason: 0
3006
+ };
3007
+ _processChannelQueue(_channelQueue, updateCtx, function (chainCtx) {
3008
+ chainCtx[_DYN_PROCESS_NEXT ](theUpdateState);
3009
+ }, function () {
3010
+ updateCtx[_DYN_PROCESS_NEXT ](theUpdateState);
3011
+ });
3012
+ return true;
3013
+ }
3014
+ function _getChannel(pluginIdentifier) {
3015
+ var thePlugin = null;
3016
+ if (_channelQueue && _channelQueue[_DYN_LENGTH ] > 0) {
3017
+ arrForEach(_channelQueue, function (channels) {
3018
+ if (channels && channels.queue[_DYN_LENGTH ] > 0) {
3019
+ arrForEach(channels[_DYN_QUEUE ], function (ext) {
3020
+ if (ext[_DYN_IDENTIFIER ] === pluginIdentifier) {
3021
+ thePlugin = ext;
3022
+ return -1;
3023
+ }
3024
+ });
3025
+ if (thePlugin) {
3026
+ return -1;
3027
+ }
3028
+ }
3029
+ });
3030
+ }
3031
+ return thePlugin;
3032
+ }
3033
+ var channelController = {
3034
+ init: function (channelQueue, core) {
3035
+ _channelQueue = channelQueue;
3036
+ _core = core;
3037
+ },
3038
+ getQueues: function () {
3039
+ return _channelQueue;
3040
+ },
3041
+ processTelemetry: function (item, itemCtx) {
3042
+ _processChannelQueue(_channelQueue, itemCtx || _getTelCtx(_core), function (chainCtx) {
3043
+ chainCtx[_DYN_PROCESS_NEXT ](item);
3044
+ }, function () {
3045
+ itemCtx[_DYN_PROCESS_NEXT ](item);
3046
+ });
3047
+ },
3048
+ update: _doUpdate,
3049
+ pause: function () {
3050
+ _processChannelQueue(_channelQueue, _getTelCtx(_core), function (chainCtx) {
3051
+ chainCtx.iterate(function (plugin) {
3052
+ plugin.pause && plugin.pause();
3053
+ });
3054
+ }, null);
3055
+ },
3056
+ resume: function () {
3057
+ _processChannelQueue(_channelQueue, _getTelCtx(_core), function (chainCtx) {
3058
+ chainCtx.iterate(function (plugin) {
3059
+ plugin.resume && plugin.resume();
3060
+ });
3061
+ }, null);
3062
+ },
3063
+ teardown: function (unloadCtx, unloadState, onComplete) {
3064
+ var theUnloadState = unloadState || {
3065
+ reason: 0 ,
3066
+ isAsync: false
3067
+ };
3068
+ _processChannelQueue(_channelQueue, unloadCtx, function (chainCtx) {
3069
+ chainCtx[_DYN_PROCESS_NEXT ](theUnloadState);
3070
+ }, function () {
3071
+ unloadCtx[_DYN_PROCESS_NEXT ](theUnloadState);
3072
+ onComplete && onComplete();
3073
+ });
3074
+ return true;
3075
+ },
3076
+ getChannel: _getChannel,
3077
+ flush: function (isAsync, callBack, sendReason, cbTimeout) {
3078
+ var waiting = 1;
3079
+ var doneIterating = false;
3080
+ var cbTimer = null;
3081
+ var result = true;
3082
+ cbTimeout = cbTimeout || 5000;
3083
+ if (isAsync && !callBack) {
3084
+ result = createPromise(function (resolve) {
3085
+ callBack = resolve;
3086
+ });
3087
+ }
3088
+ function doCallback() {
3089
+ waiting--;
3090
+ if (doneIterating && waiting === 0) {
3091
+ cbTimer && cbTimer.cancel();
3092
+ cbTimer = null;
3093
+ callBack && callBack(doneIterating);
3094
+ callBack = null;
3095
+ }
3096
+ }
3097
+ _processChannelQueue(_channelQueue, _getTelCtx(_core), function (chainCtx) {
3098
+ chainCtx.iterate(function (plugin) {
3099
+ if (plugin.flush) {
3100
+ waiting++;
3101
+ var handled_1 = false;
3102
+ if (!plugin.flush(isAsync, function () {
3103
+ handled_1 = true;
3104
+ doCallback();
3105
+ }, sendReason)) {
3106
+ if (!handled_1) {
3107
+ if (isAsync && cbTimer == null) {
3108
+ cbTimer = scheduleTimeout(function () {
3109
+ cbTimer = null;
3110
+ doCallback();
3111
+ }, cbTimeout);
3112
+ }
3113
+ else {
3114
+ doCallback();
3115
+ }
3116
+ }
3117
+ }
3118
+ }
3119
+ });
3120
+ }, function () {
3121
+ doneIterating = true;
3122
+ doCallback();
3123
+ });
3124
+ return result;
3125
+ }
3126
+ };
3127
+ return channelController;
3128
+ }
3129
+
3130
+ var _a;
3131
+ var ChannelValidationMessage = "Channel has invalid priority - ";
3132
+ var defaultTeeChannelConfig = objDeepFreeze((_a = {},
3133
+ _a[_DYN_TEE_CHANNELS ] = null,
3134
+ _a[_DYN_IGNORE_CORE_CHANNELS ] = cfgDfBoolean(),
3135
+ _a));
3136
+ function _addChannelQueue(channelQueue, queue, core, teeChannel) {
3137
+ var _a;
3138
+ if (queue && isArray(queue) && queue[_DYN_LENGTH ] > 0) {
3139
+ queue = queue.sort(function (a, b) {
3140
+ return a[_DYN_PRIORITY ] - b[_DYN_PRIORITY ];
3141
+ });
3142
+ var _queue_1 = [];
3143
+ arrForEach(queue, function (queueItem) {
3144
+ if (queueItem[_DYN_PRIORITY ] < ChannelControllerPriority) {
3145
+ throwError(ChannelValidationMessage + queueItem[_DYN_IDENTIFIER ]);
3146
+ }
3147
+ if (queueItem !== teeChannel) {
3148
+ _queue_1.push(queueItem);
3149
+ }
3150
+ });
3151
+ channelQueue.push((_a = {},
3152
+ _a[_DYN_QUEUE ] = objFreeze(_queue_1),
3153
+ _a));
3154
+ }
3155
+ }
3156
+ function _createChannelQueues(config, core, teeChannel) {
3157
+ var channelQueue = [];
3158
+ if (config) {
3159
+ if (!config[_DYN_IGNORE_CORE_CHANNELS ] && core.config.channels) {
3160
+ arrForEach(core.config.channels, function (queue, idx) {
3161
+ if (idx > 0) {
3162
+ _addChannelQueue(channelQueue, queue, core, teeChannel);
3163
+ }
3164
+ });
3165
+ }
3166
+ if (config[_DYN_TEE_CHANNELS ]) {
3167
+ arrForEach(config[_DYN_TEE_CHANNELS ], function (queue) { return _addChannelQueue(channelQueue, queue, core, teeChannel); });
3168
+ }
3169
+ }
3170
+ return channelQueue;
3171
+ }
3172
+ var TeeChannel = /** @class */ (function (_super) {
3173
+ __extendsFn(TeeChannel, _super);
3174
+ function TeeChannel() {
3175
+ var _this = _super.call(this) || this;
3176
+ _this.identifier = "TeeChannelController";
3177
+ _this.priority = 999;
3178
+ var _channelController;
3179
+ var _isInitialized;
3180
+ dynamicProto(TeeChannel, _this, function (_self, base) {
3181
+ _initDefaults();
3182
+ _self.initialize = function (config, core, extensions, pluginChain) {
3183
+ if (!_isInitialized) {
3184
+ _isInitialized = true;
3185
+ _initChannels(_self, core);
3186
+ }
3187
+ };
3188
+ _self.getTeeChannels = function () {
3189
+ var controls = [];
3190
+ var channelQueues = _channelController[_DYN_GET_QUEUES ]();
3191
+ if (channelQueues) {
3192
+ arrForEach(channelQueues, function (channels) {
3193
+ controls.push(channels[_DYN_QUEUE ]);
3194
+ });
3195
+ }
3196
+ return objFreeze(controls);
3197
+ };
3198
+ _self.isInitialized = function () {
3199
+ return _isInitialized;
3200
+ };
3201
+ _self[_DYN_TEARDOWN ] = function (unloadCtx, unloadState) {
3202
+ return _channelController[_DYN_TEARDOWN ](unloadCtx, unloadState, function () {
3203
+ _isInitialized = false;
3204
+ });
3205
+ };
3206
+ proxyFunctions(_self, _channelController, [
3207
+ "processTelemetry",
3208
+ "update",
3209
+ "pause",
3210
+ "resume",
3211
+ "getChannel",
3212
+ "flush"
3213
+ ]);
3214
+ });
3215
+ function _initDefaults() {
3216
+ _channelController = createChannelControllerPlugin();
3217
+ _isInitialized = false;
3218
+ }
3219
+ function _initChannels(self, core) {
3220
+ self._addHook(onConfigChange(core.config, function (details) {
3221
+ var ctx = createProcessTelemetryContext(null, details.cfg, core);
3222
+ var theConfig = ctx.getExtCfg(self[_DYN_IDENTIFIER ], defaultTeeChannelConfig);
3223
+ var channelQueue = _createChannelQueues(theConfig, core, self);
3224
+ arrForEach(channelQueue, function (channels) {
3225
+ if (channels && channels.queue[_DYN_LENGTH ] > 0) {
3226
+ initializePlugins(ctx.createNew(channels[_DYN_QUEUE ]), details.cfg.extensions);
3227
+ }
3228
+ });
3229
+ _channelController.init(channelQueue, core);
3230
+ }));
3231
+ }
3232
+ return _this;
3233
+ }
3234
+ TeeChannel.__ieDyn=1;
3235
+ return TeeChannel;
3236
+ }(BaseTelemetryPlugin));
3237
+
3238
+ exports.TeeChannel = TeeChannel;
3239
+
3240
+ }));
3241
+ //# sourceMappingURL=applicationinsights-teechannel-js.3.0.2-nightly3.2305-04.gbl.js.map