@microsoft/applicationinsights-osplugin-js 3.4.0-nightlybeta3.2602-27 → 3.4.1

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 (49) hide show
  1. package/browser/es5/{ai.osplugin.3.4.0-nightlybeta3.2602-27.cjs.js → ai.osplugin.3.4.1.cjs.js} +139 -90
  2. package/browser/es5/ai.osplugin.3.4.1.cjs.js.map +1 -0
  3. package/browser/es5/ai.osplugin.3.4.1.cjs.min.js +6 -0
  4. package/browser/es5/ai.osplugin.3.4.1.cjs.min.js.map +1 -0
  5. package/browser/es5/{ai.osplugin.3.4.0-nightlybeta3.2602-27.gbl.js → ai.osplugin.3.4.1.gbl.js} +141 -92
  6. package/browser/es5/ai.osplugin.3.4.1.gbl.js.map +1 -0
  7. package/browser/es5/ai.osplugin.3.4.1.gbl.min.js +6 -0
  8. package/browser/es5/ai.osplugin.3.4.1.gbl.min.js.map +1 -0
  9. package/browser/es5/ai.osplugin.3.4.1.integrity.json +66 -0
  10. package/browser/es5/{ai.osplugin.3.4.0-nightlybeta3.2602-27.js → ai.osplugin.3.4.1.js} +141 -92
  11. package/browser/es5/ai.osplugin.3.4.1.js.map +1 -0
  12. package/browser/es5/ai.osplugin.3.4.1.min.js +6 -0
  13. package/browser/es5/ai.osplugin.3.4.1.min.js.map +1 -0
  14. package/browser/es5/ai.osplugin.3.cjs.js +138 -89
  15. package/browser/es5/ai.osplugin.3.cjs.js.map +1 -1
  16. package/browser/es5/ai.osplugin.3.cjs.min.js +2 -2
  17. package/browser/es5/ai.osplugin.3.cjs.min.js.map +1 -1
  18. package/browser/es5/ai.osplugin.3.gbl.js +140 -91
  19. package/browser/es5/ai.osplugin.3.gbl.js.map +1 -1
  20. package/browser/es5/ai.osplugin.3.gbl.min.js +2 -2
  21. package/browser/es5/ai.osplugin.3.gbl.min.js.map +1 -1
  22. package/browser/es5/ai.osplugin.3.integrity.json +25 -25
  23. package/browser/es5/ai.osplugin.3.js +140 -91
  24. package/browser/es5/ai.osplugin.3.js.map +1 -1
  25. package/browser/es5/ai.osplugin.3.min.js +2 -2
  26. package/browser/es5/ai.osplugin.3.min.js.map +1 -1
  27. package/dist/es5/applicationinsights-osplugin-js.js +138 -89
  28. package/dist/es5/applicationinsights-osplugin-js.js.map +1 -1
  29. package/dist/es5/applicationinsights-osplugin-js.min.js +2 -2
  30. package/dist/es5/applicationinsights-osplugin-js.min.js.map +1 -1
  31. package/dist-es5/DataModels.js +1 -1
  32. package/dist-es5/OsPlugin.js +135 -86
  33. package/dist-es5/OsPlugin.js.map +1 -1
  34. package/dist-es5/__DynamicConstants.js +3 -2
  35. package/dist-es5/__DynamicConstants.js.map +1 -1
  36. package/dist-es5/applicationinsights-osplugin-js.js +1 -1
  37. package/package.json +57 -60
  38. package/types/applicationinsights-osplugin-js.d.ts +1 -1
  39. package/types/applicationinsights-osplugin-js.namespaced.d.ts +39 -3
  40. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.cjs.js.map +0 -1
  41. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.cjs.min.js +0 -6
  42. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.cjs.min.js.map +0 -1
  43. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.gbl.js.map +0 -1
  44. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.gbl.min.js +0 -6
  45. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.gbl.min.js.map +0 -1
  46. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.integrity.json +0 -66
  47. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.js.map +0 -1
  48. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.min.js +0 -6
  49. package/browser/es5/ai.osplugin.3.4.0-nightlybeta3.2602-27.min.js.map +0 -1
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * Application Insights JavaScript SDK - OS Plugin, 3.4.0-nightlybeta3.2602-27
2
+ * Application Insights JavaScript SDK - OS Plugin, 3.4.1
3
3
  * Copyright (c) Microsoft and contributors. All rights reserved.
