@checkly/playwright-core 1.48.21 → 1.48.22-beta.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 (185) hide show
  1. package/lib/cli/cli.js +61 -0
  2. package/lib/common/debugLogger.js +90 -0
  3. package/lib/generated/clockSource.js +2 -1
  4. package/lib/generated/consoleApiSource.js +2 -1
  5. package/lib/generated/injectedScriptSource.js +2 -1
  6. package/lib/generated/pollingRecorderSource.js +2 -1
  7. package/lib/generated/recorderSource.js +1 -1
  8. package/lib/generated/utilityScriptSource.js +2 -1
  9. package/lib/generated/webSocketMockSource.js +2 -1
  10. package/lib/server/recorder/java.js +4 -36
  11. package/lib/server/trace/recorder/tracing.js +22 -17
  12. package/lib/vite/{traceViewer/assets/codeMirrorModule-U6XMqGkV.js → recorder/assets/codeMirrorModule--bQcPrZ2.js} +2 -2
  13. package/lib/vite/recorder/assets/codeMirrorModule-Cy8X9Wtw.css +344 -0
  14. package/lib/vite/recorder/assets/index-BMeslH8X.js +9946 -0
  15. package/lib/vite/recorder/assets/index-BjXmTggo.css +2515 -0
  16. package/lib/vite/recorder/index.html +2 -2
  17. package/lib/vite/traceViewer/assets/codeMirrorModule-75b0ca4f.js +24 -0
  18. package/lib/vite/traceViewer/assets/codeMirrorModule-CBokkFJ2.js +16431 -0
  19. package/lib/vite/traceViewer/assets/codeMirrorModule-CNHvVrFd.js +16437 -0
  20. package/lib/vite/traceViewer/assets/{codeMirrorModule-BdBhzV6t.js → codeMirrorModule-CpGx_S8D.js} +2 -2
  21. package/lib/vite/traceViewer/assets/codeMirrorModule-SomGa-Da.js +16443 -0
  22. package/lib/vite/traceViewer/assets/codeMirrorModule-c1454a2e.js +24 -0
  23. package/lib/vite/traceViewer/assets/codeMirrorModule-c9bb9834.js +24 -0
  24. package/lib/vite/traceViewer/assets/{codeMirrorModule-Dx6AXgMV.js → codeMirrorModule-cc2329e4.js} +11 -1256
  25. package/lib/vite/traceViewer/assets/codeMirrorModule-d2cc7db0.js +15579 -0
  26. package/lib/vite/traceViewer/assets/codeMirrorModule-da915a35.js +15586 -0
  27. package/lib/vite/traceViewer/assets/{codeMirrorModule-CcviAl53.js → codeMirrorModule-f03b1a3e.js} +1118 -2370
  28. package/lib/vite/traceViewer/assets/codeMirrorModule-f333a775.js +24 -0
  29. package/lib/vite/traceViewer/assets/{codeMirrorModule-V7N6ppkd.js → codeMirrorModule-uWDlVSQz.js} +2 -2
  30. package/lib/vite/{recorder/assets/codeMirrorModule-d0KhC1qL.js → traceViewer/assets/codeMirrorModule-xvopPhZ4.js} +1 -1
  31. package/lib/vite/traceViewer/assets/{codeMirrorModule-BqcXH1AO.js → codeMirrorModule-yboVpgC0.js} +2 -1248
  32. package/lib/vite/traceViewer/assets/{inspectorTab-DpvLVMq5.js → inspectorTab-B4ynvyY9.js} +18 -8
  33. package/lib/vite/traceViewer/assets/{inspectorTab-BPzVEZSf.js → inspectorTab-BqBvUFio.js} +18 -8
  34. package/lib/vite/traceViewer/assets/{workbench-Bjkiwcr1.js → inspectorTab-Dw0Gnh1T.js} +1847 -3605
  35. package/lib/vite/traceViewer/assets/{inspectorTab-BABZNwlH.js → inspectorTab-Ywa000c9.js} +16 -6
  36. package/lib/vite/traceViewer/assets/{inspectorTab-BHcfR9dD.js → inspectorTab-wfvwpMHs.js} +2 -2
  37. package/lib/vite/traceViewer/assets/{workbench-BcgGQnKb.js → workbench-CROk6Fcc.js} +2 -2
  38. package/lib/vite/traceViewer/assets/{workbench-ByyWxoT8.js → workbench-CfXOj3eT.js} +2 -2
  39. package/lib/vite/traceViewer/assets/{workbench-DhqI6jeL.js → workbench-D9CTkv-4.js} +2 -2
  40. package/lib/vite/traceViewer/assets/{workbench-I4s6sWjN.js → workbench-DNolpp3y.js} +1 -1
  41. package/lib/vite/traceViewer/assets/workbench-DUc2iD0P.js +1473 -0
  42. package/lib/vite/traceViewer/assets/{workbench-B13nfocr.js → workbench-LKskf2Iy.js} +1 -1
  43. package/lib/vite/traceViewer/assets/workbench-dnZM5a7x.js +1473 -0
  44. package/lib/vite/traceViewer/assets/wsPort-54626118.js +18361 -0
  45. package/lib/vite/traceViewer/assets/{workbench-Crj6jzdv.js → wsPort-57f274c6.js} +4308 -5066
  46. package/lib/vite/traceViewer/assets/wsPort-762c6840.js +64 -0
  47. package/lib/vite/traceViewer/assets/wsPort-85286e61.js +18361 -0
  48. package/lib/vite/traceViewer/assets/wsPort-98e00a94.js +64 -0
  49. package/lib/vite/traceViewer/assets/{wsPort-EUvw-dwH.js → wsPort-CAXygIGt.js} +3 -3
  50. package/lib/vite/traceViewer/assets/{workbench-C5OQh9VX.js → wsPort-cc0077b5.js} +4046 -4623
  51. package/lib/vite/traceViewer/assets/wsPort-edfeeb7d.js +64 -0
  52. package/lib/vite/traceViewer/assets/wsPort-ee2830d7.js +64 -0
  53. package/lib/vite/traceViewer/assets/{workbench-BwodYCgl.js → wsPort-peeLnQhT.js} +985 -1540
  54. package/lib/vite/traceViewer/assets/xtermModule-443332e6.js +9 -0
  55. package/lib/vite/traceViewer/assets/xtermModule-60687b6b.js +6410 -0
  56. package/lib/vite/traceViewer/codeMirrorModule.5d0f417c.css +1 -0
  57. package/lib/vite/traceViewer/codeMirrorModule.eb494ea9.css +344 -0
  58. package/lib/vite/traceViewer/codicon.79f233d0.ttf +0 -0
  59. package/lib/vite/traceViewer/{embedded.27BGR_eD.js → embedded.6N1v7bZ1.js} +4 -3
  60. package/lib/vite/traceViewer/{embedded.DTjd2aiy.js → embedded.BOw0jX78.js} +4 -3
  61. package/lib/vite/traceViewer/{embedded.Dxe2heQk.js → embedded.BXYl5zRv.js} +1 -1
  62. package/lib/vite/traceViewer/{embedded.SsjKHrxC.js → embedded.BaqdbLsy.js} +4 -3
  63. package/lib/vite/traceViewer/embedded.CwwTDBzP.js +106 -0
  64. package/lib/vite/traceViewer/{embedded.Zu332ZC1.js → embedded.DeCrOtlO.js} +2 -2
  65. package/lib/vite/traceViewer/embedded.html +6 -6
  66. package/lib/vite/traceViewer/embedded.i_k4ceMJ.js +106 -0
  67. package/lib/vite/traceViewer/index.1a1fe659.css +1 -0
  68. package/lib/vite/traceViewer/index.1b525c1c.js +181 -0
  69. package/lib/vite/traceViewer/index.55e65778.js +181 -0
  70. package/lib/vite/traceViewer/{index.6KJ-JQ0L.js → index.5nqVcfiC.js} +2 -2
  71. package/lib/vite/traceViewer/{index.C0EgJ4oW.js → index.5ooko4n7.js} +21 -36
  72. package/lib/vite/traceViewer/index.76e9f312.css +124 -0
  73. package/lib/vite/traceViewer/{index.Dz3icWJV.js → index.Bugo2TbS.js} +4 -3
  74. package/lib/vite/traceViewer/{index.PqcsvBxQ.js → index.BzvnAP7t.js} +4 -3
  75. package/lib/vite/traceViewer/{index.CLxsp2W_.js → index.CM_h9lHr.js} +2 -2
  76. package/lib/vite/traceViewer/{index.yxAwzeWG.js → index.CY13pBr8.js} +4 -3
  77. package/lib/vite/traceViewer/index.DW2ZzZfL.js +197 -0
  78. package/lib/vite/traceViewer/{index.CB297BuW.js → index.DZkJsFod.js} +1 -1
  79. package/lib/vite/traceViewer/index.DblJtEW_.js +197 -0
  80. package/lib/vite/traceViewer/index.a265fbdb.js +2 -0
  81. package/lib/vite/traceViewer/index.c9f6fa8f.js +2 -0
  82. package/lib/vite/traceViewer/index.d86e70ca.js +181 -0
  83. package/lib/vite/traceViewer/index.decad628.js +2 -0
  84. package/lib/vite/traceViewer/index.e8730524.js +181 -0
  85. package/lib/vite/traceViewer/index.ed9a3c58.js +2 -0
  86. package/lib/vite/traceViewer/index.html +7 -7
  87. package/lib/vite/traceViewer/{recorder.BufKu9Hp.js → recorder.3Xfrl_zV.js} +3 -2
  88. package/lib/vite/traceViewer/{recorder.am-MV-DQ.js → recorder.B76AH9PE.js} +3 -2
  89. package/lib/vite/traceViewer/{recorder.C88JDknq.js → recorder.BVExlUUk.js} +1 -1
  90. package/lib/vite/traceViewer/{recorder.7Wl6HrQl.js → recorder.Db1aK_DY.js} +3 -2
  91. package/lib/vite/traceViewer/recorder.html +4 -4
  92. package/lib/vite/traceViewer/recorder.uj3cfoMf.js +551 -0
  93. package/lib/vite/traceViewer/uiMode.08ab2d90.js +4 -0
  94. package/lib/vite/traceViewer/uiMode.0d0d667b.js +4 -0
  95. package/lib/vite/traceViewer/uiMode.216233d5.js +1484 -0
  96. package/lib/vite/traceViewer/{uiMode.DVWUEIHq.css → uiMode.2c31018f.css} +88 -188
  97. package/lib/vite/traceViewer/uiMode.3ff70f7d.js +4 -0
  98. package/lib/vite/traceViewer/uiMode.4d0a45af.js +1484 -0
  99. package/lib/vite/traceViewer/uiMode.66eb0ce2.js +1484 -0
  100. package/lib/vite/traceViewer/uiMode.8b41a49d.css +1 -0
  101. package/lib/vite/traceViewer/uiMode.8d080c01.js +1486 -0
  102. package/lib/vite/traceViewer/uiMode.BKrDfnAk.js +1725 -0
  103. package/lib/vite/traceViewer/uiMode.BMYUvsRh.js +1725 -0
  104. package/lib/vite/traceViewer/{uiMode.BZoFj6zV.js → uiMode.BVpTBGoe.js} +4 -3
  105. package/lib/vite/traceViewer/uiMode.BWhJCEE9.js +1725 -0
  106. package/lib/vite/traceViewer/uiMode.Bg9fACTB.js +1725 -0
  107. package/lib/vite/traceViewer/{uiMode.CpC2B27N.js → uiMode.CYBsUhm_.js} +2 -2
  108. package/lib/vite/traceViewer/{uiMode.Dlo9s_YX.js → uiMode.DCSdxlAq.js} +4 -3
  109. package/lib/vite/traceViewer/{uiMode.2tr9k625.js → uiMode.DjTS7tqC.js} +1 -1
  110. package/lib/vite/traceViewer/{uiMode.wsGnVMQK.js → uiMode.DtleKuGI.js} +4 -3
  111. package/lib/vite/traceViewer/uiMode.UamAvOMX.js +1725 -0
  112. package/lib/vite/traceViewer/uiMode.bBcXYWNF.js +1725 -0
  113. package/lib/vite/traceViewer/uiMode.ca6ec898.js +4 -0
  114. package/lib/vite/traceViewer/{uiMode.iq7CyYy7.js → uiMode.e-PLonGl.js} +2 -2
  115. package/lib/vite/traceViewer/uiMode.e_-GuqEi.js +1725 -0
  116. package/lib/vite/traceViewer/uiMode.f1YADWIl.js +1724 -0
  117. package/lib/vite/traceViewer/uiMode.html +7 -7
  118. package/lib/vite/traceViewer/uiMode.kHsXCfV8.js +1490 -0
  119. package/lib/vite/traceViewer/uiMode.myF_lyEH.js +1724 -0
  120. package/lib/vite/traceViewer/{workbench.B3X2QtYa.css → wsPort.162042f9.css} +63 -315
  121. package/lib/vite/traceViewer/{workbench.wuxQoE2z.css → wsPort.997c92cf.css} +145 -335
  122. package/lib/vite/traceViewer/wsPort.9c9a6767.css +1 -0
  123. package/lib/vite/traceViewer/xtermModule.125f4259.css +191 -0
  124. package/lib/vite/traceViewer/xtermModule.6428296b.css +32 -0
  125. package/package.json +1 -1
  126. package/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +0 -1
  127. package/lib/vite/recorder/assets/index-BW-aOBcL.css +0 -1
  128. package/lib/vite/recorder/assets/index-Bxxcmxlu.js +0 -42
  129. package/lib/vite/traceViewer/assets/codeMirrorModule-5yiV-3wl.js +0 -16831
  130. package/lib/vite/traceViewer/assets/codeMirrorModule-B7Z3vq11.js +0 -24
  131. package/lib/vite/traceViewer/assets/codeMirrorModule-C6p3E9Zg.js +0 -24
  132. package/lib/vite/traceViewer/assets/codeMirrorModule-Ca-1BNel.js +0 -24
  133. package/lib/vite/traceViewer/assets/codeMirrorModule-CqYUz5ms.js +0 -24
  134. package/lib/vite/traceViewer/assets/codeMirrorModule-DS3v0XrQ.js +0 -24
  135. package/lib/vite/traceViewer/assets/codeMirrorModule-DZoSgqUd.js +0 -24
  136. package/lib/vite/traceViewer/assets/codeMirrorModule-EhKN7Okm.js +0 -16449
  137. package/lib/vite/traceViewer/assets/codeMirrorModule-MzSmL4X2.js +0 -24
  138. package/lib/vite/traceViewer/assets/codeMirrorModule-T_sdMrbM.js +0 -24
  139. package/lib/vite/traceViewer/assets/inspectorTab-Bbgq0hgt.js +0 -64
  140. package/lib/vite/traceViewer/assets/inspectorTab-DhBbZz8I.js +0 -64
  141. package/lib/vite/traceViewer/assets/workbench-C43LWZEX.js +0 -72
  142. package/lib/vite/traceViewer/assets/workbench-DZqNXdoV.js +0 -9
  143. package/lib/vite/traceViewer/assets/workbench-DrQjKdyE.js +0 -72
  144. package/lib/vite/traceViewer/assets/workbench-Pa1v1Ojh.js +0 -72
  145. package/lib/vite/traceViewer/assets/workbench-caTaZnzx.js +0 -72
  146. package/lib/vite/traceViewer/assets/workbench-gtYcQBNA.js +0 -9
  147. package/lib/vite/traceViewer/assets/workbench-u2lRPMOT.js +0 -72
  148. package/lib/vite/traceViewer/assets/xtermModule-CZ7sDYXB.js +0 -6529
  149. package/lib/vite/traceViewer/embedded.BBZ9gQEw.js +0 -104
  150. package/lib/vite/traceViewer/embedded.BQq6Psnz.js +0 -104
  151. package/lib/vite/traceViewer/embedded.BVDVQOzc.js +0 -2
  152. package/lib/vite/traceViewer/embedded.Bn8Ptzv6.js +0 -2
  153. package/lib/vite/traceViewer/embedded.CorI3dFX.js +0 -104
  154. package/lib/vite/traceViewer/embedded.CvhnUgIi.js +0 -2
  155. package/lib/vite/traceViewer/embedded.D27cnKiB.js +0 -104
  156. package/lib/vite/traceViewer/embedded.D4lqGydT.js +0 -2
  157. package/lib/vite/traceViewer/embedded.DPqrDeET.js +0 -2
  158. package/lib/vite/traceViewer/embedded.DbzY7Q8w.js +0 -2
  159. package/lib/vite/traceViewer/embedded.f-PLGsBT.js +0 -2
  160. package/lib/vite/traceViewer/index.B7aiTMfZ.js +0 -2
  161. package/lib/vite/traceViewer/index.B8dgQwuN.js +0 -2
  162. package/lib/vite/traceViewer/index.BGj8jY3H.js +0 -2
  163. package/lib/vite/traceViewer/index.BSak5QT9.js +0 -2
  164. package/lib/vite/traceViewer/index.BrT2kfuc.js +0 -2
  165. package/lib/vite/traceViewer/index.CUpI-BFe.js +0 -195
  166. package/lib/vite/traceViewer/index.DkRbtWVo.js +0 -195
  167. package/lib/vite/traceViewer/index.DsjmhbB6.js +0 -195
  168. package/lib/vite/traceViewer/index._cX8k4co.js +0 -2
  169. package/lib/vite/traceViewer/index.pMAN88y-.js +0 -2
  170. package/lib/vite/traceViewer/recorder.Ch-WHviK.js +0 -2
  171. package/lib/vite/traceViewer/recorder.POd-toIn.js +0 -2
  172. package/lib/vite/traceViewer/uiMode.BEZVCe5O.js +0 -5
  173. package/lib/vite/traceViewer/uiMode.C4nbcio6.js +0 -1730
  174. package/lib/vite/traceViewer/uiMode.D-tg1Oci.js +0 -1730
  175. package/lib/vite/traceViewer/uiMode.D3cNFP6u.css +0 -1
  176. package/lib/vite/traceViewer/uiMode.DKjMBMlc.js +0 -1730
  177. package/lib/vite/traceViewer/uiMode.DVrL7a1K.js +0 -10
  178. package/lib/vite/traceViewer/uiMode.DdtUZZVS.js +0 -5
  179. package/lib/vite/traceViewer/uiMode.Dg9oJCQU.js +0 -10
  180. package/lib/vite/traceViewer/uiMode.DwZAzstF.js +0 -10
  181. package/lib/vite/traceViewer/uiMode.O07awP3T.js +0 -10
  182. package/lib/vite/traceViewer/uiMode.gGHHTsyL.js +0 -1730
  183. package/lib/vite/traceViewer/uiMode.jY2s-9ps.js +0 -10
  184. package/lib/vite/traceViewer/workbench.DjbIuxix.css +0 -1
  185. package/lib/vite/traceViewer/workbench.DyTpxWVb.css +0 -1
