chrome-devtools-frontend 1.0.1550444 → 1.0.1555174

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 (466) hide show
  1. package/docs/styleguide/ux/components.md +34 -8
  2. package/eslint.config.mjs +7 -0
  3. package/front_end/Images/generate-css-vars.js +8 -4
  4. package/front_end/Images/src/spark.svg +10 -0
  5. package/front_end/core/common/Settings.ts +20 -8
  6. package/front_end/core/host/UserMetrics.ts +3 -1
  7. package/front_end/core/i18n/collect-ui-strings.js +19 -10
  8. package/front_end/core/i18n/generate-locales-js.js +4 -4
  9. package/front_end/core/protocol_client/CDPConnection.ts +1 -0
  10. package/front_end/core/protocol_client/InspectorBackend.ts +5 -1
  11. package/front_end/core/root/Runtime.ts +0 -12
  12. package/front_end/core/sdk/DOMModel.ts +38 -3
  13. package/front_end/core/sdk/DebuggerModel.ts +9 -4
  14. package/front_end/core/sdk/IsolateManager.ts +7 -0
  15. package/front_end/core/sdk/PageResourceLoader.ts +3 -3
  16. package/front_end/core/sdk/RehydratingConnection.ts +5 -2
  17. package/front_end/core/sdk/ResourceTreeModel.ts +0 -1
  18. package/front_end/entrypoints/main/MainImpl.ts +28 -10
  19. package/front_end/generated/SupportedCSSProperties.js +32 -0
  20. package/front_end/models/ai_assistance/AiConversation.ts +94 -4
  21. package/front_end/models/ai_assistance/agents/AiAgent.ts +30 -15
  22. package/front_end/models/ai_assistance/agents/PerformanceAgent.ts +179 -41
  23. package/front_end/models/ai_assistance/agents/StylingAgent.snapshot.txt +5 -0
  24. package/front_end/models/ai_assistance/agents/StylingAgent.ts +62 -0
  25. package/front_end/models/ai_assistance/data_formatters/NetworkRequestFormatter.ts +2 -1
  26. package/front_end/models/ai_assistance/data_formatters/PerformanceInsightFormatter.ts +1 -7
  27. package/front_end/models/ai_assistance/data_formatters/PerformanceTraceFormatter.snapshot.txt +124 -12
  28. package/front_end/models/ai_assistance/data_formatters/PerformanceTraceFormatter.ts +125 -30
  29. package/front_end/models/ai_assistance/performance/AICallTree.ts +42 -0
  30. package/front_end/models/ai_code_generation/AiCodeGeneration.ts +12 -0
  31. package/front_end/models/issues_manager/Issue.ts +1 -0
  32. package/front_end/models/issues_manager/IssueAggregator.ts +9 -0
  33. package/front_end/models/issues_manager/IssuesManager.ts +5 -0
  34. package/front_end/models/issues_manager/PermissionElementIssue.ts +262 -0
  35. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabled.md +7 -0
  36. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabledWithOccluder.md +9 -0
  37. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabledWithOccluderParent.md +9 -0
  38. package/front_end/models/issues_manager/descriptions/permissionElementCspFrameAncestorsMissing.md +5 -0
  39. package/front_end/models/issues_manager/descriptions/permissionElementFencedFrameDisallowed.md +5 -0
  40. package/front_end/models/issues_manager/descriptions/permissionElementFontSizeTooLarge.md +5 -0
  41. package/front_end/models/issues_manager/descriptions/permissionElementFontSizeTooSmall.md +5 -0
  42. package/front_end/models/issues_manager/descriptions/permissionElementGeolocationDeprecated.md +5 -0
  43. package/front_end/models/issues_manager/descriptions/permissionElementInsetBoxShadowUnsupported.md +5 -0
  44. package/front_end/models/issues_manager/descriptions/permissionElementInvalidDisplayStyle.md +5 -0
  45. package/front_end/models/issues_manager/descriptions/permissionElementInvalidSizeValue.md +5 -0
  46. package/front_end/models/issues_manager/descriptions/permissionElementInvalidType.md +5 -0
  47. package/front_end/models/issues_manager/descriptions/permissionElementInvalidTypeActivation.md +5 -0
  48. package/front_end/models/issues_manager/descriptions/permissionElementLowContrast.md +5 -0
  49. package/front_end/models/issues_manager/descriptions/permissionElementNonOpaqueColor.md +5 -0
  50. package/front_end/models/issues_manager/descriptions/permissionElementPaddingBottomUnsupported.md +6 -0
  51. package/front_end/models/issues_manager/descriptions/permissionElementPaddingRightUnsupported.md +6 -0
  52. package/front_end/models/issues_manager/descriptions/permissionElementPermissionsPolicyBlocked.md +5 -0
  53. package/front_end/models/issues_manager/descriptions/permissionElementRegistrationFailed.md +5 -0
  54. package/front_end/models/issues_manager/descriptions/permissionElementRequestInProgress.md +5 -0
  55. package/front_end/models/issues_manager/descriptions/permissionElementSecurityChecksFailed.md +5 -0
  56. package/front_end/models/issues_manager/descriptions/permissionElementTypeNotSupported.md +5 -0
  57. package/front_end/models/issues_manager/descriptions/permissionElementUntrustedEvent.md +7 -0
  58. package/front_end/models/issues_manager/issues_manager.ts +2 -0
  59. package/front_end/models/javascript_metadata/NativeFunctions.js +23 -23
  60. package/front_end/models/stack_trace/StackTraceModel.ts +37 -18
  61. package/front_end/models/trace/Processor.ts +14 -15
  62. package/front_end/models/trace/insights/Common.ts +2 -8
  63. package/front_end/models/trace/insights/types.ts +12 -2
  64. package/front_end/models/trace/types/TraceEvents.ts +4 -1
  65. package/front_end/panels/ai_assistance/AiAssistancePanel.ts +28 -6
  66. package/front_end/panels/ai_assistance/ai_assistance-meta.ts +9 -23
  67. package/front_end/panels/ai_assistance/ai_assistance.ts +1 -0
  68. package/front_end/panels/ai_assistance/components/ChatView.ts +78 -2
  69. package/front_end/panels/ai_assistance/components/CollapsibleAssistanceContentWidget.ts +71 -0
  70. package/front_end/panels/ai_assistance/components/PerformanceAgentFlameChart.ts +126 -0
  71. package/front_end/panels/ai_assistance/components/PerformanceAgentMarkdownRenderer.ts +131 -2
  72. package/front_end/panels/ai_assistance/components/chatView.css +28 -0
  73. package/front_end/panels/ai_assistance/components/collapsibleAssistanceContentWidget.css +33 -0
  74. package/front_end/panels/application/AppManifestView.ts +1007 -521
  75. package/front_end/panels/application/ApplicationPanelSidebar.ts +1 -17
  76. package/front_end/panels/application/BounceTrackingMitigationsTreeElement.ts +2 -6
  77. package/front_end/panels/application/ExtensionStorageItemsView.ts +3 -5
  78. package/front_end/panels/application/KeyValueStorageItemsView.ts +3 -2
  79. package/front_end/panels/application/components/BackForwardCacheView.ts +2 -2
  80. package/front_end/panels/application/components/BounceTrackingMitigationsView.ts +133 -118
  81. package/front_end/panels/application/preloading/PreloadingView.ts +46 -45
  82. package/front_end/panels/application/preloading/components/MismatchedPreloadingGrid.ts +80 -75
  83. package/front_end/panels/application/preloading/components/PreloadingDisabledInfobar.ts +169 -133
  84. package/front_end/panels/application/preloading/components/RuleSetDetailsView.ts +74 -93
  85. package/front_end/panels/application/preloading/components/RuleSetGrid.ts +142 -117
  86. package/front_end/panels/application/preloading/components/UsedPreloadingView.ts +51 -11
  87. package/front_end/panels/application/preloading/components/components.ts +0 -2
  88. package/front_end/panels/common/Annotation.ts +184 -0
  89. package/front_end/panels/common/AnnotationManager.ts +148 -11
  90. package/front_end/panels/common/ExtensionView.ts +47 -0
  91. package/front_end/panels/common/PersistenceUtils.ts +22 -25
  92. package/front_end/panels/common/annotation.css +40 -0
  93. package/front_end/panels/common/common.ts +1 -0
  94. package/front_end/panels/console/ConsoleInsightTeaser.ts +187 -5
  95. package/front_end/panels/console/ConsolePinPane.ts +437 -217
  96. package/front_end/panels/console/ConsolePrompt.ts +32 -223
  97. package/front_end/panels/console/ConsoleView.ts +67 -66
  98. package/front_end/panels/console/ConsoleViewMessage.ts +8 -3
  99. package/front_end/panels/console/consoleInsightTeaser.css +23 -0
  100. package/front_end/panels/console/consoleView.css +1 -1
  101. package/front_end/panels/elements/AdoptedStyleSheetTreeElement.ts +89 -0
  102. package/front_end/panels/elements/ColorSwatchPopoverIcon.ts +2 -2
  103. package/front_end/panels/elements/ComputedStyleWidget.ts +16 -5
  104. package/front_end/panels/elements/ElementsPanel.ts +38 -12
  105. package/front_end/panels/elements/ElementsSidebarPane.ts +1 -3
  106. package/front_end/panels/elements/ElementsTreeElement.ts +313 -353
  107. package/front_end/panels/elements/ElementsTreeOutline.ts +39 -13
  108. package/front_end/panels/elements/StylePropertyTreeElement.ts +15 -14
  109. package/front_end/panels/elements/StylesSidebarPane.ts +1 -1
  110. package/front_end/panels/emulation/MediaQueryInspector.ts +171 -125
  111. package/front_end/panels/explain/components/ConsoleInsight.ts +175 -150
  112. package/front_end/panels/explain/components/consoleInsight.css +348 -347
  113. package/front_end/panels/issues/AffectedPermissionElementsView.ts +46 -0
  114. package/front_end/panels/issues/IssueView.ts +2 -0
  115. package/front_end/panels/issues/IssuesPane.ts +6 -0
  116. package/front_end/panels/layer_viewer/LayerDetailsView.ts +165 -149
  117. package/front_end/panels/layer_viewer/Layers3DView.ts +131 -78
  118. package/front_end/panels/lighthouse/LighthouseStatusView.ts +149 -100
  119. package/front_end/panels/linear_memory_inspector/components/LinearMemoryHighlightChipList.ts +90 -64
  120. package/front_end/panels/linear_memory_inspector/components/LinearMemoryInspector.ts +25 -34
  121. package/front_end/panels/linear_memory_inspector/components/LinearMemoryValueInterpreter.ts +60 -44
  122. package/front_end/panels/linear_memory_inspector/components/ValueInterpreterDisplay.ts +170 -151
  123. package/front_end/panels/linear_memory_inspector/components/ValueInterpreterSettings.ts +50 -51
  124. package/front_end/panels/linear_memory_inspector/components/valueInterpreterDisplay.css +0 -13
  125. package/front_end/panels/linear_memory_inspector/components/valueInterpreterSettings.css +20 -18
  126. package/front_end/panels/mobile_throttling/CalibrationController.ts +3 -1
  127. package/front_end/panels/network/NetworkDataGridNode.ts +14 -6
  128. package/front_end/panels/network/NetworkItemView.ts +42 -3
  129. package/front_end/panels/network/NetworkLogView.ts +10 -11
  130. package/front_end/panels/network/NetworkPanel.ts +63 -1
  131. package/front_end/panels/network/RequestInitiatorView.ts +146 -113
  132. package/front_end/panels/network/components/RequestHeaderSection.css +51 -50
  133. package/front_end/panels/network/components/RequestHeaderSection.ts +81 -71
  134. package/front_end/panels/network/components/RequestHeadersView.css +1 -1
  135. package/front_end/panels/network/components/RequestHeadersView.ts +26 -11
  136. package/front_end/panels/network/components/RequestTrustTokensView.css +24 -14
  137. package/front_end/panels/network/components/RequestTrustTokensView.ts +144 -140
  138. package/front_end/panels/profiler/IsolateSelector.ts +2 -1
  139. package/front_end/panels/protocol_monitor/ProtocolMonitor.ts +49 -33
  140. package/front_end/panels/recorder/RecorderController.ts +2 -3
  141. package/front_end/panels/recorder/components/ControlButton.ts +68 -34
  142. package/front_end/panels/recorder/components/CreateRecordingView.ts +9 -6
  143. package/front_end/panels/recorder/components/RecordingView.ts +81 -88
  144. package/front_end/panels/recorder/components/ReplaySection.ts +226 -145
  145. package/front_end/panels/recorder/{controllers → components}/SelectorPicker.ts +129 -52
  146. package/front_end/panels/recorder/components/StepEditor.ts +21 -67
  147. package/front_end/panels/recorder/components/StepView.ts +222 -180
  148. package/front_end/panels/recorder/components/TimelineSection.ts +69 -48
  149. package/front_end/panels/recorder/components/components.ts +2 -2
  150. package/front_end/panels/recorder/components/selectorPicker.css +14 -0
  151. package/front_end/panels/recorder/components/stepEditor.css +0 -5
  152. package/front_end/panels/recorder/components/stepView.css +196 -198
  153. package/front_end/panels/recorder/extensions/ExtensionManager.ts +4 -48
  154. package/front_end/panels/recorder/models/ScreenshotUtils.ts +17 -11
  155. package/front_end/panels/security/CookieControlsView.ts +30 -26
  156. package/front_end/panels/settings/components/SyncSection.ts +0 -1
  157. package/front_end/panels/sources/CSSPlugin.ts +3 -3
  158. package/front_end/panels/sources/CallStackSidebarPane.ts +60 -75
  159. package/front_end/panels/sources/SourcesPanel.ts +1 -11
  160. package/front_end/panels/sources/TabbedEditorContainer.ts +11 -8
  161. package/front_end/panels/sources/ThreadsSidebarPane.ts +96 -101
  162. package/front_end/panels/sources/threadsSidebarPane.css +6 -5
  163. package/front_end/panels/timeline/CompatibilityTracksAppender.ts +0 -1
  164. package/front_end/panels/timeline/InteractionsTrackAppender.ts +2 -3
  165. package/front_end/panels/timeline/TimelineFlameChartDataProvider.ts +23 -33
  166. package/front_end/panels/timeline/TimelineFlameChartNetworkDataProvider.ts +4 -3
  167. package/front_end/panels/timeline/TimelineFlameChartView.ts +12 -0
  168. package/front_end/panels/timeline/TimelinePanel.ts +3 -5
  169. package/front_end/panels/timeline/components/IgnoreListSetting.ts +164 -142
  170. package/front_end/panels/timeline/components/InteractionBreakdown.ts +48 -28
  171. package/front_end/panels/timeline/components/LayoutShiftDetails.ts +18 -23
  172. package/front_end/panels/timeline/components/NetworkRequestTooltip.ts +98 -73
  173. package/front_end/panels/timeline/components/Sidebar.ts +16 -7
  174. package/front_end/panels/timeline/components/SidebarInsightsTab.ts +174 -137
  175. package/front_end/panels/timeline/components/SidebarSingleInsightSet.ts +262 -291
  176. package/front_end/panels/timeline/components/Utils.ts +25 -0
  177. package/front_end/panels/timeline/components/insights/BaseInsightComponent.ts +210 -146
  178. package/front_end/panels/timeline/components/insights/CLSCulprits.ts +8 -20
  179. package/front_end/panels/timeline/components/insights/Cache.ts +0 -9
  180. package/front_end/panels/timeline/components/insights/Checklist.ts +53 -43
  181. package/front_end/panels/timeline/components/insights/DOMSize.ts +11 -33
  182. package/front_end/panels/timeline/components/insights/DocumentLatency.ts +6 -12
  183. package/front_end/panels/timeline/components/insights/DuplicatedJavaScript.ts +0 -9
  184. package/front_end/panels/timeline/components/insights/EventRef.ts +47 -109
  185. package/front_end/panels/timeline/components/insights/FontDisplay.ts +0 -9
  186. package/front_end/panels/timeline/components/insights/ForcedReflow.ts +0 -9
  187. package/front_end/panels/timeline/components/insights/INPBreakdown.ts +0 -9
  188. package/front_end/panels/timeline/components/insights/ImageDelivery.ts +1 -10
  189. package/front_end/panels/timeline/components/insights/ImageRef.ts +112 -0
  190. package/front_end/panels/timeline/components/insights/InsightRenderer.ts +91 -0
  191. package/front_end/panels/timeline/components/insights/LCPBreakdown.ts +0 -9
  192. package/front_end/panels/timeline/components/insights/LCPDiscovery.ts +11 -14
  193. package/front_end/panels/timeline/components/insights/LegacyJavaScript.ts +0 -9
  194. package/front_end/panels/timeline/components/insights/ModernHTTP.ts +0 -9
  195. package/front_end/panels/timeline/components/insights/NetworkDependencyTree.ts +6 -21
  196. package/front_end/panels/timeline/components/insights/NodeLink.ts +68 -43
  197. package/front_end/panels/timeline/components/insights/README.md +2 -3
  198. package/front_end/panels/timeline/components/insights/RenderBlocking.ts +0 -9
  199. package/front_end/panels/timeline/components/insights/SlowCSSSelector.ts +0 -9
  200. package/front_end/panels/timeline/components/insights/ThirdParties.ts +0 -9
  201. package/front_end/panels/timeline/components/insights/Viewport.ts +7 -19
  202. package/front_end/panels/timeline/components/insights/baseInsightComponent.css +5 -0
  203. package/front_end/panels/timeline/components/insights/insights.ts +2 -0
  204. package/front_end/panels/timeline/components/interactionBreakdown.css +15 -13
  205. package/front_end/panels/timeline/components/sidebarInsightsTab.css +50 -48
  206. package/front_end/panels/timeline/enable-easter-egg.js +7 -3
  207. package/front_end/third_party/chromium/README.chromium +1 -1
  208. package/front_end/third_party/puppeteer/README.chromium +2 -2
  209. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.d.ts +96 -0
  210. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.d.ts.map +1 -0
  211. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.js +8 -0
  212. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.js.map +1 -0
  213. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.d.ts +87 -0
  214. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.d.ts.map +1 -1
  215. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.js.map +1 -1
  216. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.d.ts +2 -6
  217. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.d.ts.map +1 -1
  218. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.js +5 -24
  219. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.js.map +1 -1
  220. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.d.ts +5 -0
  221. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.d.ts.map +1 -1
  222. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.js.map +1 -1
  223. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.d.ts +1 -0
  224. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.d.ts.map +1 -1
  225. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.js.map +1 -1
  226. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.d.ts +18 -0
  227. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.d.ts.map +1 -0
  228. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.js +42 -0
  229. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.js.map +1 -0
  230. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.d.ts +4 -1
  231. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.d.ts.map +1 -1
  232. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.js +10 -0
  233. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.js.map +1 -1
  234. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.d.ts +27 -0
  235. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.d.ts.map +1 -0
  236. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.js +90 -0
  237. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.js.map +1 -0
  238. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.d.ts +3 -1
  239. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.d.ts.map +1 -1
  240. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.js +3 -2
  241. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.js.map +1 -1
  242. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.d.ts +4 -1
  243. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.d.ts.map +1 -1
  244. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.js +5 -2
  245. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.js.map +1 -1
  246. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.d.ts +4 -0
  247. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.d.ts.map +1 -1
  248. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.js +14 -2
  249. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.js.map +1 -1
  250. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.d.ts.map +1 -1
  251. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.js +7 -0
  252. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.js.map +1 -1
  253. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Accessibility.js +1 -1
  254. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Accessibility.js.map +1 -1
  255. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.d.ts +18 -0
  256. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.d.ts.map +1 -0
  257. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.js +30 -0
  258. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.js.map +1 -0
  259. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.d.ts +5 -2
  260. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.d.ts.map +1 -1
  261. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.js +22 -3
  262. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.js.map +1 -1
  263. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/CdpSession.d.ts +1 -1
  264. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/CdpSession.d.ts.map +1 -1
  265. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.d.ts +2 -3
  266. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.d.ts.map +1 -1
  267. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.js +4 -6
  268. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.js.map +1 -1
  269. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.d.ts +2 -2
  270. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.d.ts.map +1 -1
  271. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.js +1 -1
  272. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.js.map +1 -1
  273. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.d.ts +2 -0
  274. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.d.ts.map +1 -1
  275. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.js +8 -0
  276. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.js.map +1 -1
  277. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.d.ts.map +1 -1
  278. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.js +8 -3
  279. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.js.map +1 -1
  280. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.d.ts +1 -0
  281. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.d.ts.map +1 -1
  282. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.js +1 -0
  283. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.js.map +1 -1
  284. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/BrowserConnector.js +30 -0
  285. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/BrowserConnector.js.map +1 -1
  286. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/ConnectOptions.d.ts +15 -0
  287. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/ConnectOptions.d.ts.map +1 -1
  288. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/injected/injected.d.ts +1 -1
  289. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.d.ts +1 -1
  290. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.d.ts.map +1 -1
  291. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.js +2 -13
  292. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.js.map +1 -1
  293. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.d.ts +5 -3
  294. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.d.ts.map +1 -1
  295. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.js +17 -0
  296. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.js.map +1 -1
  297. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.d.ts +3 -3
  298. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.js +3 -3
  299. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.js.map +1 -1
  300. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/Mutex.d.ts +2 -2
  301. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/version.d.ts +1 -1
  302. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/version.js +1 -1
  303. package/front_end/third_party/puppeteer/package/lib/es5-iife/puppeteer-core-browser.d.ts +221 -4
  304. package/front_end/third_party/puppeteer/package/lib/es5-iife/puppeteer-core-browser.js +182 -95
  305. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.d.ts +96 -0
  306. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.d.ts.map +1 -0
  307. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.js +7 -0
  308. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.js.map +1 -0
  309. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.d.ts +87 -0
  310. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.d.ts.map +1 -1
  311. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.js.map +1 -1
  312. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.d.ts +2 -6
  313. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.d.ts.map +1 -1
  314. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.js +4 -22
  315. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.js.map +1 -1
  316. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.d.ts +5 -0
  317. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.d.ts.map +1 -1
  318. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.js.map +1 -1
  319. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.d.ts +1 -0
  320. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.d.ts.map +1 -1
  321. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.js.map +1 -1
  322. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.d.ts +18 -0
  323. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.d.ts.map +1 -0
  324. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.js +38 -0
  325. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.js.map +1 -0
  326. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.d.ts +4 -1
  327. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.d.ts.map +1 -1
  328. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.js +10 -0
  329. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.js.map +1 -1
  330. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.d.ts +27 -0
  331. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.d.ts.map +1 -0
  332. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.js +85 -0
  333. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.js.map +1 -0
  334. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.d.ts +3 -1
  335. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.d.ts.map +1 -1
  336. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.js +3 -2
  337. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.js.map +1 -1
  338. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.d.ts +4 -1
  339. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.d.ts.map +1 -1
  340. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.js +5 -2
  341. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.js.map +1 -1
  342. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.d.ts +4 -0
  343. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.d.ts.map +1 -1
  344. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.js +14 -2
  345. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.js.map +1 -1
  346. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.d.ts.map +1 -1
  347. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.js +7 -0
  348. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.js.map +1 -1
  349. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Accessibility.js +1 -1
  350. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Accessibility.js.map +1 -1
  351. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.d.ts +18 -0
  352. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.d.ts.map +1 -0
  353. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.js +26 -0
  354. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.js.map +1 -0
  355. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.d.ts +5 -2
  356. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.d.ts.map +1 -1
  357. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.js +22 -3
  358. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.js.map +1 -1
  359. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/CdpSession.d.ts +1 -1
  360. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/CdpSession.d.ts.map +1 -1
  361. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.d.ts +2 -3
  362. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.d.ts.map +1 -1
  363. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.js +2 -4
  364. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.js.map +1 -1
  365. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.d.ts +2 -2
  366. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.d.ts.map +1 -1
  367. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.js +2 -2
  368. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.js.map +1 -1
  369. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.d.ts +2 -0
  370. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.d.ts.map +1 -1
  371. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.js +8 -0
  372. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.js.map +1 -1
  373. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.d.ts.map +1 -1
  374. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.js +8 -3
  375. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.js.map +1 -1
  376. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.d.ts +1 -0
  377. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.d.ts.map +1 -1
  378. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.js +1 -0
  379. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.js.map +1 -1
  380. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/BrowserConnector.js +31 -1
  381. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/BrowserConnector.js.map +1 -1
  382. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/ConnectOptions.d.ts +15 -0
  383. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/ConnectOptions.d.ts.map +1 -1
  384. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.d.ts +1 -1
  385. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.d.ts.map +1 -1
  386. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.js +2 -13
  387. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.js.map +1 -1
  388. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.d.ts +5 -3
  389. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.d.ts.map +1 -1
  390. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.js +16 -1
  391. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.js.map +1 -1
  392. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.d.ts +3 -3
  393. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.js +3 -3
  394. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.js.map +1 -1
  395. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/util/version.d.ts +1 -1
  396. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/util/version.js +1 -1
  397. package/front_end/third_party/puppeteer/package/lib/types.d.ts +221 -4
  398. package/front_end/third_party/puppeteer/package/package.json +4 -4
  399. package/front_end/third_party/puppeteer/package/src/api/BluetoothEmulation.ts +103 -0
  400. package/front_end/third_party/puppeteer/package/src/api/Browser.ts +96 -1
  401. package/front_end/third_party/puppeteer/package/src/api/DeviceRequestPrompt.ts +2 -10
  402. package/front_end/third_party/puppeteer/package/src/api/Page.ts +6 -0
  403. package/front_end/third_party/puppeteer/package/src/api/api.ts +1 -0
  404. package/front_end/third_party/puppeteer/package/src/bidi/BluetoothEmulation.ts +52 -0
  405. package/front_end/third_party/puppeteer/package/src/bidi/Browser.ts +15 -0
  406. package/front_end/third_party/puppeteer/package/src/bidi/DeviceRequestPrompt.ts +138 -0
  407. package/front_end/third_party/puppeteer/package/src/bidi/Frame.ts +7 -3
  408. package/front_end/third_party/puppeteer/package/src/bidi/Page.ts +10 -2
  409. package/front_end/third_party/puppeteer/package/src/bidi/core/BrowsingContext.ts +30 -2
  410. package/front_end/third_party/puppeteer/package/src/bidi/util.ts +8 -0
  411. package/front_end/third_party/puppeteer/package/src/cdp/Accessibility.ts +1 -1
  412. package/front_end/third_party/puppeteer/package/src/cdp/BluetoothEmulation.ts +47 -0
  413. package/front_end/third_party/puppeteer/package/src/cdp/Browser.ts +33 -3
  414. package/front_end/third_party/puppeteer/package/src/cdp/CdpSession.ts +1 -1
  415. package/front_end/third_party/puppeteer/package/src/cdp/DeviceRequestPrompt.ts +3 -8
  416. package/front_end/third_party/puppeteer/package/src/cdp/Frame.ts +2 -2
  417. package/front_end/third_party/puppeteer/package/src/cdp/FrameManager.ts +9 -4
  418. package/front_end/third_party/puppeteer/package/src/cdp/Page.ts +13 -0
  419. package/front_end/third_party/puppeteer/package/src/cdp/WebWorker.ts +8 -3
  420. package/front_end/third_party/puppeteer/package/src/cdp/cdp.ts +1 -0
  421. package/front_end/third_party/puppeteer/package/src/common/BrowserConnector.ts +45 -1
  422. package/front_end/third_party/puppeteer/package/src/common/ConnectOptions.ts +20 -0
  423. package/front_end/third_party/puppeteer/package/src/node/ChromeLauncher.ts +5 -17
  424. package/front_end/third_party/puppeteer/package/src/node/LaunchOptions.ts +23 -7
  425. package/front_end/third_party/puppeteer/package/src/revisions.ts +3 -3
  426. package/front_end/third_party/puppeteer/package/src/util/version.ts +1 -1
  427. package/front_end/third_party/puppeteer/puppeteer-tsconfig.json +4 -0
  428. package/front_end/ui/components/annotations/AnnotationRepository.ts +153 -13
  429. package/front_end/ui/components/settings/SettingCheckbox.ts +4 -6
  430. package/front_end/ui/components/snackbars/Snackbars.docs.ts +0 -1
  431. package/front_end/ui/components/text_editor/AiCodeCompletionTeaserPlaceholder.ts +12 -3
  432. package/front_end/ui/components/text_editor/AiCodeGenerationProvider.ts +182 -0
  433. package/front_end/ui/components/text_editor/text_editor.ts +1 -0
  434. package/front_end/ui/helpers/OpenInNewTab.ts +5 -1
  435. package/front_end/ui/i18n/i18n.ts +9 -9
  436. package/front_end/ui/kit/icons/Icon.docs.ts +22 -65
  437. package/front_end/ui/kit/kit.ts +1 -0
  438. package/front_end/ui/kit/link/Link.docs.ts +15 -0
  439. package/front_end/ui/kit/link/Link.ts +151 -0
  440. package/front_end/ui/kit/link/link.css +27 -0
  441. package/front_end/ui/legacy/EmptyWidget.ts +6 -0
  442. package/front_end/ui/legacy/Floaty.ts +442 -0
  443. package/front_end/ui/legacy/InspectorView.ts +12 -0
  444. package/front_end/ui/legacy/ReportView.ts +1 -1
  445. package/front_end/ui/legacy/SelectMenu.docs.ts +0 -1
  446. package/front_end/ui/legacy/TabbedPane.ts +150 -65
  447. package/front_end/ui/legacy/Widget.ts +1 -3
  448. package/front_end/ui/legacy/components/cookie_table/CookiesTable.ts +1 -1
  449. package/front_end/ui/legacy/components/inline_editor/ColorSwatch.ts +36 -36
  450. package/front_end/ui/legacy/components/object_ui/JavaScriptREPL.ts +22 -37
  451. package/front_end/ui/legacy/components/object_ui/RemoteObjectPreviewFormatter.ts +31 -1
  452. package/front_end/ui/legacy/components/perf_ui/FlameChart.ts +2 -2
  453. package/front_end/ui/legacy/components/utils/Linkifier.ts +7 -11
  454. package/front_end/ui/legacy/floaty.css +77 -0
  455. package/front_end/ui/legacy/legacy.ts +2 -0
  456. package/front_end/ui/legacy/tabbedPane.css +4 -7
  457. package/front_end/ui/visual_logging/KnownContextValues.ts +7 -0
  458. package/inspector_overlay/loadCSS.rollup.js +5 -4
  459. package/package.json +2 -2
  460. package/front_end/panels/application/preloading/components/PreloadingMismatchedHeadersGrid.ts +0 -99
  461. package/front_end/panels/recorder/components/SelectButton.ts +0 -304
  462. package/front_end/panels/recorder/controllers/controllers.ts +0 -7
  463. package/front_end/ui/components/chrome_link/ChromeLink.ts +0 -76
  464. package/front_end/ui/components/chrome_link/chromeLink.css +0 -12
  465. package/front_end/ui/components/chrome_link/chrome_link.ts +0 -9
  466. /package/front_end/panels/recorder/components/{selectButton.css → replaySection.css} +0 -0
