@openreplay/tracker 11.0.6 → 12.0.0

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 (113) hide show
  1. package/CHANGELOG.md +4 -2
  2. package/cjs/app/index.d.ts +84 -6
  3. package/cjs/app/index.js +427 -58
  4. package/cjs/app/logger.d.ts +7 -17
  5. package/cjs/app/logger.js +11 -19
  6. package/cjs/app/messages.gen.d.ts +2 -0
  7. package/cjs/app/messages.gen.js +20 -1
  8. package/cjs/app/observer/iframe_observer.js +4 -1
  9. package/cjs/app/observer/shadow_root_observer.js +4 -1
  10. package/cjs/app/observer/top_observer.js +7 -4
  11. package/cjs/common/interaction.d.ts +5 -2
  12. package/cjs/common/messages.gen.d.ts +17 -2
  13. package/cjs/index.d.ts +45 -2
  14. package/cjs/index.js +237 -106
  15. package/cjs/modules/Network/beaconProxy.js +4 -1
  16. package/cjs/modules/Network/fetchProxy.js +24 -1
  17. package/cjs/modules/Network/index.js +6 -3
  18. package/cjs/modules/Network/xhrProxy.js +24 -1
  19. package/cjs/modules/conditionsManager.d.ts +84 -0
  20. package/cjs/modules/conditionsManager.js +343 -0
  21. package/cjs/modules/exception.js +4 -1
  22. package/cjs/modules/featureFlags.d.ts +1 -1
  23. package/cjs/modules/featureFlags.js +36 -46
  24. package/cjs/modules/network.js +5 -2
  25. package/cjs/modules/tagWatcher.d.ts +21 -0
  26. package/cjs/modules/tagWatcher.js +77 -0
  27. package/cjs/modules/userTesting/index.js +30 -4
  28. package/cjs/modules/userTesting/recorder.js +71 -88
  29. package/coverage/clover.xml +577 -544
  30. package/coverage/coverage-final.json +8 -8
  31. package/coverage/lcov-report/index.html +28 -28
  32. package/coverage/lcov-report/main/app/canvas.ts.html +97 -46
  33. package/coverage/lcov-report/main/app/guards.ts.html +1 -1
  34. package/coverage/lcov-report/main/app/index.html +19 -19
  35. package/coverage/lcov-report/main/app/index.ts.html +62 -35
  36. package/coverage/lcov-report/main/app/logger.ts.html +1 -1
  37. package/coverage/lcov-report/main/app/messages.gen.ts.html +32 -5
  38. package/coverage/lcov-report/main/app/nodes.ts.html +17 -5
  39. package/coverage/lcov-report/main/app/observer/iframe_observer.ts.html +1 -1
  40. package/coverage/lcov-report/main/app/observer/iframe_offsets.ts.html +1 -1
  41. package/coverage/lcov-report/main/app/observer/index.html +1 -1
  42. package/coverage/lcov-report/main/app/observer/shadow_root_observer.ts.html +1 -1
  43. package/coverage/lcov-report/main/app/observer/top_observer.ts.html +1 -1
  44. package/coverage/lcov-report/main/app/sanitizer.ts.html +1 -1
  45. package/coverage/lcov-report/main/app/session.ts.html +1 -1
  46. package/coverage/lcov-report/main/app/ticker.ts.html +1 -1
  47. package/coverage/lcov-report/main/index.html +9 -9
  48. package/coverage/lcov-report/main/index.ts.html +27 -6
  49. package/coverage/lcov-report/main/modules/Network/beaconProxy.ts.html +1 -1
  50. package/coverage/lcov-report/main/modules/Network/fetchProxy.ts.html +1 -1
  51. package/coverage/lcov-report/main/modules/Network/index.html +1 -1
  52. package/coverage/lcov-report/main/modules/Network/index.ts.html +1 -1
  53. package/coverage/lcov-report/main/modules/Network/networkMessage.ts.html +1 -1
  54. package/coverage/lcov-report/main/modules/Network/utils.ts.html +1 -1
  55. package/coverage/lcov-report/main/modules/Network/xhrProxy.ts.html +1 -1
  56. package/coverage/lcov-report/main/modules/attributeSender.ts.html +1 -1
  57. package/coverage/lcov-report/main/modules/axiosSpy.ts.html +1 -1
  58. package/coverage/lcov-report/main/modules/conditionsManager.ts.html +92 -38
  59. package/coverage/lcov-report/main/modules/connection.ts.html +1 -1
  60. package/coverage/lcov-report/main/modules/console.ts.html +1 -1
  61. package/coverage/lcov-report/main/modules/constructedStyleSheets.ts.html +1 -1
  62. package/coverage/lcov-report/main/modules/cssrules.ts.html +1 -1
  63. package/coverage/lcov-report/main/modules/exception.ts.html +1 -1
  64. package/coverage/lcov-report/main/modules/featureFlags.ts.html +1 -1
  65. package/coverage/lcov-report/main/modules/focus.ts.html +1 -1
  66. package/coverage/lcov-report/main/modules/fonts.ts.html +1 -1
  67. package/coverage/lcov-report/main/modules/img.ts.html +1 -1
  68. package/coverage/lcov-report/main/modules/index.html +21 -21
  69. package/coverage/lcov-report/main/modules/input.ts.html +1 -1
  70. package/coverage/lcov-report/main/modules/mouse.ts.html +1 -1
  71. package/coverage/lcov-report/main/modules/network.ts.html +1 -1
  72. package/coverage/lcov-report/main/modules/performance.ts.html +1 -1
  73. package/coverage/lcov-report/main/modules/scroll.ts.html +1 -1
  74. package/coverage/lcov-report/main/modules/selection.ts.html +1 -1
  75. package/coverage/lcov-report/main/modules/tabs.ts.html +1 -1
  76. package/coverage/lcov-report/main/modules/tagWatcher.ts.html +54 -27
  77. package/coverage/lcov-report/main/modules/timing.ts.html +1 -1
  78. package/coverage/lcov-report/main/modules/userTesting/SignalManager.ts.html +1 -1
  79. package/coverage/lcov-report/main/modules/userTesting/dnd.ts.html +1 -1
  80. package/coverage/lcov-report/main/modules/userTesting/index.html +1 -1
  81. package/coverage/lcov-report/main/modules/userTesting/index.ts.html +1 -1
  82. package/coverage/lcov-report/main/modules/userTesting/recorder.ts.html +1 -1
  83. package/coverage/lcov-report/main/modules/userTesting/styles.ts.html +1 -1
  84. package/coverage/lcov-report/main/modules/userTesting/utils.ts.html +1 -1
  85. package/coverage/lcov-report/main/modules/viewport.ts.html +1 -1
  86. package/coverage/lcov-report/main/utils.ts.html +1 -1
  87. package/coverage/lcov-report/webworker/BatchWriter.ts.html +1 -1
  88. package/coverage/lcov-report/webworker/MessageEncoder.gen.ts.html +17 -5
  89. package/coverage/lcov-report/webworker/PrimitiveEncoder.ts.html +1 -1
  90. package/coverage/lcov-report/webworker/QueueSender.ts.html +1 -1
  91. package/coverage/lcov-report/webworker/index.html +7 -7
  92. package/coverage/lcov-report/webworker/index.ts.html +1 -1
  93. package/coverage/lcov.info +1100 -1033
  94. package/lib/app/index.d.ts +84 -6
  95. package/lib/app/index.js +387 -44
  96. package/lib/app/logger.d.ts +7 -17
  97. package/lib/app/logger.js +11 -19
  98. package/lib/app/messages.gen.d.ts +2 -0
  99. package/lib/app/messages.gen.js +17 -0
  100. package/lib/common/interaction.d.ts +5 -2
  101. package/lib/common/messages.gen.d.ts +17 -2
  102. package/lib/common/tsconfig.tsbuildinfo +1 -1
  103. package/lib/index.d.ts +45 -2
  104. package/lib/index.js +191 -86
  105. package/lib/modules/conditionsManager.d.ts +84 -0
  106. package/lib/modules/conditionsManager.js +340 -0
  107. package/lib/modules/featureFlags.d.ts +1 -1
  108. package/lib/modules/featureFlags.js +36 -46
  109. package/lib/modules/tagWatcher.d.ts +21 -0
  110. package/lib/modules/tagWatcher.js +74 -0
  111. package/lib/modules/userTesting/recorder.js +71 -88
  112. package/package.json +1 -1
  113. package/tsconfig-base.json +3 -2