@@ -0,0 +1,124 @@
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,5 +1,5 @@
1
- import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-BPzVEZSf.js";
2
- import { W as Workbench } from "./assets/workbench-DhqI6jeL.js";
1
+ import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-CHcHvp_a.js";
2
+ import { W as Workbench } from "./assets/workbench-D9CTkv-4.js";
3
3
  import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
4
  const WorkbenchLoader = () => {
5
5
  const [isServer, setIsServer] = reactExports.useState(false);
@@ -98,6 +98,7 @@ const WorkbenchLoader = () => {
98
98
  params.set("trace", url);
99
99
  if (uploadedTraceNames.length)
100
100
  params.set("traceFileName", uploadedTraceNames[i]);
101
+ params.set("limit", String(traceURLs.length));
101
102
  const response = await fetch(`contexts?${params.toString()}`);
102
103
  if (!response.ok) {
103
104
  if (!isServer)
@@ -193,4 +194,4 @@ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.
193
194
  }
194
195
  createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
195
196
  })();
196
- //# sourceMappingURL=index.Dz3icWJV.js.map
197
+ //# sourceMappingURL=index.Bugo2TbS.js.map
@@ -1,5 +1,5 @@
1
- import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-DpvLVMq5.js";
2
- import { W as Workbench } from "./assets/workbench-BcgGQnKb.js";
1
+ import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-B4ynvyY9.js";
2
+ import { W as Workbench } from "./assets/workbench-CROk6Fcc.js";
3
3
  import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