@@ -1,25 +1,19 @@
1
1
  // Copyright 2023 The Chromium Authors
2
2
  // Use of this source code is governed by a BSD-style license that can be
3
3
  // found in the LICENSE file.
4
- /* eslint-disable @devtools/no-lit-render-outside-of-view */
5
4
 
6
5
  import * as i18n from '../../../../core/i18n/i18n.js';
7
- import {assertNotNullOrUndefined} from '../../../../core/platform/platform.js';
8
6
  import * as SDK from '../../../../core/sdk/sdk.js';
9
7
  import type * as Protocol from '../../../../generated/protocol.js';
10
8
  import * as Formatter from '../../../../models/formatter/formatter.js';
11
9
  import * as CodeMirror from '../../../../third_party/codemirror.next/codemirror.next.js';
12
10
  import * as CodeHighlighter from '../../../../ui/components/code_highlighter/code_highlighter.js';
13
- import * as LegacyWrapper from '../../../../ui/components/legacy_wrapper/legacy_wrapper.js';
14
- import * as RenderCoordinator from '../../../../ui/components/render_coordinator/render_coordinator.js';
15
11
  import * as TextEditor from '../../../../ui/components/text_editor/text_editor.js';
16
12
  import * as UI from '../../../../ui/legacy/legacy.js';
