chrome-devtools-frontend 1.0.1550444 → 1.0.1553956

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 (455) 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/core/common/Settings.ts +20 -8
  5. package/front_end/core/host/UserMetrics.ts +3 -1
  6. package/front_end/core/i18n/collect-ui-strings.js +19 -10
  7. package/front_end/core/i18n/generate-locales-js.js +4 -4
  8. package/front_end/core/protocol_client/CDPConnection.ts +1 -0
  9. package/front_end/core/protocol_client/InspectorBackend.ts +5 -1
  10. package/front_end/core/root/Runtime.ts +0 -12
  11. package/front_end/core/sdk/DOMModel.ts +38 -3
  12. package/front_end/core/sdk/DebuggerModel.ts +9 -4
  13. package/front_end/core/sdk/IsolateManager.ts +7 -0
  14. package/front_end/core/sdk/PageResourceLoader.ts +3 -3
  15. package/front_end/core/sdk/RehydratingConnection.ts +5 -2
  16. package/front_end/entrypoints/main/MainImpl.ts +28 -10
  17. package/front_end/generated/SupportedCSSProperties.js +14 -0
  18. package/front_end/models/ai_assistance/AiConversation.ts +94 -4
  19. package/front_end/models/ai_assistance/agents/AiAgent.ts +30 -15
  20. package/front_end/models/ai_assistance/agents/PerformanceAgent.ts +179 -41
  21. package/front_end/models/ai_assistance/agents/StylingAgent.snapshot.txt +5 -0
  22. package/front_end/models/ai_assistance/agents/StylingAgent.ts +62 -0
  23. package/front_end/models/ai_assistance/data_formatters/NetworkRequestFormatter.ts +2 -1
  24. package/front_end/models/ai_assistance/data_formatters/PerformanceInsightFormatter.ts +1 -7
  25. package/front_end/models/ai_assistance/data_formatters/PerformanceTraceFormatter.snapshot.txt +124 -12
  26. package/front_end/models/ai_assistance/data_formatters/PerformanceTraceFormatter.ts +125 -30
  27. package/front_end/models/ai_assistance/performance/AICallTree.ts +42 -0
  28. package/front_end/models/ai_code_generation/AiCodeGeneration.ts +12 -0
  29. package/front_end/models/issues_manager/Issue.ts +1 -0
  30. package/front_end/models/issues_manager/IssueAggregator.ts +9 -0
  31. package/front_end/models/issues_manager/IssuesManager.ts +5 -0
  32. package/front_end/models/issues_manager/PermissionElementIssue.ts +262 -0
  33. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabled.md +7 -0
  34. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabledWithOccluder.md +9 -0
  35. package/front_end/models/issues_manager/descriptions/permissionElementActivationDisabledWithOccluderParent.md +9 -0
  36. package/front_end/models/issues_manager/descriptions/permissionElementCspFrameAncestorsMissing.md +5 -0
  37. package/front_end/models/issues_manager/descriptions/permissionElementFencedFrameDisallowed.md +5 -0
  38. package/front_end/models/issues_manager/descriptions/permissionElementFontSizeTooLarge.md +5 -0
  39. package/front_end/models/issues_manager/descriptions/permissionElementFontSizeTooSmall.md +5 -0
  40. package/front_end/models/issues_manager/descriptions/permissionElementGeolocationDeprecated.md +5 -0
  41. package/front_end/models/issues_manager/descriptions/permissionElementInsetBoxShadowUnsupported.md +5 -0
  42. package/front_end/models/issues_manager/descriptions/permissionElementInvalidDisplayStyle.md +5 -0
  43. package/front_end/models/issues_manager/descriptions/permissionElementInvalidSizeValue.md +5 -0
  44. package/front_end/models/issues_manager/descriptions/permissionElementInvalidType.md +5 -0
  45. package/front_end/models/issues_manager/descriptions/permissionElementInvalidTypeActivation.md +5 -0
  46. package/front_end/models/issues_manager/descriptions/permissionElementLowContrast.md +5 -0
  47. package/front_end/models/issues_manager/descriptions/permissionElementNonOpaqueColor.md +5 -0
  48. package/front_end/models/issues_manager/descriptions/permissionElementPaddingBottomUnsupported.md +6 -0
  49. package/front_end/models/issues_manager/descriptions/permissionElementPaddingRightUnsupported.md +6 -0
  50. package/front_end/models/issues_manager/descriptions/permissionElementPermissionsPolicyBlocked.md +5 -0
  51. package/front_end/models/issues_manager/descriptions/permissionElementRegistrationFailed.md +5 -0
  52. package/front_end/models/issues_manager/descriptions/permissionElementRequestInProgress.md +5 -0
  53. package/front_end/models/issues_manager/descriptions/permissionElementSecurityChecksFailed.md +5 -0
  54. package/front_end/models/issues_manager/descriptions/permissionElementTypeNotSupported.md +5 -0
  55. package/front_end/models/issues_manager/descriptions/permissionElementUntrustedEvent.md +7 -0
  56. package/front_end/models/issues_manager/issues_manager.ts +2 -0
  57. package/front_end/models/javascript_metadata/NativeFunctions.js +8 -0
  58. package/front_end/models/stack_trace/StackTraceModel.ts +37 -18
  59. package/front_end/models/trace/Processor.ts +14 -15
  60. package/front_end/models/trace/insights/Common.ts +2 -8
  61. package/front_end/models/trace/insights/types.ts +12 -2
  62. package/front_end/models/trace/types/TraceEvents.ts +4 -1
  63. package/front_end/panels/ai_assistance/AiAssistancePanel.ts +28 -6
  64. package/front_end/panels/ai_assistance/ai_assistance-meta.ts +9 -23
  65. package/front_end/panels/ai_assistance/ai_assistance.ts +1 -0
  66. package/front_end/panels/ai_assistance/components/ChatView.ts +78 -2
  67. package/front_end/panels/ai_assistance/components/CollapsibleAssistanceContentWidget.ts +71 -0
  68. package/front_end/panels/ai_assistance/components/PerformanceAgentFlameChart.ts +126 -0
  69. package/front_end/panels/ai_assistance/components/PerformanceAgentMarkdownRenderer.ts +131 -2
  70. package/front_end/panels/ai_assistance/components/chatView.css +28 -0
  71. package/front_end/panels/ai_assistance/components/collapsibleAssistanceContentWidget.css +33 -0
  72. package/front_end/panels/application/AppManifestView.ts +1007 -521
  73. package/front_end/panels/application/ApplicationPanelSidebar.ts +1 -17
  74. package/front_end/panels/application/ExtensionStorageItemsView.ts +3 -5
  75. package/front_end/panels/application/KeyValueStorageItemsView.ts +3 -2
  76. package/front_end/panels/application/components/BackForwardCacheView.ts +2 -2
  77. package/front_end/panels/application/preloading/PreloadingView.ts +46 -45
  78. package/front_end/panels/application/preloading/components/MismatchedPreloadingGrid.ts +80 -75
  79. package/front_end/panels/application/preloading/components/PreloadingDisabledInfobar.ts +169 -133
  80. package/front_end/panels/application/preloading/components/RuleSetDetailsView.ts +74 -93
  81. package/front_end/panels/application/preloading/components/RuleSetGrid.ts +142 -117
  82. package/front_end/panels/application/preloading/components/UsedPreloadingView.ts +51 -11
  83. package/front_end/panels/application/preloading/components/components.ts +0 -2
  84. package/front_end/panels/common/Annotation.ts +184 -0
  85. package/front_end/panels/common/AnnotationManager.ts +148 -11
  86. package/front_end/panels/common/ExtensionView.ts +47 -0
  87. package/front_end/panels/common/PersistenceUtils.ts +22 -25
  88. package/front_end/panels/common/annotation.css +40 -0
  89. package/front_end/panels/common/common.ts +1 -0
  90. package/front_end/panels/console/ConsoleInsightTeaser.ts +187 -5
  91. package/front_end/panels/console/ConsolePinPane.ts +437 -217
  92. package/front_end/panels/console/ConsolePrompt.ts +32 -223
  93. package/front_end/panels/console/ConsoleView.ts +67 -66
  94. package/front_end/panels/console/ConsoleViewMessage.ts +8 -3
  95. package/front_end/panels/console/consoleInsightTeaser.css +23 -0
  96. package/front_end/panels/console/consoleView.css +1 -1
  97. package/front_end/panels/elements/AdoptedStyleSheetTreeElement.ts +89 -0
  98. package/front_end/panels/elements/ColorSwatchPopoverIcon.ts +2 -2
  99. package/front_end/panels/elements/ComputedStyleWidget.ts +16 -5
  100. package/front_end/panels/elements/ElementsPanel.ts +38 -12
  101. package/front_end/panels/elements/ElementsSidebarPane.ts +1 -3
  102. package/front_end/panels/elements/ElementsTreeElement.ts +313 -353
  103. package/front_end/panels/elements/ElementsTreeOutline.ts +39 -13
  104. package/front_end/panels/elements/StylePropertyTreeElement.ts +15 -14
  105. package/front_end/panels/elements/StylesSidebarPane.ts +1 -1
  106. package/front_end/panels/emulation/MediaQueryInspector.ts +171 -125
  107. package/front_end/panels/explain/components/ConsoleInsight.ts +175 -150
  108. package/front_end/panels/explain/components/consoleInsight.css +348 -347
  109. package/front_end/panels/issues/AffectedPermissionElementsView.ts +46 -0
  110. package/front_end/panels/issues/IssueView.ts +2 -0
  111. package/front_end/panels/issues/IssuesPane.ts +6 -0
  112. package/front_end/panels/layer_viewer/LayerDetailsView.ts +165 -149
  113. package/front_end/panels/layer_viewer/Layers3DView.ts +131 -78
  114. package/front_end/panels/lighthouse/LighthouseStatusView.ts +149 -100
  115. package/front_end/panels/linear_memory_inspector/components/LinearMemoryHighlightChipList.ts +90 -64
  116. package/front_end/panels/linear_memory_inspector/components/LinearMemoryInspector.ts +25 -34
  117. package/front_end/panels/linear_memory_inspector/components/LinearMemoryValueInterpreter.ts +60 -44
  118. package/front_end/panels/linear_memory_inspector/components/ValueInterpreterDisplay.ts +170 -151
  119. package/front_end/panels/linear_memory_inspector/components/ValueInterpreterSettings.ts +50 -51
  120. package/front_end/panels/linear_memory_inspector/components/valueInterpreterDisplay.css +0 -13
  121. package/front_end/panels/linear_memory_inspector/components/valueInterpreterSettings.css +20 -18
  122. package/front_end/panels/mobile_throttling/CalibrationController.ts +3 -1
  123. package/front_end/panels/network/NetworkDataGridNode.ts +14 -6
  124. package/front_end/panels/network/NetworkItemView.ts +42 -3
  125. package/front_end/panels/network/NetworkLogView.ts +10 -11
  126. package/front_end/panels/network/NetworkPanel.ts +63 -1
  127. package/front_end/panels/network/RequestInitiatorView.ts +146 -113
  128. package/front_end/panels/network/components/RequestHeaderSection.css +51 -50
  129. package/front_end/panels/network/components/RequestHeaderSection.ts +81 -71
  130. package/front_end/panels/network/components/RequestHeadersView.css +1 -1
  131. package/front_end/panels/network/components/RequestHeadersView.ts +26 -11
  132. package/front_end/panels/network/components/RequestTrustTokensView.css +24 -14
  133. package/front_end/panels/network/components/RequestTrustTokensView.ts +144 -140
  134. package/front_end/panels/profiler/IsolateSelector.ts +2 -1
  135. package/front_end/panels/protocol_monitor/ProtocolMonitor.ts +49 -33
  136. package/front_end/panels/recorder/RecorderController.ts +2 -3
  137. package/front_end/panels/recorder/components/ControlButton.ts +68 -34
  138. package/front_end/panels/recorder/components/CreateRecordingView.ts +9 -6
  139. package/front_end/panels/recorder/components/RecordingView.ts +81 -88
  140. package/front_end/panels/recorder/components/ReplaySection.ts +226 -145
  141. package/front_end/panels/recorder/{controllers → components}/SelectorPicker.ts +129 -52
  142. package/front_end/panels/recorder/components/StepEditor.ts +21 -67
  143. package/front_end/panels/recorder/components/StepView.ts +222 -180
  144. package/front_end/panels/recorder/components/TimelineSection.ts +69 -48
  145. package/front_end/panels/recorder/components/components.ts +2 -2
  146. package/front_end/panels/recorder/components/selectorPicker.css +14 -0
  147. package/front_end/panels/recorder/components/stepEditor.css +0 -5
  148. package/front_end/panels/recorder/components/stepView.css +196 -198
  149. package/front_end/panels/recorder/extensions/ExtensionManager.ts +4 -48
  150. package/front_end/panels/recorder/models/ScreenshotUtils.ts +17 -11
  151. package/front_end/panels/security/CookieControlsView.ts +9 -16
  152. package/front_end/panels/settings/components/SyncSection.ts +0 -1
  153. package/front_end/panels/sources/CSSPlugin.ts +3 -3
  154. package/front_end/panels/sources/CallStackSidebarPane.ts +60 -75
  155. package/front_end/panels/sources/SourcesPanel.ts +1 -11
  156. package/front_end/panels/sources/TabbedEditorContainer.ts +11 -8
  157. package/front_end/panels/sources/ThreadsSidebarPane.ts +96 -101
  158. package/front_end/panels/sources/threadsSidebarPane.css +6 -5
  159. package/front_end/panels/timeline/InteractionsTrackAppender.ts +2 -3
  160. package/front_end/panels/timeline/TimelineFlameChartDataProvider.ts +23 -33
  161. package/front_end/panels/timeline/TimelineFlameChartNetworkDataProvider.ts +4 -3
  162. package/front_end/panels/timeline/TimelineFlameChartView.ts +12 -0
  163. package/front_end/panels/timeline/TimelinePanel.ts +3 -5
  164. package/front_end/panels/timeline/components/IgnoreListSetting.ts +164 -142
  165. package/front_end/panels/timeline/components/InteractionBreakdown.ts +48 -28
  166. package/front_end/panels/timeline/components/LayoutShiftDetails.ts +18 -23
  167. package/front_end/panels/timeline/components/NetworkRequestTooltip.ts +98 -73
  168. package/front_end/panels/timeline/components/SidebarInsightsTab.ts +9 -12
  169. package/front_end/panels/timeline/components/SidebarSingleInsightSet.ts +262 -291
  170. package/front_end/panels/timeline/components/Utils.ts +25 -0
  171. package/front_end/panels/timeline/components/insights/BaseInsightComponent.ts +210 -146
  172. package/front_end/panels/timeline/components/insights/CLSCulprits.ts +8 -20
  173. package/front_end/panels/timeline/components/insights/Cache.ts +0 -9
  174. package/front_end/panels/timeline/components/insights/DOMSize.ts +11 -33
  175. package/front_end/panels/timeline/components/insights/DocumentLatency.ts +0 -9
  176. package/front_end/panels/timeline/components/insights/DuplicatedJavaScript.ts +0 -9
  177. package/front_end/panels/timeline/components/insights/EventRef.ts +47 -109
  178. package/front_end/panels/timeline/components/insights/FontDisplay.ts +0 -9
  179. package/front_end/panels/timeline/components/insights/ForcedReflow.ts +0 -9
  180. package/front_end/panels/timeline/components/insights/INPBreakdown.ts +0 -9
  181. package/front_end/panels/timeline/components/insights/ImageDelivery.ts +1 -10
  182. package/front_end/panels/timeline/components/insights/ImageRef.ts +112 -0
  183. package/front_end/panels/timeline/components/insights/InsightRenderer.ts +91 -0
  184. package/front_end/panels/timeline/components/insights/LCPBreakdown.ts +0 -9
  185. package/front_end/panels/timeline/components/insights/LCPDiscovery.ts +4 -11
  186. package/front_end/panels/timeline/components/insights/LegacyJavaScript.ts +0 -9
  187. package/front_end/panels/timeline/components/insights/ModernHTTP.ts +0 -9
  188. package/front_end/panels/timeline/components/insights/NetworkDependencyTree.ts +6 -21
  189. package/front_end/panels/timeline/components/insights/NodeLink.ts +68 -43
  190. package/front_end/panels/timeline/components/insights/README.md +2 -3
  191. package/front_end/panels/timeline/components/insights/RenderBlocking.ts +0 -9
  192. package/front_end/panels/timeline/components/insights/SlowCSSSelector.ts +0 -9
  193. package/front_end/panels/timeline/components/insights/ThirdParties.ts +0 -9
  194. package/front_end/panels/timeline/components/insights/Viewport.ts +7 -19
  195. package/front_end/panels/timeline/components/insights/baseInsightComponent.css +5 -0
  196. package/front_end/panels/timeline/components/insights/insights.ts +2 -0
  197. package/front_end/panels/timeline/components/interactionBreakdown.css +15 -13
  198. package/front_end/panels/timeline/enable-easter-egg.js +7 -3
  199. package/front_end/third_party/chromium/README.chromium +1 -1
  200. package/front_end/third_party/puppeteer/README.chromium +2 -2
  201. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.d.ts +96 -0
  202. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.d.ts.map +1 -0
  203. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.js +8 -0
  204. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/BluetoothEmulation.js.map +1 -0
  205. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.d.ts +87 -0
  206. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.d.ts.map +1 -1
  207. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Browser.js.map +1 -1
  208. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.d.ts +2 -6
  209. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.d.ts.map +1 -1
  210. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.js +5 -24
  211. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/DeviceRequestPrompt.js.map +1 -1
  212. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.d.ts +5 -0
  213. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.d.ts.map +1 -1
  214. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/Page.js.map +1 -1
  215. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.d.ts +1 -0
  216. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.d.ts.map +1 -1
  217. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/api/api.js.map +1 -1
  218. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.d.ts +18 -0
  219. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.d.ts.map +1 -0
  220. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.js +42 -0
  221. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/BluetoothEmulation.js.map +1 -0
  222. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.d.ts +4 -1
  223. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.d.ts.map +1 -1
  224. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.js +10 -0
  225. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Browser.js.map +1 -1
  226. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.d.ts +27 -0
  227. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.d.ts.map +1 -0
  228. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.js +90 -0
  229. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/DeviceRequestPrompt.js.map +1 -0
  230. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.d.ts +3 -1
  231. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.d.ts.map +1 -1
  232. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.js +3 -2
  233. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Frame.js.map +1 -1
  234. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.d.ts +4 -1
  235. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.d.ts.map +1 -1
  236. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.js +5 -2
  237. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/Page.js.map +1 -1
  238. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.d.ts +4 -0
  239. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.d.ts.map +1 -1
  240. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.js +14 -2
  241. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/core/BrowsingContext.js.map +1 -1
  242. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.d.ts.map +1 -1
  243. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.js +7 -0
  244. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/bidi/util.js.map +1 -1
  245. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Accessibility.js +1 -1
  246. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Accessibility.js.map +1 -1
  247. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.d.ts +18 -0
  248. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.d.ts.map +1 -0
  249. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.js +30 -0
  250. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/BluetoothEmulation.js.map +1 -0
  251. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.d.ts +5 -2
  252. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.d.ts.map +1 -1
  253. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.js +22 -3
  254. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Browser.js.map +1 -1
  255. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/CdpSession.d.ts +1 -1
  256. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/CdpSession.d.ts.map +1 -1
  257. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.d.ts +2 -3
  258. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.d.ts.map +1 -1
  259. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.js +4 -6
  260. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/DeviceRequestPrompt.js.map +1 -1
  261. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.d.ts +2 -2
  262. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.d.ts.map +1 -1
  263. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.js +1 -1
  264. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/FrameManager.js.map +1 -1
  265. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.d.ts +2 -0
  266. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.d.ts.map +1 -1
  267. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.js +8 -0
  268. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/Page.js.map +1 -1
  269. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.d.ts.map +1 -1
  270. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.js +8 -3
  271. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/WebWorker.js.map +1 -1
  272. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.d.ts +1 -0
  273. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.d.ts.map +1 -1
  274. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.js +1 -0
  275. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/cdp/cdp.js.map +1 -1
  276. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/BrowserConnector.js +30 -0
  277. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/BrowserConnector.js.map +1 -1
  278. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/ConnectOptions.d.ts +15 -0
  279. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/common/ConnectOptions.d.ts.map +1 -1
  280. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/injected/injected.d.ts +1 -1
  281. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.d.ts +1 -1
  282. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.d.ts.map +1 -1
  283. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.js +2 -13
  284. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/ChromeLauncher.js.map +1 -1
  285. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.d.ts +5 -3
  286. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.d.ts.map +1 -1
  287. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.js +17 -0
  288. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/node/LaunchOptions.js.map +1 -1
  289. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.d.ts +3 -3
  290. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.js +3 -3
  291. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/revisions.js.map +1 -1
  292. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/Mutex.d.ts +2 -2
  293. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/version.d.ts +1 -1
  294. package/front_end/third_party/puppeteer/package/lib/cjs/puppeteer/util/version.js +1 -1
  295. package/front_end/third_party/puppeteer/package/lib/es5-iife/puppeteer-core-browser.d.ts +221 -4
  296. package/front_end/third_party/puppeteer/package/lib/es5-iife/puppeteer-core-browser.js +182 -95
  297. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.d.ts +96 -0
  298. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.d.ts.map +1 -0
  299. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.js +7 -0
  300. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/BluetoothEmulation.js.map +1 -0
  301. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.d.ts +87 -0
  302. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.d.ts.map +1 -1
  303. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Browser.js.map +1 -1
  304. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.d.ts +2 -6
  305. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.d.ts.map +1 -1
  306. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.js +4 -22
  307. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/DeviceRequestPrompt.js.map +1 -1
  308. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.d.ts +5 -0
  309. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.d.ts.map +1 -1
  310. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/Page.js.map +1 -1
  311. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.d.ts +1 -0
  312. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.d.ts.map +1 -1
  313. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/api/api.js.map +1 -1
  314. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.d.ts +18 -0
  315. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.d.ts.map +1 -0
  316. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.js +38 -0
  317. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/BluetoothEmulation.js.map +1 -0
  318. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.d.ts +4 -1
  319. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.d.ts.map +1 -1
  320. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.js +10 -0
  321. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Browser.js.map +1 -1
  322. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.d.ts +27 -0
  323. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.d.ts.map +1 -0
  324. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.js +85 -0
  325. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/DeviceRequestPrompt.js.map +1 -0
  326. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.d.ts +3 -1
  327. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.d.ts.map +1 -1
  328. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.js +3 -2
  329. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Frame.js.map +1 -1
  330. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.d.ts +4 -1
  331. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.d.ts.map +1 -1
  332. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.js +5 -2
  333. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/Page.js.map +1 -1
  334. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.d.ts +4 -0
  335. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.d.ts.map +1 -1
  336. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.js +14 -2
  337. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/core/BrowsingContext.js.map +1 -1
  338. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.d.ts.map +1 -1
  339. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.js +7 -0
  340. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/bidi/util.js.map +1 -1
  341. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Accessibility.js +1 -1
  342. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Accessibility.js.map +1 -1
  343. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.d.ts +18 -0
  344. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.d.ts.map +1 -0
  345. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.js +26 -0
  346. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/BluetoothEmulation.js.map +1 -0
  347. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.d.ts +5 -2
  348. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.d.ts.map +1 -1
  349. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.js +22 -3
  350. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Browser.js.map +1 -1
  351. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/CdpSession.d.ts +1 -1
  352. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/CdpSession.d.ts.map +1 -1
  353. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.d.ts +2 -3
  354. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.d.ts.map +1 -1
  355. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.js +2 -4
  356. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/DeviceRequestPrompt.js.map +1 -1
  357. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.d.ts +2 -2
  358. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.d.ts.map +1 -1
  359. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.js +2 -2
  360. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/FrameManager.js.map +1 -1
  361. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.d.ts +2 -0
  362. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.d.ts.map +1 -1
  363. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.js +8 -0
  364. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/Page.js.map +1 -1
  365. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.d.ts.map +1 -1
  366. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.js +8 -3
  367. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/WebWorker.js.map +1 -1
  368. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.d.ts +1 -0
  369. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.d.ts.map +1 -1
  370. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.js +1 -0
  371. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/cdp/cdp.js.map +1 -1
  372. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/BrowserConnector.js +31 -1
  373. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/BrowserConnector.js.map +1 -1
  374. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/ConnectOptions.d.ts +15 -0
  375. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/common/ConnectOptions.d.ts.map +1 -1
  376. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.d.ts +1 -1
  377. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.d.ts.map +1 -1
  378. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.js +2 -13
  379. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/ChromeLauncher.js.map +1 -1
  380. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.d.ts +5 -3
  381. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.d.ts.map +1 -1
  382. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.js +16 -1
  383. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/node/LaunchOptions.js.map +1 -1
  384. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.d.ts +3 -3
  385. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.js +3 -3
  386. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/revisions.js.map +1 -1
  387. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/util/version.d.ts +1 -1
  388. package/front_end/third_party/puppeteer/package/lib/esm/puppeteer/util/version.js +1 -1
  389. package/front_end/third_party/puppeteer/package/lib/types.d.ts +221 -4
  390. package/front_end/third_party/puppeteer/package/package.json +4 -4
  391. package/front_end/third_party/puppeteer/package/src/api/BluetoothEmulation.ts +103 -0
  392. package/front_end/third_party/puppeteer/package/src/api/Browser.ts +96 -1
  393. package/front_end/third_party/puppeteer/package/src/api/DeviceRequestPrompt.ts +2 -10
  394. package/front_end/third_party/puppeteer/package/src/api/Page.ts +6 -0
  395. package/front_end/third_party/puppeteer/package/src/api/api.ts +1 -0
  396. package/front_end/third_party/puppeteer/package/src/bidi/BluetoothEmulation.ts +52 -0
  397. package/front_end/third_party/puppeteer/package/src/bidi/Browser.ts +15 -0
  398. package/front_end/third_party/puppeteer/package/src/bidi/DeviceRequestPrompt.ts +138 -0
  399. package/front_end/third_party/puppeteer/package/src/bidi/Frame.ts +7 -3
  400. package/front_end/third_party/puppeteer/package/src/bidi/Page.ts +10 -2
  401. package/front_end/third_party/puppeteer/package/src/bidi/core/BrowsingContext.ts +30 -2
  402. package/front_end/third_party/puppeteer/package/src/bidi/util.ts +8 -0
  403. package/front_end/third_party/puppeteer/package/src/cdp/Accessibility.ts +1 -1
  404. package/front_end/third_party/puppeteer/package/src/cdp/BluetoothEmulation.ts +47 -0
  405. package/front_end/third_party/puppeteer/package/src/cdp/Browser.ts +33 -3
  406. package/front_end/third_party/puppeteer/package/src/cdp/CdpSession.ts +1 -1
  407. package/front_end/third_party/puppeteer/package/src/cdp/DeviceRequestPrompt.ts +3 -8
  408. package/front_end/third_party/puppeteer/package/src/cdp/Frame.ts +2 -2
  409. package/front_end/third_party/puppeteer/package/src/cdp/FrameManager.ts +9 -4
  410. package/front_end/third_party/puppeteer/package/src/cdp/Page.ts +13 -0
  411. package/front_end/third_party/puppeteer/package/src/cdp/WebWorker.ts +8 -3
  412. package/front_end/third_party/puppeteer/package/src/cdp/cdp.ts +1 -0
  413. package/front_end/third_party/puppeteer/package/src/common/BrowserConnector.ts +45 -1
  414. package/front_end/third_party/puppeteer/package/src/common/ConnectOptions.ts +20 -0
  415. package/front_end/third_party/puppeteer/package/src/node/ChromeLauncher.ts +5 -17
  416. package/front_end/third_party/puppeteer/package/src/node/LaunchOptions.ts +23 -7
  417. package/front_end/third_party/puppeteer/package/src/revisions.ts +3 -3
  418. package/front_end/third_party/puppeteer/package/src/util/version.ts +1 -1
  419. package/front_end/third_party/puppeteer/puppeteer-tsconfig.json +4 -0
  420. package/front_end/ui/components/annotations/AnnotationRepository.ts +153 -13
  421. package/front_end/ui/components/snackbars/Snackbars.docs.ts +0 -1
  422. package/front_end/ui/components/text_editor/AiCodeCompletionTeaserPlaceholder.ts +12 -3
  423. package/front_end/ui/components/text_editor/AiCodeGenerationProvider.ts +182 -0
  424. package/front_end/ui/components/text_editor/text_editor.ts +1 -0
  425. package/front_end/ui/helpers/OpenInNewTab.ts +5 -1
  426. package/front_end/ui/i18n/i18n.ts +9 -9
  427. package/front_end/ui/kit/icons/Icon.docs.ts +22 -65
  428. package/front_end/ui/kit/kit.ts +1 -0
  429. package/front_end/ui/kit/link/Link.docs.ts +15 -0
  430. package/front_end/ui/kit/link/Link.ts +151 -0
  431. package/front_end/ui/kit/link/link.css +27 -0
  432. package/front_end/ui/legacy/EmptyWidget.ts +6 -0
  433. package/front_end/ui/legacy/Floaty.ts +442 -0
  434. package/front_end/ui/legacy/InspectorView.ts +12 -0
  435. package/front_end/ui/legacy/ReportView.ts +1 -1
  436. package/front_end/ui/legacy/SelectMenu.docs.ts +0 -1
  437. package/front_end/ui/legacy/TabbedPane.ts +131 -53
  438. package/front_end/ui/legacy/components/cookie_table/CookiesTable.ts +1 -1
  439. package/front_end/ui/legacy/components/inline_editor/ColorSwatch.ts +36 -36
  440. package/front_end/ui/legacy/components/object_ui/JavaScriptREPL.ts +22 -37
  441. package/front_end/ui/legacy/components/object_ui/RemoteObjectPreviewFormatter.ts +31 -1
  442. package/front_end/ui/legacy/components/perf_ui/FlameChart.ts +2 -2
  443. package/front_end/ui/legacy/components/utils/Linkifier.ts +7 -11
  444. package/front_end/ui/legacy/floaty.css +77 -0
  445. package/front_end/ui/legacy/legacy.ts +2 -0
  446. package/front_end/ui/visual_logging/KnownContextValues.ts +6 -0
  447. package/inspector_overlay/loadCSS.rollup.js +5 -4
  448. package/package.json +2 -2
  449. package/front_end/panels/application/preloading/components/PreloadingMismatchedHeadersGrid.ts +0 -99
  450. package/front_end/panels/recorder/components/SelectButton.ts +0 -304
  451. package/front_end/panels/recorder/controllers/controllers.ts +0 -7
  452. package/front_end/ui/components/chrome_link/ChromeLink.ts +0 -76
  453. package/front_end/ui/components/chrome_link/chromeLink.css +0 -12
  454. package/front_end/ui/components/chrome_link/chrome_link.ts +0 -9
  455. /package/front_end/panels/recorder/components/{selectButton.css → replaySection.css} +0 -0