4
  const WorkbenchLoader = () => {
5
5
  const [isServer, setIsServer] = reactExports.useState(false);
@@ -98,6 +98,7 @@ const WorkbenchLoader = () => {
98
98
  params.set("trace", url);
99
99
  if (uploadedTraceNames.length)
100
100
  params.set("traceFileName", uploadedTraceNames[i]);
101
+ params.set("limit", String(traceURLs.length));
101
102
  const response = await fetch(`contexts?${params.toString()}`);
102
103
  if (!response.ok) {
103
104
  if (!isServer)
@@ -193,4 +194,4 @@ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.
193
194
  }
194
195
  createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
195
196
  })();
196
- //# sourceMappingURL=index.PqcsvBxQ.js.map
197
+ //# sourceMappingURL=index.BzvnAP7t.js.map
@@ -1,5 +1,5 @@
1
1
  import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-DOc4D3cX.js";
2
- import { W as Workbench } from "./assets/workbench-I4s6sWjN.js";
2
+ import { W as Workbench } from "./assets/workbench-DNolpp3y.js";
3
3
  import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
4
  const WorkbenchLoader = () => {
5
5
  const [isServer, setIsServer] = reactExports.useState(false);
@@ -194,4 +194,4 @@ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.
194
194
  }
195
195
  createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
196
196
  })();
197
- //# sourceMappingURL=index.CLxsp2W_.js.map
197
+ //# sourceMappingURL=index.CM_h9lHr.js.map
@@ -1,5 +1,5 @@
1
- import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-BABZNwlH.js";
2
- import { W as Workbench } from "./assets/workbench-ByyWxoT8.js";
1
+ import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-Dw0Gnh1T.js";
2
+ import { W as Workbench } from "./assets/workbench-dnZM5a7x.js";
3
3
  import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
4
  const WorkbenchLoader = () => {
5
5
  const [isServer, setIsServer] = reactExports.useState(false);
@@ -98,6 +98,7 @@ const WorkbenchLoader = () => {
98
98
  params.set("trace", url);
99
99
  if (uploadedTraceNames.length)
100
100
  params.set("traceFileName", uploadedTraceNames[i]);
101
+ params.set("limit", String(traceURLs.length));
101
102
  const response = await fetch(`contexts?${params.toString()}`);
102
103
  if (!response.ok) {
103
104
  if (!isServer)
@@ -193,4 +194,4 @@ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.
193
194
  }
194
195
  createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
195
196
  })();