@@ -1,12 +1,3 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
1
  export const Quality = {
11
2
  Standard: { width: 1280, height: 720 },
12
3
  High: { width: 1920, height: 1080 },
@@ -19,93 +10,85 @@ export default class Recorder {
19
10
  this.stream = null;
20
11
  this.recStartTs = null;
21
12
  }
22
- startRecording(fps, quality, micReq, camReq) {
23
- return __awaiter(this, void 0, void 0, function* () {
24
- this.recStartTs = this.app.timestamp();
25
- const videoConstraints = quality;
26
- try {
27
- this.stream = yield navigator.mediaDevices.getUserMedia({
28
- video: camReq ? Object.assign(Object.assign({}, videoConstraints), { frameRate: { ideal: fps } }) : false,
29
- audio: micReq,
30
- });
31
- this.mediaRecorder = new MediaRecorder(this.stream, {
32
- mimeType: 'video/webm;codecs=vp9',
33
- });
34
- this.recordedChunks = [];
35
- this.mediaRecorder.ondataavailable = (event) => {
36
- if (event.data.size > 0) {
37
- this.recordedChunks.push(event.data);
38
- }
39
- };
40
- this.mediaRecorder.start();
41
- }
42
- catch (error) {
43
- console.error(error);
44
- }
45
- });
46
- }
47
- stopRecording() {
48
- return __awaiter(this, void 0, void 0, function* () {
49
- return new Promise((resolve) => {
50
- if (!this.mediaRecorder)
51
- return;
52
- this.mediaRecorder.onstop = () => {
53
- const blob = new Blob(this.recordedChunks, {
54
- type: 'video/webm',
55
- });
56
- resolve(blob);
57
- };
58
- this.mediaRecorder.stop();
13
+ async startRecording(fps, quality, micReq, camReq) {
14
+ this.recStartTs = this.app.timestamp();
15
+ const videoConstraints = quality;
16
+ try {
17
+ this.stream = await navigator.mediaDevices.getUserMedia({
18
+ video: camReq ? Object.assign(Object.assign({}, videoConstraints), { frameRate: { ideal: fps } }) : false,
19
+ audio: micReq,
59
20
  });
21
+ this.mediaRecorder = new MediaRecorder(this.stream, {
22
+ mimeType: 'video/webm;codecs=vp9',
23
+ });
24
+ this.recordedChunks = [];
25
+ this.mediaRecorder.ondataavailable = (event) => {
26
+ if (event.data.size > 0) {
27
+ this.recordedChunks.push(event.data);
28
+ }
29
+ };
30
+ this.mediaRecorder.start();
31
+ }
32
+ catch (error) {
33
+ console.error(error);
34
+ }
35
+ }
36
+ async stopRecording() {
37
+ return new Promise((resolve) => {
38
+ if (!this.mediaRecorder)
39
+ return;
40
+ this.mediaRecorder.onstop = () => {
41
+ const blob = new Blob(this.recordedChunks, {
42
+ type: 'video/webm',
43
+ });
44
+ resolve(blob);
45
+ };
46
+ this.mediaRecorder.stop();
60
47
  });
61
48
  }
62
- sendToAPI() {
63
- return __awaiter(this, void 0, void 0, function* () {
64
- const blob = yield this.stopRecording();
65
- // const formData = new FormData()
66
- // formData.append('file', blob, 'record.webm')
67
- // formData.append('start', this.recStartTs?.toString() ?? '')
68
- return fetch(`${this.app.options.ingestPoint}/v1/web/uxt/upload-url`, {
49
+ async sendToAPI() {
50
+ const blob = await this.stopRecording();
51
+ // const formData = new FormData()
52
+ // formData.append('file', blob, 'record.webm')
53
+ // formData.append('start', this.recStartTs?.toString() ?? '')
54
+ return fetch(`${this.app.options.ingestPoint}/v1/web/uxt/upload-url`, {
55
+ headers: {
56
+ Authorization: `Bearer ${this.app.session.getSessionToken()}`,
57
+ },
58
+ })
59
+ .then((r) => {
60
+ if (r.ok) {
61
+ return r.json();
62
+ }
63
+ else {
64
+ throw new Error('Failed to get upload url');
65
+ }
66
+ })
67
+ .then(({ url }) => {
68
+ return fetch(url, {
69
+ method: 'PUT',
69
70
  headers: {
70
- Authorization: `Bearer ${this.app.session.getSessionToken()}`,
71
+ 'Content-Type': 'video/webm',
71
72
  },
72
- })
73
- .then((r) => {
74
- if (r.ok) {
75
- return r.json();
76
- }
77
- else {
78
- throw new Error('Failed to get upload url');
79
- }
80
- })
81
- .then(({ url }) => {
82
- return fetch(url, {
83
- method: 'PUT',
84
- headers: {
85
- 'Content-Type': 'video/webm',
86
- },
87
- body: blob,
88
- });
89
- })
90
- .catch(console.error)
91
- .finally(() => {
92
- this.discard();
73
+ body: blob,
93
74
  });
75
+ })
76
+ .catch(console.error)
77
+ .finally(() => {
78
+ this.discard();
94
79
  });
95
80
  }
96
- saveToFile(fileName = 'recorded-video.webm') {
97
- return __awaiter(this, void 0, void 0, function* () {
98
- const blob = yield this.stopRecording();
99
- const url = URL.createObjectURL(blob);
100
- const a = document.createElement('a');
101
- a.style.display = 'none';
102
- a.href = url;
103
- a.download = fileName;
104
- document.body.appendChild(a);
105
- a.click();
106
- window.URL.revokeObjectURL(url);
107
- document.body.removeChild(a);
108
- });
81
+ async saveToFile(fileName = 'recorded-video.webm') {
82
+ const blob = await this.stopRecording();
83
+ const url = URL.createObjectURL(blob);
84
+ const a = document.createElement('a');
85
+ a.style.display = 'none';
86
+ a.href = url;
87
+ a.download = fileName;
88
+ document.body.appendChild(a);
89
+ a.click();
90
+ window.URL.revokeObjectURL(url);
91
+ document.body.removeChild(a);
109
92
  }
110
93
  discard() {
111
94
  var _a, _b;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@openreplay/tracker",
3
3
  "description": "The OpenReplay tracker main package",
4
- "version": "11.0.6",
4
+ "version": "12.0.0",
5
5
  "keywords": [
6
6
  "logging",
7
7
  "replay"
@@ -7,9 +7,10 @@
7
7
  "noImplicitThis": true,
8
8
  "strictNullChecks": true,
9
9
  "alwaysStrict": true,
10
- "target": "es6",
10
+ "target": "es2017",
11
11
  "module": "es6",
12
- "moduleResolution": "nodenext"
12
+ "moduleResolution": "nodenext",
13
+ "esModuleInterop": true
13
14
  },
14
15
  "exclude": ["**/*.test.ts"]
15
16
  }