@atlaskit/react-ufo 2.4.6 → 2.4.7
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.
- package/CHANGELOG.md +14 -0
- package/create-experimental-interaction-metrics-payload/package.json +15 -0
- package/dist/cjs/config/index.js +40 -18
- package/dist/cjs/create-experimental-interaction-metrics-payload/index.js +89 -0
- package/dist/cjs/create-payload/common/utils/index.js +85 -1
- package/dist/cjs/create-payload/index.js +37 -77
- package/dist/cjs/create-post-interaction-log-payload/index.js +1 -4
- package/dist/cjs/interaction-metrics/common/constants.js +7 -1
- package/dist/cjs/interaction-metrics/common/index.js +151 -0
- package/dist/cjs/interaction-metrics/index.js +139 -204
- package/dist/cjs/interaction-metrics/post-interaction-log.js +6 -2
- package/dist/cjs/interaction-metrics-init/index.js +27 -9
- package/dist/cjs/load-hold/UFOLoadHold.js +3 -4
- package/dist/cjs/segment/segment.js +7 -9
- package/dist/cjs/trace-pageload/index.js +2 -1
- package/dist/es2019/config/index.js +22 -0
- package/dist/es2019/create-experimental-interaction-metrics-payload/index.js +67 -0
- package/dist/es2019/create-payload/common/utils/index.js +86 -1
- package/dist/es2019/create-payload/index.js +28 -74
- package/dist/es2019/create-post-interaction-log-payload/index.js +1 -4
- package/dist/es2019/interaction-metrics/common/constants.js +6 -0
- package/dist/es2019/interaction-metrics/common/index.js +103 -0
- package/dist/es2019/interaction-metrics/index.js +92 -129
- package/dist/es2019/interaction-metrics/post-interaction-log.js +6 -2
- package/dist/es2019/interaction-metrics-init/index.js +21 -8
- package/dist/es2019/load-hold/UFOLoadHold.js +3 -4
- package/dist/es2019/segment/segment.js +6 -12
- package/dist/es2019/trace-pageload/index.js +1 -1
- package/dist/esm/config/index.js +39 -18
- package/dist/esm/create-experimental-interaction-metrics-payload/index.js +81 -0
- package/dist/esm/create-payload/common/utils/index.js +80 -1
- package/dist/esm/create-payload/index.js +33 -75
- package/dist/esm/create-post-interaction-log-payload/index.js +1 -4
- package/dist/esm/interaction-metrics/common/constants.js +6 -0
- package/dist/esm/interaction-metrics/common/index.js +132 -0
- package/dist/esm/interaction-metrics/index.js +87 -156
- package/dist/esm/interaction-metrics/post-interaction-log.js +6 -2
- package/dist/esm/interaction-metrics-init/index.js +24 -10
- package/dist/esm/load-hold/UFOLoadHold.js +3 -4
- package/dist/esm/segment/segment.js +7 -9
- package/dist/esm/trace-pageload/index.js +1 -1
- package/dist/types/common/common/types.d.ts +9 -5
- package/dist/types/config/index.d.ts +6 -0
- package/dist/types/create-experimental-interaction-metrics-payload/index.d.ts +31 -0
- package/dist/types/create-payload/common/utils/index.d.ts +12 -0
- package/dist/types/create-payload/index.d.ts +13 -5660
- package/dist/types/create-post-interaction-log-payload/index.d.ts +2 -0
- package/dist/types/interaction-metrics/common/constants.d.ts +31 -1
- package/dist/types/interaction-metrics/common/index.d.ts +16 -0
- package/dist/types/interaction-metrics/index.d.ts +4 -15
- package/dist/types/interaction-metrics/post-interaction-log.d.ts +1 -1
- package/dist/types/load-hold/UFOLoadHold.d.ts +1 -2
- package/dist/types/trace-pageload/index.d.ts +1 -0
- package/dist/types-ts4.5/common/common/types.d.ts +9 -5
- package/dist/types-ts4.5/config/index.d.ts +6 -0
- package/dist/types-ts4.5/create-experimental-interaction-metrics-payload/index.d.ts +31 -0
- package/dist/types-ts4.5/create-payload/common/utils/index.d.ts +12 -0
- package/dist/types-ts4.5/create-payload/index.d.ts +13 -5660
- package/dist/types-ts4.5/create-post-interaction-log-payload/index.d.ts +2 -0
- package/dist/types-ts4.5/interaction-metrics/common/constants.d.ts +31 -1
- package/dist/types-ts4.5/interaction-metrics/common/index.d.ts +16 -0
- package/dist/types-ts4.5/interaction-metrics/index.d.ts +4 -15
- package/dist/types-ts4.5/interaction-metrics/post-interaction-log.d.ts +1 -1
- package/dist/types-ts4.5/load-hold/UFOLoadHold.d.ts +1 -2
- package/dist/types-ts4.5/trace-pageload/index.d.ts +1 -0
- package/package.json +2 -1
|
@@ -3,6 +3,12 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.default = void 0;
|
|
6
|
+
exports.segmentObservers = exports.segmentCache = exports.moduleLoadingRequests = exports.interactionQueue = exports.default = exports.CLEANUP_TIMEOUT_AFTER_APDEX = exports.CLEANUP_TIMEOUT = void 0;
|
|
7
7
|
var interactions = new Map();
|
|
8
|
+
var CLEANUP_TIMEOUT = exports.CLEANUP_TIMEOUT = 60 * 1000;
|
|
9
|
+
var CLEANUP_TIMEOUT_AFTER_APDEX = exports.CLEANUP_TIMEOUT_AFTER_APDEX = 15 * 1000;
|
|
10
|
+
var interactionQueue = exports.interactionQueue = [];
|
|
11
|
+
var segmentCache = exports.segmentCache = new Map();
|
|
12
|
+
var segmentObservers = exports.segmentObservers = [];
|
|
13
|
+
var moduleLoadingRequests = exports.moduleLoadingRequests = {};
|
|
8
14
|
var _default = exports.default = interactions;
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.addHoldCriterion = addHoldCriterion;
|
|
8
|
+
exports.addSegmentObserver = addSegmentObserver;
|
|
9
|
+
exports.callCancelCallbacks = callCancelCallbacks;
|
|
10
|
+
exports.callCleanUpCallbacks = callCleanUpCallbacks;
|
|
11
|
+
exports.getSegmentCacheKey = getSegmentCacheKey;
|
|
12
|
+
exports.isPerformanceTracingEnabled = isPerformanceTracingEnabled;
|
|
13
|
+
exports.isSegmentLabel = isSegmentLabel;
|
|
14
|
+
exports.labelStackToIdString = labelStackToIdString;
|
|
15
|
+
exports.labelStackToString = labelStackToString;
|
|
16
|
+
exports.pushToQueue = void 0;
|
|
17
|
+
exports.reactProfilerTimingMap = reactProfilerTimingMap;
|
|
18
|
+
exports.removeHoldCriterion = removeHoldCriterion;
|
|
19
|
+
exports.removeSegmentObserver = removeSegmentObserver;
|
|
20
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
21
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
22
|
+
var _config = require("../../config");
|
|
23
|
+
var _constants = require("./constants");
|
|
24
|
+
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
|
|
25
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
26
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
27
|
+
function isPerformanceTracingEnabled() {
|
|
28
|
+
var _getConfig;
|
|
29
|
+
return ((_getConfig = (0, _config.getConfig)()) === null || _getConfig === void 0 ? void 0 : _getConfig.enableAdditionalPerformanceMarks) || window.__REACT_UFO_ENABLE_PERF_TRACING || process.env.NODE_ENV !== 'production';
|
|
30
|
+
}
|
|
31
|
+
function labelStackToString(labelStack, name) {
|
|
32
|
+
var _stack$map;
|
|
33
|
+
var stack = (0, _toConsumableArray2.default)(labelStack !== null && labelStack !== void 0 ? labelStack : []);
|
|
34
|
+
if (name) {
|
|
35
|
+
stack.push({
|
|
36
|
+
name: name
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
return (_stack$map = stack.map(function (l) {
|
|
40
|
+
return l.name;
|
|
41
|
+
})) === null || _stack$map === void 0 ? void 0 : _stack$map.join('/');
|
|
42
|
+
}
|
|
43
|
+
function labelStackToIdString(labelStack) {
|
|
44
|
+
var _labelStack$map;
|
|
45
|
+
return labelStack === null || labelStack === void 0 || (_labelStack$map = labelStack.map(function (l) {
|
|
46
|
+
return 'segmentId' in l ? "".concat(l.name, ":").concat(l.segmentId) : "".concat(l.name);
|
|
47
|
+
})) === null || _labelStack$map === void 0 ? void 0 : _labelStack$map.join('/');
|
|
48
|
+
}
|
|
49
|
+
function addSegmentObserver(observer) {
|
|
50
|
+
_constants.segmentObservers.push(observer);
|
|
51
|
+
var _iterator = _createForOfIteratorHelper(_constants.segmentCache.values()),
|
|
52
|
+
_step;
|
|
53
|
+
try {
|
|
54
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
55
|
+
var segmentInfo = _step.value;
|
|
56
|
+
observer.onAdd(segmentInfo);
|
|
57
|
+
}
|
|
58
|
+
} catch (err) {
|
|
59
|
+
_iterator.e(err);
|
|
60
|
+
} finally {
|
|
61
|
+
_iterator.f();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
function removeSegmentObserver(observer) {
|
|
65
|
+
var index = _constants.segmentObservers.findIndex(function (obs) {
|
|
66
|
+
return obs === observer;
|
|
67
|
+
});
|
|
68
|
+
if (index !== -1) {
|
|
69
|
+
_constants.segmentObservers.splice(index, 1);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
function addHoldCriterion(id, labelStack, name, startTime) {
|
|
73
|
+
var _window$__CRITERION__;
|
|
74
|
+
if (!((_window$__CRITERION__ = window.__CRITERION__) !== null && _window$__CRITERION__ !== void 0 && _window$__CRITERION__.addUFOHold)) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
window.__CRITERION__.addUFOHold(id, labelStackToString(labelStack), name, startTime);
|
|
78
|
+
}
|
|
79
|
+
function removeHoldCriterion(id) {
|
|
80
|
+
var _window$__CRITERION__2;
|
|
81
|
+
if (!((_window$__CRITERION__2 = window.__CRITERION__) !== null && _window$__CRITERION__2 !== void 0 && _window$__CRITERION__2.removeUFOHold)) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
window.__CRITERION__.removeUFOHold(id);
|
|
85
|
+
}
|
|
86
|
+
var pushToQueue = exports.pushToQueue = function pushToQueue(id, data) {
|
|
87
|
+
_constants.interactionQueue.push({
|
|
88
|
+
id: id,
|
|
89
|
+
data: data
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
function callCleanUpCallbacks(interaction) {
|
|
93
|
+
interaction.cleanupCallbacks.reverse().forEach(function (cleanUpCallback) {
|
|
94
|
+
cleanUpCallback();
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
function reactProfilerTimingMap(data) {
|
|
98
|
+
var profilerTimingMap = new Map();
|
|
99
|
+
data.reactProfilerTimings.forEach(function (profilerTiming) {
|
|
100
|
+
var labelStackId = labelStackToIdString(profilerTiming.labelStack);
|
|
101
|
+
if (labelStackId) {
|
|
102
|
+
var _profilerTimingMap$ge, _timing$start, _timing$end;
|
|
103
|
+
var timing = (_profilerTimingMap$ge = profilerTimingMap.get(labelStackId)) !== null && _profilerTimingMap$ge !== void 0 ? _profilerTimingMap$ge : {
|
|
104
|
+
labelStack: profilerTiming.labelStack
|
|
105
|
+
};
|
|
106
|
+
timing.start = profilerTiming.startTime < ((_timing$start = timing.start) !== null && _timing$start !== void 0 ? _timing$start : Number.MAX_SAFE_INTEGER) ? profilerTiming.startTime : timing.start;
|
|
107
|
+
timing.end = profilerTiming.commitTime > ((_timing$end = timing.end) !== null && _timing$end !== void 0 ? _timing$end : Number.MIN_SAFE_INTEGER) ? profilerTiming.commitTime : timing.end;
|
|
108
|
+
profilerTimingMap.set(labelStackId, timing);
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
try {
|
|
112
|
+
// for Firefox 102 and older
|
|
113
|
+
var _iterator2 = _createForOfIteratorHelper(profilerTimingMap.entries()),
|
|
114
|
+
_step2;
|
|
115
|
+
try {
|
|
116
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
117
|
+
var _step2$value = (0, _slicedToArray2.default)(_step2.value, 2),
|
|
118
|
+
_step2$value$ = _step2$value[1],
|
|
119
|
+
labelStack = _step2$value$.labelStack,
|
|
120
|
+
start = _step2$value$.start,
|
|
121
|
+
end = _step2$value$.end;
|
|
122
|
+
performance.measure("\uD83D\uDEF8 ".concat(labelStackToString(labelStack), " [segment_ttai]"), {
|
|
123
|
+
start: start,
|
|
124
|
+
end: end
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
} catch (err) {
|
|
128
|
+
_iterator2.e(err);
|
|
129
|
+
} finally {
|
|
130
|
+
_iterator2.f();
|
|
131
|
+
}
|
|
132
|
+
} catch (e) {
|
|
133
|
+
// do nothing
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
function callCancelCallbacks(interaction) {
|
|
137
|
+
interaction.cancelCallbacks.reverse().forEach(function (cancelCallback) {
|
|
138
|
+
cancelCallback();
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
function isSegmentLabel(obj) {
|
|
142
|
+
return obj && typeof obj.name === 'string' && typeof obj.segmentId === 'string';
|
|
143
|
+
}
|
|
144
|
+
function getSegmentCacheKey(labelStack) {
|
|
145
|
+
return labelStack.map(function (l) {
|
|
146
|
+
if (isSegmentLabel(l)) {
|
|
147
|
+
return "".concat(l.name, "_").concat(l.segmentId);
|
|
148
|
+
}
|
|
149
|
+
return l.name;
|
|
150
|
+
}).join('|');
|
|
151
|
+
}
|