196
- //# sourceMappingURL=index.yxAwzeWG.js.map
197
+ //# sourceMappingURL=index.CY13pBr8.js.map
@@ -0,0 +1,197 @@
1
+ import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-BqBvUFio.js";
2
+ import { W as Workbench } from "./assets/workbench-DUc2iD0P.js";
3
+ import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
+ const WorkbenchLoader = () => {
5
+ const [isServer, setIsServer] = reactExports.useState(false);
6
+ const [traceURLs, setTraceURLs] = reactExports.useState([]);
7
+ const [uploadedTraceNames, setUploadedTraceNames] = reactExports.useState([]);
8
+ const [model, setModel] = reactExports.useState(emptyModel);
9
+ const [progress, setProgress] = reactExports.useState({ done: 0, total: 0 });
10
+ const [dragOver, setDragOver] = reactExports.useState(false);
11
+ const [processingErrorMessage, setProcessingErrorMessage] = reactExports.useState(null);
12
+ const [fileForLocalModeError, setFileForLocalModeError] = reactExports.useState(null);
13
+ const processTraceFiles = reactExports.useCallback((files) => {
14
+ const blobUrls = [];
15
+ const fileNames = [];
16
+ const url = new URL(window.location.href);
17
+ for (let i = 0; i < files.length; i++) {
18
+ const file = files.item(i);
19
+ if (!file)
20
+ continue;
21
+ const blobTraceURL = URL.createObjectURL(file);
22
+ blobUrls.push(blobTraceURL);
23
+ fileNames.push(file.name);
24
+ url.searchParams.append("trace", blobTraceURL);
25
+ url.searchParams.append("traceFileName", file.name);
26
+ }
27
+ const href = url.toString();
28
+ window.history.pushState({}, "", href);
29
+ setTraceURLs(blobUrls);
30
+ setUploadedTraceNames(fileNames);
31
+ setDragOver(false);
32
+ setProcessingErrorMessage(null);
33
+ }, []);
34
+ reactExports.useEffect(() => {
35
+ const listener = async (e) => {
36
+ var _a;
37
+ if (!((_a = e.clipboardData) == null ? void 0 : _a.files.length))
38
+ return;
39
+ for (const file of e.clipboardData.files) {
40
+ if (file.type !== "application/zip")
41
+ return;
42
+ }
43
+ e.preventDefault();
44
+ processTraceFiles(e.clipboardData.files);
45
+ };
46
+ document.addEventListener("paste", listener);
47
+ return () => document.removeEventListener("paste", listener);
48
+ });
49
+ const handleDropEvent = reactExports.useCallback((event) => {
50
+ event.preventDefault();
51
+ processTraceFiles(event.dataTransfer.files);
52
+ }, [processTraceFiles]);
53
+ const handleFileInputChange = reactExports.useCallback((event) => {
54
+ event.preventDefault();
55
+ if (!event.target.files)
56
+ return;
57
+ processTraceFiles(event.target.files);
58
+ }, [processTraceFiles]);
59
+ reactExports.useEffect(() => {
60
+ const params = new URL(window.location.href).searchParams;
61
+ const newTraceURLs = params.getAll("trace");
62
+ setIsServer(params.has("isServer"));
63
+ for (const url of newTraceURLs) {
64
+ if (url.startsWith("file:")) {
65
+ setFileForLocalModeError(url || null);
66
+ return;
67
+ }
68
+ }
69
+ if (params.has("isServer")) {
70
+ const guid = new URLSearchParams(window.location.search).get("ws");
71
+ const wsURL = new URL(`../${guid}`, window.location.toString());
72
+ wsURL.protocol = window.location.protocol === "https:" ? "wss:" : "ws:";
73
+ const testServerConnection = new TestServerConnection(new WebSocketTestServerTransport(wsURL));
74
+ testServerConnection.onLoadTraceRequested(async (params2) => {
75
+ setTraceURLs(params2.traceUrl ? [params2.traceUrl] : []);
76
+ setDragOver(false);
77
+ setProcessingErrorMessage(null);
78
+ });
79
+ testServerConnection.initialize({}).catch(() => {
80
+ });
81
+ } else if (!newTraceURLs.some((url) => url.startsWith("blob:"))) {
82
+ setTraceURLs(newTraceURLs);
83
+ }
84
+ }, []);
85
+ reactExports.useEffect(() => {
86
+ (async () => {
87
+ if (traceURLs.length) {
88
+ const swListener = (event) => {
89
+ if (event.data.method === "progress")
90
+ setProgress(event.data.params);
91
+ };
92
+ navigator.serviceWorker.addEventListener("message", swListener);
93
+ setProgress({ done: 0, total: 1 });
94
+ const contextEntries = [];
95
+ for (let i = 0; i < traceURLs.length; i++) {
96
+ const url = traceURLs[i];
97
+ const params = new URLSearchParams();
98
+ params.set("trace", url);
99
+ if (uploadedTraceNames.length)
100
+ params.set("traceFileName", uploadedTraceNames[i]);
101
+ params.set("limit", String(traceURLs.length));
102
+ const response = await fetch(`contexts?${params.toString()}`);
103
+ if (!response.ok) {
104
+ if (!isServer)
105
+ setTraceURLs([]);
106
+ setProcessingErrorMessage((await response.json()).error);
107
+ return;
108
+ }
109
+ contextEntries.push(...await response.json());
110
+ }
111
+ navigator.serviceWorker.removeEventListener("message", swListener);
112
+ const model2 = new MultiTraceModel(contextEntries);
113
+ setProgress({ done: 0, total: 0 });
114
+ setModel(model2);
115
+ } else {
116
+ setModel(emptyModel);
117
+ }
118
+ })();
119
+ }, [isServer, traceURLs, uploadedTraceNames]);
120
+ const showFileUploadDropArea = !!(!isServer && !dragOver && !fileForLocalModeError && (!traceURLs.length || processingErrorMessage));
121
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "vbox workbench-loader", onDragOver: (event) => {
122
+ event.preventDefault();
123
+ setDragOver(true);
124
+ }, children: [
125
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "hbox header", ...showFileUploadDropArea ? { inert: "true" } : {}, children: [
126
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "logo", children: /* @__PURE__ */ jsxRuntimeExports.jsx("img", { src: "playwright-logo.svg", alt: "Playwright logo" }) }),
127
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "product", children: "Playwright" }),
128
+ model.title && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: model.title }),
129
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "spacer" }),
130
+ /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarButton, { icon: "color-mode", title: "Toggle color mode", toggled: false, onClick: () => toggleTheme() })
131
+ ] }),
132
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "progress", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "inner-progress", style: { width: progress.total ? 100 * progress.done / progress.total + "%" : 0 } }) }),
133
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Workbench, { model, inert: showFileUploadDropArea, showSettings: true }),
134
+ fileForLocalModeError && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
135
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "Trace Viewer uses Service Workers to show traces. To view trace:" }),
136
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { style: { paddingTop: 20 }, children: [
137
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
138
+ "1. Click ",
139
+ /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: fileForLocalModeError, children: "here" }),
140
+ " to put your trace into the download shelf"
141
+ ] }),
142
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
143
+ "2. Go to ",
144
+ /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: "https://trace.playwright.dev", children: "trace.playwright.dev" })
145
+ ] }),
146
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "3. Drop the trace from the download shelf into the page" })
147
+ ] })
148
+ ] }),
149
+ showFileUploadDropArea && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
150
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "processing-error", role: "alert", children: processingErrorMessage }),
151
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", role: "heading", "aria-level": 1, children: "Drop Playwright Trace to load" }),
152
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "or" }),
153
+ /* @__PURE__ */ jsxRuntimeExports.jsx("button", { onClick: () => {
154
+ const input = document.createElement("input");
155
+ input.type = "file";
156
+ input.multiple = true;
157
+ input.click();
158
+ input.addEventListener("change", (e) => handleFileInputChange(e));
159
+ }, type: "button", children: "Select file(s)" }),
160
+ /* @__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." })
161
+ ] }),
162
+ isServer && !traceURLs.length && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "drop-target", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Select test to see the trace" }) }),
163
+ dragOver && /* @__PURE__ */ jsxRuntimeExports.jsx(
164
+ "div",
165
+ {
166
+ className: "drop-target",
167
+ onDragLeave: () => {
168
+ setDragOver(false);
169
+ },
170
+ onDrop: (event) => handleDropEvent(event),
171
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Release to analyse the Playwright Trace" })
172
+ }
173
+ )
174
+ ] });
175
+ };
176
+ const emptyModel = new MultiTraceModel([]);
177
+ (async () => {
178
+ applyTheme();
179
+ if (window.location.protocol !== "file:") {
180
+ if (window.location.href.includes("isUnderTest=true"))
181
+ await new Promise((f) => setTimeout(f, 1e3));
182
+ if (!navigator.serviceWorker)
183
+ throw new Error(`Service workers are not supported.
184
+ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);
185
+ navigator.serviceWorker.register("sw.bundle.js");
186
+ if (!navigator.serviceWorker.controller) {
187
+ await new Promise((f) => {
188
+ navigator.serviceWorker.oncontrollerchange = () => f();
189
+ });
190
+ }
191
+ setInterval(function() {
192
+ fetch("ping");
193
+ }, 1e4);
194
+ }
195
+ createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
196
+ })();
197
+ //# sourceMappingURL=index.DW2ZzZfL.js.map
@@ -1,2 +1,2 @@
1
- import{M as k,r as o,j as e,T as W,t as D,a as M,c as C}from"./assets/inspectorTab-BHcfR9dD.js";import{W as F}from"./assets/workbench-DZqNXdoV.js";import{T as O,W as A}from"./assets/testServerConnection-DeE2kSzz.js";const I=()=>{const[i,N]=o.useState(!1),[c,p]=o.useState([]),[u,E]=o.useState([]),[f,S]=o.useState(L),[v,m]=o.useState({done:0,total:0}),[T,g]=o.useState(!1),[y,w]=o.useState(null),[x,U]=o.useState(null),h=o.useCallback(t=>{const r=[],a=[],s=new URL(window.location.href);for(let n=0;n<t.length;n++){const l=t.item(n);if(!l)continue;const b=URL.createObjectURL(l);r.push(b),a.push(l.name),s.searchParams.append("trace",b),s.searchParams.append("traceFileName",l.name)}const d=s.toString();window.history.pushState({},"",d),p(r),E(a),g(!1),w(null)},[]);o.useEffect(()=>{const t=async r=>{var a;if((a=r.clipboardData)!=null&&a.files.length){for(const s of r.clipboardData.files)if(s.type!=="application/zip")return;r.preventDefault(),h(r.clipboardData.files)}};return document.addEventListener("paste",t),()=>document.removeEventListener("paste",t)});const P=o.useCallback(t=>{t.preventDefault(),h(t.dataTransfer.files)},[h]),R=o.useCallback(t=>{t.preventDefault(),t.target.files&&h(t.target.files)},[h]);o.useEffect(()=>{const t=new URL(window.location.href).searchParams,r=t.getAll("trace");N(t.has("isServer"));for(const a of r)if(a.startsWith("file:")){U(a||null);return}if(t.has("isServer")){const a=new URLSearchParams(window.location.search).get("ws"),s=new URL(`../${a}`,window.location.toString());s.protocol=window.location.protocol==="https:"?"wss:":"ws:";const d=new O(new A(s));d.onLoadTraceRequested(async n=>{p(n.traceUrl?[n.traceUrl]:[]),g(!1),w(null)}),d.initialize({}).catch(()=>{})}else r.some(a=>a.startsWith("blob:"))||p(r)},[]),o.useEffect(()=>{(async()=>{if(c.length){const t=s=>{s.data.method==="progress"&&m(s.data.params)};navigator.serviceWorker.addEventListener("message",t),m({done:0,total:1});const r=[];for(let s=0;s<c.length;s++){const d=c[s],n=new URLSearchParams;n.set("trace",d),u.length&&n.set("traceFileName",u[s]),n.set("limit",String(c.length));const l=await fetch(`contexts?${n.toString()}`);if(!l.ok){i||p([]),w((await l.json()).error);return}r.push(...await l.json())}navigator.serviceWorker.removeEventListener("message",t);const a=new k(r);m({done:0,total:0}),S(a)}else S(L)})()},[i,c,u]);const j=!!(!i&&!T&&!x&&(!c.length||y));return e.jsxs("div",{className:"vbox workbench-loader",onDragOver:t=>{t.preventDefault(),g(!0)},children:[e.jsxs("div",{className:"hbox header",...j?{inert:"true"}:{},children:[e.jsx("div",{className:"logo",children:e.jsx("img",{src:"playwright-logo.svg",alt:"Playwright logo"})}),e.jsx("div",{className:"product",children:"Playwright"}),f.title&&e.jsx("div",{className:"title",children:f.title}),e.jsx("div",{className:"spacer"}),e.jsx(W,{icon:"color-mode",title:"Toggle color mode",toggled:!1,onClick:()=>D()})]}),e.jsx("div",{className:"progress",children:e.jsx("div",{className:"inner-progress",style:{width:v.total?100*v.done/v.total+"%":0}})}),e.jsx(F,{model:f,inert:j,showSettings:!0}),x&&e.jsxs("div",{className:"drop-target",children:[e.jsx("div",{children:"Trace Viewer uses Service Workers to show traces. To view trace:"}),e.jsxs("div",{style:{paddingTop:20},children:[e.jsxs("div",{children:["1. Click ",e.jsx("a",{href:x,children:"here"})," to put your trace into the download shelf"]}),e.jsxs("div",{children:["2. Go to ",e.jsx("a",{href:"https://trace.playwright.dev",children:"trace.playwright.dev"})]}),e.jsx("div",{children:"3. Drop the trace from the download shelf into the page"})]})]}),j&&e.jsxs("div",{className:"drop-target",children:[e.jsx("div",{className:"processing-error",role:"alert",children:y}),e.jsx("div",{className:"title",role:"heading","aria-level":1,children:"Drop Playwright Trace to load"}),e.jsx("div",{children:"or"}),e.jsx("button",{onClick:()=>{const t=document.createElement("input");t.type="file",t.multiple=!0,t.click(),t.addEventListener("change",r=>R(r))},type:"button",children:"Select file(s)"}),e.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."})]}),i&&!c.length&&e.jsx("div",{className:"drop-target",children:e.jsx("div",{className:"title",children:"Select test to see the trace"})}),T&&e.jsx("div",{className:"drop-target",onDragLeave:()=>{g(!1)},onDrop:t=>P(t),children:e.jsx("div",{className:"title",children:"Release to analyse the Playwright Trace"})})]})},L=new k([]);(async()=>{if(M(),window.location.protocol!=="file:"){if(window.location.href.includes("isUnderTest=true")&&await new Promise(i=>setTimeout(i,1e3)),!navigator.serviceWorker)throw new Error(`Service workers are not supported.
1
+ import{M as k,r as o,j as e,T as W,t as D,a as M,c as C}from"./assets/inspectorTab-wfvwpMHs.js";import{W as F}from"./assets/workbench-LKskf2Iy.js";import{T as O,W as A}from"./assets/testServerConnection-DeE2kSzz.js";const I=()=>{const[i,N]=o.useState(!1),[c,p]=o.useState([]),[u,E]=o.useState([]),[f,S]=o.useState(L),[v,m]=o.useState({done:0,total:0}),[T,g]=o.useState(!1),[y,w]=o.useState(null),[x,U]=o.useState(null),h=o.useCallback(t=>{const r=[],a=[],s=new URL(window.location.href);for(let n=0;n<t.length;n++){const l=t.item(n);if(!l)continue;const b=URL.createObjectURL(l);r.push(b),a.push(l.name),s.searchParams.append("trace",b),s.searchParams.append("traceFileName",l.name)}const d=s.toString();window.history.pushState({},"",d),p(r),E(a),g(!1),w(null)},[]);o.useEffect(()=>{const t=async r=>{var a;if((a=r.clipboardData)!=null&&a.files.length){for(const s of r.clipboardData.files)if(s.type!=="application/zip")return;r.preventDefault(),h(r.clipboardData.files)}};return document.addEventListener("paste",t),()=>document.removeEventListener("paste",t)});const P=o.useCallback(t=>{t.preventDefault(),h(t.dataTransfer.files)},[h]),R=o.useCallback(t=>{t.preventDefault(),t.target.files&&h(t.target.files)},[h]);o.useEffect(()=>{const t=new URL(window.location.href).searchParams,r=t.getAll("trace");N(t.has("isServer"));for(const a of r)if(a.startsWith("file:")){U(a||null);return}if(t.has("isServer")){const a=new URLSearchParams(window.location.search).get("ws"),s=new URL(`../${a}`,window.location.toString());s.protocol=window.location.protocol==="https:"?"wss:":"ws:";const d=new O(new A(s));d.onLoadTraceRequested(async n=>{p(n.traceUrl?[n.traceUrl]:[]),g(!1),w(null)}),d.initialize({}).catch(()=>{})}else r.some(a=>a.startsWith("blob:"))||p(r)},[]),o.useEffect(()=>{(async()=>{if(c.length){const t=s=>{s.data.method==="progress"&&m(s.data.params)};navigator.serviceWorker.addEventListener("message",t),m({done:0,total:1});const r=[];for(let s=0;s<c.length;s++){const d=c[s],n=new URLSearchParams;n.set("trace",d),u.length&&n.set("traceFileName",u[s]),n.set("limit",String(c.length));const l=await fetch(`contexts?${n.toString()}`);if(!l.ok){i||p([]),w((await l.json()).error);return}r.push(...await l.json())}navigator.serviceWorker.removeEventListener("message",t);const a=new k(r);m({done:0,total:0}),S(a)}else S(L)})()},[i,c,u]);const j=!!(!i&&!T&&!x&&(!c.length||y));return e.jsxs("div",{className:"vbox workbench-loader",onDragOver:t=>{t.preventDefault(),g(!0)},children:[e.jsxs("div",{className:"hbox header",...j?{inert:"true"}:{},children:[e.jsx("div",{className:"logo",children:e.jsx("img",{src:"playwright-logo.svg",alt:"Playwright logo"})}),e.jsx("div",{className:"product",children:"Playwright"}),f.title&&e.jsx("div",{className:"title",children:f.title}),e.jsx("div",{className:"spacer"}),e.jsx(W,{icon:"color-mode",title:"Toggle color mode",toggled:!1,onClick:()=>D()})]}),e.jsx("div",{className:"progress",children:e.jsx("div",{className:"inner-progress",style:{width:v.total?100*v.done/v.total+"%":0}})}),e.jsx(F,{model:f,inert:j,showSettings:!0}),x&&e.jsxs("div",{className:"drop-target",children:[e.jsx("div",{children:"Trace Viewer uses Service Workers to show traces. To view trace:"}),e.jsxs("div",{style:{paddingTop:20},children:[e.jsxs("div",{children:["1. Click ",e.jsx("a",{href:x,children:"here"})," to put your trace into the download shelf"]}),e.jsxs("div",{children:["2. Go to ",e.jsx("a",{href:"https://trace.playwright.dev",children:"trace.playwright.dev"})]}),e.jsx("div",{children:"3. Drop the trace from the download shelf into the page"})]})]}),j&&e.jsxs("div",{className:"drop-target",children:[e.jsx("div",{className:"processing-error",role:"alert",children:y}),e.jsx("div",{className:"title",role:"heading","aria-level":1,children:"Drop Playwright Trace to load"}),e.jsx("div",{children:"or"}),e.jsx("button",{onClick:()=>{const t=document.createElement("input");t.type="file",t.multiple=!0,t.click(),t.addEventListener("change",r=>R(r))},type:"button",children:"Select file(s)"}),e.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."})]}),i&&!c.length&&e.jsx("div",{className:"drop-target",children:e.jsx("div",{className:"title",children:"Select test to see the trace"})}),T&&e.jsx("div",{className:"drop-target",onDragLeave:()=>{g(!1)},onDrop:t=>P(t),children:e.jsx("div",{className:"title",children:"Release to analyse the Playwright Trace"})})]})},L=new k([]);(async()=>{if(M(),window.location.protocol!=="file:"){if(window.location.href.includes("isUnderTest=true")&&await new Promise(i=>setTimeout(i,1e3)),!navigator.serviceWorker)throw new Error(`Service workers are not supported.
2
2
  Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);navigator.serviceWorker.register("sw.bundle.js"),navigator.serviceWorker.controller||await new Promise(i=>{navigator.serviceWorker.oncontrollerchange=()=>i()}),setInterval(function(){fetch("ping")},1e4)}C(document.querySelector("#root")).render(e.jsx(I,{}))})();
@@ -0,0 +1,197 @@
1
+ import { M as MultiTraceModel, r as reactExports, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, a as applyTheme, c as createRoot } from "./assets/inspectorTab-Ywa000c9.js";
2
+ import { W as Workbench } from "./assets/workbench-CfXOj3eT.js";
3
+ import { T as TestServerConnection, W as WebSocketTestServerTransport } from "./assets/testServerConnection-D-tXL3sj.js";
4
+ const WorkbenchLoader = () => {
5
+ const [isServer, setIsServer] = reactExports.useState(false);
6
+ const [traceURLs, setTraceURLs] = reactExports.useState([]);
7
+ const [uploadedTraceNames, setUploadedTraceNames] = reactExports.useState([]);
8
+ const [model, setModel] = reactExports.useState(emptyModel);
9
+ const [progress, setProgress] = reactExports.useState({ done: 0, total: 0 });
10
+ const [dragOver, setDragOver] = reactExports.useState(false);
11
+ const [processingErrorMessage, setProcessingErrorMessage] = reactExports.useState(null);
12
+ const [fileForLocalModeError, setFileForLocalModeError] = reactExports.useState(null);
13
+ const processTraceFiles = reactExports.useCallback((files) => {
14
+ const blobUrls = [];
15
+ const fileNames = [];
16
+ const url = new URL(window.location.href);
17
+ for (let i = 0; i < files.length; i++) {
18
+ const file = files.item(i);
19
+ if (!file)
20
+ continue;
21
+ const blobTraceURL = URL.createObjectURL(file);
22
+ blobUrls.push(blobTraceURL);
23
+ fileNames.push(file.name);
24
+ url.searchParams.append("trace", blobTraceURL);
25
+ url.searchParams.append("traceFileName", file.name);
26
+ }
27
+ const href = url.toString();
28
+ window.history.pushState({}, "", href);
29
+ setTraceURLs(blobUrls);
30
+ setUploadedTraceNames(fileNames);
31
+ setDragOver(false);
32
+ setProcessingErrorMessage(null);
33
+ }, []);
34
+ reactExports.useEffect(() => {
35
+ const listener = async (e) => {
36
+ var _a;
37
+ if (!((_a = e.clipboardData) == null ? void 0 : _a.files.length))
38
+ return;
39
+ for (const file of e.clipboardData.files) {
40
+ if (file.type !== "application/zip")
41
+ return;
42
+ }
43
+ e.preventDefault();
44
+ processTraceFiles(e.clipboardData.files);
45
+ };
46
+ document.addEventListener("paste", listener);
47
+ return () => document.removeEventListener("paste", listener);
48
+ });
49
+ const handleDropEvent = reactExports.useCallback((event) => {
50
+ event.preventDefault();
51
+ processTraceFiles(event.dataTransfer.files);
52
+ }, [processTraceFiles]);
53
+ const handleFileInputChange = reactExports.useCallback((event) => {
54
+ event.preventDefault();
55
+ if (!event.target.files)
56
+ return;
57
+ processTraceFiles(event.target.files);
58
+ }, [processTraceFiles]);
59
+ reactExports.useEffect(() => {
60
+ const params = new URL(window.location.href).searchParams;
61
+ const newTraceURLs = params.getAll("trace");
62
+ setIsServer(params.has("isServer"));
63
+ for (const url of newTraceURLs) {
64
+ if (url.startsWith("file:")) {
65
+ setFileForLocalModeError(url || null);
66
+ return;
67
+ }
68
+ }
69
+ if (params.has("isServer")) {
70
+ const guid = new URLSearchParams(window.location.search).get("ws");
71
+ const wsURL = new URL(`../${guid}`, window.location.toString());
72
+ wsURL.protocol = window.location.protocol === "https:" ? "wss:" : "ws:";
73
+ const testServerConnection = new TestServerConnection(new WebSocketTestServerTransport(wsURL));
74
+ testServerConnection.onLoadTraceRequested(async (params2) => {
75
+ setTraceURLs(params2.traceUrl ? [params2.traceUrl] : []);
76
+ setDragOver(false);
77
+ setProcessingErrorMessage(null);
78
+ });
79
+ testServerConnection.initialize({}).catch(() => {
80
+ });
81
+ } else if (!newTraceURLs.some((url) => url.startsWith("blob:"))) {
82
+ setTraceURLs(newTraceURLs);
83
+ }
84
+ }, []);
85
+ reactExports.useEffect(() => {
86
+ (async () => {
87
+ if (traceURLs.length) {
88
+ const swListener = (event) => {
89
+ if (event.data.method === "progress")
90
+ setProgress(event.data.params);
91
+ };
92
+ navigator.serviceWorker.addEventListener("message", swListener);
93
+ setProgress({ done: 0, total: 1 });
94
+ const contextEntries = [];
95
+ for (let i = 0; i < traceURLs.length; i++) {
96
+ const url = traceURLs[i];
97
+ const params = new URLSearchParams();
98
+ params.set("trace", url);
99
+ if (uploadedTraceNames.length)
100
+ params.set("traceFileName", uploadedTraceNames[i]);
101
+ params.set("limit", String(traceURLs.length));
102
+ const response = await fetch(`contexts?${params.toString()}`);
103
+ if (!response.ok) {
104
+ if (!isServer)
105
+ setTraceURLs([]);
106
+ setProcessingErrorMessage((await response.json()).error);
107
+ return;
108
+ }
109
+ contextEntries.push(...await response.json());
110
+ }
111
+ navigator.serviceWorker.removeEventListener("message", swListener);
112
+ const model2 = new MultiTraceModel(contextEntries);
113
+ setProgress({ done: 0, total: 0 });
114
+ setModel(model2);
115
+ } else {
116
+ setModel(emptyModel);
117
+ }
118
+ })();
119
+ }, [isServer, traceURLs, uploadedTraceNames]);
120
+ const showFileUploadDropArea = !!(!isServer && !dragOver && !fileForLocalModeError && (!traceURLs.length || processingErrorMessage));
121
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "vbox workbench-loader", onDragOver: (event) => {
122
+ event.preventDefault();
123
+ setDragOver(true);
124
+ }, children: [
125
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "hbox header", ...showFileUploadDropArea ? { inert: "true" } : {}, children: [
126
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "logo", children: /* @__PURE__ */ jsxRuntimeExports.jsx("img", { src: "playwright-logo.svg", alt: "Playwright logo" }) }),
127
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "product", children: "Playwright" }),
128
+ model.title && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: model.title }),
129
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "spacer" }),
130
+ /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarButton, { icon: "color-mode", title: "Toggle color mode", toggled: false, onClick: () => toggleTheme() })
131
+ ] }),
132
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "progress", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "inner-progress", style: { width: progress.total ? 100 * progress.done / progress.total + "%" : 0 } }) }),
133
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Workbench, { model, inert: showFileUploadDropArea, showSettings: true }),
134
+ fileForLocalModeError && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
135
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "Trace Viewer uses Service Workers to show traces. To view trace:" }),
136
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { style: { paddingTop: 20 }, children: [
137
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
138
+ "1. Click ",
139
+ /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: fileForLocalModeError, children: "here" }),
140
+ " to put your trace into the download shelf"
141
+ ] }),
142
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
143
+ "2. Go to ",
144
+ /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: "https://trace.playwright.dev", children: "trace.playwright.dev" })
145
+ ] }),
146
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "3. Drop the trace from the download shelf into the page" })
147
+ ] })
148
+ ] }),
149
+ showFileUploadDropArea && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
150
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "processing-error", role: "alert", children: processingErrorMessage }),
151
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", role: "heading", "aria-level": 1, children: "Drop Playwright Trace to load" }),
152
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "or" }),
153
+ /* @__PURE__ */ jsxRuntimeExports.jsx("button", { onClick: () => {
154
+ const input = document.createElement("input");
155
+ input.type = "file";
156
+ input.multiple = true;
157
+ input.click();
158
+ input.addEventListener("change", (e) => handleFileInputChange(e));
159
+ }, type: "button", children: "Select file(s)" }),
160
+ /* @__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." })
161
+ ] }),
162
+ isServer && !traceURLs.length && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "drop-target", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Select test to see the trace" }) }),
163
+ dragOver && /* @__PURE__ */ jsxRuntimeExports.jsx(
164
+ "div",
165
+ {
166
+ className: "drop-target",
167
+ onDragLeave: () => {
168
+ setDragOver(false);
169
+ },
170
+ onDrop: (event) => handleDropEvent(event),
171
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Release to analyse the Playwright Trace" })
172
+ }
173
+ )
174
+ ] });
175
+ };
176
+ const emptyModel = new MultiTraceModel([]);
177
+ (async () => {
178
+ applyTheme();
179
+ if (window.location.protocol !== "file:") {
180
+ if (window.location.href.includes("isUnderTest=true"))
181
+ await new Promise((f) => setTimeout(f, 1e3));
182
+ if (!navigator.serviceWorker)
183
+ throw new Error(`Service workers are not supported.
184
+ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);
185
+ navigator.serviceWorker.register("sw.bundle.js");
186
+ if (!navigator.serviceWorker.controller) {
187
+ await new Promise((f) => {
188
+ navigator.serviceWorker.oncontrollerchange = () => f();
189
+ });
190
+ }
191
+ setInterval(function() {
192
+ fetch("ping");
193
+ }, 1e4);
194
+ }
195
+ createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}));
196
+ })();
197
+ //# sourceMappingURL=index.DblJtEW_.js.map
@@ -0,0 +1,2 @@
1
+ import{M as E,r as s,c as R,j as c,a as r,T as x,t as C,W as j,b as F,d as O}from"./assets/wsPort-98e00a94.js";const I=()=>{const[l,P]=s.useState(!1),[d,h]=s.useState([]),[p,W]=s.useState([]),[v,S]=s.useState(L),[f,m]=s.useState({done:0,total:0}),[b,g]=s.useState(!1),[k,w]=s.useState(null),[T,U]=s.useState(null),u=s.useCallback(e=>{const o=[],a=[],t=new URL(window.location.href);for(let i=0;i<e.length;i++){const n=e.item(i);if(!n)continue;const N=URL.createObjectURL(n);o.push(N),a.push(n.name),t.searchParams.append("trace",N),t.searchParams.append("traceFileName",n.name)}const y=t.toString();window.history.pushState({},"",y),h(o),W(a),g(!1),w(null)},[]),D=s.useCallback(e=>{e.preventDefault(),u(e.dataTransfer.files)},[u]),M=s.useCallback(e=>{e.preventDefault(),e.target.files&&u(e.target.files)},[u]);return s.useEffect(()=>{const e=new URL(window.location.href).searchParams,o=e.getAll("trace");P(e.has("isServer"));for(const a of o)if(a.startsWith("file:")){U(a||null);return}e.has("isServer")?R({onEvent(a,t){a==="loadTrace"&&(h(t.url?[t.url]:[]),g(!1),w(null))},onClose(){}}).then(a=>{a("ready")}):o.some(a=>a.startsWith("blob:"))||h(o)},[]),s.useEffect(()=>{(async()=>{if(d.length){const e=t=>{t.data.method==="progress"&&m(t.data.params)};navigator.serviceWorker.addEventListener("message",e),m({done:0,total:1});const o=[];for(let t=0;t<d.length;t++){const y=d[t],i=new URLSearchParams;i.set("trace",y),p.length&&i.set("traceFileName",p[t]);const n=await fetch(`contexts?${i.toString()}`);if(!n.ok){l||h([]),w((await n.json()).error);return}o.push(...await n.json())}navigator.serviceWorker.removeEventListener("message",e);const a=new E(o);m({done:0,total:0}),S(a)}else S(L)})()},[l,d,p]),c("div",{className:"vbox workbench-loader",onDragOver:e=>{e.preventDefault(),g(!0)},children:[c("div",{className:"hbox header",children:[r("div",{className:"logo",children:r("img",{src:"playwright-logo.svg",alt:"Playwright logo"})}),r("div",{className:"product",children:"Playwright"}),v.title&&r("div",{className:"title",children:v.title}),r("div",{className:"spacer"}),r(x,{icon:"color-mode",title:"Toggle color mode",toggled:!1,onClick:()=>C()})]}),r("div",{className:"progress",children:r("div",{className:"inner-progress",style:{width:f.total?100*f.done/f.total+"%":0}})}),r(j,{model:v}),T&&c("div",{className:"drop-target",children:[r("div",{children:"Trace Viewer uses Service Workers to show traces. To view trace:"}),c("div",{style:{paddingTop:20},children:[c("div",{children:["1. Click ",r("a",{href:T,children:"here"})," to put your trace into the download shelf"]}),c("div",{children:["2. Go to ",r("a",{href:"https://trace.playwright.dev",children:"trace.playwright.dev"})]}),r("div",{children:"3. Drop the trace from the download shelf into the page"})]})]}),!l&&!b&&!T&&(!d.length||k)&&c("div",{className:"drop-target",children:[r("div",{className:"processing-error",children:k}),r("div",{className:"title",children:"Drop Playwright Trace to load"}),r("div",{children:"or"}),r("button",{onClick:()=>{const e=document.createElement("input");e.type="file",e.multiple=!0,e.click(),e.addEventListener("change",o=>M(o))},children:"Select file(s)"}),r("div",{style:{maxWidth:400},children:"Playwright Trace Viewer is a Progressive Web App, it does not send your trace anywhere, it opens it locally."})]}),l&&!d.length&&r("div",{className:"drop-target",children:r("div",{className:"title",children:"Select test to see the trace"})}),b&&r("div",{className:"drop-target",onDragLeave:()=>{g(!1)},onDrop:e=>D(e),children:r("div",{className:"title",children:"Release to analyse the Playwright Trace"})})]})},L=new E([]);(async()=>{if(F(),window.location.protocol!=="file:"){if(window.location.href.includes("isUnderTest=true")&&await new Promise(l=>setTimeout(l,1e3)),!navigator.serviceWorker)throw new Error(`Service workers are not supported.
2
+ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);navigator.serviceWorker.register("sw.bundle.js"),navigator.serviceWorker.controller||await new Promise(l=>{navigator.serviceWorker.oncontrollerchange=()=>l()}),setInterval(function(){fetch("ping")},1e4)}O.render(r(I,{}),document.querySelector("#root"))})();
@@ -0,0 +1,2 @@
1
+ import{M as E,r as s,c as R,j as c,a as r,T as x,t as C,W as j,b as F,d as O}from"./assets/wsPort-edfeeb7d.js";const I=()=>{const[l,P]=s.useState(!1),[d,h]=s.useState([]),[p,W]=s.useState([]),[v,S]=s.useState(L),[f,m]=s.useState({done:0,total:0}),[b,g]=s.useState(!1),[k,w]=s.useState(null),[T,U]=s.useState(null),u=s.useCallback(e=>{const o=[],a=[],t=new URL(window.location.href);for(let i=0;i<e.length;i++){const n=e.item(i);if(!n)continue;const N=URL.createObjectURL(n);o.push(N),a.push(n.name),t.searchParams.append("trace",N),t.searchParams.append("traceFileName",n.name)}const y=t.toString();window.history.pushState({},"",y),h(o),W(a),g(!1),w(null)},[]),D=s.useCallback(e=>{e.preventDefault(),u(e.dataTransfer.files)},[u]),M=s.useCallback(e=>{e.preventDefault(),e.target.files&&u(e.target.files)},[u]);return s.useEffect(()=>{const e=new URL(window.location.href).searchParams,o=e.getAll("trace");P(e.has("isServer"));for(const a of o)if(a.startsWith("file:")){U(a||null);return}e.has("isServer")?R({onEvent(a,t){a==="loadTrace"&&(h(t.url?[t.url]:[]),g(!1),w(null))},onClose(){}}).then(a=>{a("ready")}):o.some(a=>a.startsWith("blob:"))||h(o)},[]),s.useEffect(()=>{(async()=>{if(d.length){const e=t=>{t.data.method==="progress"&&m(t.data.params)};navigator.serviceWorker.addEventListener("message",e),m({done:0,total:1});const o=[];for(let t=0;t<d.length;t++){const y=d[t],i=new URLSearchParams;i.set("trace",y),p.length&&i.set("traceFileName",p[t]);const n=await fetch(`contexts?${i.toString()}`);if(!n.ok){l||h([]),w((await n.json()).error);return}o.push(...await n.json())}navigator.serviceWorker.removeEventListener("message",e);const a=new E(o);m({done:0,total:0}),S(a)}else S(L)})()},[l,d,p]),c("div",{className:"vbox workbench-loader",onDragOver:e=>{e.preventDefault(),g(!0)},children:[c("div",{className:"hbox header",children:[r("div",{className:"logo",children:r("img",{src:"playwright-logo.svg",alt:"Playwright logo"})}),r("div",{className:"product",children:"Playwright"}),v.title&&r("div",{className:"title",children:v.title}),r("div",{className:"spacer"}),r(x,{icon:"color-mode",title:"Toggle color mode",toggled:!1,onClick:()=>C()})]}),r("div",{className:"progress",children:r("div",{className:"inner-progress",style:{width:f.total?100*f.done/f.total+"%":0}})}),r(j,{model:v}),T&&c("div",{className:"drop-target",children:[r("div",{children:"Trace Viewer uses Service Workers to show traces. To view trace:"}),c("div",{style:{paddingTop:20},children:[c("div",{children:["1. Click ",r("a",{href:T,children:"here"})," to put your trace into the download shelf"]}),c("div",{children:["2. Go to ",r("a",{href:"https://trace.playwright.dev",children:"trace.playwright.dev"})]}),r("div",{children:"3. Drop the trace from the download shelf into the page"})]})]}),!l&&!b&&!T&&(!d.length||k)&&c("div",{className:"drop-target",children:[r("div",{className:"processing-error",children:k}),r("div",{className:"title",children:"Drop Playwright Trace to load"}),r("div",{children:"or"}),r("button",{onClick:()=>{const e=document.createElement("input");e.type="file",e.multiple=!0,e.click(),e.addEventListener("change",o=>M(o))},children:"Select file(s)"}),r("div",{style:{maxWidth:400},children:"Playwright Trace Viewer is a Progressive Web App, it does not send your trace anywhere, it opens it locally."})]}),l&&!d.length&&r("div",{className:"drop-target",children:r("div",{className:"title",children:"Select test to see the trace"})}),b&&r("div",{className:"drop-target",onDragLeave:()=>{g(!1)},onDrop:e=>D(e),children:r("div",{className:"title",children:"Release to analyse the Playwright Trace"})})]})},L=new E([]);(async()=>{if(F(),window.location.protocol!=="file:"){if(window.location.href.includes("isUnderTest=true")&&await new Promise(l=>setTimeout(l,1e3)),!navigator.serviceWorker)throw new Error(`Service workers are not supported.
2
+ Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);navigator.serviceWorker.register("sw.bundle.js"),navigator.serviceWorker.controller||await new Promise(l=>{navigator.serviceWorker.oncontrollerchange=()=>l()}),setInterval(function(){fetch("ping")},1e4)}O.render(r(I,{}),document.querySelector("#root"))})();