@@ -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,
@@ -0,0 +1,184 @@
1
+ // Copyright 2025 The Chromium Authors
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+ /* eslint-disable @devtools/no-imperative-dom-api */
5
+ /* eslint-disable @devtools/no-lit-render-outside-of-view */
6
+
7
+ import * as Annotations from '../../ui/components/annotations/annotations.js';
8
+ import * as UI from '../../ui/legacy/legacy.js';
9
+ import * as ThemeSupport from '../../ui/legacy/theme_support/theme_support.js';
10
+ import {html, nothing, render} from '../../ui/lit/lit.js';
11
+ import * as VisualLogging from '../../ui/visual_logging/visual_logging.js';
12
+
13
+ import annotationStyles from './annotation.css.js';
14
+
15
+ // This class handles drawing of Annotations for the GreenDev project, but
16
+ // is not for general use (at the moment).
17
+ //
18
+ // **Important**: all of this functionality is behind the GreenDev flag. We
19
+ // have **no intention** of pushing this feature live in this state. This
20
+ // is code landing to user test in Canary that will not ship without an
21
+ // additional project to make this code fully production worthy. That is
22
+ // why this CL has no tests, for example.
23
+
24
+ // The label is angled on the left from the centre of the entry it belongs to.
25
+ // `LABEL_AND_CONNECTOR_SHIFT_LENGTH` specifies how many pixels to the left it is shifted.
26
+ const LABEL_AND_CONNECTOR_SHIFT_LENGTH = 8;
27
+ // Length of the line that connects the label to the entry.
28
+ const LABEL_CONNECTOR_HEIGHT = 7;
29
+
30
+ interface ViewInput {
31
+ inputText: string;
32
+ isExpanded: boolean;
33
+ anchored: boolean;
34
+ expandable: boolean;
35
+ showCloseButton: boolean;
36
+ clickHandler: () => void;
37
+ closeHandler: () => void;
38
+ }
39
+
40
+ type View = (input: ViewInput, output: undefined, target: HTMLElement) => void;
41
+
42
+ export const DEFAULT_VIEW: View = (input, _, target) => {
43
+ const {inputText: label, isExpanded, anchored, expandable, showCloseButton, clickHandler, closeHandler} = input;
44
+
45
+ // TODO(finnur): Use `x`, and `y` passed via `input` to set the coordinates for the
46
+ // *Widget* (not the `overlay` div), then remove the `this.element.style` calls and
47
+ // remove the lint override no-imperative-dom-api from the top.
48
+ const connectorColor = ThemeSupport.ThemeSupport.instance().getComputedValue('--color-text-primary');
49
+
50
+ const overlayStyles = [
51
+ anchored ? 'left: 17px; top: 11px;' : '',
52
+ !expandable ? 'pointer-events: none;' : '',
53
+ ].join(' ');
54
+
55
+ // clang-format off
56
+ render(html`
57
+ <style>${annotationStyles}</style>
58
+ ${anchored ? html`
59
+ <svg class="connectorContainer"
60
+ width=${LABEL_AND_CONNECTOR_SHIFT_LENGTH * 2}
61
+ height=${LABEL_CONNECTOR_HEIGHT}>
62
+ <line
63
+ x1=${LABEL_AND_CONNECTOR_SHIFT_LENGTH}
64
+ y1=0
65
+ x2=${LABEL_AND_CONNECTOR_SHIFT_LENGTH * 2}
66
+ y2=${LABEL_CONNECTOR_HEIGHT}
67
+ stroke=${connectorColor}
68
+ stroke-width=2
69
+ />
70
+ <circle
71
+ cx=${LABEL_AND_CONNECTOR_SHIFT_LENGTH}
72
+ cy=0
73
+ r=3
74
+ fill=${connectorColor}
75
+ />
76
+ </svg>
77
+ ` : nothing}
78
+ <div class='overlay' style=${overlayStyles} @click=${expandable ? clickHandler : null}>
79
+ ${isExpanded ? label : '!'}
80
+ </div>
81
+ ${showCloseButton ?
82
+ html`<svg @click=${closeHandler} class="close-button" width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
83
+ <circle cx="8" cy="8" r="7.5" fill="#EEE" stroke="#888"/>
84
+ <path d="M5 5L11 11M5 11L11 5" stroke="#888" stroke-width="2"/>
85
+ </svg>` : nothing}
86
+ `, target);
87
+ // clang-format on
88
+ };
89
+
90
+ export class Annotation extends UI.Widget.Widget {
91
+ readonly #view: View;
92
+ readonly #id: number;
93
+ #inputText: string;
94
+ #x = 0;
95
+ #y = 0;
96
+ #isExpanded = false;
97
+ #hasShown = false;
98
+ #anchored = false;
99
+ #expandable = false;
100
+ #showCloseButton = false;
101
+
102
+ constructor(
103
+ id: number, label: string, showExpanded: boolean, anchored: boolean, expandable: boolean,
104
+ showCloseButton: boolean, view = DEFAULT_VIEW) {
105
+ super({jslog: `${VisualLogging.panel('annotation').track({resize: true})}`, useShadowDom: true});
106
+ this.#id = id;
107
+ this.#view = view;
108
+ this.#isExpanded = showExpanded;
109
+ this.#inputText = label;
110
+ this.#anchored = anchored;
111
+ this.#expandable = expandable;
112
+ this.#showCloseButton = showCloseButton;
113
+ }
114
+
115
+ #toggle(): void {
116
+ this.#isExpanded = !this.#isExpanded;
117
+ this.requestUpdate();
118
+ }
119
+
120
+ #closeHandler(): void {
121
+ this.hide();
122
+ Annotations.AnnotationRepository.instance().deleteAnnotation(this.#id);
123
+ }
124
+
125
+ override wasShown(): void {
126
+ this.element.style.position = 'absolute';
127
+ this.element.style.left = `${this.#x}px`;
128
+ this.element.style.top = `${this.#y}px`;
129
+ super.wasShown();
130
+ this.#hasShown = true;
131
+ this.requestUpdate();
132
+ }
133
+
134
+ override performUpdate(): void {
135
+ if (!this.isShowing()) {
136
+ return;
137
+ }
138
+ const input = {
139
+ inputText: this.#inputText,
140
+ isExpanded: this.#isExpanded,
141
+ anchored: this.#anchored,
142
+ expandable: this.#expandable,
143
+ showCloseButton: this.#showCloseButton,
144
+ x: this.#x,
145
+ y: this.#y,
146
+ clickHandler: this.#toggle.bind(this),
147
+ closeHandler: this.#closeHandler.bind(this),
148
+ };
149
+ this.#view(input, undefined, this.contentElement);
150
+
151
+ if (this.#showCloseButton) {
152
+ const overlay = this.contentElement.querySelector('.overlay') as HTMLElement | null;
153
+ const closeButton = this.contentElement.querySelector('.close-button') as HTMLElement | null;
154
+ if (overlay && closeButton) {
155
+ const overlayLeft = parseFloat(overlay.style.left || '0');
156
+ const overlayWidth = overlay.getBoundingClientRect().width;
157
+ // Position the button to the right of the overlay, adjusting for button width.
158
+ closeButton.style.left = `${overlayLeft + overlayWidth - 16}px`;
159
+ }
160
+ }
161
+ }
162
+
163
+ hide(): void {
164
+ this.detach();
165
+ }
166
+
167
+ getCoordinates(): {x: number, y: number} {
168
+ return {x: this.#x, y: this.#y};
169
+ }
170
+
171
+ setCoordinates(x: number, y: number): void {
172
+ this.#x = x;
173
+ this.#y = y;
174
+ if (this.isShowing()) {
175
+ this.element.style.left = `${this.#x}px`;
176
+ this.element.style.top = `${this.#y}px`;
177
+ }
178
+ this.requestUpdate();
179
+ }
180
+
181
+ hasShown(): boolean {
182
+ return this.#hasShown;
183
+ }
184
+ }