@checkly/playwright-core 1.42.16 → 1.42.18

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 (32) hide show
  1. package/lib/vite/recorder/assets/{codeMirrorModule-LTVFY0Ab.js → codeMirrorModule-W69B4LBB.js} +14 -14
  2. package/lib/vite/recorder/assets/{index-wuONJPd7.js → index-Ly3PcVUb.js} +2 -2
  3. package/lib/vite/recorder/index.html +1 -1
  4. package/lib/vite/traceViewer/index.html +2 -2
  5. package/lib/vite/traceViewer/uiMode.html +2 -2
  6. package/package.json +1 -1
  7. package/lib/vite/traceViewer/assets/codeMirrorModule-BK3t1EEu.js +0 -24
  8. package/lib/vite/traceViewer/assets/codeMirrorModule-RVP_AMUu.js +0 -15585
  9. package/lib/vite/traceViewer/assets/codeMirrorModule-V7N6ppkd.js +0 -15585
  10. package/lib/vite/traceViewer/assets/codeMirrorModule-Vg1kIqMp.js +0 -24
  11. package/lib/vite/traceViewer/assets/codeMirrorModule-yboVpgC0.js +0 -15592
  12. package/lib/vite/traceViewer/assets/wsPort-1-6TL4lc.js +0 -18540
  13. package/lib/vite/traceViewer/assets/wsPort-964mA9MZ.js +0 -69
  14. package/lib/vite/traceViewer/assets/wsPort-CAXygIGt.js +0 -18540
  15. package/lib/vite/traceViewer/assets/wsPort-EUvw-dwH.js +0 -18540
  16. package/lib/vite/traceViewer/assets/wsPort-RIoVGhlT.js +0 -69
  17. package/lib/vite/traceViewer/assets/xtermModule-_6TC5FYT.js +0 -6529
  18. package/lib/vite/traceViewer/codeMirrorModule.svF_VrcJ.css +0 -344
  19. package/lib/vite/traceViewer/index.5mge2rY_.css +0 -124
  20. package/lib/vite/traceViewer/index.5nqVcfiC.js +0 -180
  21. package/lib/vite/traceViewer/index.6KJ-JQ0L.js +0 -180
  22. package/lib/vite/traceViewer/index.UNF4A0jZ.js +0 -180
  23. package/lib/vite/traceViewer/index.cbtHmFgM.js +0 -2
  24. package/lib/vite/traceViewer/index.qOFdH9Ja.js +0 -2
  25. package/lib/vite/traceViewer/uiMode.e-PLonGl.js +0 -1490
  26. package/lib/vite/traceViewer/uiMode.fEEgOxJh.js +0 -1490
  27. package/lib/vite/traceViewer/uiMode.fcU_T5Nf.js +0 -10
  28. package/lib/vite/traceViewer/uiMode.iNIhieBM.js +0 -10
  29. package/lib/vite/traceViewer/uiMode.iq7CyYy7.js +0 -1490
  30. package/lib/vite/traceViewer/uiMode.xvJHbkzl.css +0 -1324
  31. package/lib/vite/traceViewer/wsPort.p5jUwABW.css +0 -3450
  32. package/lib/vite/traceViewer/xtermModule.OKEVRlkP.css +0 -209