4
4
  */
5
5
  'use strict';
@@ -11,7 +11,7 @@ var strShimUndefined = "undefined";
11
11
  var strShimPrototype = "prototype";
12
12
  var ObjClass$1 = Object;
13
13
 
14
- /*! https://github.com/nevware21/ts-utils v0.12.6 */
14
+ /*! https://github.com/nevware21/ts-utils v0.13.0 */
15
15
  /*#__NO_SIDE_EFFECTS__*/
16
16
  function _pureAssign(func1, func2) {
17
17
  return func1 || func2;
@@ -370,6 +370,9 @@ function polyUtcNow() {
370
370
  function fnApply(fn, thisArg, argArray) {
371
371
  return fn.apply(thisArg, argArray);
372
372
  }
373
+ function fnCall(fn, thisArg) {
374
+ return fn.apply(thisArg, ArrSlice[CALL](arguments, 2));
375
+ }
373
376
  var _globalLazyTestHooks;
374
377
  function _initTestHooks() {
375
378
  _globalLazyTestHooks = _getGlobalConfig();
@@ -629,7 +632,7 @@ function _setName(baseClass, name) {
629
632
  name && (baseClass[NAME] = name);
630
633
  }
631
634
  /*#__NO_SIDE_EFFECTS__*/
632
- function createCustomError(name, constructCb, errorBase) {
635
+ function createCustomError(name, constructCb, errorBase, superArgsFn) {
633
636
  var theBaseClass = errorBase || Error;
634
637
  var orgName = theBaseClass[PROTOTYPE][NAME];
635
638
  var captureFn = Error.captureStackTrace;
@@ -638,7 +641,7 @@ function createCustomError(name, constructCb, errorBase) {
638
641
  var theArgs = arguments;
639
642
  try {
640
643
  safe(_setName, [theBaseClass, name]);
641
- var _self = fnApply(theBaseClass, _this, ArrSlice[CALL](theArgs)) || _this;
644
+ var _self = fnApply(theBaseClass, _this, superArgsFn ? superArgsFn(theArgs) : ArrSlice[CALL](theArgs)) || _this;
642
645
  if (_self !== _this) {
643
646
  var orgProto = objGetPrototypeOf(_this);
644
647
  if (orgProto !== objGetPrototypeOf(_self)) {
@@ -1111,9 +1114,12 @@ var _DYN_IS_CHILD_EVT = "isChildEvt";
1111
1114
  var _DYN_GET_CTX = "getCtx";
1112
1115
  var _DYN_SET_CTX = "setCtx";
1113
1116
  var _DYN_CONFIG = "config";
1117
+ var _DYN_CALL = "call";
1114
1118
  var _DYN_REPLACE = "replace";
1115
1119
  var _DYN_TYPE = "type";
1120
+ var _DYN_USER_AGENT = "userAgent";
1116
1121
  var _DYN_TO_STRING = "toString";
1122
+ var _DYN_HANDLER = "handler";
1117
1123
  var _DYN_EVT_NAME = "evtName";
1118
1124
  var _DYN_CONCAT = "concat";
1119
1125
  var _DYN_REMOVE_ITEM = "removeItem";
@@ -1322,7 +1328,7 @@ function getUserAgentString() {
1322
1328
  if (!_userAgent) {
1323
1329
  _userAgent = getLazy(function () {
1324
1330
  var nav = getNavigator() || {};
1325
- return nav.userAgent || STR_EMPTY;
1331
+ return nav[_DYN_USER_AGENT ] || STR_EMPTY;
1326
1332
  });
1327
1333
  }
1328
1334
  return _userAgent.v;
@@ -1434,7 +1440,7 @@ function newId(maxLength) {
1434
1440
  return result;
1435
1441
  }
1436
1442
 
1437
- var version = '3.4.0-nightlybeta3.2602-27';
1443
+ var version = '3.4.1';
1438
1444
  var instanceName = "." + newId(6);
1439
1445
  var _dataUid = 0;
1440
1446
  function _canAcceptData(target) {
@@ -2172,7 +2178,7 @@ var _InternalLogMessage = /** @class */ (function () {
2172
2178
  }());
2173
2179
  /*#__NO_SIDE_EFFECTS__*/
2174
2180
  function safeGetLogger(core, config) {
2175
- return (core || {})[_DYN_LOGGER ] || new DiagnosticLogger(config);
2181
+ return (core || {})[_DYN_LOGGER ] || new DiagnosticLogger(config || (core || {})[_DYN_CONFIG ]);
2176
2182
  }
2177
2183
  var DiagnosticLogger = /** @class */ (function () {
2178
2184
  function DiagnosticLogger(config) {
@@ -2492,7 +2498,7 @@ function _createInternalContext(telemetryChain, dynamicHandler, core, startAt) {
2492
2498
  if (onComplete && onComplete[_DYN_LENGTH ] > 0) {
2493
2499
  arrForEach(onComplete, function (completeDetails) {
2494
2500
  try {
2495
- completeDetails.func.call(completeDetails.self, completeDetails.args);
2501
+ completeDetails.func[_DYN_CALL ](completeDetails.self, completeDetails.args);
2496
2502
  }
2497
2503
  catch (e) {
2498
2504
  _throwInternal(core[_DYN_LOGGER ], 2 , 73 , "Unexpected Exception during onComplete - " + dumpObj(e));
@@ -2815,7 +2821,7 @@ function createUnloadHookContainer() {
2815
2821
  _hooks = [];
2816
2822
  arrForEach(oldHooks, function (fn) {
2817
2823
  try {
2818
- (fn.rm || fn.remove).call(fn);
2824
+ (fn.rm || fn.remove)[_DYN_CALL ](fn);
2819
2825
  }
2820
2826
  catch (e) {
2821
2827
  _throwInternal(logger, 2 , 73 , "Unloading:" + dumpObj(e));
@@ -3078,7 +3084,7 @@ function _doUnregister(target, events, evtName, unRegFn) {
3078
3084
  if (theEvent) {
3079
3085
  if (!evtName.ns || evtName.ns === theEvent[_DYN_EVT_NAME ].ns) {
3080
3086
  if (!unRegFn || unRegFn(theEvent)) {
3081
- _doDetach(target, theEvent[_DYN_EVT_NAME ], theEvent.handler, theEvent.capture);
3087
+ _doDetach(target, theEvent.evtName, theEvent[_DYN_HANDLER ], theEvent.capture);
3082
3088
  events[_DYN_SPLICE ](idx, 1);
3083
3089
  }
3084
3090
  }
@@ -3145,7 +3151,7 @@ function eventOff(target, eventName, handlerRef, evtNamespace, useCapture) {
3145
3151
  var evtName_1 = _getEvtNamespace(eventName, evtNamespace);
3146
3152
  var found_1 = false;
3147
3153
  _unregisterEvents(target, evtName_1, function (regEvent) {
3148
- if ((evtName_1.ns && !handlerRef) || regEvent.handler === handlerRef) {
3154
+ if ((evtName_1.ns && !handlerRef) || regEvent[_DYN_HANDLER ] === handlerRef) {
3149
3155
  found_1 = true;
3150
3156
  return true;
3151
3157
  }
@@ -3321,8 +3327,9 @@ var Extensions = {
3321
3327
  SDKExt: "sdk"
3322
3328
  };
3323
3329
 
3324
- var _DYN_PLATFORM_VERSION = "platformVersion";
3325
3330
  var _DYN_MERGE_OS_NAME_VERSIO0 = "mergeOsNameVersion";
3331
+ var _DYN_IS_STORAGE_USE_DISAB1 = "isStorageUseDisabled";
3332
+ var _DYN_PLATFORM_VERSION = "platformVersion";
3326
3333
 
3327
3334
  var defaultMaxTimeout = 200;
3328
3335
  var strExt = "ext";
@@ -3336,21 +3343,19 @@ var OsPlugin = /** @class */ (function (_super) {
3336
3343
  var _this = _super.call(this) || this;
3337
3344
  _this.identifier = "OsPlugin";
3338
3345
  _this.priority = 195;
3339
- _this.version = '3.4.0-nightlybeta3.2602-27';
3346
+ _this.version = '3.4.1';
3340
3347
  var _core;
3341
3348
  var _ocConfig;
3342
- var _getOSInProgress;
3343
3349
  var _getOSTimeout;
3344
- var _maxTimeout;
3345
- var _platformVersionResponse;
3346
- var _retrieveFullVersion;
3350
+ var _fetchedFullVersion;
3347
3351
  var _mergeOsNameVersion;
3348
3352
  var _eventQueue;
3349
3353
  var _evtNamespace;
3350
3354
  var _excludePageUnloadEvents;
3355
+ var _disableFlushOnUnload;
3356
+ var _addedUnloadEvents;
3351
3357
  var _os;
3352
3358
  var _osVer;
3353
- var _firstAttempt;
3354
3359
  dynamicProto(OsPlugin, _this, function (_self, _base) {
3355
3360
  _initDefaults();
3356
3361
  _self.initialize = function (coreConfig, core, extensions) {
@@ -3359,23 +3364,11 @@ var OsPlugin = /** @class */ (function (_super) {
3359
3364
  _super.prototype.initialize.call(_this, coreConfig, core, extensions);
3360
3365
  var identifier = _self.identifier;
3361
3366
  _evtNamespace = mergeEvtNamespace(createUniqueNamespace(identifier), core.evtNamespace && core.evtNamespace());
3362
- if (utlCanUseSessionStorage) {
3363
- try {
3364
- _platformVersionResponse = JSON.parse(utlGetSessionStorage(core.logger, "ai_osplugin"));
3365
- }
3366
- catch (error) {
3367
- }
3368
- }
3369
- if (_platformVersionResponse) {
3370
- _retrieveFullVersion = true;
3371
- _osVer = parseInt(_platformVersionResponse[_DYN_PLATFORM_VERSION ]);
3372
- _os = _platformVersionResponse.platform;
3373
- }
3367
+ _fetchedFullVersion = _fetchCachedOSVersion(coreConfig);
3374
3368
  _self._addHook(onConfigChange(coreConfig, function (details) {
3375
3369
  var coreConfig = details.cfg;
3376
3370
  var ctx = createProcessTelemetryContext(null, coreConfig, core);
3377
3371
  _ocConfig = ctx.getExtCfg(identifier, defaultOSConfig);
3378
- _maxTimeout = _ocConfig.maxTimeout;
3379
3372
  if (_ocConfig[_DYN_MERGE_OS_NAME_VERSIO0 ] !== undefined) {
3380
3373
  _mergeOsNameVersion = _ocConfig[_DYN_MERGE_OS_NAME_VERSIO0 ];
3381
3374
  }
@@ -3386,87 +3379,141 @@ var OsPlugin = /** @class */ (function (_super) {
3386
3379
  _mergeOsNameVersion = false;
3387
3380
  }
3388
3381
  var excludePageUnloadEvents = coreConfig.disablePageUnloadEvents || [];
3389
- if (_excludePageUnloadEvents && _excludePageUnloadEvents !== excludePageUnloadEvents) {
3390
- removePageUnloadEventListener(null, _evtNamespace);
3391
- removePageHideEventListener(null, _evtNamespace);
3382
+ var disableFlushOnUnload = coreConfig.disableFlushOnUnload || false;
3383
+ var removeEvents = _excludePageUnloadEvents && _excludePageUnloadEvents !== excludePageUnloadEvents;
3384
+ if (_disableFlushOnUnload !== disableFlushOnUnload) {
3385
+ removeEvents = true;
3386
+ }
3387
+ if (removeEvents && _addedUnloadEvents) {
3388
+ _removeUnloadHandlers();
3392
3389
  _excludePageUnloadEvents = null;
3393
3390
  }
3394
- if (!_excludePageUnloadEvents) {
3395
- addPageUnloadEventListener(_doUnload, excludePageUnloadEvents, _evtNamespace);
3396
- addPageHideEventListener(_doUnload, excludePageUnloadEvents, _evtNamespace);
3391
+ if (!_excludePageUnloadEvents && !disableFlushOnUnload) {
3392
+ _addUnloadHandlers(excludePageUnloadEvents);
3397
3393
  }
3398
3394
  _excludePageUnloadEvents = excludePageUnloadEvents;
3395
+ _disableFlushOnUnload = disableFlushOnUnload;
3399
3396
  }));
3400
- function _doUnload() {
3401
- _releaseEventQueue();
3397
+ if (!_fetchedFullVersion) {
3398
+ _startRetrieveOsVersion(_ocConfig.maxTimeout);
3402
3399
  }
3403
3400
  };
3404
3401
  _self.processTelemetry = function (event, itemCtx) {
3405
3402
  itemCtx = _self._getTelCtx(itemCtx);
3406
- if (!_retrieveFullVersion && !_getOSInProgress && _firstAttempt) {
3407
- _getOSInProgress = true;
3408
- startRetrieveOsVersion();
3409
- _firstAttempt = false;
3410
- }
3411
- if (_getOSInProgress) {
3403
+ if (_getOSTimeout) {
3412
3404
  _eventQueue.push({
3413
3405
  ctx: itemCtx,
3414
3406
  item: event
3415
3407
  });
3416
3408
  }
3417
3409
  else {
3418
- updateTeleItemWithOs(event);
3410
+ _updateTeleItemWithOs(event);
3419
3411
  _self.processNext(event, itemCtx);
3420
3412
  }
3421
3413
  };
3422
3414
  _self._doTeardown = function (unloadCtx, unloadState) {
3423
3415
  _completeOsRetrieve();
3424
- removePageUnloadEventListener(null, _evtNamespace);
3425
- removePageHideEventListener(null, _evtNamespace);
3416
+ _removeUnloadHandlers();
3426
3417
  _initDefaults();
3427
3418
  };
3428
- function startRetrieveOsVersion() {
3429
- var _a;
3430
- _getOSTimeout = scheduleTimeout(function () {
3431
- _completeOsRetrieve();
3432
- }, _maxTimeout);
3433
- if (navigator.userAgent) {
3434
- var getHighEntropyValues = (_a = navigator.userAgentData) === null || _a === void 0 ? void 0 : _a.getHighEntropyValues;
3435
- if (getHighEntropyValues) {
3436
- doAwaitResponse(navigator.userAgentData.getHighEntropyValues(["platformVersion"]), function (response) {
3437
- if (!response.rejected) {
3438
- _platformVersionResponse = response.value;
3439
- _retrieveFullVersion = true;
3440
- if (_platformVersionResponse[_DYN_PLATFORM_VERSION ] && _platformVersionResponse.platform) {
3441
- _os = _platformVersionResponse.platform;
3442
- _osVer = parseInt(_platformVersionResponse[_DYN_PLATFORM_VERSION ]);
3443
- if (_os === "Windows") {
3444
- if (_osVer == 0) {
3445
- _osVer = 8;
3446
- }
3447
- else if (_osVer < 13) {
3448
- _osVer = 10;
3449
- }
3450
- else {
3451
- _osVer = 11;
3419
+ function _fetchCachedOSVersion(coreConfig) {
3420
+ var fetched = false;
3421
+ if (coreConfig[_DYN_IS_STORAGE_USE_DISAB1 ] !== true) {
3422
+ try {
3423
+ var platformVersionResponse = JSON.parse(utlGetSessionStorage(safeGetLogger(_core), "ai_osplugin"));
3424
+ if (platformVersionResponse) {
3425
+ _os = platformVersionResponse.platform;
3426
+ if (platformVersionResponse[_DYN_PLATFORM_VERSION ]) {
3427
+ var ver = parseInt(platformVersionResponse[_DYN_PLATFORM_VERSION ]);
3428
+ if (!isNaN(ver)) {
3429
+ _osVer = ver;
3430
+ }
3431
+ }
3432
+ fetched = !!(_os && _osVer);
3433
+ }
3434
+ }
3435
+ catch (error) {
3436
+ }
3437
+ }
3438
+ return fetched;
3439
+ }
3440
+ function _storeCachedOSVersion(coreConfig) {
3441
+ if (coreConfig[_DYN_IS_STORAGE_USE_DISAB1 ] !== true) {
3442
+ try {
3443
+ utlSetSessionStorage(safeGetLogger(_core), "ai_osplugin", JSON.stringify({ platform: _os, platformVersion: _osVer }));
3444
+ }
3445
+ catch (error) {
3446
+ }
3447
+ }
3448
+ }
3449
+ function _addUnloadHandlers(excludePageUnloadEvents) {
3450
+ function _unloading() {
3451
+ _releaseEventQueue();
3452
+ _removeUnloadHandlers();
3453
+ }
3454
+ if (!_addedUnloadEvents && !_fetchedFullVersion) {
3455
+ addPageUnloadEventListener(_unloading, excludePageUnloadEvents, _evtNamespace);
3456
+ addPageHideEventListener(_unloading, excludePageUnloadEvents, _evtNamespace);
3457
+ _addedUnloadEvents = true;
3458
+ }
3459
+ }
3460
+ function _removeUnloadHandlers() {
3461
+ if (_addedUnloadEvents) {
3462
+ removePageUnloadEventListener(null, _evtNamespace);
3463
+ removePageHideEventListener(null, _evtNamespace);
3464
+ _addedUnloadEvents = false;
3465
+ }
3466
+ }
3467
+ function _startRetrieveOsVersion(maxTimeout) {
3468
+ if (_core && !_getOSTimeout) {
3469
+ var nav = getNavigator();
3470
+ var userAgentData = (nav || {}).userAgentData;
3471
+ if (userAgentData) {
3472
+ var getHighEntropyValues = userAgentData.getHighEntropyValues;
3473
+ if (getHighEntropyValues) {
3474
+ _getOSTimeout = scheduleTimeout(function () {
3475
+ _completeOsRetrieve();
3476
+ }, maxTimeout);
3477
+ doAwaitResponse(fnCall(getHighEntropyValues, userAgentData, ["platformVersion"]), function (response) {
3478
+ _fetchedFullVersion = true;
3479
+ try {
3480
+ if (!response.rejected) {
3481
+ var platformVersionResponse = response.value;
3482
+ if (platformVersionResponse[_DYN_PLATFORM_VERSION ] && platformVersionResponse.platform) {
3483
+ _os = platformVersionResponse.platform;
3484
+ _osVer = parseInt(platformVersionResponse[_DYN_PLATFORM_VERSION ]);
3485
+ if (_os === "Windows" && !isNaN(_osVer)) {
3486
+ if (_osVer == 0) {
3487
+ _osVer = 8;
3488
+ }
3489
+ else if (_osVer < 13) {
3490
+ _osVer = 10;
3491
+ }
3492
+ else {
3493
+ _osVer = 11;
3494
+ }
3495
+ }
3496
+ _storeCachedOSVersion((_core || {}).config);
3452
3497
  }
3453
3498
  }
3454
- utlSetSessionStorage(_core.logger, "ai_osplugin", JSON.stringify({ platform: _os, platformVersion: _osVer }));
3499
+ else {
3500
+ _throwInternal(safeGetLogger(_core), 1 , 73 , "Could not retrieve operating system: " + response.reason);
3501
+ }
3455
3502
  }
3456
- }
3457
- else {
3458
- _throwInternal(_core.logger, 1 , 73 , "Could not retrieve operating system: " + response.reason);
3459
- }
3460
- _completeOsRetrieve();
3461
- });
3503
+ finally {
3504
+ _completeOsRetrieve();
3505
+ }
3506
+ });
3507
+ }
3462
3508
  }
3463
3509
  }
3464
3510
  }
3465
- function updateTeleItemWithOs(event) {
3466
- if (_retrieveFullVersion) {
3511
+ function _updateTeleItemWithOs(event) {
3512
+ if (_fetchedFullVersion && (_os || _osVer)) {
3467
3513
  var extOS = getSetValue(getSetValue(event, strExt), Extensions.OSExt);
3468
3514
  if (_mergeOsNameVersion) {
3469
- setValue(extOS, "osVer", _os + _osVer, isString);
3515
+ var mergedOS = (_os || "") + (_osVer ? asString(_osVer) : "");
3516
+ setValue(extOS, "osVer", mergedOS, isString);
3470
3517
  }
3471
3518
  else {
3472
3519
  setValue(extOS, "osVer", _osVer);
@@ -3477,13 +3524,14 @@ var OsPlugin = /** @class */ (function (_super) {
3477
3524
  function _completeOsRetrieve() {
3478
3525
  if (_getOSTimeout) {
3479
3526
  _getOSTimeout.cancel();
3527
+ _getOSTimeout = null;
3480
3528
  }
3481
- _getOSInProgress = false;
3529
+ _removeUnloadHandlers();
3482
3530
  _releaseEventQueue();
3483
3531
  }
3484
3532
  function _releaseEventQueue() {
3485
3533
  arrForEach(_eventQueue, function (evt) {
3486
- updateTeleItemWithOs(evt.item);
3534
+ _updateTeleItemWithOs(evt.item);
3487
3535
  _self.processNext(evt.item, evt.ctx);
3488
3536
  });
3489
3537
  _eventQueue = [];
@@ -3491,15 +3539,16 @@ var OsPlugin = /** @class */ (function (_super) {
3491
3539
  function _initDefaults() {
3492
3540
  _core = null;
3493
3541
  _ocConfig = null;
3494
- _getOSInProgress = false;
3495
3542
  _getOSTimeout = null;
3496
- _maxTimeout = null;
3497
- _retrieveFullVersion = false;
3498
3543
  _eventQueue = [];
3499
- _firstAttempt = true;
3544
+ _os = null;
3545
+ _osVer = null;
3546
+ _fetchedFullVersion = false;
3547
+ _addedUnloadEvents = false;
3548
+ _excludePageUnloadEvents = null;
3500
3549
  }
3501
3550
  _self["_getDbgPlgTargets"] = function () {
3502
- return [_platformVersionResponse, _eventQueue, _getOSInProgress];
3551
+ return [{ platform: _os, platformVersion: _osVer }, _eventQueue, !!_getOSTimeout];
3503
3552
  };
3504
3553
  });
3505
3554
  return _this;
@@ -3509,4 +3558,4 @@ var OsPlugin = /** @class */ (function (_super) {
3509
3558
  }(BaseTelemetryPlugin));
3510
3559
 
3511
3560
  exports.OsPlugin = OsPlugin;
3512
- //# sourceMappingURL=ai.osplugin.3.4.0-nightlybeta3.2602-27.cjs.js.map
3561
+ //# sourceMappingURL=ai.osplugin.3.4.1.cjs.js.map