clarity-decode 0.6.23
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/README.md +26 -0
- package/build/clarity.decode.js +677 -0
- package/build/clarity.decode.min.js +1 -0
- package/build/clarity.decode.module.js +673 -0
- package/package.json +61 -0
- package/rollup.config.ts +30 -0
- package/src/clarity.ts +195 -0
- package/src/data.ts +87 -0
- package/src/diagnostic.ts +34 -0
- package/src/global.ts +9 -0
- package/src/index.ts +1 -0
- package/src/interaction.ts +80 -0
- package/src/layout.ts +163 -0
- package/src/performance.ts +38 -0
- package/tsconfig.json +20 -0
- package/tslint.json +33 -0
- package/types/core.d.ts +8 -0
- package/types/data.d.ts +84 -0
- package/types/diagnostic.d.ts +9 -0
- package/types/index.d.ts +10 -0
- package/types/interaction.d.ts +23 -0
- package/types/layout.d.ts +29 -0
- package/types/performance.d.ts +8 -0
|
@@ -0,0 +1,673 @@
|
|
|
1
|
+
// tslint:disable: no-bitwise
|
|
2
|
+
function hash (input) {
|
|
3
|
+
// Code inspired from C# GetHashCode: https://github.com/Microsoft/referencesource/blob/master/mscorlib/system/string.cs
|
|
4
|
+
var hash = 0;
|
|
5
|
+
var hashOne = 5381;
|
|
6
|
+
var hashTwo = hashOne;
|
|
7
|
+
for (var i = 0; i < input.length; i += 2) {
|
|
8
|
+
var charOne = input.charCodeAt(i);
|
|
9
|
+
hashOne = ((hashOne << 5) + hashOne) ^ charOne;
|
|
10
|
+
if (i + 1 < input.length) {
|
|
11
|
+
var charTwo = input.charCodeAt(i + 1);
|
|
12
|
+
hashTwo = ((hashTwo << 5) + hashTwo) ^ charTwo;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
// Replace the magic number from C# implementation (1566083941) with a smaller prime number (11579)
|
|
16
|
+
// This ensures we don't hit integer overflow and prevent collisions
|
|
17
|
+
hash = Math.abs(hashOne + (hashTwo * 11579));
|
|
18
|
+
return hash.toString(36);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
var version$1 = "0.6.23";
|
|
22
|
+
|
|
23
|
+
function selector (tag, prefix, attributes, position) {
|
|
24
|
+
var suffix = position ? ":nth-of-type(" + position + ")" : "" /* Empty */;
|
|
25
|
+
switch (tag) {
|
|
26
|
+
case "STYLE":
|
|
27
|
+
case "TITLE":
|
|
28
|
+
case "LINK":
|
|
29
|
+
case "META":
|
|
30
|
+
case "*T" /* TextTag */:
|
|
31
|
+
case "*D" /* DocumentTag */:
|
|
32
|
+
return "" /* Empty */;
|
|
33
|
+
case "HTML":
|
|
34
|
+
return "HTML" /* HTML */;
|
|
35
|
+
default:
|
|
36
|
+
if (prefix === null) {
|
|
37
|
+
return "" /* Empty */;
|
|
38
|
+
}
|
|
39
|
+
tag = tag.indexOf("svg:" /* SvgPrefix */) === 0 ? tag.substr("svg:" /* SvgPrefix */.length) : tag;
|
|
40
|
+
var selector = "" + prefix + tag + suffix;
|
|
41
|
+
if ("class" /* Class */ in attributes && attributes["class" /* Class */].length > 0) {
|
|
42
|
+
selector = "" + prefix + tag + "." + attributes.class.trim().split(/\s+/).join(".") + suffix;
|
|
43
|
+
}
|
|
44
|
+
return selector;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
var helper = { hash: hash, selector: selector };
|
|
49
|
+
var version = version$1;
|
|
50
|
+
|
|
51
|
+
function decode$5(tokens) {
|
|
52
|
+
var time = tokens[0];
|
|
53
|
+
var event = tokens[1];
|
|
54
|
+
switch (event) {
|
|
55
|
+
case 25 /* Ping */:
|
|
56
|
+
var ping = { gap: tokens[2] };
|
|
57
|
+
return { time: time, event: event, data: ping };
|
|
58
|
+
case 35 /* Limit */:
|
|
59
|
+
var limit = { check: tokens[2] };
|
|
60
|
+
return { time: time, event: event, data: limit };
|
|
61
|
+
case 24 /* Custom */:
|
|
62
|
+
var custom = { key: tokens[2], value: tokens[3] };
|
|
63
|
+
return { time: time, event: event, data: custom };
|
|
64
|
+
case 3 /* Upgrade */:
|
|
65
|
+
var upgrade = { key: tokens[2] };
|
|
66
|
+
return { time: time, event: event, data: upgrade };
|
|
67
|
+
case 2 /* Upload */:
|
|
68
|
+
var upload = { sequence: tokens[2], attempts: tokens[3], status: tokens[4] };
|
|
69
|
+
return { time: time, event: event, data: upload };
|
|
70
|
+
case 0 /* Metric */:
|
|
71
|
+
var m = 2; // Start from 3rd index since first two are used for time & event
|
|
72
|
+
var metrics = {};
|
|
73
|
+
while (m < tokens.length) {
|
|
74
|
+
metrics[tokens[m++]] = tokens[m++];
|
|
75
|
+
}
|
|
76
|
+
return { time: time, event: event, data: metrics };
|
|
77
|
+
case 1 /* Dimension */:
|
|
78
|
+
var d = 2; // Start from 3rd index since first two are used for time & event
|
|
79
|
+
var dimensions = {};
|
|
80
|
+
while (d < tokens.length) {
|
|
81
|
+
dimensions[tokens[d++]] = tokens[d++];
|
|
82
|
+
}
|
|
83
|
+
return { time: time, event: event, data: dimensions };
|
|
84
|
+
case 36 /* Summary */:
|
|
85
|
+
var s = 2; // Start from 3rd index since first two are used for time & event
|
|
86
|
+
var summary = {};
|
|
87
|
+
while (s < tokens.length) {
|
|
88
|
+
var key = tokens[s++];
|
|
89
|
+
var values = tokens[s++];
|
|
90
|
+
summary[key] = [];
|
|
91
|
+
for (var i = 0; i < values.length - 1; i += 2) {
|
|
92
|
+
summary[key].push([values[i], values[i + 1]]);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return { time: time, event: event, data: summary };
|
|
96
|
+
case 4 /* Baseline */:
|
|
97
|
+
var baselineData = {
|
|
98
|
+
visible: tokens[2],
|
|
99
|
+
docWidth: tokens[3],
|
|
100
|
+
docHeight: tokens[4],
|
|
101
|
+
screenWidth: tokens[5],
|
|
102
|
+
screenHeight: tokens[6],
|
|
103
|
+
scrollX: tokens[7],
|
|
104
|
+
scrollY: tokens[8],
|
|
105
|
+
pointerX: tokens[9],
|
|
106
|
+
pointerY: tokens[10],
|
|
107
|
+
activityTime: tokens[11]
|
|
108
|
+
};
|
|
109
|
+
return { time: time, event: event, data: baselineData };
|
|
110
|
+
case 34 /* Variable */:
|
|
111
|
+
var v = 2; // Start from 3rd index since first two are used for time & event
|
|
112
|
+
var variables = {};
|
|
113
|
+
while (v < tokens.length) {
|
|
114
|
+
variables[tokens[v++]] = typeof tokens[v + 1] == "string" /* String */ ? [tokens[v++]] : tokens[v++];
|
|
115
|
+
}
|
|
116
|
+
return { time: time, event: event, data: variables };
|
|
117
|
+
}
|
|
118
|
+
return null;
|
|
119
|
+
}
|
|
120
|
+
function envelope(tokens) {
|
|
121
|
+
return {
|
|
122
|
+
version: tokens[0],
|
|
123
|
+
sequence: tokens[1],
|
|
124
|
+
start: tokens[2],
|
|
125
|
+
duration: tokens[3],
|
|
126
|
+
projectId: tokens[4],
|
|
127
|
+
userId: tokens[5],
|
|
128
|
+
sessionId: tokens[6],
|
|
129
|
+
pageNum: tokens[7],
|
|
130
|
+
upload: tokens[8],
|
|
131
|
+
end: tokens[9]
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
function decode$4(tokens) {
|
|
136
|
+
var time = tokens[0];
|
|
137
|
+
var event = tokens[1];
|
|
138
|
+
switch (event) {
|
|
139
|
+
case 32 /* ImageError */:
|
|
140
|
+
var imageError = {
|
|
141
|
+
source: tokens[2],
|
|
142
|
+
target: tokens[3],
|
|
143
|
+
};
|
|
144
|
+
return { time: time, event: event, data: imageError };
|
|
145
|
+
case 31 /* ScriptError */:
|
|
146
|
+
var scriptError = {
|
|
147
|
+
message: tokens[2],
|
|
148
|
+
line: tokens[3],
|
|
149
|
+
column: tokens[4],
|
|
150
|
+
stack: tokens[5],
|
|
151
|
+
source: tokens[6]
|
|
152
|
+
};
|
|
153
|
+
return { time: time, event: event, data: scriptError };
|
|
154
|
+
case 33 /* Log */:
|
|
155
|
+
var log = {
|
|
156
|
+
code: tokens[2],
|
|
157
|
+
name: tokens[3],
|
|
158
|
+
message: tokens[4],
|
|
159
|
+
stack: tokens[5],
|
|
160
|
+
severity: tokens[6]
|
|
161
|
+
};
|
|
162
|
+
return { time: time, event: event, data: log };
|
|
163
|
+
}
|
|
164
|
+
return null;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
function decode$3(tokens) {
|
|
168
|
+
var time = tokens[0];
|
|
169
|
+
var event = tokens[1];
|
|
170
|
+
switch (event) {
|
|
171
|
+
case 13 /* MouseDown */:
|
|
172
|
+
case 14 /* MouseUp */:
|
|
173
|
+
case 12 /* MouseMove */:
|
|
174
|
+
case 15 /* MouseWheel */:
|
|
175
|
+
case 16 /* DoubleClick */:
|
|
176
|
+
case 17 /* TouchStart */:
|
|
177
|
+
case 20 /* TouchCancel */:
|
|
178
|
+
case 18 /* TouchEnd */:
|
|
179
|
+
case 19 /* TouchMove */:
|
|
180
|
+
var pointerData = {
|
|
181
|
+
target: tokens[2],
|
|
182
|
+
x: tokens[3],
|
|
183
|
+
y: tokens[4]
|
|
184
|
+
};
|
|
185
|
+
return { time: time, event: event, data: pointerData };
|
|
186
|
+
case 9 /* Click */:
|
|
187
|
+
var clickData = {
|
|
188
|
+
target: tokens[2],
|
|
189
|
+
x: tokens[3],
|
|
190
|
+
y: tokens[4],
|
|
191
|
+
eX: tokens[5],
|
|
192
|
+
eY: tokens[6],
|
|
193
|
+
button: tokens[7],
|
|
194
|
+
reaction: tokens[8],
|
|
195
|
+
context: tokens[9],
|
|
196
|
+
text: tokens[10],
|
|
197
|
+
link: tokens[11],
|
|
198
|
+
hash: tokens[12]
|
|
199
|
+
};
|
|
200
|
+
return { time: time, event: event, data: clickData };
|
|
201
|
+
case 11 /* Resize */:
|
|
202
|
+
var resizeData = { width: tokens[2], height: tokens[3] };
|
|
203
|
+
return { time: time, event: event, data: resizeData };
|
|
204
|
+
case 27 /* Input */:
|
|
205
|
+
var inputData = {
|
|
206
|
+
target: tokens[2],
|
|
207
|
+
value: tokens[3]
|
|
208
|
+
};
|
|
209
|
+
return { time: time, event: event, data: inputData };
|
|
210
|
+
case 21 /* Selection */:
|
|
211
|
+
var selectionData = {
|
|
212
|
+
start: tokens[2],
|
|
213
|
+
startOffset: tokens[3],
|
|
214
|
+
end: tokens[4],
|
|
215
|
+
endOffset: tokens[5]
|
|
216
|
+
};
|
|
217
|
+
return { time: time, event: event, data: selectionData };
|
|
218
|
+
case 10 /* Scroll */:
|
|
219
|
+
var scrollData = {
|
|
220
|
+
target: tokens[2],
|
|
221
|
+
x: tokens[3],
|
|
222
|
+
y: tokens[4]
|
|
223
|
+
};
|
|
224
|
+
return { time: time, event: event, data: scrollData };
|
|
225
|
+
case 22 /* Timeline */:
|
|
226
|
+
var timelineData = {
|
|
227
|
+
type: tokens[2],
|
|
228
|
+
hash: tokens[3],
|
|
229
|
+
x: tokens[4],
|
|
230
|
+
y: tokens[5],
|
|
231
|
+
reaction: tokens[6],
|
|
232
|
+
context: tokens[7]
|
|
233
|
+
};
|
|
234
|
+
return { time: time, event: event, data: timelineData };
|
|
235
|
+
case 28 /* Visibility */:
|
|
236
|
+
var visibleData = { visible: tokens[2] };
|
|
237
|
+
return { time: time, event: event, data: visibleData };
|
|
238
|
+
case 26 /* Unload */:
|
|
239
|
+
var unloadData = { name: tokens[2] };
|
|
240
|
+
return { time: time, event: event, data: unloadData };
|
|
241
|
+
}
|
|
242
|
+
return null;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
var AverageWordLength = 6;
|
|
246
|
+
var Space = " ";
|
|
247
|
+
var hashes = {};
|
|
248
|
+
function reset() {
|
|
249
|
+
hashes = {};
|
|
250
|
+
}
|
|
251
|
+
function decode$2(tokens) {
|
|
252
|
+
var time = tokens[0];
|
|
253
|
+
var event = tokens[1];
|
|
254
|
+
switch (event) {
|
|
255
|
+
case 8 /* Document */:
|
|
256
|
+
var documentData = { width: tokens[2], height: tokens[3] };
|
|
257
|
+
return { time: time, event: event, data: documentData };
|
|
258
|
+
case 7 /* Region */:
|
|
259
|
+
var regionData = [];
|
|
260
|
+
// From 0.6.15 we send each reach update in an individual event. This allows us to include time with it.
|
|
261
|
+
// To keep it backward compatible (<= 0.6.14), we look for multiple regions in the same event. This works both with newer and older payloads.
|
|
262
|
+
// In future, we can update the logic to look deterministically for only 3 fields and remove the for loop.
|
|
263
|
+
for (var i = 2; i < tokens.length; i += 3) {
|
|
264
|
+
var region = {
|
|
265
|
+
id: tokens[i],
|
|
266
|
+
state: tokens[i + 1],
|
|
267
|
+
name: tokens[i + 2]
|
|
268
|
+
};
|
|
269
|
+
regionData.push(region);
|
|
270
|
+
}
|
|
271
|
+
return { time: time, event: event, data: regionData };
|
|
272
|
+
case 37 /* Box */:
|
|
273
|
+
var boxData = [];
|
|
274
|
+
for (var i = 2; i < tokens.length; i += 3) {
|
|
275
|
+
var box = {
|
|
276
|
+
id: tokens[i],
|
|
277
|
+
width: tokens[i + 1] / 100 /* BoxPrecision */,
|
|
278
|
+
height: tokens[i + 2] / 100 /* BoxPrecision */
|
|
279
|
+
};
|
|
280
|
+
boxData.push(box);
|
|
281
|
+
}
|
|
282
|
+
return { time: time, event: event, data: boxData };
|
|
283
|
+
case 5 /* Discover */:
|
|
284
|
+
case 6 /* Mutation */:
|
|
285
|
+
var lastType = null;
|
|
286
|
+
var node = [];
|
|
287
|
+
var tagIndex = 0;
|
|
288
|
+
var domData = [];
|
|
289
|
+
for (var i = 2; i < tokens.length; i++) {
|
|
290
|
+
var token = tokens[i];
|
|
291
|
+
var type = typeof (token);
|
|
292
|
+
switch (type) {
|
|
293
|
+
case "number":
|
|
294
|
+
if (type !== lastType && lastType !== null) {
|
|
295
|
+
domData.push(process(node, tagIndex));
|
|
296
|
+
node = [];
|
|
297
|
+
tagIndex = 0;
|
|
298
|
+
}
|
|
299
|
+
node.push(token);
|
|
300
|
+
tagIndex++;
|
|
301
|
+
break;
|
|
302
|
+
case "string":
|
|
303
|
+
node.push(token);
|
|
304
|
+
break;
|
|
305
|
+
case "object":
|
|
306
|
+
var subtoken = token[0];
|
|
307
|
+
var subtype = typeof (subtoken);
|
|
308
|
+
switch (subtype) {
|
|
309
|
+
case "number":
|
|
310
|
+
for (var _i = 0, _a = token; _i < _a.length; _i++) {
|
|
311
|
+
var t = _a[_i];
|
|
312
|
+
node.push(tokens.length > t ? tokens[t] : null);
|
|
313
|
+
}
|
|
314
|
+
break;
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
lastType = type;
|
|
318
|
+
}
|
|
319
|
+
// Process last node
|
|
320
|
+
domData.push(process(node, tagIndex));
|
|
321
|
+
return { time: time, event: event, data: domData };
|
|
322
|
+
}
|
|
323
|
+
return null;
|
|
324
|
+
}
|
|
325
|
+
function process(node, tagIndex) {
|
|
326
|
+
var _a = node[tagIndex] ? node[tagIndex].split("~") : [node[tagIndex]], tag = _a[0], position = _a[1];
|
|
327
|
+
var output = {
|
|
328
|
+
id: Math.abs(node[0]),
|
|
329
|
+
parent: tagIndex > 1 ? node[1] : null,
|
|
330
|
+
previous: tagIndex > 2 ? node[2] : null,
|
|
331
|
+
tag: tag,
|
|
332
|
+
position: position ? parseInt(position, 10) : null,
|
|
333
|
+
selector: null,
|
|
334
|
+
hash: null
|
|
335
|
+
};
|
|
336
|
+
var masked = node[0] < 0;
|
|
337
|
+
var hasAttribute = false;
|
|
338
|
+
var attributes = {};
|
|
339
|
+
var value = null;
|
|
340
|
+
var prefix = output.parent in hashes ? hashes[output.parent] + ">" : (output.parent ? "" /* Empty */ : null);
|
|
341
|
+
for (var i = tagIndex + 1; i < node.length; i++) {
|
|
342
|
+
// Explicitly convert the token into a string value
|
|
343
|
+
var token = node[i].toString();
|
|
344
|
+
var keyIndex = token.indexOf("=");
|
|
345
|
+
var firstChar = token[0];
|
|
346
|
+
var lastChar = token[token.length - 1];
|
|
347
|
+
if (i === (node.length - 1) && output.tag === "STYLE") {
|
|
348
|
+
value = token;
|
|
349
|
+
}
|
|
350
|
+
else if (output.tag !== "*T" /* TextTag */ && lastChar === ">" && keyIndex === -1) {
|
|
351
|
+
prefix = token;
|
|
352
|
+
}
|
|
353
|
+
else if (output.tag !== "*T" /* TextTag */ && firstChar === "#" /* Box */ && keyIndex === -1) {
|
|
354
|
+
var parts = token.substr(1).split("." /* Period */);
|
|
355
|
+
if (parts.length === 2) {
|
|
356
|
+
output.width = num(parts[0]) / 100 /* BoxPrecision */;
|
|
357
|
+
output.height = num(parts[1]) / 100 /* BoxPrecision */;
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
else if (output.tag !== "*T" /* TextTag */ && keyIndex > 0) {
|
|
361
|
+
hasAttribute = true;
|
|
362
|
+
var k = token.substr(0, keyIndex);
|
|
363
|
+
var v = token.substr(keyIndex + 1);
|
|
364
|
+
attributes[k] = v;
|
|
365
|
+
}
|
|
366
|
+
else if (output.tag === "*T" /* TextTag */) {
|
|
367
|
+
value = masked ? unmask(token) : token;
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
var selector = helper.selector(output.tag, prefix, attributes, output.position);
|
|
371
|
+
if (selector.length > 0) {
|
|
372
|
+
output.selector = selector;
|
|
373
|
+
output.hash = helper.hash(selector);
|
|
374
|
+
hashes[output.id] = selector;
|
|
375
|
+
}
|
|
376
|
+
if (hasAttribute) {
|
|
377
|
+
output.attributes = attributes;
|
|
378
|
+
}
|
|
379
|
+
if (value) {
|
|
380
|
+
output.value = value;
|
|
381
|
+
}
|
|
382
|
+
return output;
|
|
383
|
+
}
|
|
384
|
+
function num(input) {
|
|
385
|
+
return input ? parseInt(input, 36) : null;
|
|
386
|
+
}
|
|
387
|
+
function unmask(value) {
|
|
388
|
+
var trimmed = value.trim();
|
|
389
|
+
if (trimmed.length > 0 && trimmed.indexOf(Space) === -1) {
|
|
390
|
+
var length_1 = num(trimmed);
|
|
391
|
+
if (length_1 > 0) {
|
|
392
|
+
var quotient = Math.floor(length_1 / AverageWordLength);
|
|
393
|
+
var remainder = length_1 % AverageWordLength;
|
|
394
|
+
var output = Array(remainder + 1).join("\u2022" /* Mask */);
|
|
395
|
+
for (var i = 0; i < quotient; i++) {
|
|
396
|
+
output += (i === 0 && remainder === 0 ? "\u2022" /* Mask */ : Space) + Array(AverageWordLength).join("\u2022" /* Mask */);
|
|
397
|
+
}
|
|
398
|
+
return output;
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
return value;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
function decode$1(tokens) {
|
|
405
|
+
var time = tokens[0];
|
|
406
|
+
var event = tokens[1];
|
|
407
|
+
switch (event) {
|
|
408
|
+
case 30 /* Connection */:
|
|
409
|
+
var connectionData = {
|
|
410
|
+
downlink: tokens[2],
|
|
411
|
+
rtt: tokens[3],
|
|
412
|
+
saveData: tokens[4],
|
|
413
|
+
type: tokens[5]
|
|
414
|
+
};
|
|
415
|
+
return { time: time, event: event, data: connectionData };
|
|
416
|
+
case 29 /* Navigation */:
|
|
417
|
+
var navigationData = {
|
|
418
|
+
fetchStart: tokens[2],
|
|
419
|
+
connectStart: tokens[3],
|
|
420
|
+
connectEnd: tokens[4],
|
|
421
|
+
requestStart: tokens[5],
|
|
422
|
+
responseStart: tokens[6],
|
|
423
|
+
responseEnd: tokens[7],
|
|
424
|
+
domInteractive: tokens[8],
|
|
425
|
+
domComplete: tokens[9],
|
|
426
|
+
loadEventStart: tokens[10],
|
|
427
|
+
loadEventEnd: tokens[11],
|
|
428
|
+
redirectCount: tokens[12],
|
|
429
|
+
size: tokens[13],
|
|
430
|
+
type: tokens[14],
|
|
431
|
+
protocol: tokens[15],
|
|
432
|
+
encodedSize: tokens[16],
|
|
433
|
+
decodedSize: tokens[17]
|
|
434
|
+
};
|
|
435
|
+
return { time: time, event: event, data: navigationData };
|
|
436
|
+
}
|
|
437
|
+
return null;
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
function decode(input) {
|
|
441
|
+
var json = JSON.parse(input);
|
|
442
|
+
var envelope$1 = envelope(json.e);
|
|
443
|
+
var timestamp = Date.now();
|
|
444
|
+
var payload = { timestamp: timestamp, envelope: envelope$1 };
|
|
445
|
+
// Sort encoded events by time to simplify summary computation
|
|
446
|
+
// It's possible for individual events to be out of order, dependent on how they are buffered on the client
|
|
447
|
+
// E.g. scroll events are queued internally before they are sent over the wire.
|
|
448
|
+
// By comparison, events like resize & click are sent out immediately.
|
|
449
|
+
var encoded = json.p ? json.a.concat(json.p) : json.a;
|
|
450
|
+
encoded = encoded.sort(function (a, b) { return a[0] - b[0]; });
|
|
451
|
+
// Check if the incoming version is compatible with the current running code
|
|
452
|
+
// We do an exact match for the major version and minor version.
|
|
453
|
+
// For patch, we are backward and forward compatible with up to version change.
|
|
454
|
+
var jsonVersion = parseVersion(payload.envelope.version);
|
|
455
|
+
var codeVersion = parseVersion(version);
|
|
456
|
+
if (jsonVersion.major !== codeVersion.major ||
|
|
457
|
+
Math.abs(jsonVersion.minor - codeVersion.minor) > 1) {
|
|
458
|
+
throw new Error("Invalid version. Actual: " + payload.envelope.version + " | Expected: " + version + " (+/- 1) | " + input.substr(0, 250));
|
|
459
|
+
}
|
|
460
|
+
/* Reset components before decoding to keep them stateless */
|
|
461
|
+
reset();
|
|
462
|
+
for (var _i = 0, encoded_1 = encoded; _i < encoded_1.length; _i++) {
|
|
463
|
+
var entry = encoded_1[_i];
|
|
464
|
+
switch (entry[1]) {
|
|
465
|
+
case 4 /* Baseline */:
|
|
466
|
+
if (payload.baseline === undefined) {
|
|
467
|
+
payload.baseline = [];
|
|
468
|
+
}
|
|
469
|
+
payload.baseline.push(decode$5(entry));
|
|
470
|
+
break;
|
|
471
|
+
case 25 /* Ping */:
|
|
472
|
+
if (payload.ping === undefined) {
|
|
473
|
+
payload.ping = [];
|
|
474
|
+
}
|
|
475
|
+
payload.ping.push(decode$5(entry));
|
|
476
|
+
break;
|
|
477
|
+
case 35 /* Limit */:
|
|
478
|
+
if (payload.limit === undefined) {
|
|
479
|
+
payload.limit = [];
|
|
480
|
+
}
|
|
481
|
+
payload.limit.push(decode$5(entry));
|
|
482
|
+
break;
|
|
483
|
+
case 3 /* Upgrade */:
|
|
484
|
+
if (payload.upgrade === undefined) {
|
|
485
|
+
payload.upgrade = [];
|
|
486
|
+
}
|
|
487
|
+
payload.upgrade.push(decode$5(entry));
|
|
488
|
+
break;
|
|
489
|
+
case 0 /* Metric */:
|
|
490
|
+
if (payload.metric === undefined) {
|
|
491
|
+
payload.metric = [];
|
|
492
|
+
}
|
|
493
|
+
var metric = decode$5(entry);
|
|
494
|
+
// It's not possible to accurately include the byte count of the payload within the same payload
|
|
495
|
+
// The value we get from clarity-js lags behind by a payload. To work around that,
|
|
496
|
+
// we increment the bytes from the incoming payload at decode time.
|
|
497
|
+
metric.data[2 /* TotalBytes */] = input.length;
|
|
498
|
+
payload.metric.push(metric);
|
|
499
|
+
break;
|
|
500
|
+
case 1 /* Dimension */:
|
|
501
|
+
if (payload.dimension === undefined) {
|
|
502
|
+
payload.dimension = [];
|
|
503
|
+
}
|
|
504
|
+
payload.dimension.push(decode$5(entry));
|
|
505
|
+
break;
|
|
506
|
+
case 36 /* Summary */:
|
|
507
|
+
if (payload.summary === undefined) {
|
|
508
|
+
payload.summary = [];
|
|
509
|
+
}
|
|
510
|
+
payload.summary.push(decode$5(entry));
|
|
511
|
+
break;
|
|
512
|
+
case 24 /* Custom */:
|
|
513
|
+
if (payload.custom === undefined) {
|
|
514
|
+
payload.custom = [];
|
|
515
|
+
}
|
|
516
|
+
payload.custom.push(decode$5(entry));
|
|
517
|
+
break;
|
|
518
|
+
case 34 /* Variable */:
|
|
519
|
+
if (payload.variable === undefined) {
|
|
520
|
+
payload.variable = [];
|
|
521
|
+
}
|
|
522
|
+
payload.variable.push(decode$5(entry));
|
|
523
|
+
break;
|
|
524
|
+
case 2 /* Upload */:
|
|
525
|
+
if (payload.upload === undefined) {
|
|
526
|
+
payload.upload = [];
|
|
527
|
+
}
|
|
528
|
+
payload.upload.push(decode$5(entry));
|
|
529
|
+
break;
|
|
530
|
+
case 13 /* MouseDown */:
|
|
531
|
+
case 14 /* MouseUp */:
|
|
532
|
+
case 12 /* MouseMove */:
|
|
533
|
+
case 15 /* MouseWheel */:
|
|
534
|
+
case 16 /* DoubleClick */:
|
|
535
|
+
case 17 /* TouchStart */:
|
|
536
|
+
case 20 /* TouchCancel */:
|
|
537
|
+
case 18 /* TouchEnd */:
|
|
538
|
+
case 19 /* TouchMove */:
|
|
539
|
+
if (payload.pointer === undefined) {
|
|
540
|
+
payload.pointer = [];
|
|
541
|
+
}
|
|
542
|
+
payload.pointer.push(decode$3(entry));
|
|
543
|
+
break;
|
|
544
|
+
case 9 /* Click */:
|
|
545
|
+
if (payload.click === undefined) {
|
|
546
|
+
payload.click = [];
|
|
547
|
+
}
|
|
548
|
+
var clickEntry = decode$3(entry);
|
|
549
|
+
payload.click.push(clickEntry);
|
|
550
|
+
break;
|
|
551
|
+
case 10 /* Scroll */:
|
|
552
|
+
if (payload.scroll === undefined) {
|
|
553
|
+
payload.scroll = [];
|
|
554
|
+
}
|
|
555
|
+
payload.scroll.push(decode$3(entry));
|
|
556
|
+
break;
|
|
557
|
+
case 11 /* Resize */:
|
|
558
|
+
if (payload.resize === undefined) {
|
|
559
|
+
payload.resize = [];
|
|
560
|
+
}
|
|
561
|
+
payload.resize.push(decode$3(entry));
|
|
562
|
+
break;
|
|
563
|
+
case 21 /* Selection */:
|
|
564
|
+
if (payload.selection === undefined) {
|
|
565
|
+
payload.selection = [];
|
|
566
|
+
}
|
|
567
|
+
payload.selection.push(decode$3(entry));
|
|
568
|
+
break;
|
|
569
|
+
case 22 /* Timeline */:
|
|
570
|
+
if (payload.timeline === undefined) {
|
|
571
|
+
payload.timeline = [];
|
|
572
|
+
}
|
|
573
|
+
payload.timeline.push(decode$3(entry));
|
|
574
|
+
break;
|
|
575
|
+
case 27 /* Input */:
|
|
576
|
+
if (payload.input === undefined) {
|
|
577
|
+
payload.input = [];
|
|
578
|
+
}
|
|
579
|
+
payload.input.push(decode$3(entry));
|
|
580
|
+
break;
|
|
581
|
+
case 26 /* Unload */:
|
|
582
|
+
if (payload.unload === undefined) {
|
|
583
|
+
payload.unload = [];
|
|
584
|
+
}
|
|
585
|
+
payload.unload.push(decode$3(entry));
|
|
586
|
+
break;
|
|
587
|
+
case 28 /* Visibility */:
|
|
588
|
+
if (payload.visibility === undefined) {
|
|
589
|
+
payload.visibility = [];
|
|
590
|
+
}
|
|
591
|
+
payload.visibility.push(decode$3(entry));
|
|
592
|
+
break;
|
|
593
|
+
case 37 /* Box */:
|
|
594
|
+
if (payload.box === undefined) {
|
|
595
|
+
payload.box = [];
|
|
596
|
+
}
|
|
597
|
+
payload.box.push(decode$2(entry));
|
|
598
|
+
break;
|
|
599
|
+
case 7 /* Region */:
|
|
600
|
+
if (payload.region === undefined) {
|
|
601
|
+
payload.region = [];
|
|
602
|
+
}
|
|
603
|
+
payload.region.push(decode$2(entry));
|
|
604
|
+
break;
|
|
605
|
+
case 5 /* Discover */:
|
|
606
|
+
case 6 /* Mutation */:
|
|
607
|
+
if (payload.dom === undefined) {
|
|
608
|
+
payload.dom = [];
|
|
609
|
+
}
|
|
610
|
+
payload.dom.push(decode$2(entry));
|
|
611
|
+
break;
|
|
612
|
+
case 8 /* Document */:
|
|
613
|
+
if (payload.doc === undefined) {
|
|
614
|
+
payload.doc = [];
|
|
615
|
+
}
|
|
616
|
+
payload.doc.push(decode$2(entry));
|
|
617
|
+
break;
|
|
618
|
+
case 31 /* ScriptError */:
|
|
619
|
+
if (payload.script === undefined) {
|
|
620
|
+
payload.script = [];
|
|
621
|
+
}
|
|
622
|
+
payload.script.push(decode$4(entry));
|
|
623
|
+
break;
|
|
624
|
+
case 32 /* ImageError */:
|
|
625
|
+
if (payload.image === undefined) {
|
|
626
|
+
payload.image = [];
|
|
627
|
+
}
|
|
628
|
+
payload.image.push(decode$4(entry));
|
|
629
|
+
break;
|
|
630
|
+
case 33 /* Log */:
|
|
631
|
+
if (payload.log === undefined) {
|
|
632
|
+
payload.log = [];
|
|
633
|
+
}
|
|
634
|
+
payload.log.push(decode$4(entry));
|
|
635
|
+
break;
|
|
636
|
+
case 30 /* Connection */:
|
|
637
|
+
if (payload.connection === undefined) {
|
|
638
|
+
payload.connection = [];
|
|
639
|
+
}
|
|
640
|
+
payload.connection.push(decode$1(entry));
|
|
641
|
+
break;
|
|
642
|
+
case 29 /* Navigation */:
|
|
643
|
+
if (payload.navigation === undefined) {
|
|
644
|
+
payload.navigation = [];
|
|
645
|
+
}
|
|
646
|
+
payload.navigation.push(decode$1(entry));
|
|
647
|
+
break;
|
|
648
|
+
default:
|
|
649
|
+
console.error("No handler for Event: " + JSON.stringify(entry));
|
|
650
|
+
break;
|
|
651
|
+
}
|
|
652
|
+
}
|
|
653
|
+
return payload;
|
|
654
|
+
}
|
|
655
|
+
function parseVersion(ver) {
|
|
656
|
+
var output = { major: 0, minor: 0, patch: 0, beta: 0 };
|
|
657
|
+
var parts = ver.split(".");
|
|
658
|
+
if (parts.length === 3) {
|
|
659
|
+
var subparts = parts[2].split("-b");
|
|
660
|
+
output.major = parseInt(parts[0], 10);
|
|
661
|
+
output.minor = parseInt(parts[1], 10);
|
|
662
|
+
if (subparts.length === 2) {
|
|
663
|
+
output.patch = parseInt(subparts[0], 10);
|
|
664
|
+
output.beta = parseInt(subparts[1], 10);
|
|
665
|
+
}
|
|
666
|
+
else {
|
|
667
|
+
output.patch = parseInt(parts[2], 10);
|
|
668
|
+
}
|
|
669
|
+
}
|
|
670
|
+
return output;
|
|
671
|
+
}
|
|
672
|
+
|
|
673
|
+
export { decode };
|