17
- import * as Lit from '../../../../ui/lit/lit.js';
13
+ import {html, nothing, render} from '../../../../ui/lit/lit.js';
18
14
 
19
15
  import ruleSetDetailsViewStyles from './RuleSetDetailsView.css.js';
20
16
 
21
- const {html} = Lit;
22
-
23
17
  const UIStrings = {
24
18
  /**
25
19
  * @description Text in RuleSetDetailsView of the Application panel if no element is selected. An element here is an item in a
@@ -41,118 +35,105 @@ type RuleSet = Protocol.Preload.RuleSet;
41
35
 
42
36
  const codeMirrorJsonType = await CodeHighlighter.CodeHighlighter.languageFromMIME('application/json');
43
37
 
44
- export type RuleSetDetailsViewData = RuleSet|null;
45
-
46
- export class RuleSetDetailsView extends LegacyWrapper.LegacyWrapper.WrappableComponent<UI.Widget.VBox> {
47
- readonly #shadow = this.attachShadow({mode: 'open'});
48
- #data: RuleSetDetailsViewData = null;
49
- #shouldPrettyPrint = true;
50
- #editorState?: CodeMirror.EditorState;
51
-
52
- set data(data: RuleSetDetailsViewData) {
53
- this.#data = data;
54
- void this.#render();
55
- }
56
-
57
- set shouldPrettyPrint(shouldPrettyPrint: boolean) {
58
- this.#shouldPrettyPrint = shouldPrettyPrint;
59
- }
38
+ export interface ViewInput {
39
+ url: string;
40
+ errorMessage?: string;
41
+ editorState: CodeMirror.EditorState;
42
+ sourceText: string;
43
+ }
60
44
 
61
- async #render(): Promise<void> {
62
- await RenderCoordinator.write('RuleSetDetailsView render', async () => {
63
- if (this.#data === null) {
64
- Lit.render(
65
- html`
66
- <style>${ruleSetDetailsViewStyles}</style>
67
- <style>${UI.inspectorCommonStyles}</style>
45
+ export const DEFAULT_VIEW = (input: ViewInput|null, _output: object, target: HTMLElement): void => {
46
+ // clang-format off
47
+ render(html`
48
+ <style>${ruleSetDetailsViewStyles}</style>
49
+ <style>${UI.inspectorCommonStyles}</style>
50
+ ${input
51
+ ? html`
52
+ <div class="content">
53
+ <div class="ruleset-header" id="ruleset-url">${input.url}</div>
54
+ ${input.errorMessage ? html`
55
+ <div class="ruleset-header">
56
+ <devtools-icon name="cross-circle" class="medium">
57
+ </devtools-icon>
58
+ <span id="error-message-text">${input.errorMessage}</span>
59
+ </div>
60
+ ` : nothing}
61
+ </div>
62
+ <div class="text-ellipsis">
63
+ <devtools-text-editor .style.flexGrow=${'1'} .state=${input.editorState}></devtools-text-editor>
64
+ </div>`
65
+ : html`
68
66
  <div class="placeholder">
69
67
  <div class="empty-state">
70
68
  <span class="empty-state-header">${i18nString(UIStrings.noElementSelected)}</span>
71
69
  <span class="empty-state-description">${i18nString(UIStrings.selectAnElementForMoreDetails)}</span>
72
70
  </div>
73
- </div>
74
- `,
75
- this.#shadow, {host: this});
76
- // clang-format on
77
- return;
78
- }
79
-
80
- const sourceText = await this.#getSourceText();
81
-
82
- // Disabled until https://crbug.com/1079231 is fixed.
83
- // clang-format off
84
- Lit.render(html`
85
- <style>${ruleSetDetailsViewStyles}</style>
86
- <style>${UI.inspectorCommonStyles}</style>
87
- <div class="content">
88
- <div class="ruleset-header" id="ruleset-url">${this.#data?.url || SDK.TargetManager.TargetManager.instance().inspectedURL()}</div>
89
- ${this.#maybeError()}
90
- </div>
91
- <div class="text-ellipsis">
92
- ${this.#renderSource(sourceText)}
93
- </div>
94
- `, this.#shadow, {host: this});
95
- // clang-format on
96
- });
71
+ </div>`
72
+ }
73
+ `, target);
74
+ // clang-format on
75
+ };
76
+
77
+ export class RuleSetDetailsView extends UI.Widget.VBox {
78
+ readonly #view: typeof DEFAULT_VIEW;
79
+ #ruleSet: RuleSet|null = null;
80
+ #shouldPrettyPrint = true;
81
+
82
+ constructor(element?: HTMLElement, view = DEFAULT_VIEW) {
83
+ super(element, {useShadowDom: true});
84
+ this.#view = view;
97
85
  }
98
86
 
99
- // TODO(https://crbug.com/1425354): Support i18n.
100
- #maybeError(): Lit.LitTemplate {
101
- assertNotNullOrUndefined(this.#data);
87
+ override wasShown(): void {
88
+ super.wasShown();
89
+ this.requestUpdate();
90
+ }
102
91
 
103
- if (this.#data.errorMessage === undefined) {
104
- return Lit.nothing;
105
- }
92
+ set ruleSet(ruleSet: RuleSet|null) {
93
+ this.#ruleSet = ruleSet;
94
+ this.requestUpdate();
95
+ }
106
96
 
107
- // Disabled until https://crbug.com/1079231 is fixed.
108
- // clang-format off
109
- return html`
110
- <div class="ruleset-header">
111
- <devtools-icon name="cross-circle" class="medium">
112
- </devtools-icon>
113
- <span id="error-message-text">${this.#data.errorMessage}</span>
114
- </div>
115
- `;
116
- // clang-format on
97
+ set shouldPrettyPrint(shouldPrettyPrint: boolean) {
98
+ this.#shouldPrettyPrint = shouldPrettyPrint;
99
+ this.requestUpdate();
117
100
  }
118
101
 
119
- #renderSource(sourceText: string): Lit.LitTemplate {
120
- this.#editorState = CodeMirror.EditorState.create({
102
+ override async performUpdate(): Promise<void> {
103
+ if (!this.#ruleSet) {
104
+ this.#view(null, {}, this.contentElement);
105
+ return;
106
+ }
107
+
108
+ const sourceText = await this.#getSourceText();
109
+ const editorState = CodeMirror.EditorState.create({
121
110
  doc: sourceText,
122
111
  extensions: [
123
- TextEditor.Config.baseConfiguration(sourceText || ''),
112
+ TextEditor.Config.baseConfiguration(sourceText),
124
113
  CodeMirror.lineNumbers(),
125
114
  CodeMirror.EditorState.readOnly.of(true),
126
115
  codeMirrorJsonType as CodeMirror.Extension,
127
116
  CodeMirror.syntaxHighlighting(CodeHighlighter.CodeHighlighter.highlightStyle),
128
117
  ],
129
118
  });
130
- // Disabled until https://crbug.com/1079231 is fixed.
131
- // clang-format off
132
- // TODO(https://crbug.com/1425354): Add Raw button.
133
- return html`
134
- <devtools-text-editor .style.flexGrow=${'1'} .state=${
135
- this.#editorState
136
- }></devtools-text-editor>
137
- `;
138
- // clang-format on
119
+
120
+ this.#view(
121
+ {
122
+ url: this.#ruleSet.url || SDK.TargetManager.TargetManager.instance().inspectedURL(),
123
+ errorMessage: this.#ruleSet.errorMessage,
124
+ editorState,
125
+ sourceText,
126
+ },
127
+ {}, this.contentElement);
139
128
  }
140
129
 
141
130
  async #getSourceText(): Promise<string> {
142
- if (this.#shouldPrettyPrint && this.#data?.sourceText !== undefined) {
131
+ if (this.#shouldPrettyPrint && this.#ruleSet?.sourceText !== undefined) {
143
132
  const formattedResult =
144
- await Formatter.ScriptFormatter.formatScriptContent('application/json', this.#data.sourceText);
133
+ await Formatter.ScriptFormatter.formatScriptContent('application/json', this.#ruleSet.sourceText);
145
134
  return formattedResult.formattedContent;
146
135
  }
147
136
 
148
- return this.#data?.sourceText || '';
149
- }
150
- }
151
-
152
- customElements.define('devtools-resources-rulesets-details-view', RuleSetDetailsView);
153
-
154
- declare global {
155
- interface HTMLElementTagNameMap {
156
- 'devtools-resources-rulesets-details-view': RuleSetDetailsView;
137
+ return this.#ruleSet?.sourceText || '';
157
138
  }
158
139
  }
@@ -1,7 +1,6 @@
1
1
  // Copyright 2023 The Chromium Authors
2
2
  // Use of this source code is governed by a BSD-style license that can be
3
3
  // found in the LICENSE file.
4
- /* eslint-disable @devtools/no-lit-render-outside-of-view */
5
4
 
6
5
  import '../../../../ui/legacy/components/data_grid/data_grid.js';
7
6
  import '../../../../ui/kit/kit.js';
@@ -12,9 +11,8 @@ import type * as Platform from '../../../../core/platform/platform.js';
12
11
  import {assertNotNullOrUndefined} from '../../../../core/platform/platform.js';
13
12
  import * as SDK from '../../../../core/sdk/sdk.js';
14
13
  import * as Protocol from '../../../../generated/protocol.js';
15
- import * as LegacyWrapper from '../../../../ui/components/legacy_wrapper/legacy_wrapper.js';
16
- import type * as UI from '../../../../ui/legacy/legacy.js';
17
- import * as Lit from '../../../../ui/lit/lit.js';
14
+ import * as UI from '../../../../ui/legacy/legacy.js';
15
+ import {Directives, html, type LitTemplate, nothing, render} from '../../../../ui/lit/lit.js';
18
16
  import * as VisualLogging from '../../../../ui/visual_logging/visual_logging.js';
19
17
  import * as NetworkForward from '../../../network/forward/forward.js';
20
18
  import * as PreloadingHelper from '../helper/helper.js';
@@ -22,7 +20,7 @@ import * as PreloadingHelper from '../helper/helper.js';
22
20
  import * as PreloadingString from './PreloadingString.js';
23
21
  import ruleSetGridStyles from './ruleSetGrid.css.js';
24
22
 
25
- const {html, Directives: {styleMap}} = Lit;
23
+ const {styleMap} = Directives;
26
24
 
27
25
  const UIStrings = {
28
26
  /**
@@ -63,29 +61,145 @@ export interface RuleSetGridRow {
63
61
  preloadsStatusSummary: string;
64
62
  }
65
63
 
64
+ export type View = (input: ViewInput, output: ViewOutput, target: HTMLElement) => void;
65
+
66
+ export interface ViewInput {
67
+ data: RuleSetGridData|null;
68
+ onSelect: (ruleSetId: Protocol.Preload.RuleSetId) => void;
69
+ onRevealInElements: (ruleSet: Protocol.Preload.RuleSet) => void;
70
+ onRevealInNetwork: (ruleSet: Protocol.Preload.RuleSet) => void;
71
+ onRevealPreloadsAssociatedWithRuleSet: (ruleSet: Protocol.Preload.RuleSet) => void;
72
+ }
73
+
74
+ export type ViewOutput = unknown;
75
+
76
+ export const DEFAULT_VIEW: View = (input, _output, target) => {
77
+ let template: LitTemplate = nothing;
78
+ if (input.data !== null) {
79
+ const {rows, pageURL} = input.data;
80
+
81
+ // Disabled until https://crbug.com/1079231 is fixed.
82
+ // clang-format off
83
+ template =
84
+ html`
85
+ <style>${ruleSetGridStyles}</style>
86
+ <div class="ruleset-container" jslog=${VisualLogging.pane('preloading-rules')}>
87
+ <devtools-data-grid striped>
88
+ <table>
89
+ <tr>
90
+ <th id="rule-set" weight="20" sortable>
91
+ ${i18nString(UIStrings.ruleSet)}
92
+ </th>
93
+ <th id="status" weight="80" sortable>
94
+ ${i18nString(UIStrings.status)}
95
+ </th>
96
+ </tr>
97
+ ${rows.map(({ruleSet, preloadsStatusSummary}) => {
98
+ const location = PreloadingString.ruleSetTagOrLocationShort(ruleSet, pageURL);
99
+ const revealInElements = ruleSet.backendNodeId !== undefined;
100
+ const revealInNetwork = ruleSet.url !== undefined && ruleSet.requestId;
101
+ return html`
102
+ <tr @select=${() => input.onSelect(ruleSet.id)}>
103
+ <td>
104
+ ${revealInElements || revealInNetwork ? html`
105
+ <button class="link" role="link"
106
+ @click=${() => {
107
+ if (revealInElements) {
108
+ input.onRevealInElements(ruleSet);
109
+ } else {
110
+ input.onRevealInNetwork(ruleSet);
111
+ }
112
+ }}
113
+ title=${revealInElements ? i18nString(UIStrings.clickToOpenInElementsPanel)
114
+ : i18nString(UIStrings.clickToOpenInNetworkPanel)}
115
+ style=${styleMap({
116
+ border: 'none',
117
+ background: 'none',
118
+ color: 'var(--icon-link)',
119
+ cursor: 'pointer',
120
+ 'text-decoration': 'underline',
121
+ 'padding-inline-start': '0',
122
+ 'padding-inline-end': '0',
123
+ })}
124
+ jslog=${VisualLogging
125
+ .action(revealInElements ? 'reveal-in-elements' : 'reveal-in-network')
126
+ .track({click: true})}
127
+ >
128
+ <devtools-icon name=${revealInElements ? 'code-circle' : 'arrow-up-down-circle'} class="medium"
129
+ style=${styleMap({
130
+ color: 'var(--icon-link)',
131
+ 'vertical-align': 'sub',
132
+ })}
133
+ ></devtools-icon>
134
+ ${location}
135
+ </button>`
136
+ : location}
137
+ </td>
138
+ <td>
139
+ ${ruleSet.errorType !== undefined ? html`
140
+ <span style=${styleMap({color: 'var(--sys-color-error)'})}>
141
+ ${i18nString(UIStrings.errors, {errorCount: 1})}
142
+ </span>` : ''} ${ruleSet.errorType !== Protocol.Preload.RuleSetErrorType.SourceIsNotJsonObject &&
143
+ ruleSet.errorType !== Protocol.Preload.RuleSetErrorType.InvalidRulesetLevelTag ?
144
+ html`
145
+ <button class="link" role="link"
146
+ @click=${() => input.onRevealPreloadsAssociatedWithRuleSet(ruleSet)}
147
+ title=${i18nString(UIStrings.buttonRevealPreloadsAssociatedWithRuleSet)}
148
+ style=${styleMap({
149
+ color: 'var(--sys-color-primary)',
150
+ 'text-decoration': 'underline',
151
+ cursor: 'pointer',
152
+ border: 'none',
153
+ background: 'none',
154
+ 'padding-inline-start': '0',
155
+ 'padding-inline-end': '0',
156
+ })}
157
+ jslog=${VisualLogging.action('reveal-preloads').track({click: true})}>
158
+ ${preloadsStatusSummary}
159
+ </button>` : ''}
160
+ </td>
161
+ </tr>
162
+ `;})}
163
+ </table>
164
+ </devtools-data-grid>
165
+ </div>`;
166
+ // clang-format on
167
+ }
168
+ render(template, target);
169
+ };
170
+
66
171
  /** Grid component to show SpeculationRules rule sets. **/
67
- export class RuleSetGrid extends LegacyWrapper.LegacyWrapper.WrappableComponent<UI.Widget.VBox> {
68
- readonly #shadow = this.attachShadow({mode: 'open'});
172
+ export class RuleSetGrid extends Common.ObjectWrapper.eventMixin<EventTypes, typeof UI.Widget.VBox>(UI.Widget.VBox) {
173
+ readonly #view: View;
69
174
  #data: RuleSetGridData|null = null;
70
175
 
71
- connectedCallback(): void {
72
- this.#render();
176
+ constructor(view: View = DEFAULT_VIEW) {
177
+ super({useShadowDom: true});
178
+ this.#view = view;
179
+ }
180
+
181
+ get data(): RuleSetGridData|null {
182
+ return this.#data;
73
183
  }
74
184
 
75
- update(data: RuleSetGridData): void {
185
+ set data(data: RuleSetGridData|null) {
76
186
  this.#data = data;
77
- this.#render();
187
+ this.requestUpdate();
78
188
  }
79
189
 
80
- async #revealSpeculationRules(ruleSet: Protocol.Preload.RuleSet): Promise<void> {
81
- if (ruleSet.backendNodeId !== undefined) {
82
- await this.#revealSpeculationRulesInElements(ruleSet);
83
- } else if (ruleSet.url !== undefined && ruleSet.requestId) {
84
- await this.#revealSpeculationRulesInNetwork(ruleSet);
85
- }
190
+ override performUpdate(): void {
191
+ const input: ViewInput = {
192
+ data: this.#data,
193
+ onSelect: this.dispatchEventToListeners.bind(this, Events.SELECT),
194
+ onRevealInElements: this.#revealSpeculationRulesInElements.bind(this),
195
+ onRevealInNetwork: this.#revealSpeculationRulesInNetwork.bind(this),
196
+ onRevealPreloadsAssociatedWithRuleSet: this.#revealAttemptViewWithFilter.bind(this),
197
+ };
198
+ const output = undefined;
199
+ this.#view(input, output, this.contentElement);
86
200
  }
87
201
 
88
- async #revealSpeculationRulesInElements(ruleSet: Protocol.Preload.RuleSet): Promise<void> {
202
+ #revealSpeculationRulesInElements(ruleSet: Protocol.Preload.RuleSet): void {
89
203
  assertNotNullOrUndefined(ruleSet.backendNodeId);
90
204
 
91
205
  const target = SDK.TargetManager.TargetManager.instance().scopeTarget();
@@ -93,10 +207,10 @@ export class RuleSetGrid extends LegacyWrapper.LegacyWrapper.WrappableComponent<
93
207
  return;
94
208
  }
95
209
 
96
- await Common.Revealer.reveal(new SDK.DOMModel.DeferredDOMNode(target, ruleSet.backendNodeId));
210
+ void Common.Revealer.reveal(new SDK.DOMModel.DeferredDOMNode(target, ruleSet.backendNodeId));
97
211
  }
98
212
 
99
- async #revealSpeculationRulesInNetwork(ruleSet: Protocol.Preload.RuleSet): Promise<void> {
213
+ #revealSpeculationRulesInNetwork(ruleSet: Protocol.Preload.RuleSet): void {
100
214
  assertNotNullOrUndefined(ruleSet.requestId);
101
215
  const request = SDK.TargetManager.TargetManager.instance()
102
216
  .scopeTarget()
@@ -109,107 +223,18 @@ export class RuleSetGrid extends LegacyWrapper.LegacyWrapper.WrappableComponent<
109
223
 
110
224
  const requestLocation = NetworkForward.UIRequestLocation.UIRequestLocation.tab(
111
225
  request, NetworkForward.UIRequestLocation.UIRequestTabs.PREVIEW, {clearFilter: false});
112
- await Common.Revealer.reveal(requestLocation);
113
- }
114
-
115
- async #revealAttemptViewWithFilter(ruleSet: Protocol.Preload.RuleSet): Promise<void> {
116
- await Common.Revealer.reveal(new PreloadingHelper.PreloadingForward.AttemptViewWithFilter(ruleSet.id));
226
+ void Common.Revealer.reveal(requestLocation);
117
227
  }
118
228
 
119
- #render(): void {
120
- if (this.#data === null) {
121
- return;
122
- }
123
-
124
- const {rows, pageURL} = this.#data;
125
-
126
- // Disabled until https://crbug.com/1079231 is fixed.
127
- // clang-format off
128
- Lit.render(html`
129
- <style>${ruleSetGridStyles}</style>
130
- <div class="ruleset-container" jslog=${VisualLogging.pane('preloading-rules')}>
131
- <devtools-data-grid striped>
132
- <table>
133
- <tr>
134
- <th id="rule-set" weight="20" sortable>
135
- ${i18nString(UIStrings.ruleSet)}
136
- </th>
137
- <th id="status" weight="80" sortable>
138
- ${i18nString(UIStrings.status)}
139
- </th>
140
- </tr>
141
- ${rows.map(({ruleSet, preloadsStatusSummary}) => {
142
- const location = PreloadingString.ruleSetTagOrLocationShort(ruleSet, pageURL);
143
- const revealInElements = ruleSet.backendNodeId !== undefined;
144
- const revealInNetwork = ruleSet.url !== undefined && ruleSet.requestId;
145
- return html`
146
- <tr @select=${() => this.dispatchEvent(new CustomEvent('select', {detail: ruleSet.id}))}>
147
- <td>
148
- ${revealInElements || revealInNetwork ? html`
149
- <button class="link" role="link"
150
- @click=${() => this.#revealSpeculationRules(ruleSet)}
151
- title=${revealInElements ? i18nString(UIStrings.clickToOpenInElementsPanel)
152
- : i18nString(UIStrings.clickToOpenInNetworkPanel)}
153
- style=${styleMap({
154
- border: 'none',
155
- background: 'none',
156
- color: 'var(--icon-link)',
157
- cursor: 'pointer',
158
- 'text-decoration': 'underline',
159
- 'padding-inline-start': '0',
160
- 'padding-inline-end': '0',
161
- })}
162
- jslog=${VisualLogging
163
- .action(revealInElements ? 'reveal-in-elements' : 'reveal-in-network')
164
- .track({click: true})}
165
- >
166
- <devtools-icon name=${revealInElements ? 'code-circle' : 'arrow-up-down-circle'} class="medium"
167
- style=${styleMap({
168
- color: 'var(--icon-link)',
169
- 'vertical-align': 'sub',
170
- })}
171
- ></devtools-icon>
172
- ${location}
173
- </button>`
174
- : location}
175
- </td>
176
- <td>
177
- ${ruleSet.errorType !== undefined ? html`
178
- <span style=${styleMap({color: 'var(--sys-color-error)'})}>
179
- ${i18nString(UIStrings.errors, {errorCount: 1})}
180
- </span>` : ''} ${ruleSet.errorType !== Protocol.Preload.RuleSetErrorType.SourceIsNotJsonObject &&
181
- ruleSet.errorType !== Protocol.Preload.RuleSetErrorType.InvalidRulesetLevelTag ?
182
- html`
183
- <button class="link" role="link"
184
- @click=${() => this.#revealAttemptViewWithFilter(ruleSet)}
185
- title=${i18nString(UIStrings.buttonRevealPreloadsAssociatedWithRuleSet)}
186
- style=${styleMap({
187
- color: 'var(--sys-color-primary)',
188
- 'text-decoration': 'underline',
189
- cursor: 'pointer',
190
- border: 'none',
191
- background: 'none',
192
- 'padding-inline-start': '0',
193
- 'padding-inline-end': '0',
194
- })}
195
- jslog=${VisualLogging.action('reveal-preloads').track({click: true})}>
196
- ${preloadsStatusSummary}
197
- </button>` : ''}
198
- </td>
199
- </tr>
200
- `;})}
201
- </table>
202
- </devtools-data-grid>
203
- </div>
204
- `, this.#shadow, {host: this});
205
- // clang-format on
229
+ #revealAttemptViewWithFilter(ruleSet: Protocol.Preload.RuleSet): void {
230
+ void Common.Revealer.reveal(new PreloadingHelper.PreloadingForward.AttemptViewWithFilter(ruleSet.id));
206
231
  }
207
232
  }
208
233
 
209
- customElements.define('devtools-resources-ruleset-grid', RuleSetGrid);
234
+ export const enum Events {
235
+ SELECT = 'select',
236
+ }
210
237
 
211
- declare global {
212
- interface HTMLElementTagNameMap {
213
- 'devtools-resources-ruleset-grid': RuleSetGrid;
214
- }
238
+ export interface EventTypes {
239
+ [Events.SELECT]: Protocol.Preload.RuleSetId;
215
240
  }
@@ -5,7 +5,6 @@
5
5
 
6
6
  import '../../../../ui/kit/kit.js';
7
7
  import '../../../../ui/components/report_view/report_view.js';
8
- import './PreloadingMismatchedHeadersGrid.js';
9
8
  import './MismatchedPreloadingGrid.js';
10
9
 
11
10
  import * as Common from '../../../../core/common/common.js';
@@ -16,12 +15,13 @@ import * as SDK from '../../../../core/sdk/sdk.js';
16
15
  import * as Protocol from '../../../../generated/protocol.js';
17
16
  import * as LegacyWrapper from '../../../../ui/components/legacy_wrapper/legacy_wrapper.js';
18
17
  import * as RenderCoordinator from '../../../../ui/components/render_coordinator/render_coordinator.js';
19
- import type * as UI from '../../../../ui/legacy/legacy.js';
18
+ import * as UI from '../../../../ui/legacy/legacy.js';
20
19
  import * as Lit from '../../../../ui/lit/lit.js';
21
20
  import * as VisualLogging from '../../../../ui/visual_logging/visual_logging.js';
22
21
  import * as PreloadingHelper from '../helper/helper.js';
23
22
 
24
- import type * as MismatchedPreloadingGrid from './MismatchedPreloadingGrid.js';
23
+ import * as MismatchedPreloadingGrid from './MismatchedPreloadingGrid.js';
24
+ import preloadingGridStyles from './preloadingGrid.css.js';
25
25
  import {prefetchFailureReason, prerenderFailureReason} from './PreloadingString.js';
26
26
  import usedPreloadingStyles from './usedPreloadingView.css.js';
27
27
 
@@ -119,6 +119,22 @@ const UIStrings = {
119
119
  * @description Label for badge, indicating how many failed speculations there are.
120
120
  */
121
121
  badgeFailureWithCount: '{n, plural, =1 {# failure} other {# failures}}',
122
+ /**
123
+ * @description The name of the HTTP request header.
124
+ */
125
+ headerName: 'Header name',
126
+ /**
127
+ * @description The value of the HTTP request header in initial navigation.
128
+ */
129
+ initialNavigationValue: 'Value in initial navigation',
130
+ /**
131
+ * @description The value of the HTTP request header in activation navigation.
132
+ */
133
+ activationNavigationValue: 'Value in activation navigation',
134
+ /**
135
+ * @description The string to indicate the value of the header is missing.
136
+ */
137
+ missing: '(missing)',
122
138
  } as const;
123
139
  const str_ = i18n.i18n.registerUIStrings('panels/application/preloading/components/UsedPreloadingView.ts', UIStrings);
124
140
  const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
@@ -337,8 +353,9 @@ export class UsedPreloadingView extends LegacyWrapper.LegacyWrapper.WrappableCom
337
353
  <devtools-report-section-header>${i18nString(UIStrings.preloadedURLs)}</devtools-report-section-header>
338
354
  <devtools-report-section
339
355
  jslog=${VisualLogging.section('preloaded-urls')}>
340
- <devtools-resources-mismatched-preloading-grid
341
- .data=${data as MismatchedPreloadingGrid.MismatchedPreloadingGridData}></devtools-resources-mismatched-preloading-grid>
356
+ <devtools-widget
357
+ .widgetConfig=${UI.Widget.widgetConfig(MismatchedPreloadingGrid.MismatchedPreloadingGrid, {data})}
358
+ ></devtools-widget>
342
359
  </devtools-report-section>
343
360
  `;
344
361
  // clang-format on
@@ -346,8 +363,10 @@ export class UsedPreloadingView extends LegacyWrapper.LegacyWrapper.WrappableCom
346
363
 
347
364
  #maybeMismatchedHTTPHeadersSections(): Lit.LitTemplate {
348
365
  const attempt = this.#data.previousAttempts.find(
349
- attempt => this.#isPrerenderAttempt(attempt) && attempt.mismatchedHeaders !== null);
350
- if (attempt === undefined) {
366
+ attempt => this.#isPrerenderAttempt(attempt) && attempt.mismatchedHeaders !== null) as
367
+ SDK.PreloadingModel.PrerenderAttempt |
368
+ SDK.PreloadingModel.PrerenderUntilScriptAttempt | undefined;
369
+ if (!attempt?.mismatchedHeaders) {
351
370
  return Lit.nothing;
352
371
  }
353
372
 
@@ -363,10 +382,31 @@ export class UsedPreloadingView extends LegacyWrapper.LegacyWrapper.WrappableCom
363
382
  return html`
364
383
  <devtools-report-section-header>${i18nString(UIStrings.mismatchedHeadersDetail)}</devtools-report-section-header>
365
384
  <devtools-report-section>
366
- <devtools-resources-preloading-mismatched-headers-grid
367
- .data=${
368
- attempt as SDK.PreloadingModel.PrerenderAttempt |
369
- SDK.PreloadingModel.PrerenderUntilScriptAttempt}></devtools-resources-preloading-mismatched-headers-grid>
385
+ <style>${preloadingGridStyles}</style>
386
+ <div class="preloading-container">
387
+ <devtools-data-grid striped inline>
388
+ <table>
389
+ <tr>
390
+ <th id="header-name" weight="30" sortable>
391
+ ${i18nString(UIStrings.headerName)}
392
+ </th>
393
+ <th id="initial-value" weight="30" sortable>
394
+ ${i18nString(UIStrings.initialNavigationValue)}
395
+ </th>
396
+ <th id="activation-value" weight="30" sortable>
397
+ ${i18nString(UIStrings.activationNavigationValue)}
398
+ </th>
399
+ </tr>
400
+ ${attempt.mismatchedHeaders.map(mismatchedHeaders => html`
401
+ <tr>
402
+ <td>${mismatchedHeaders.headerName}</td>
403
+ <td>${mismatchedHeaders.initialValue ?? i18nString(UIStrings.missing)}</td>
404
+ <td>${mismatchedHeaders.activationValue ?? i18nString(UIStrings.missing)}</td>
405
+ </tr>
406
+ `)}
407
+ </table>
408
+ </devtools-data-grid>
409
+ </div>
370
410
  </devtools-report-section>
371
411
  `;
372
412
  // clang-format on
@@ -6,7 +6,6 @@ import * as MismatchedPreloadingGrid from './MismatchedPreloadingGrid.js';
6
6
  import * as PreloadingDetailsReportView from './PreloadingDetailsReportView.js';
7
7
  import * as PreloadingDisabledInfobar from './PreloadingDisabledInfobar.js';
8
8
  import * as PreloadingGrid from './PreloadingGrid.js';
9
- import * as PreloadingMismatchedHeadersGrid from './PreloadingMismatchedHeadersGrid.js';
10
9
  import * as RuleSetDetailsView from './RuleSetDetailsView.js';
11
10
  import * as RuleSetGrid from './RuleSetGrid.js';
12
11
  import * as UsedPreloadingView from './UsedPreloadingView.js';
@@ -16,7 +15,6 @@ export {
16
15
  PreloadingDetailsReportView,
17
16
  PreloadingDisabledInfobar,
18
17
  PreloadingGrid,
19
- PreloadingMismatchedHeadersGrid,
20
18
  RuleSetDetailsView,
21
19
  RuleSetGrid,
22
20
  UsedPreloadingView,