@@ -1,344 +0,0 @@
1
- /* BASICS */
2
-
3
- .CodeMirror {
4
- /* Set height, width, borders, and global font properties here */
5
- font-family: monospace;
6
- height: 300px;
7
- color: black;
8
- direction: ltr;
9
- }
10
-
11
- /* PADDING */
12
-
13
- .CodeMirror-lines {
14
- padding: 4px 0; /* Vertical padding around content */
15
- }
16
- .CodeMirror pre.CodeMirror-line,
17
- .CodeMirror pre.CodeMirror-line-like {
18
- padding: 0 4px; /* Horizontal padding of content */
19
- }
20
-
21
- .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
22
- background-color: white; /* The little square between H and V scrollbars */
23
- }
24
-
25
- /* GUTTER */
26
-
27
- .CodeMirror-gutters {
28
- border-right: 1px solid #ddd;
29
- background-color: #f7f7f7;
30
- white-space: nowrap;
31
- }
32
- .CodeMirror-linenumbers {}
33
- .CodeMirror-linenumber {
34
- padding: 0 3px 0 5px;
35
- min-width: 20px;
36
- text-align: right;
37
- color: #999;
38
- white-space: nowrap;
39
- }
40
-
41
- .CodeMirror-guttermarker { color: black; }
42
- .CodeMirror-guttermarker-subtle { color: #999; }
43
-
44
- /* CURSOR */
45
-
46
- .CodeMirror-cursor {
47
- border-left: 1px solid black;
48
- border-right: none;
49
- width: 0;
50
- }
51
- /* Shown when moving in bi-directional text */
52
- .CodeMirror div.CodeMirror-secondarycursor {
53
- border-left: 1px solid silver;
54
- }
55
- .cm-fat-cursor .CodeMirror-cursor {
56
- width: auto;
57
- border: 0 !important;
58
- background: #7e7;
59
- }
60
- .cm-fat-cursor div.CodeMirror-cursors {
61
- z-index: 1;
62
- }
63
- .cm-fat-cursor .CodeMirror-line::selection,
64
- .cm-fat-cursor .CodeMirror-line > span::selection,
65
- .cm-fat-cursor .CodeMirror-line > span > span::selection { background: transparent; }
66
- .cm-fat-cursor .CodeMirror-line::-moz-selection,
67
- .cm-fat-cursor .CodeMirror-line > span::-moz-selection,
68
- .cm-fat-cursor .CodeMirror-line > span > span::-moz-selection { background: transparent; }
69
- .cm-fat-cursor { caret-color: transparent; }
70
- @-moz-keyframes blink {
71
- 0% {}
72
- 50% { background-color: transparent; }
73
- 100% {}
74
- }
75
- @-webkit-keyframes blink {
76
- 0% {}
77
- 50% { background-color: transparent; }
78
- 100% {}
79
- }
80
- @keyframes blink {
81
- 0% {}
82
- 50% { background-color: transparent; }
83
- 100% {}
84
- }
85
-
86
- /* Can style cursor different in overwrite (non-insert) mode */
87
- .CodeMirror-overwrite .CodeMirror-cursor {}
88
-
89
- .cm-tab { display: inline-block; text-decoration: inherit; }
90
-
91
- .CodeMirror-rulers {
92
- position: absolute;
93
- left: 0; right: 0; top: -50px; bottom: 0;
94
- overflow: hidden;
95
- }
96
- .CodeMirror-ruler {
97
- border-left: 1px solid #ccc;
98
- top: 0; bottom: 0;
99
- position: absolute;
100
- }
101
-
102
- /* DEFAULT THEME */
103
-
104
- .cm-s-default .cm-header {color: blue;}
105
- .cm-s-default .cm-quote {color: #090;}
106
- .cm-negative {color: #d44;}
107
- .cm-positive {color: #292;}
108
- .cm-header, .cm-strong {font-weight: bold;}
109
- .cm-em {font-style: italic;}
110
- .cm-link {text-decoration: underline;}
111
- .cm-strikethrough {text-decoration: line-through;}
112
-
113
- .cm-s-default .cm-keyword {color: #708;}
114
- .cm-s-default .cm-atom {color: #219;}
115
- .cm-s-default .cm-number {color: #164;}
116
- .cm-s-default .cm-def {color: #00f;}
117
- .cm-s-default .cm-variable,
118
- .cm-s-default .cm-punctuation,
119
- .cm-s-default .cm-property,
120
- .cm-s-default .cm-operator {}
121
- .cm-s-default .cm-variable-2 {color: #05a;}
122
- .cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}
123
- .cm-s-default .cm-comment {color: #a50;}
124
- .cm-s-default .cm-string {color: #a11;}
125
- .cm-s-default .cm-string-2 {color: #f50;}
126
- .cm-s-default .cm-meta {color: #555;}
127
- .cm-s-default .cm-qualifier {color: #555;}
128
- .cm-s-default .cm-builtin {color: #30a;}
129
- .cm-s-default .cm-bracket {color: #997;}
130
- .cm-s-default .cm-tag {color: #170;}
131
- .cm-s-default .cm-attribute {color: #00c;}
132
- .cm-s-default .cm-hr {color: #999;}
133
- .cm-s-default .cm-link {color: #00c;}
134
-
135
- .cm-s-default .cm-error {color: #f00;}
136
- .cm-invalidchar {color: #f00;}
137
-
138
- .CodeMirror-composing { border-bottom: 2px solid; }
139
-
140
- /* Default styles for common addons */
141
-
142
- div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}
143
- div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}
144
- .CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
145
- .CodeMirror-activeline-background {background: #e8f2ff;}
146
-
147
- /* STOP */
148
-
149
- /* The rest of this file contains styles related to the mechanics of
150
- the editor. You probably shouldn't touch them. */
151
-
152
- .CodeMirror {
153
- position: relative;
154
- overflow: hidden;
155
- background: white;
156
- }
157
-
158
- .CodeMirror-scroll {
159
- overflow: scroll !important; /* Things will break if this is overridden */
160
- /* 50px is the magic margin used to hide the element's real scrollbars */
161
- /* See overflow: hidden in .CodeMirror */
162
- margin-bottom: -50px; margin-right: -50px;
163
- padding-bottom: 50px;
164
- height: 100%;
165
- outline: none; /* Prevent dragging from highlighting the element */
166
- position: relative;
167
- z-index: 0;
168
- }
169
- .CodeMirror-sizer {
170
- position: relative;
171
- border-right: 50px solid transparent;
172
- }
173
-
174
- /* The fake, visible scrollbars. Used to force redraw during scrolling
175
- before actual scrolling happens, thus preventing shaking and
176
- flickering artifacts. */
177
- .CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
178
- position: absolute;
179
- z-index: 6;
180
- display: none;
181
- outline: none;
182
- }
183
- .CodeMirror-vscrollbar {
184
- right: 0; top: 0;
185
- overflow-x: hidden;
186
- overflow-y: scroll;
187
- }
188
- .CodeMirror-hscrollbar {
189
- bottom: 0; left: 0;
190
- overflow-y: hidden;
191
- overflow-x: scroll;
192
- }
193
- .CodeMirror-scrollbar-filler {
194
- right: 0; bottom: 0;
195
- }
196
- .CodeMirror-gutter-filler {
197
- left: 0; bottom: 0;
198
- }
199
-
200
- .CodeMirror-gutters {
201
- position: absolute; left: 0; top: 0;
202
- min-height: 100%;
203
- z-index: 3;
204
- }
205
- .CodeMirror-gutter {
206
- white-space: normal;
207
- height: 100%;
208
- display: inline-block;
209
- vertical-align: top;
210
- margin-bottom: -50px;
211
- }
212
- .CodeMirror-gutter-wrapper {
213
- position: absolute;
214
- z-index: 4;
215
- background: none !important;
216
- border: none !important;
217
- }
218
- .CodeMirror-gutter-background {
219
- position: absolute;
220
- top: 0; bottom: 0;
221
- z-index: 4;
222
- }
223
- .CodeMirror-gutter-elt {
224
- position: absolute;
225
- cursor: default;
226
- z-index: 4;
227
- }
228
- .CodeMirror-gutter-wrapper ::selection { background-color: transparent }
229
- .CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }
230
-
231
- .CodeMirror-lines {
232
- cursor: text;
233
- min-height: 1px; /* prevents collapsing before first draw */
234
- }
235
- .CodeMirror pre.CodeMirror-line,
236
- .CodeMirror pre.CodeMirror-line-like {
237
- /* Reset some styles that the rest of the page might have set */
238
- -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
239
- border-width: 0;
240
- background: transparent;
241
- font-family: inherit;
242
- font-size: inherit;
243
- margin: 0;
244
- white-space: pre;
245
- word-wrap: normal;
246
- line-height: inherit;
247
- color: inherit;
248
- z-index: 2;
249
- position: relative;
250
- overflow: visible;
251
- -webkit-tap-highlight-color: transparent;
252
- -webkit-font-variant-ligatures: contextual;
253
- font-variant-ligatures: contextual;
254
- }
255
- .CodeMirror-wrap pre.CodeMirror-line,
256
- .CodeMirror-wrap pre.CodeMirror-line-like {
257
- word-wrap: break-word;
258
- white-space: pre-wrap;
259
- word-break: normal;
260
- }
261
-
262
- .CodeMirror-linebackground {
263
- position: absolute;
264
- left: 0; right: 0; top: 0; bottom: 0;
265
- z-index: 0;
266
- }
267
-
268
- .CodeMirror-linewidget {
269
- position: relative;
270
- z-index: 2;
271
- padding: 0.1px; /* Force widget margins to stay inside of the container */
272
- }
273
-
274
- .CodeMirror-widget {}
275
-
276
- .CodeMirror-rtl pre { direction: rtl; }
277
-
278
- .CodeMirror-code {
279
- outline: none;
280
- }
281
-
282
- /* Force content-box sizing for the elements where we expect it */
283
- .CodeMirror-scroll,
284
- .CodeMirror-sizer,
285
- .CodeMirror-gutter,
286
- .CodeMirror-gutters,
287
- .CodeMirror-linenumber {
288
- -moz-box-sizing: content-box;
289
- box-sizing: content-box;
290
- }
291
-
292
- .CodeMirror-measure {
293
- position: absolute;
294
- width: 100%;
295
- height: 0;
296
- overflow: hidden;
297
- visibility: hidden;
298
- }
299
-
300
- .CodeMirror-cursor {
301
- position: absolute;
302
- pointer-events: none;
303
- }
304
- .CodeMirror-measure pre { position: static; }
305
-
306
- div.CodeMirror-cursors {
307
- visibility: hidden;
308
- position: relative;
309
- z-index: 3;
310
- }
311
- div.CodeMirror-dragcursors {
312
- visibility: visible;
313
- }
314
-
315
- .CodeMirror-focused div.CodeMirror-cursors {
316
- visibility: visible;
317
- }
318
-
319
- .CodeMirror-selected { background: #d9d9d9; }
320
- .CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
321
- .CodeMirror-crosshair { cursor: crosshair; }
322
- .CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
323
- .CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }
324
-
325
- .cm-searching {
326
- background-color: #ffa;
327
- background-color: rgba(255, 255, 0, .4);
328
- }
329
-
330
- /* Used to force a border model for a node */
331
- .cm-force-border { padding-right: .1px; }
332
-
333
- @media print {
334
- /* Hide the cursor when printing */
335
- .CodeMirror div.CodeMirror-cursors {
336
- visibility: hidden;
337
- }
338
- }
339
-
340
- /* See issue #2901 */
341
- .cm-tab-wrap-hack:after { content: ''; }
342
-
343
- /* Help users use markselection to safely style text background */
344
- span.CodeMirror-selectedtext { background: none; }
@@ -1,124 +0,0 @@
1
- /*
2
- Copyright (c) Microsoft Corporation.
3
-
4
- Licensed under the Apache License, Version 2.0 (the "License");
5
- you may not use this file except in compliance with the License.
6
- You may obtain a copy of the License at
7
-
8
- http://www.apache.org/licenses/LICENSE-2.0
9
-
10
- Unless required by applicable law or agreed to in writing, software
11
- distributed under the License is distributed on an "AS IS" BASIS,
12
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- See the License for the specific language governing permissions and
14
- limitations under the License.
15
- */
16
-
17
- .drop-target {
18
- display: flex;
19
- align-items: center;
20
- justify-content: center;
21
- flex: auto;
22
- flex-direction: column;
23
- background-color: var(--vscode-editor-background);
24
- position: absolute;
25
- top: 0;
26
- right: 0;
27
- bottom: 0;
28
- left: 0;
29
- z-index: 100;
30
- line-height: 24px;
31
- }
32
-
33
- body .drop-target {
34
- background: rgba(255, 255, 255, 0.8);
35
- }
36
-
37
- body.dark-mode .drop-target {
38
- background: rgba(0, 0, 0, 0.8);
39
- }
40
-
41
- .drop-target .title {
42
- font-size: 24px;
43
- font-weight: bold;
44
- margin-bottom: 30px;
45
- }
46
-
47
- .drop-target .processing-error {
48
- font-size: 24px;
49
- color: #e74c3c;
50
- font-weight: bold;
51
- text-align: center;
52
- margin: 30px;
53
- }
54
-
55
- .drop-target input {
56
- margin-top: 50px;
57
- }
58
-
59
- .drop-target button {
60
- color: rgb(255, 255, 255);
61
- background-color: rgb(0, 122, 204);
62
- padding: 8px 12px;
63
- border: none;
64
- margin: 30px 0;
65
- cursor: pointer;
66
- }
67
-
68
- .progress {
69
- flex: none;
70
- width: 100%;
71
- height: 3px;
72
- margin-top: -3px;
73
- z-index: 10;
74
- }
75
-
76
- .inner-progress {
77
- background-color: var(--vscode-progressBar-background);
78
- height: 100%;
79
- }
80
-
81
- .header {
82
- display: flex;
83
- background-color: #000;
84
- flex: none;
85
- flex-basis: 48px;
86
- line-height: 48px;
87
- font-size: 16px;
88
- color: #cccccc;
89
- }
90
-
91
- .workbench-loader {
92
- contain: size;
93
- }
94
-
95
- .workbench-loader .header .toolbar-button {
96
- margin: 12px;
97
- padding: 8px 4px;
98
- }
99
-
100
- .workbench-loader .logo {
101
- margin-left: 16px;
102
- display: flex;
103
- align-items: center;
104
- }
105
-
106
- .workbench-loader .logo img {
107
- height: 32px;
108
- width: 32px;
109
- pointer-events: none;
110
- flex: none;
111
- }
112
-
113
- .workbench-loader .product {
114
- font-weight: 600;
115
- margin-left: 16px;
116
- flex: none;
117
- }
118
-
119
- .workbench-loader .header .title {
120
- margin-left: 16px;
121
- overflow: hidden;
122
- text-overflow: ellipsis;
123
- text-wrap: nowrap;
124
- }
@@ -1,180 +0,0 @@
1
- import { M as MultiTraceModel, r as reactExports, c as connect, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, W as Workbench, a as applyTheme, b as reactDomExports } from "./assets/wsPort-CAXygIGt.js";
2
- const WorkbenchLoader = () => {
3
- const [isServer, setIsServer] = reactExports.useState(false);
4
- const [traceURLs, setTraceURLs] = reactExports.useState([]);
5
- const [uploadedTraceNames, setUploadedTraceNames] = reactExports.useState([]);
6
- const [model, setModel] = reactExports.useState(emptyModel);
7
- const [progress, setProgress] = reactExports.useState({ done: 0, total: 0 });
8
- const [dragOver, setDragOver] = reactExports.useState(false);
9
- const [processingErrorMessage, setProcessingErrorMessage] = reactExports.useState(null);
10
- const [fileForLocalModeError, setFileForLocalModeError] = reactExports.useState(null);
11
- const processTraceFiles = reactExports.useCallback((files) => {
12
- const blobUrls = [];
13
- const fileNames = [];
14
- const url = new URL(window.location.href);
15
- for (let i = 0; i < files.length; i++) {
16
- const file = files.item(i);
17
- if (!file)
18
- continue;
19
- const blobTraceURL = URL.createObjectURL(file);
20
- blobUrls.push(blobTraceURL);
21
- fileNames.push(file.name);
22
- url.searchParams.append("trace", blobTraceURL);
23
- url.searchParams.append("traceFileName", file.name);
24
- }
25
- const href = url.toString();
26
- window.history.pushState({}, "", href);
27
- setTraceURLs(blobUrls);
28
- setUploadedTraceNames(fileNames);
29
- setDragOver(false);
30
- setProcessingErrorMessage(null);
31
- }, []);
32
- const handleDropEvent = reactExports.useCallback((event) => {
33
- event.preventDefault();
34
- processTraceFiles(event.dataTransfer.files);
35
- }, [processTraceFiles]);
36
- const handleFileInputChange = reactExports.useCallback((event) => {
37
- event.preventDefault();
38
- if (!event.target.files)
39
- return;
40
- processTraceFiles(event.target.files);
41
- }, [processTraceFiles]);
42
- reactExports.useEffect(() => {
43
- const params = new URL(window.location.href).searchParams;
44
- const newTraceURLs = params.getAll("trace");
45
- setIsServer(params.has("isServer"));
46
- for (const url of newTraceURLs) {
47
- if (url.startsWith("file:")) {
48
- setFileForLocalModeError(url || null);
49
- return;
50
- }
51
- }
52
- if (params.has("isServer")) {
53
- connect({
54
- onEvent(method, params2) {
55
- if (method === "loadTrace") {
56
- setTraceURLs(params2.url ? [params2.url] : []);
57
- setDragOver(false);
58
- setProcessingErrorMessage(null);
59
- }
60
- },
61
- onClose() {
62
- }
63
- }).then((sendMessage) => {
64
- sendMessage("ready");
65
- });
66
- } else if (!newTraceURLs.some((url) => url.startsWith("blob:"))) {
67
- setTraceURLs(newTraceURLs);
68
- }
69
- }, []);
70
- reactExports.useEffect(() => {
71
- (async () => {
72
- if (traceURLs.length) {
73
- const swListener = (event) => {
74
- if (event.data.method === "progress")
75
- setProgress(event.data.params);
76
- };
77
- navigator.serviceWorker.addEventListener("message", swListener);
78
- setProgress({ done: 0, total: 1 });
79
- const contextEntries = [];
80
- for (let i = 0; i < traceURLs.length; i++) {
81
- const url = traceURLs[i];
82
- const params = new URLSearchParams();
83
- params.set("trace", url);
84
- if (uploadedTraceNames.length)
85
- params.set("traceFileName", uploadedTraceNames[i]);
86
- const response = await fetch(`contexts?${params.toString()}`);
87
- if (!response.ok) {
88
- if (!isServer)
89
- setTraceURLs([]);
90
- setProcessingErrorMessage((await response.json()).error);
91
- return;
92
- }
93
- contextEntries.push(...await response.json());
94
- }
95
- navigator.serviceWorker.removeEventListener("message", swListener);
96
- const model2 = new MultiTraceModel(contextEntries);
97
- setProgress({ done: 0, total: 0 });
98
- setModel(model2);
99
- } else {
100
- setModel(emptyModel);
101
- }
102
- })();
103
- }, [isServer, traceURLs, uploadedTraceNames]);
104
- return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "vbox workbench-loader", onDragOver: (event) => {
105
- event.preventDefault();
106
- setDragOver(true);
107
- }, children: [
108
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "hbox header", children: [
109
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "logo", children: /* @__PURE__ */ jsxRuntimeExports.jsx("img", { src: "playwright-logo.svg", alt: "Playwright logo" }) }),
110
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "product", children: "Playwright" }),
111
- model.title && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: model.title }),
112
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "spacer" }),
113
- /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarButton, { icon: "color-mode", title: "Toggle color mode", toggled: false, onClick: () => toggleTheme() })
114
- ] }),
115
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "progress", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "inner-progress", style: { width: progress.total ? 100 * progress.done / progress.total + "%" : 0 } }) }),
116
- /* @__PURE__ */ jsxRuntimeExports.jsx(Workbench, { model }),
117
- fileForLocalModeError && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
118
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "Trace Viewer uses Service Workers to show traces. To view trace:" }),
119
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { style: { paddingTop: 20 }, children: [
120
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
121
- "1. Click ",
122
- /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: fileForLocalModeError, children: "here" }),
123
- " to put your trace into the download shelf"
124
- ] }),
125
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
126
- "2. Go to ",
127
- /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: "https://trace.playwright.dev", children: "trace.playwright.dev" })
128
- ] }),
129
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "3. Drop the trace from the download shelf into the page" })
130
- ] })
131
- ] }),
132
- !isServer && !dragOver && !fileForLocalModeError && (!traceURLs.length || processingErrorMessage) && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
133
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "processing-error", children: processingErrorMessage }),
134
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Drop Playwright Trace to load" }),
135
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "or" }),
136
- /* @__PURE__ */ jsxRuntimeExports.jsx("button", { onClick: () => {
137
- const input = document.createElement("input");
138
- input.type = "file";
139
- input.multiple = true;
140
- input.click();
141
- input.addEventListener("change", (e) => handleFileInputChange(e));
142
- }, children: "Select file(s)" }),
143
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { style: { maxWidth: 400 }, children: "Playwright Trace Viewer is a Progressive Web App, it does not send your trace anywhere, it opens it locally." })
144
- ] }),
145
- isServer && !traceURLs.length && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "drop-target", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Select test to see the trace" }) }),
146
- dragOver && /* @__PURE__ */ jsxRuntimeExports.jsx(
147
- "div",
148
- {
149
- className: "drop-target",
150
- onDragLeave: () => {
151
- setDragOver(false);
152
- },
153
- onDrop: (event) => handleDropEvent(event),
154
- children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Release to analyse the Playwright Trace" })
155
- }
156
- )
157
- ] });
158
- };
159
- const emptyModel = new MultiTraceModel([]);
160
- (async () => {
161
- applyTheme();
162
- if (window.location.protocol !== "file:") {
163
- if (window.location.href.includes("isUnderTest=true"))
164
- await new Promise((f) => setTimeout(f, 1e3));
165
- if (!navigator.serviceWorker)
166
- throw new Error(`Service workers are not supported.
167
- Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);
168
- navigator.serviceWorker.register("sw.bundle.js");
169
- if (!navigator.serviceWorker.controller) {
170
- await new Promise((f) => {
171
- navigator.serviceWorker.oncontrollerchange = () => f();
172
- });
173
- }
174
- setInterval(function() {
175
- fetch("ping");
176
- }, 1e4);
177
- }
178
- reactDomExports.render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}), document.querySelector("#root"));
179
- })();
180
- //# sourceMappingURL=index.5nqVcfiC.js.map