devtools-tracing 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (397) hide show
  1. package/generate.ts +643 -0
  2. package/index.ts +16 -0
  3. package/lib/front_end/core/common/App.ts +7 -0
  4. package/lib/front_end/core/common/AppProvider.ts +32 -0
  5. package/lib/front_end/core/common/Base64.ts +47 -0
  6. package/lib/front_end/core/common/CharacterIdMap.ts +30 -0
  7. package/lib/front_end/core/common/Color.ts +2506 -0
  8. package/lib/front_end/core/common/ColorConverter.ts +402 -0
  9. package/lib/front_end/core/common/ColorUtils.ts +252 -0
  10. package/lib/front_end/core/common/Console.ts +114 -0
  11. package/lib/front_end/core/common/Debouncer.ts +15 -0
  12. package/lib/front_end/core/common/EventTarget.ts +52 -0
  13. package/lib/front_end/core/common/Gzip.ts +74 -0
  14. package/lib/front_end/core/common/JavaScriptMetaData.ts +29 -0
  15. package/lib/front_end/core/common/Lazy.ts +31 -0
  16. package/lib/front_end/core/common/Linkifier.ts +55 -0
  17. package/lib/front_end/core/common/MapWithDefault.ts +26 -0
  18. package/lib/front_end/core/common/Mutex.ts +55 -0
  19. package/lib/front_end/core/common/Object.ts +145 -0
  20. package/lib/front_end/core/common/ParsedURL.ts +554 -0
  21. package/lib/front_end/core/common/Progress.ts +180 -0
  22. package/lib/front_end/core/common/QueryParamHandler.ts +7 -0
  23. package/lib/front_end/core/common/ResolverBase.ts +85 -0
  24. package/lib/front_end/core/common/ResourceType.ts +588 -0
  25. package/lib/front_end/core/common/ReturnToPanel.ts +17 -0
  26. package/lib/front_end/core/common/Revealer.ts +192 -0
  27. package/lib/front_end/core/common/Runnable.ts +41 -0
  28. package/lib/front_end/core/common/SegmentedRange.ts +87 -0
  29. package/lib/front_end/core/common/SettingRegistration.ts +339 -0
  30. package/lib/front_end/core/common/Settings.ts +1497 -0
  31. package/lib/front_end/core/common/SimpleHistoryManager.ts +124 -0
  32. package/lib/front_end/core/common/StringOutputStream.ts +26 -0
  33. package/lib/front_end/core/common/TextDictionary.ts +48 -0
  34. package/lib/front_end/core/common/Throttler.ts +99 -0
  35. package/lib/front_end/core/common/Trie.ts +152 -0
  36. package/lib/front_end/core/common/Worker.ts +60 -0
  37. package/lib/front_end/core/common/common.ts +81 -0
  38. package/lib/front_end/core/host/AidaClient.ts +733 -0
  39. package/lib/front_end/core/host/GdpClient.ts +316 -0
  40. package/lib/front_end/core/host/InspectorFrontendHost.ts +648 -0
  41. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +551 -0
  42. package/lib/front_end/core/host/Platform.ts +76 -0
  43. package/lib/front_end/core/host/ResourceLoader.ts +282 -0
  44. package/lib/front_end/core/host/UserMetrics.ts +1230 -0
  45. package/lib/front_end/core/host/host.ts +23 -0
  46. package/lib/front_end/core/i18n/ByteUtilities.ts +82 -0
  47. package/lib/front_end/core/i18n/DevToolsLocale.ts +87 -0
  48. package/lib/front_end/core/i18n/NumberFormatter.ts +82 -0
  49. package/lib/front_end/core/i18n/i18n.ts +17 -0
  50. package/lib/front_end/core/i18n/i18nImpl.ts +204 -0
  51. package/lib/front_end/core/i18n/i18nTypes.ts +10 -0
  52. package/lib/front_end/core/i18n/locales.js +14 -0
  53. package/lib/front_end/core/i18n/time-utilities.ts +174 -0
  54. package/lib/front_end/core/platform/ArrayUtilities.ts +271 -0
  55. package/lib/front_end/core/platform/Brand.ts +23 -0
  56. package/lib/front_end/core/platform/Constructor.ts +10 -0
  57. package/lib/front_end/core/platform/DOMUtilities.ts +138 -0
  58. package/lib/front_end/core/platform/DateUtilities.ts +15 -0
  59. package/lib/front_end/core/platform/DevToolsPath.ts +53 -0
  60. package/lib/front_end/core/platform/KeyboardUtilities.ts +38 -0
  61. package/lib/front_end/core/platform/MapUtilities.ts +95 -0
  62. package/lib/front_end/core/platform/MimeType.ts +175 -0
  63. package/lib/front_end/core/platform/NumberUtilities.ts +80 -0
  64. package/lib/front_end/core/platform/StringUtilities.ts +588 -0
  65. package/lib/front_end/core/platform/Timing.ts +17 -0
  66. package/lib/front_end/core/platform/TypedArrayUtilities.ts +189 -0
  67. package/lib/front_end/core/platform/TypescriptUtilities.ts +86 -0
  68. package/lib/front_end/core/platform/UIString.ts +39 -0
  69. package/lib/front_end/core/platform/UserVisibleError.ts +28 -0
  70. package/lib/front_end/core/platform/platform.ts +45 -0
  71. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +26 -0
  72. package/lib/front_end/core/protocol_client/InspectorBackend.ts +1050 -0
  73. package/lib/front_end/core/protocol_client/NodeURL.ts +42 -0
  74. package/lib/front_end/core/protocol_client/protocol_client.ts +13 -0
  75. package/lib/front_end/core/root/Runtime.ts +609 -0
  76. package/lib/front_end/core/root/root.ts +6 -0
  77. package/lib/front_end/core/sdk/AccessibilityModel.ts +353 -0
  78. package/lib/front_end/core/sdk/AnimationModel.ts +1041 -0
  79. package/lib/front_end/core/sdk/AutofillModel.ts +184 -0
  80. package/lib/front_end/core/sdk/CPUProfilerModel.ts +148 -0
  81. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +282 -0
  82. package/lib/front_end/core/sdk/CSSContainerQuery.ts +139 -0
  83. package/lib/front_end/core/sdk/CSSFontFace.ts +40 -0
  84. package/lib/front_end/core/sdk/CSSLayer.ts +30 -0
  85. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +1646 -0
  86. package/lib/front_end/core/sdk/CSSMedia.ts +121 -0
  87. package/lib/front_end/core/sdk/CSSMetadata.ts +1647 -0
  88. package/lib/front_end/core/sdk/CSSModel.ts +1128 -0
  89. package/lib/front_end/core/sdk/CSSProperty.ts +384 -0
  90. package/lib/front_end/core/sdk/CSSPropertyParser.ts +681 -0
  91. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +1395 -0
  92. package/lib/front_end/core/sdk/CSSQuery.ts +72 -0
  93. package/lib/front_end/core/sdk/CSSRule.ts +465 -0
  94. package/lib/front_end/core/sdk/CSSScope.ts +30 -0
  95. package/lib/front_end/core/sdk/CSSStartingStyle.ts +29 -0
  96. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +313 -0
  97. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +196 -0
  98. package/lib/front_end/core/sdk/CSSSupports.ts +33 -0
  99. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +64 -0
  100. package/lib/front_end/core/sdk/ChildTargetManager.ts +314 -0
  101. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +62 -0
  102. package/lib/front_end/core/sdk/Connections.ts +293 -0
  103. package/lib/front_end/core/sdk/ConsoleModel.ts +808 -0
  104. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +15 -0
  105. package/lib/front_end/core/sdk/Cookie.ts +319 -0
  106. package/lib/front_end/core/sdk/CookieModel.ts +239 -0
  107. package/lib/front_end/core/sdk/CookieParser.ts +185 -0
  108. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +787 -0
  109. package/lib/front_end/core/sdk/DOMModel.ts +1961 -0
  110. package/lib/front_end/core/sdk/DebuggerModel.ts +1605 -0
  111. package/lib/front_end/core/sdk/EmulationModel.ts +648 -0
  112. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +515 -0
  113. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +183 -0
  114. package/lib/front_end/core/sdk/FrameAssociated.ts +11 -0
  115. package/lib/front_end/core/sdk/FrameManager.ts +259 -0
  116. package/lib/front_end/core/sdk/HeapProfilerModel.ts +225 -0
  117. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +77 -0
  118. package/lib/front_end/core/sdk/IOModel.ts +91 -0
  119. package/lib/front_end/core/sdk/IsolateManager.ts +257 -0
  120. package/lib/front_end/core/sdk/IssuesModel.ts +70 -0
  121. package/lib/front_end/core/sdk/LayerTreeBase.ts +169 -0
  122. package/lib/front_end/core/sdk/LogModel.ts +56 -0
  123. package/lib/front_end/core/sdk/NetworkManager.ts +2823 -0
  124. package/lib/front_end/core/sdk/NetworkRequest.ts +2253 -0
  125. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +52 -0
  126. package/lib/front_end/core/sdk/OverlayModel.ts +1011 -0
  127. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +522 -0
  128. package/lib/front_end/core/sdk/PageLoad.ts +35 -0
  129. package/lib/front_end/core/sdk/PageResourceLoader.ts +435 -0
  130. package/lib/front_end/core/sdk/PaintProfiler.ts +110 -0
  131. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +84 -0
  132. package/lib/front_end/core/sdk/PreloadingModel.ts +863 -0
  133. package/lib/front_end/core/sdk/RehydratingConnection.ts +386 -0
  134. package/lib/front_end/core/sdk/RehydratingObject.ts +66 -0
  135. package/lib/front_end/core/sdk/RemoteObject.ts +1160 -0
  136. package/lib/front_end/core/sdk/Resource.ts +232 -0
  137. package/lib/front_end/core/sdk/ResourceTreeModel.ts +1160 -0
  138. package/lib/front_end/core/sdk/RuntimeModel.ts +732 -0
  139. package/lib/front_end/core/sdk/SDKModel.ts +65 -0
  140. package/lib/front_end/core/sdk/ScopeTreeCache.ts +45 -0
  141. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +255 -0
  142. package/lib/front_end/core/sdk/Script.ts +534 -0
  143. package/lib/front_end/core/sdk/SecurityOriginManager.ts +76 -0
  144. package/lib/front_end/core/sdk/ServerSentEvents.ts +80 -0
  145. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +122 -0
  146. package/lib/front_end/core/sdk/ServerTiming.ts +260 -0
  147. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +377 -0
  148. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +605 -0
  149. package/lib/front_end/core/sdk/SourceMap.ts +867 -0
  150. package/lib/front_end/core/sdk/SourceMapCache.ts +54 -0
  151. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +156 -0
  152. package/lib/front_end/core/sdk/SourceMapManager.ts +239 -0
  153. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +189 -0
  154. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +508 -0
  155. package/lib/front_end/core/sdk/StorageBucketsModel.ts +204 -0
  156. package/lib/front_end/core/sdk/StorageKeyManager.ts +98 -0
  157. package/lib/front_end/core/sdk/Target.ts +332 -0
  158. package/lib/front_end/core/sdk/TargetManager.ts +453 -0
  159. package/lib/front_end/core/sdk/TraceObject.ts +61 -0
  160. package/lib/front_end/core/sdk/WebAuthnModel.ts +104 -0
  161. package/lib/front_end/core/sdk/sdk.ts +174 -0
  162. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +59 -0
  163. package/lib/front_end/generated/InspectorBackendCommands.js +1617 -0
  164. package/lib/front_end/generated/SupportedCSSProperties.js +7512 -0
  165. package/lib/front_end/generated/protocol-proxy-api.d.ts +5022 -0
  166. package/lib/front_end/generated/protocol.ts +22014 -0
  167. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +571 -0
  168. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +103 -0
  169. package/lib/front_end/models/cpu_profile/cpu_profile.ts +11 -0
  170. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +219 -0
  171. package/lib/front_end/models/formatter/ScriptFormatter.ts +112 -0
  172. package/lib/front_end/models/formatter/formatter.ts +8 -0
  173. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +37 -0
  174. package/lib/front_end/models/text_utils/ContentData.ts +199 -0
  175. package/lib/front_end/models/text_utils/ContentProvider.ts +68 -0
  176. package/lib/front_end/models/text_utils/StaticContentProvider.ts +49 -0
  177. package/lib/front_end/models/text_utils/StreamingContentData.ts +108 -0
  178. package/lib/front_end/models/text_utils/Text.ts +90 -0
  179. package/lib/front_end/models/text_utils/TextCursor.ts +44 -0
  180. package/lib/front_end/models/text_utils/TextRange.ts +266 -0
  181. package/lib/front_end/models/text_utils/TextUtils.ts +401 -0
  182. package/lib/front_end/models/text_utils/WasmDisassembly.ts +87 -0
  183. package/lib/front_end/models/text_utils/text_utils.ts +27 -0
  184. package/lib/front_end/models/trace/EntityMapper.ts +141 -0
  185. package/lib/front_end/models/trace/EventsSerializer.ts +101 -0
  186. package/lib/front_end/models/trace/LanternComputationData.ts +438 -0
  187. package/lib/front_end/models/trace/ModelImpl.ts +236 -0
  188. package/lib/front_end/models/trace/Name.ts +136 -0
  189. package/lib/front_end/models/trace/Processor.ts +652 -0
  190. package/lib/front_end/models/trace/Styles.ts +1138 -0
  191. package/lib/front_end/models/trace/extras/FilmStrip.ts +78 -0
  192. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +86 -0
  193. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +236 -0
  194. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +203 -0
  195. package/lib/front_end/models/trace/extras/ThirdParties.ts +164 -0
  196. package/lib/front_end/models/trace/extras/TraceFilter.ts +62 -0
  197. package/lib/front_end/models/trace/extras/TraceTree.ts +701 -0
  198. package/lib/front_end/models/trace/extras/extras.ts +11 -0
  199. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +128 -0
  200. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +36 -0
  201. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +239 -0
  202. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +183 -0
  203. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +31 -0
  204. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +306 -0
  205. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +175 -0
  206. package/lib/front_end/models/trace/handlers/FramesHandler.ts +571 -0
  207. package/lib/front_end/models/trace/handlers/GPUHandler.ts +50 -0
  208. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +183 -0
  209. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +193 -0
  210. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +168 -0
  211. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +109 -0
  212. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +35 -0
  213. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +123 -0
  214. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +573 -0
  215. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +31 -0
  216. package/lib/front_end/models/trace/handlers/MetaHandler.ts +525 -0
  217. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +34 -0
  218. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +672 -0
  219. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +52 -0
  220. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +460 -0
  221. package/lib/front_end/models/trace/handlers/RendererHandler.ts +428 -0
  222. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +271 -0
  223. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +122 -0
  224. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +336 -0
  225. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +110 -0
  226. package/lib/front_end/models/trace/handlers/Threads.ts +139 -0
  227. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +400 -0
  228. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +233 -0
  229. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +162 -0
  230. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +45 -0
  231. package/lib/front_end/models/trace/handlers/handlers.ts +8 -0
  232. package/lib/front_end/models/trace/handlers/helpers.ts +196 -0
  233. package/lib/front_end/models/trace/handlers/types.ts +75 -0
  234. package/lib/front_end/models/trace/helpers/Extensions.ts +54 -0
  235. package/lib/front_end/models/trace/helpers/Network.ts +129 -0
  236. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +544 -0
  237. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +87 -0
  238. package/lib/front_end/models/trace/helpers/Timing.ts +248 -0
  239. package/lib/front_end/models/trace/helpers/Trace.ts +928 -0
  240. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +320 -0
  241. package/lib/front_end/models/trace/helpers/helpers.ts +11 -0
  242. package/lib/front_end/models/trace/insights/CLSCulprits.ts +668 -0
  243. package/lib/front_end/models/trace/insights/Cache.ts +269 -0
  244. package/lib/front_end/models/trace/insights/Common.ts +453 -0
  245. package/lib/front_end/models/trace/insights/DOMSize.ts +223 -0
  246. package/lib/front_end/models/trace/insights/DocumentLatency.ts +319 -0
  247. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +126 -0
  248. package/lib/front_end/models/trace/insights/FontDisplay.ts +119 -0
  249. package/lib/front_end/models/trace/insights/ForcedReflow.ts +220 -0
  250. package/lib/front_end/models/trace/insights/INPBreakdown.ts +171 -0
  251. package/lib/front_end/models/trace/insights/ImageDelivery.ts +348 -0
  252. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +268 -0
  253. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +237 -0
  254. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +138 -0
  255. package/lib/front_end/models/trace/insights/Models.ts +22 -0
  256. package/lib/front_end/models/trace/insights/ModernHTTP.ts +257 -0
  257. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +726 -0
  258. package/lib/front_end/models/trace/insights/RenderBlocking.ts +257 -0
  259. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +175 -0
  260. package/lib/front_end/models/trace/insights/Statistics.ts +101 -0
  261. package/lib/front_end/models/trace/insights/ThirdParties.ts +130 -0
  262. package/lib/front_end/models/trace/insights/Viewport.ts +138 -0
  263. package/lib/front_end/models/trace/insights/insights.ts +10 -0
  264. package/lib/front_end/models/trace/insights/types.ts +157 -0
  265. package/lib/front_end/models/trace/lantern/core/LanternError.ts +7 -0
  266. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +619 -0
  267. package/lib/front_end/models/trace/lantern/core/core.ts +6 -0
  268. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +345 -0
  269. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +80 -0
  270. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +101 -0
  271. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +636 -0
  272. package/lib/front_end/models/trace/lantern/graph/graph.ts +8 -0
  273. package/lib/front_end/models/trace/lantern/lantern.ts +17 -0
  274. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +187 -0
  275. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +88 -0
  276. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +92 -0
  277. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +72 -0
  278. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +126 -0
  279. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +126 -0
  280. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +82 -0
  281. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +112 -0
  282. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +12 -0
  283. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +150 -0
  284. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +46 -0
  285. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +61 -0
  286. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +196 -0
  287. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +556 -0
  288. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +192 -0
  289. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +10 -0
  290. package/lib/front_end/models/trace/lantern/types/Lantern.ts +220 -0
  291. package/lib/front_end/models/trace/lantern/types/types.ts +5 -0
  292. package/lib/front_end/models/trace/trace.ts +33 -0
  293. package/lib/front_end/models/trace/types/Configuration.ts +110 -0
  294. package/lib/front_end/models/trace/types/Extensions.ts +136 -0
  295. package/lib/front_end/models/trace/types/File.ts +281 -0
  296. package/lib/front_end/models/trace/types/Overlays.ts +138 -0
  297. package/lib/front_end/models/trace/types/Timing.ts +30 -0
  298. package/lib/front_end/models/trace/types/TraceEvents.ts +3277 -0
  299. package/lib/front_end/models/trace/types/types.ts +10 -0
  300. package/lib/front_end/third_party/i18n/LICENSE +202 -0
  301. package/lib/front_end/third_party/i18n/README.chromium +15 -0
  302. package/lib/front_end/third_party/i18n/i18n-impl.ts +61 -0
  303. package/lib/front_end/third_party/i18n/i18n.ts +11 -0
  304. package/lib/front_end/third_party/i18n/localized-string-set.ts +129 -0
  305. package/lib/front_end/third_party/intl-messageformat/LICENSE +33 -0
  306. package/lib/front_end/third_party/intl-messageformat/README.chromium +24 -0
  307. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +16 -0
  308. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +6 -0
  309. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +33 -0
  310. package/lib/front_end/third_party/intl-messageformat/package/README.md +3 -0
  311. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +6 -0
  312. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +1 -0
  313. package/lib/front_end/third_party/intl-messageformat/package/index.js +13 -0
  314. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +5 -0
  315. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +1710 -0
  316. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +1815 -0
  317. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +6 -0
  318. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +1 -0
  319. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +10 -0
  320. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +34 -0
  321. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +1 -0
  322. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +229 -0
  323. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +28 -0
  324. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +1 -0
  325. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +48 -0
  326. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +34 -0
  327. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +1 -0
  328. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +179 -0
  329. package/lib/front_end/third_party/intl-messageformat/package/package.json +42 -0
  330. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +34 -0
  331. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +1 -0
  332. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +230 -0
  333. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +28 -0
  334. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +1 -0
  335. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +51 -0
  336. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +34 -0
  337. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +1 -0
  338. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +182 -0
  339. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +79 -0
  340. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +15 -0
  341. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +153 -0
  342. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +139 -0
  343. package/lib/front_end/third_party/legacy-javascript/LICENSE +202 -0
  344. package/lib/front_end/third_party/legacy-javascript/README.chromium +13 -0
  345. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +8 -0
  346. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +3 -0
  347. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +18 -0
  348. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +943 -0
  349. package/lib/front_end/third_party/legacy-javascript/package.json +8 -0
  350. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +9 -0
  351. package/lib/front_end/third_party/third-party-web/LICENSE +20 -0
  352. package/lib/front_end/third_party/third-party-web/README.chromium +13 -0
  353. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +2 -0
  354. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +149 -0
  355. package/lib/front_end/third_party/third-party-web/package/LICENSE +20 -0
  356. package/lib/front_end/third_party/third-party-web/package/README.md +929 -0
  357. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +1 -0
  358. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +1 -0
  359. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +1 -0
  360. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +1 -0
  361. package/lib/front_end/third_party/third-party-web/package/facades.md +46 -0
  362. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +1 -0
  363. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +1 -0
  364. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +1 -0
  365. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +1 -0
  366. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +1006 -0
  367. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +139 -0
  368. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +44 -0
  369. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +27 -0
  370. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +34 -0
  371. package/lib/front_end/third_party/third-party-web/package/lib/index.js +3 -0
  372. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +246 -0
  373. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +36 -0
  374. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +9 -0
  375. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +5 -0
  376. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +151 -0
  377. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +1 -0
  378. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +1 -0
  379. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +1 -0
  380. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +14 -0
  381. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +1 -0
  382. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +3 -0
  383. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +1 -0
  384. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +3 -0
  385. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +1 -0
  386. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +3 -0
  387. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +1 -0
  388. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +3 -0
  389. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +1 -0
  390. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +1 -0
  391. package/lib/front_end/third_party/third-party-web/package/package.json +46 -0
  392. package/lib/front_end/third_party/third-party-web/package.json +8 -0
  393. package/lib/front_end/third_party/third-party-web/rebuild.sh +13 -0
  394. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +8 -0
  395. package/lib/front_end/third_party/third-party-web/third-party-web.ts +3 -0
  396. package/package.json +24 -0
  397. package/patches/chrome-devtools-frontend+1.0.1533544.patch +187 -0
@@ -0,0 +1,1011 @@
1
+ // Copyright 2017 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
+
5
+ import type * as Platform from '../../core/platform/platform.js';
6
+ import type * as ProtocolProxyApi from '../../generated/protocol-proxy-api.js';
7
+ import * as Protocol from '../../generated/protocol.js';
8
+ import * as Common from '../common/common.js';
9
+ import * as i18n from '../i18n/i18n.js';
10
+ import * as Root from '../root/root.js';
11
+
12
+ import type {CSSModel} from './CSSModel.js';
13
+ import {DebuggerModel, Events as DebuggerModelEvents} from './DebuggerModel.js';
14
+ import {DeferredDOMNode, DOMModel, type DOMNode, Events as DOMModelEvents} from './DOMModel.js';
15
+ import {OverlayPersistentHighlighter} from './OverlayPersistentHighlighter.js';
16
+ import type {RemoteObject} from './RemoteObject.js';
17
+ import {SDKModel} from './SDKModel.js';
18
+ import {Capability, type Target} from './Target.js';
19
+ import {TargetManager} from './TargetManager.js';
20
+
21
+ const UIStrings = {
22
+ /**
23
+ * @description Text in Overlay Model
24
+ */
25
+ pausedInDebugger: 'Paused in debugger',
26
+ } as const;
27
+ const str_ = i18n.i18n.registerUIStrings('core/sdk/OverlayModel.ts', UIStrings);
28
+ const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
29
+
30
+ export interface HighlightColor {
31
+ r: number;
32
+ g: number;
33
+ b: number;
34
+ a: number;
35
+ }
36
+
37
+ export interface HighlightRect {
38
+ x: number;
39
+ y: number;
40
+ width: number;
41
+ height: number;
42
+ color: HighlightColor;
43
+ outlineColor: HighlightColor;
44
+ }
45
+ export interface Hinge {
46
+ width: number;
47
+ height: number;
48
+ x: number;
49
+ y: number;
50
+ contentColor: HighlightColor;
51
+ outlineColor: HighlightColor;
52
+ }
53
+
54
+ export const enum EmulatedOSType {
55
+ WINDOWS = 'Windows',
56
+ MAC = 'Mac',
57
+ LINUX = 'Linux',
58
+ }
59
+
60
+ interface PlatformOverlayDimensions {
61
+ mac: {x: number, y: number, width: number, height: number};
62
+ linux: {x: number, y: number, width: number, height: number};
63
+ windows: {x: number, y: number, width: number, height: number};
64
+ }
65
+
66
+ const platformOverlayDimensions: Readonly<PlatformOverlayDimensions> = {
67
+ mac: {x: 85, y: 0, width: 185, height: 40},
68
+ linux: {x: 0, y: 0, width: 196, height: 34},
69
+ windows: {x: 0, y: 0, width: 238, height: 33},
70
+ };
71
+
72
+ export class OverlayModel extends SDKModel<EventTypes> implements ProtocolProxyApi.OverlayDispatcher {
73
+ readonly #domModel: DOMModel;
74
+ overlayAgent: ProtocolProxyApi.OverlayApi;
75
+ readonly #debuggerModel: DebuggerModel|null;
76
+ #inspectModeEnabled = false;
77
+ #hideHighlightTimeout: number|null = null;
78
+ #defaultHighlighter: Highlighter;
79
+ #highlighter: Highlighter;
80
+ #showPaintRectsSetting: Common.Settings.Setting<boolean>;
81
+ #showLayoutShiftRegionsSetting: Common.Settings.Setting<boolean>;
82
+ #showAdHighlightsSetting: Common.Settings.Setting<boolean>;
83
+ #showDebugBordersSetting: Common.Settings.Setting<boolean>;
84
+ #showFPSCounterSetting: Common.Settings.Setting<boolean>;
85
+ #showScrollBottleneckRectsSetting: Common.Settings.Setting<boolean>;
86
+ #registeredListeners: Common.EventTarget.EventDescriptor[] = [];
87
+ #showViewportSizeOnResize = true;
88
+ #persistentHighlighter: OverlayPersistentHighlighter|null;
89
+ readonly #sourceOrderHighlighter: SourceOrderHighlighter;
90
+ #sourceOrderModeActive = false;
91
+ #windowControls: WindowControls;
92
+
93
+ constructor(target: Target) {
94
+ super(target);
95
+ this.#domModel = (target.model(DOMModel) as DOMModel);
96
+
97
+ target.registerOverlayDispatcher(this);
98
+ this.overlayAgent = target.overlayAgent();
99
+
100
+ this.#debuggerModel = target.model(DebuggerModel);
101
+ if (this.#debuggerModel) {
102
+ Common.Settings.Settings.instance()
103
+ .moduleSetting('disable-paused-state-overlay')
104
+ .addChangeListener(this.updatePausedInDebuggerMessage, this);
105
+ this.#debuggerModel.addEventListener(
106
+ DebuggerModelEvents.DebuggerPaused, this.updatePausedInDebuggerMessage, this);
107
+ this.#debuggerModel.addEventListener(
108
+ DebuggerModelEvents.DebuggerResumed, this.updatePausedInDebuggerMessage, this);
109
+ // TODO(dgozman): we should get DebuggerResumed on navigations instead of listening to GlobalObjectCleared.
110
+ this.#debuggerModel.addEventListener(
111
+ DebuggerModelEvents.GlobalObjectCleared, this.updatePausedInDebuggerMessage, this);
112
+ }
113
+
114
+ this.#defaultHighlighter = new DefaultHighlighter(this);
115
+ this.#highlighter = this.#defaultHighlighter;
116
+
117
+ this.#showPaintRectsSetting = Common.Settings.Settings.instance().moduleSetting<boolean>('show-paint-rects');
118
+ this.#showLayoutShiftRegionsSetting =
119
+ Common.Settings.Settings.instance().moduleSetting<boolean>('show-layout-shift-regions');
120
+ this.#showAdHighlightsSetting = Common.Settings.Settings.instance().moduleSetting<boolean>('show-ad-highlights');
121
+ this.#showDebugBordersSetting = Common.Settings.Settings.instance().moduleSetting<boolean>('show-debug-borders');
122
+ this.#showFPSCounterSetting = Common.Settings.Settings.instance().moduleSetting<boolean>('show-fps-counter');
123
+ this.#showScrollBottleneckRectsSetting =
124
+ Common.Settings.Settings.instance().moduleSetting<boolean>('show-scroll-bottleneck-rects');
125
+
126
+ if (!target.suspended()) {
127
+ void this.overlayAgent.invoke_enable();
128
+ void this.wireAgentToSettings();
129
+ }
130
+
131
+ this.#persistentHighlighter = new OverlayPersistentHighlighter(this, {
132
+ onGridOverlayStateChanged: ({nodeId, enabled}) =>
133
+ this.dispatchEventToListeners(Events.PERSISTENT_GRID_OVERLAY_STATE_CHANGED, {nodeId, enabled}),
134
+ onFlexOverlayStateChanged: ({nodeId, enabled}) =>
135
+ this.dispatchEventToListeners(Events.PERSISTENT_FLEX_CONTAINER_OVERLAY_STATE_CHANGED, {nodeId, enabled}),
136
+ onContainerQueryOverlayStateChanged: ({nodeId, enabled}) =>
137
+ this.dispatchEventToListeners(Events.PERSISTENT_CONTAINER_QUERY_OVERLAY_STATE_CHANGED, {nodeId, enabled}),
138
+ onScrollSnapOverlayStateChanged: ({nodeId, enabled}) =>
139
+ this.dispatchEventToListeners(Events.PERSISTENT_SCROLL_SNAP_OVERLAY_STATE_CHANGED, {nodeId, enabled}),
140
+ });
141
+ this.#domModel.addEventListener(DOMModelEvents.NodeRemoved, () => {
142
+ if (!this.#persistentHighlighter) {
143
+ return;
144
+ }
145
+
146
+ this.#persistentHighlighter.refreshHighlights();
147
+ });
148
+
149
+ this.#domModel.addEventListener(DOMModelEvents.DocumentUpdated, () => {
150
+ if (!this.#persistentHighlighter) {
151
+ return;
152
+ }
153
+
154
+ // Hide all the overlays initially after document update
155
+ this.#persistentHighlighter.hideAllInOverlayWithoutSave();
156
+
157
+ if (!target.suspended()) {
158
+ void this.#persistentHighlighter.restoreHighlightsForDocument();
159
+ }
160
+ });
161
+
162
+ this.#sourceOrderHighlighter = new SourceOrderHighlighter(this);
163
+ this.#windowControls = new WindowControls(this.#domModel.cssModel());
164
+ }
165
+
166
+ static highlightObjectAsDOMNode(object: RemoteObject): void {
167
+ const domModel = object.runtimeModel().target().model(DOMModel);
168
+ if (domModel) {
169
+ domModel.overlayModel().highlightInOverlay({object, selectorList: undefined});
170
+ }
171
+ }
172
+
173
+ static hideDOMNodeHighlight(): void {
174
+ for (const overlayModel of TargetManager.instance().models(OverlayModel)) {
175
+ overlayModel.delayedHideHighlight(0);
176
+ }
177
+ }
178
+
179
+ static async muteHighlight(): Promise<void[]> {
180
+ return await Promise.all(TargetManager.instance().models(OverlayModel).map(model => model.suspendModel()));
181
+ }
182
+
183
+ static async unmuteHighlight(): Promise<void[]> {
184
+ return await Promise.all(TargetManager.instance().models(OverlayModel).map(model => model.resumeModel()));
185
+ }
186
+
187
+ static highlightRect(rect: HighlightRect): void {
188
+ for (const overlayModel of TargetManager.instance().models(OverlayModel)) {
189
+ void overlayModel.highlightRect(rect);
190
+ }
191
+ }
192
+
193
+ static clearHighlight(): void {
194
+ for (const overlayModel of TargetManager.instance().models(OverlayModel)) {
195
+ void overlayModel.clearHighlight();
196
+ }
197
+ }
198
+
199
+ getDOMModel(): DOMModel {
200
+ return this.#domModel;
201
+ }
202
+
203
+ highlightRect({x, y, width, height, color, outlineColor}: HighlightRect):
204
+ Promise<Protocol.ProtocolResponseWithError> {
205
+ const highlightColor = color || {r: 255, g: 0, b: 255, a: 0.3};
206
+ const highlightOutlineColor = outlineColor || {r: 255, g: 0, b: 255, a: 0.5};
207
+ return this.overlayAgent.invoke_highlightRect(
208
+ {x, y, width, height, color: highlightColor, outlineColor: highlightOutlineColor});
209
+ }
210
+
211
+ clearHighlight(): Promise<Protocol.ProtocolResponseWithError> {
212
+ return this.overlayAgent.invoke_hideHighlight();
213
+ }
214
+
215
+ private async wireAgentToSettings(): Promise<void> {
216
+ this.#registeredListeners = [
217
+ this.#showPaintRectsSetting.addChangeListener(
218
+ () => this.overlayAgent.invoke_setShowPaintRects({result: this.#showPaintRectsSetting.get()})),
219
+ this.#showLayoutShiftRegionsSetting.addChangeListener(
220
+ () =>
221
+ this.overlayAgent.invoke_setShowLayoutShiftRegions({result: this.#showLayoutShiftRegionsSetting.get()})),
222
+ this.#showAdHighlightsSetting.addChangeListener(
223
+ () => this.overlayAgent.invoke_setShowAdHighlights({show: this.#showAdHighlightsSetting.get()})),
224
+ this.#showDebugBordersSetting.addChangeListener(
225
+ () => this.overlayAgent.invoke_setShowDebugBorders({show: this.#showDebugBordersSetting.get()})),
226
+ this.#showFPSCounterSetting.addChangeListener(
227
+ () => this.overlayAgent.invoke_setShowFPSCounter({show: this.#showFPSCounterSetting.get()})),
228
+ this.#showScrollBottleneckRectsSetting.addChangeListener(
229
+ () => this.overlayAgent.invoke_setShowScrollBottleneckRects(
230
+ {show: this.#showScrollBottleneckRectsSetting.get()})),
231
+ ];
232
+
233
+ if (this.#showPaintRectsSetting.get()) {
234
+ void this.overlayAgent.invoke_setShowPaintRects({result: true});
235
+ }
236
+ if (this.#showLayoutShiftRegionsSetting.get()) {
237
+ void this.overlayAgent.invoke_setShowLayoutShiftRegions({result: true});
238
+ }
239
+ if (this.#showAdHighlightsSetting.get()) {
240
+ void this.overlayAgent.invoke_setShowAdHighlights({show: true});
241
+ }
242
+ if (this.#showDebugBordersSetting.get()) {
243
+ void this.overlayAgent.invoke_setShowDebugBorders({show: true});
244
+ }
245
+ if (this.#showFPSCounterSetting.get()) {
246
+ void this.overlayAgent.invoke_setShowFPSCounter({show: true});
247
+ }
248
+ if (this.#showScrollBottleneckRectsSetting.get()) {
249
+ void this.overlayAgent.invoke_setShowScrollBottleneckRects({show: true});
250
+ }
251
+ if (this.#debuggerModel && this.#debuggerModel.isPaused()) {
252
+ this.updatePausedInDebuggerMessage();
253
+ }
254
+ await this.overlayAgent.invoke_setShowViewportSizeOnResize({show: this.#showViewportSizeOnResize});
255
+ this.#persistentHighlighter?.resetOverlay();
256
+ }
257
+
258
+ override async suspendModel(): Promise<void> {
259
+ Common.EventTarget.removeEventListeners(this.#registeredListeners);
260
+ await this.overlayAgent.invoke_disable();
261
+ }
262
+
263
+ override async resumeModel(): Promise<void> {
264
+ await Promise.all([this.overlayAgent.invoke_enable(), this.wireAgentToSettings()]);
265
+ }
266
+
267
+ setShowViewportSizeOnResize(show: boolean): void {
268
+ if (this.#showViewportSizeOnResize === show) {
269
+ return;
270
+ }
271
+
272
+ this.#showViewportSizeOnResize = show;
273
+ if (this.target().suspended()) {
274
+ return;
275
+ }
276
+ void this.overlayAgent.invoke_setShowViewportSizeOnResize({show});
277
+ }
278
+
279
+ private updatePausedInDebuggerMessage(): void {
280
+ if (this.target().suspended()) {
281
+ return;
282
+ }
283
+ const message = this.#debuggerModel && this.#debuggerModel.isPaused() &&
284
+ !Common.Settings.Settings.instance().moduleSetting('disable-paused-state-overlay').get() ?
285
+ i18nString(UIStrings.pausedInDebugger) :
286
+ undefined;
287
+ void this.overlayAgent.invoke_setPausedInDebuggerMessage({message});
288
+ }
289
+
290
+ setHighlighter(highlighter: Highlighter|null): void {
291
+ this.#highlighter = highlighter || this.#defaultHighlighter;
292
+ }
293
+
294
+ async setInspectMode(mode: Protocol.Overlay.InspectMode, showDetailedTooltip: boolean|undefined = true):
295
+ Promise<void> {
296
+ await this.#domModel.requestDocument();
297
+ this.#inspectModeEnabled = mode !== Protocol.Overlay.InspectMode.None;
298
+ this.dispatchEventToListeners(Events.INSPECT_MODE_WILL_BE_TOGGLED, this);
299
+ void this.#highlighter.setInspectMode(mode, this.buildHighlightConfig('all', showDetailedTooltip));
300
+ }
301
+
302
+ inspectModeEnabled(): boolean {
303
+ return this.#inspectModeEnabled;
304
+ }
305
+
306
+ highlightInOverlay(data: HighlightData, mode?: string, showInfo?: boolean): void {
307
+ if (this.#sourceOrderModeActive) {
308
+ // Return early if the source order is currently being shown the in the
309
+ // overlay, so that it is not cleared by the highlight
310
+ return;
311
+ }
312
+ if (this.#hideHighlightTimeout) {
313
+ clearTimeout(this.#hideHighlightTimeout);
314
+ this.#hideHighlightTimeout = null;
315
+ }
316
+ const highlightConfig = this.buildHighlightConfig(mode);
317
+ if (typeof showInfo !== 'undefined') {
318
+ highlightConfig.showInfo = showInfo;
319
+ }
320
+ this.#highlighter.highlightInOverlay(data, highlightConfig);
321
+ }
322
+
323
+ highlightInOverlayForTwoSeconds(data: HighlightData): void {
324
+ this.highlightInOverlay(data);
325
+ this.delayedHideHighlight(2000);
326
+ }
327
+
328
+ highlightGridInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
329
+ if (!this.#persistentHighlighter) {
330
+ return;
331
+ }
332
+ this.#persistentHighlighter.highlightGridInOverlay(nodeId);
333
+ }
334
+
335
+ isHighlightedGridInPersistentOverlay(nodeId: Protocol.DOM.NodeId): boolean {
336
+ if (!this.#persistentHighlighter) {
337
+ return false;
338
+ }
339
+ return this.#persistentHighlighter.isGridHighlighted(nodeId);
340
+ }
341
+
342
+ hideGridInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
343
+ if (!this.#persistentHighlighter) {
344
+ return;
345
+ }
346
+ this.#persistentHighlighter.hideGridInOverlay(nodeId);
347
+ }
348
+
349
+ highlightScrollSnapInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
350
+ if (!this.#persistentHighlighter) {
351
+ return;
352
+ }
353
+ this.#persistentHighlighter.highlightScrollSnapInOverlay(nodeId);
354
+ }
355
+
356
+ isHighlightedScrollSnapInPersistentOverlay(nodeId: Protocol.DOM.NodeId): boolean {
357
+ if (!this.#persistentHighlighter) {
358
+ return false;
359
+ }
360
+ return this.#persistentHighlighter.isScrollSnapHighlighted(nodeId);
361
+ }
362
+
363
+ hideScrollSnapInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
364
+ if (!this.#persistentHighlighter) {
365
+ return;
366
+ }
367
+ this.#persistentHighlighter.hideScrollSnapInOverlay(nodeId);
368
+ }
369
+
370
+ highlightFlexContainerInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
371
+ if (!this.#persistentHighlighter) {
372
+ return;
373
+ }
374
+ this.#persistentHighlighter.highlightFlexInOverlay(nodeId);
375
+ }
376
+
377
+ isHighlightedFlexContainerInPersistentOverlay(nodeId: Protocol.DOM.NodeId): boolean {
378
+ if (!this.#persistentHighlighter) {
379
+ return false;
380
+ }
381
+ return this.#persistentHighlighter.isFlexHighlighted(nodeId);
382
+ }
383
+
384
+ hideFlexContainerInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
385
+ if (!this.#persistentHighlighter) {
386
+ return;
387
+ }
388
+ this.#persistentHighlighter.hideFlexInOverlay(nodeId);
389
+ }
390
+
391
+ highlightContainerQueryInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
392
+ if (!this.#persistentHighlighter) {
393
+ return;
394
+ }
395
+ this.#persistentHighlighter.highlightContainerQueryInOverlay(nodeId);
396
+ }
397
+
398
+ isHighlightedContainerQueryInPersistentOverlay(nodeId: Protocol.DOM.NodeId): boolean {
399
+ if (!this.#persistentHighlighter) {
400
+ return false;
401
+ }
402
+ return this.#persistentHighlighter.isContainerQueryHighlighted(nodeId);
403
+ }
404
+
405
+ hideContainerQueryInPersistentOverlay(nodeId: Protocol.DOM.NodeId): void {
406
+ if (!this.#persistentHighlighter) {
407
+ return;
408
+ }
409
+ this.#persistentHighlighter.hideContainerQueryInOverlay(nodeId);
410
+ }
411
+
412
+ highlightSourceOrderInOverlay(node: DOMNode): void {
413
+ const sourceOrderConfig = {
414
+ parentOutlineColor: Common.Color.SourceOrderHighlight.ParentOutline.toProtocolRGBA(),
415
+ childOutlineColor: Common.Color.SourceOrderHighlight.ChildOutline.toProtocolRGBA(),
416
+ };
417
+ this.#sourceOrderHighlighter.highlightSourceOrderInOverlay(node, sourceOrderConfig);
418
+ }
419
+
420
+ colorOfGridInPersistentOverlay(nodeId: Protocol.DOM.NodeId): string|null {
421
+ if (!this.#persistentHighlighter) {
422
+ return null;
423
+ }
424
+ return this.#persistentHighlighter.colorOfGrid(nodeId).asString(Common.Color.Format.HEX);
425
+ }
426
+
427
+ setColorOfGridInPersistentOverlay(nodeId: Protocol.DOM.NodeId, colorStr: string): void {
428
+ if (!this.#persistentHighlighter) {
429
+ return;
430
+ }
431
+ const color = Common.Color.parse(colorStr);
432
+ if (!color) {
433
+ return;
434
+ }
435
+ this.#persistentHighlighter.setColorOfGrid(nodeId, color);
436
+ this.#persistentHighlighter.resetOverlay();
437
+ }
438
+
439
+ colorOfFlexInPersistentOverlay(nodeId: Protocol.DOM.NodeId): string|null {
440
+ if (!this.#persistentHighlighter) {
441
+ return null;
442
+ }
443
+ return this.#persistentHighlighter.colorOfFlex(nodeId).asString(Common.Color.Format.HEX);
444
+ }
445
+
446
+ setColorOfFlexInPersistentOverlay(nodeId: Protocol.DOM.NodeId, colorStr: string): void {
447
+ if (!this.#persistentHighlighter) {
448
+ return;
449
+ }
450
+ const color = Common.Color.parse(colorStr);
451
+ if (!color) {
452
+ return;
453
+ }
454
+ this.#persistentHighlighter.setColorOfFlex(nodeId, color);
455
+ this.#persistentHighlighter.resetOverlay();
456
+ }
457
+
458
+ hideSourceOrderInOverlay(): void {
459
+ this.#sourceOrderHighlighter.hideSourceOrderHighlight();
460
+ }
461
+
462
+ setSourceOrderActive(isActive: boolean): void {
463
+ this.#sourceOrderModeActive = isActive;
464
+ }
465
+
466
+ private delayedHideHighlight(delay: number): void {
467
+ if (this.#hideHighlightTimeout === null) {
468
+ this.#hideHighlightTimeout = window.setTimeout(() => this.highlightInOverlay({clear: true}), delay);
469
+ }
470
+ }
471
+
472
+ highlightFrame(frameId: Protocol.Page.FrameId): void {
473
+ if (this.#hideHighlightTimeout) {
474
+ clearTimeout(this.#hideHighlightTimeout);
475
+ this.#hideHighlightTimeout = null;
476
+ }
477
+ this.#highlighter.highlightFrame(frameId);
478
+ }
479
+
480
+ showHingeForDualScreen(hinge: Hinge|null): void {
481
+ if (hinge) {
482
+ const {x, y, width, height, contentColor, outlineColor} = hinge;
483
+ void this.overlayAgent.invoke_setShowHinge({
484
+ hingeConfig: {rect: {x, y, width, height}, contentColor, outlineColor},
485
+ });
486
+ } else {
487
+ void this.overlayAgent.invoke_setShowHinge({});
488
+ }
489
+ }
490
+
491
+ setWindowControlsPlatform(selectedPlatform: EmulatedOSType): void {
492
+ this.#windowControls.selectedPlatform = selectedPlatform;
493
+ }
494
+
495
+ setWindowControlsThemeColor(themeColor: string): void {
496
+ this.#windowControls.themeColor = themeColor;
497
+ }
498
+
499
+ getWindowControlsConfig(): Protocol.Overlay.WindowControlsOverlayConfig {
500
+ return this.#windowControls.config;
501
+ }
502
+
503
+ async toggleWindowControlsToolbar(show: boolean): Promise<void> {
504
+ const wcoConfigObj = show ? {windowControlsOverlayConfig: this.#windowControls.config} : {};
505
+
506
+ const setWindowControlsOverlayOperation = this.overlayAgent.invoke_setShowWindowControlsOverlay(wcoConfigObj);
507
+ const toggleStylesheetOperation = this.#windowControls.toggleEmulatedOverlay(show);
508
+
509
+ await Promise.all([setWindowControlsOverlayOperation, toggleStylesheetOperation]);
510
+
511
+ this.setShowViewportSizeOnResize(!show);
512
+ }
513
+
514
+ private buildHighlightConfig(mode: string|undefined = 'all', showDetailedToolip: boolean|undefined = false):
515
+ Protocol.Overlay.HighlightConfig {
516
+ const showRulers = Common.Settings.Settings.instance().moduleSetting('show-metrics-rulers').get();
517
+ const highlightConfig: Protocol.Overlay.HighlightConfig = {
518
+ showInfo: mode === 'all' || mode === 'container-outline',
519
+ showRulers,
520
+ showStyles: showDetailedToolip,
521
+ showAccessibilityInfo: showDetailedToolip,
522
+ showExtensionLines: showRulers,
523
+ gridHighlightConfig: {},
524
+ flexContainerHighlightConfig: {},
525
+ flexItemHighlightConfig: {},
526
+ contrastAlgorithm: Root.Runtime.experiments.isEnabled('apca') ? Protocol.Overlay.ContrastAlgorithm.Apca :
527
+ Protocol.Overlay.ContrastAlgorithm.Aa,
528
+ };
529
+
530
+ if (mode === 'all' || mode === 'content') {
531
+ highlightConfig.contentColor = Common.Color.PageHighlight.Content.toProtocolRGBA();
532
+ }
533
+
534
+ if (mode === 'all' || mode === 'padding') {
535
+ highlightConfig.paddingColor = Common.Color.PageHighlight.Padding.toProtocolRGBA();
536
+ }
537
+
538
+ if (mode === 'all' || mode === 'border') {
539
+ highlightConfig.borderColor = Common.Color.PageHighlight.Border.toProtocolRGBA();
540
+ }
541
+
542
+ if (mode === 'all' || mode === 'margin') {
543
+ highlightConfig.marginColor = Common.Color.PageHighlight.Margin.toProtocolRGBA();
544
+ }
545
+
546
+ if (mode === 'all') {
547
+ highlightConfig.eventTargetColor = Common.Color.PageHighlight.EventTarget.toProtocolRGBA();
548
+ highlightConfig.shapeColor = Common.Color.PageHighlight.Shape.toProtocolRGBA();
549
+ highlightConfig.shapeMarginColor = Common.Color.PageHighlight.ShapeMargin.toProtocolRGBA();
550
+
551
+ highlightConfig.gridHighlightConfig = {
552
+ rowGapColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
553
+ rowHatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
554
+ columnGapColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
555
+ columnHatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
556
+ rowLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
557
+ columnLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
558
+ rowLineDash: true,
559
+ columnLineDash: true,
560
+ };
561
+
562
+ highlightConfig.flexContainerHighlightConfig = {
563
+ containerBorder: {
564
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
565
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
566
+ },
567
+ itemSeparator: {
568
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
569
+ pattern: Protocol.Overlay.LineStylePattern.Dotted,
570
+ },
571
+ lineSeparator: {
572
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
573
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
574
+ },
575
+ mainDistributedSpace: {
576
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
577
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
578
+ },
579
+ crossDistributedSpace: {
580
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
581
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
582
+ },
583
+ rowGapSpace: {
584
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
585
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
586
+ },
587
+ columnGapSpace: {
588
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
589
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
590
+ },
591
+ };
592
+
593
+ highlightConfig.flexItemHighlightConfig = {
594
+ baseSizeBox: {
595
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
596
+ },
597
+ baseSizeBorder: {
598
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
599
+ pattern: Protocol.Overlay.LineStylePattern.Dotted,
600
+ },
601
+ flexibilityArrow: {
602
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
603
+ },
604
+ };
605
+ }
606
+
607
+ if (mode.endsWith('gap')) {
608
+ highlightConfig.gridHighlightConfig = {
609
+ gridBorderColor: Common.Color.PageHighlight.GridBorder.toProtocolRGBA(),
610
+ gridBorderDash: true,
611
+ };
612
+
613
+ if (mode === 'gap' || mode === 'row-gap') {
614
+ highlightConfig.gridHighlightConfig.rowGapColor = Common.Color.PageHighlight.GapBackground.toProtocolRGBA();
615
+ highlightConfig.gridHighlightConfig.rowHatchColor = Common.Color.PageHighlight.GapHatch.toProtocolRGBA();
616
+ }
617
+ if (mode === 'gap' || mode === 'column-gap') {
618
+ highlightConfig.gridHighlightConfig.columnGapColor = Common.Color.PageHighlight.GapBackground.toProtocolRGBA();
619
+ highlightConfig.gridHighlightConfig.columnHatchColor = Common.Color.PageHighlight.GapHatch.toProtocolRGBA();
620
+ }
621
+ }
622
+
623
+ if (mode.endsWith('gap')) {
624
+ highlightConfig.flexContainerHighlightConfig = {
625
+ containerBorder: {
626
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
627
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
628
+ },
629
+ };
630
+
631
+ if (mode === 'gap' || mode === 'row-gap') {
632
+ highlightConfig.flexContainerHighlightConfig.rowGapSpace = {
633
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
634
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
635
+ };
636
+ }
637
+ if (mode === 'gap' || mode === 'column-gap') {
638
+ highlightConfig.flexContainerHighlightConfig.columnGapSpace = {
639
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
640
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
641
+ };
642
+ }
643
+ }
644
+
645
+ if (mode === 'grid-areas') {
646
+ highlightConfig.gridHighlightConfig = {
647
+ rowLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
648
+ columnLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
649
+ rowLineDash: true,
650
+ columnLineDash: true,
651
+ showAreaNames: true,
652
+ areaBorderColor: Common.Color.PageHighlight.GridAreaBorder.toProtocolRGBA(),
653
+ };
654
+ }
655
+
656
+ if (mode === 'grid-template-columns') {
657
+ highlightConfig.contentColor = Common.Color.PageHighlight.Content.toProtocolRGBA();
658
+ highlightConfig.gridHighlightConfig = {
659
+ columnLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
660
+ columnLineDash: true,
661
+ };
662
+ }
663
+
664
+ if (mode === 'grid-template-rows') {
665
+ highlightConfig.contentColor = Common.Color.PageHighlight.Content.toProtocolRGBA();
666
+ highlightConfig.gridHighlightConfig = {
667
+ rowLineColor: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
668
+ rowLineDash: true,
669
+ };
670
+ }
671
+
672
+ if (mode === 'justify-content') {
673
+ highlightConfig.flexContainerHighlightConfig = {
674
+ containerBorder: {
675
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
676
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
677
+ },
678
+ mainDistributedSpace: {
679
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
680
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
681
+ },
682
+ };
683
+ }
684
+
685
+ if (mode === 'align-content') {
686
+ highlightConfig.flexContainerHighlightConfig = {
687
+ containerBorder: {
688
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
689
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
690
+ },
691
+ crossDistributedSpace: {
692
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
693
+ fillColor: Common.Color.PageHighlight.GapBackground.toProtocolRGBA(),
694
+ },
695
+ };
696
+ }
697
+
698
+ if (mode === 'align-items') {
699
+ highlightConfig.flexContainerHighlightConfig = {
700
+ containerBorder: {
701
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
702
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
703
+ },
704
+ lineSeparator: {
705
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
706
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
707
+ },
708
+ crossAlignment: {color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA()},
709
+ };
710
+ }
711
+
712
+ if (mode === 'flexibility') {
713
+ highlightConfig.flexItemHighlightConfig = {
714
+ baseSizeBox: {
715
+ hatchColor: Common.Color.PageHighlight.GapHatch.toProtocolRGBA(),
716
+ },
717
+ baseSizeBorder: {
718
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
719
+ pattern: Protocol.Overlay.LineStylePattern.Dotted,
720
+ },
721
+ flexibilityArrow: {
722
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
723
+ },
724
+ };
725
+ }
726
+
727
+ if (mode === 'container-outline') {
728
+ highlightConfig.containerQueryContainerHighlightConfig = {
729
+ containerBorder: {
730
+ color: Common.Color.PageHighlight.LayoutLine.toProtocolRGBA(),
731
+ pattern: Protocol.Overlay.LineStylePattern.Dashed,
732
+ },
733
+ };
734
+ }
735
+
736
+ return highlightConfig;
737
+ }
738
+
739
+ nodeHighlightRequested({nodeId}: Protocol.Overlay.NodeHighlightRequestedEvent): void {
740
+ const node = this.#domModel.nodeForId(nodeId);
741
+ if (node) {
742
+ this.dispatchEventToListeners(Events.HIGHLIGHT_NODE_REQUESTED, node);
743
+ }
744
+ }
745
+
746
+ static setInspectNodeHandler(handler: (arg0: DOMNode) => Promise<void>): void {
747
+ OverlayModel.inspectNodeHandler = handler;
748
+ }
749
+
750
+ inspectNodeRequested({backendNodeId}: Protocol.Overlay.InspectNodeRequestedEvent): void {
751
+ const deferredNode = new DeferredDOMNode(this.target(), backendNodeId);
752
+ if (OverlayModel.inspectNodeHandler) {
753
+ void deferredNode.resolvePromise().then(node => {
754
+ if (node && OverlayModel.inspectNodeHandler) {
755
+ void OverlayModel.inspectNodeHandler(node);
756
+ }
757
+ });
758
+ } else {
759
+ void Common.Revealer.reveal(deferredNode);
760
+ }
761
+ this.dispatchEventToListeners(Events.EXITED_INSPECT_MODE);
762
+ }
763
+
764
+ screenshotRequested({viewport}: Protocol.Overlay.ScreenshotRequestedEvent): void {
765
+ this.dispatchEventToListeners(Events.SCREENSHOT_REQUESTED, viewport);
766
+ this.dispatchEventToListeners(Events.EXITED_INSPECT_MODE);
767
+ }
768
+
769
+ inspectModeCanceled(): void {
770
+ this.dispatchEventToListeners(Events.EXITED_INSPECT_MODE);
771
+ }
772
+
773
+ static inspectNodeHandler: ((node: DOMNode) => Promise<void>)|null = null;
774
+
775
+ getOverlayAgent(): ProtocolProxyApi.OverlayApi {
776
+ return this.overlayAgent;
777
+ }
778
+
779
+ async hasStyleSheetText(url: Platform.DevToolsPath.UrlString): Promise<boolean> {
780
+ return await this.#windowControls.initializeStyleSheetText(url);
781
+ }
782
+ }
783
+
784
+ export class WindowControls {
785
+ readonly #cssModel: CSSModel;
786
+ #originalStylesheetText: string|undefined;
787
+ #stylesheetId?: Protocol.CSS.StyleSheetId;
788
+ #currentUrl: Platform.DevToolsPath.UrlString|undefined;
789
+
790
+ #config: Protocol.Overlay.WindowControlsOverlayConfig = {
791
+ showCSS: false,
792
+ selectedPlatform: EmulatedOSType.WINDOWS,
793
+ themeColor: '#ffffff',
794
+ };
795
+
796
+ constructor(cssModel: CSSModel) {
797
+ this.#cssModel = cssModel;
798
+ }
799
+
800
+ get selectedPlatform(): string {
801
+ return this.#config.selectedPlatform;
802
+ }
803
+
804
+ set selectedPlatform(osType: EmulatedOSType) {
805
+ this.#config.selectedPlatform = osType;
806
+ }
807
+
808
+ get themeColor(): string {
809
+ return this.#config.themeColor;
810
+ }
811
+
812
+ set themeColor(color: string) {
813
+ this.#config.themeColor = color;
814
+ }
815
+
816
+ get config(): Protocol.Overlay.WindowControlsOverlayConfig {
817
+ return this.#config;
818
+ }
819
+
820
+ async initializeStyleSheetText(url: Platform.DevToolsPath.UrlString): Promise<boolean> {
821
+ if (this.#originalStylesheetText && url === this.#currentUrl) {
822
+ return true;
823
+ }
824
+
825
+ const cssSourceUrl = this.#fetchCssSourceUrl(url);
826
+ if (!cssSourceUrl) {
827
+ return false;
828
+ }
829
+
830
+ this.#stylesheetId = this.#fetchCurrentStyleSheet(cssSourceUrl);
831
+ if (!this.#stylesheetId) {
832
+ return false;
833
+ }
834
+
835
+ const stylesheetText = await this.#cssModel.getStyleSheetText(this.#stylesheetId);
836
+
837
+ if (!stylesheetText) {
838
+ return false;
839
+ }
840
+
841
+ this.#originalStylesheetText = stylesheetText;
842
+ this.#currentUrl = url;
843
+
844
+ return true;
845
+ }
846
+
847
+ async toggleEmulatedOverlay(showOverlay: boolean): Promise<void> {
848
+ if (!this.#stylesheetId || !this.#originalStylesheetText) {
849
+ return;
850
+ }
851
+ if (showOverlay) {
852
+ const styleSheetText = WindowControls.#getStyleSheetForPlatform(
853
+ this.#config.selectedPlatform.toLowerCase(), this.#originalStylesheetText);
854
+ if (styleSheetText) {
855
+ await this.#cssModel.setStyleSheetText(this.#stylesheetId, styleSheetText, false);
856
+ }
857
+ } else {
858
+ // Restore the original stylesheet
859
+ await this.#cssModel.setStyleSheetText(this.#stylesheetId, this.#originalStylesheetText, false);
860
+ }
861
+ }
862
+
863
+ static #getStyleSheetForPlatform(platform: string, originalStyleSheet: string|undefined): string|undefined {
864
+ const overlayDimensions = platformOverlayDimensions[platform as keyof PlatformOverlayDimensions];
865
+ return WindowControls.#transformStyleSheet(
866
+ overlayDimensions.x, overlayDimensions.y, overlayDimensions.width, overlayDimensions.height,
867
+ originalStyleSheet);
868
+ }
869
+
870
+ #fetchCssSourceUrl(url: Platform.DevToolsPath.UrlString): Platform.DevToolsPath.UrlString|undefined {
871
+ const parentURL = Common.ParsedURL.ParsedURL.extractOrigin(url);
872
+ const cssHeaders = this.#cssModel.styleSheetHeaders();
873
+ const header = cssHeaders.find(header => header.sourceURL && header.sourceURL.includes(parentURL));
874
+ return header?.sourceURL;
875
+ }
876
+
877
+ #fetchCurrentStyleSheet(cssSourceUrl: Platform.DevToolsPath.UrlString): Protocol.CSS.StyleSheetId|undefined {
878
+ const stylesheetIds = this.#cssModel.getStyleSheetIdsForURL(cssSourceUrl);
879
+ return stylesheetIds.length > 0 ? stylesheetIds[0] : undefined;
880
+ }
881
+
882
+ // The primary objective of this function is to adjust certain CSS environment variables within the existing stylesheet
883
+ // and provide it as the style sheet for the emulated overlay.
884
+ static #transformStyleSheet(
885
+ x: number, y: number, width: number, height: number, originalStyleSheet: string|undefined): string|undefined {
886
+ if (!originalStyleSheet) {
887
+ return undefined;
888
+ }
889
+ const stylesheetText = originalStyleSheet;
890
+
891
+ const updatedStylesheet =
892
+ stylesheetText.replace(/: env\(titlebar-area-x(?:,[^)]*)?\);/g, `: env(titlebar-area-x, ${x}px);`)
893
+ .replace(/: env\(titlebar-area-y(?:,[^)]*)?\);/g, `: env(titlebar-area-y, ${y}px);`)
894
+ .replace(
895
+ /: env\(titlebar-area-width(?:,[^)]*)?\);/g, `: env(titlebar-area-width, calc(100% - ${width}px));`)
896
+ .replace(/: env\(titlebar-area-height(?:,[^)]*)?\);/g, `: env(titlebar-area-height, ${height}px);`);
897
+
898
+ return updatedStylesheet;
899
+ }
900
+
901
+ transformStyleSheetforTesting(
902
+ x: number, y: number, width: number, height: number, originalStyleSheet: string|undefined): string|undefined {
903
+ return WindowControls.#transformStyleSheet(x, y, width, height, originalStyleSheet);
904
+ }
905
+ }
906
+
907
+ export const enum Events {
908
+ INSPECT_MODE_WILL_BE_TOGGLED = 'InspectModeWillBeToggled',
909
+ EXITED_INSPECT_MODE = 'InspectModeExited',
910
+ HIGHLIGHT_NODE_REQUESTED = 'HighlightNodeRequested',
911
+ SCREENSHOT_REQUESTED = 'ScreenshotRequested',
912
+ PERSISTENT_GRID_OVERLAY_STATE_CHANGED = 'PersistentGridOverlayStateChanged',
913
+ PERSISTENT_FLEX_CONTAINER_OVERLAY_STATE_CHANGED = 'PersistentFlexContainerOverlayStateChanged',
914
+ PERSISTENT_SCROLL_SNAP_OVERLAY_STATE_CHANGED = 'PersistentScrollSnapOverlayStateChanged',
915
+ PERSISTENT_CONTAINER_QUERY_OVERLAY_STATE_CHANGED = 'PersistentContainerQueryOverlayStateChanged',
916
+ }
917
+
918
+ export interface ChangedNodeId {
919
+ nodeId: number;
920
+ enabled: boolean;
921
+ }
922
+
923
+ export interface EventTypes {
924
+ [Events.INSPECT_MODE_WILL_BE_TOGGLED]: OverlayModel;
925
+ [Events.EXITED_INSPECT_MODE]: void;
926
+ [Events.HIGHLIGHT_NODE_REQUESTED]: DOMNode;
927
+ [Events.SCREENSHOT_REQUESTED]: Protocol.Page.Viewport;
928
+ [Events.PERSISTENT_GRID_OVERLAY_STATE_CHANGED]: ChangedNodeId;
929
+ [Events.PERSISTENT_FLEX_CONTAINER_OVERLAY_STATE_CHANGED]: ChangedNodeId;
930
+ [Events.PERSISTENT_SCROLL_SNAP_OVERLAY_STATE_CHANGED]: ChangedNodeId;
931
+ [Events.PERSISTENT_CONTAINER_QUERY_OVERLAY_STATE_CHANGED]: ChangedNodeId;
932
+ }
933
+
934
+ export interface Highlighter {
935
+ highlightInOverlay(data: HighlightData, config: Protocol.Overlay.HighlightConfig): void;
936
+
937
+ setInspectMode(mode: Protocol.Overlay.InspectMode, config: Protocol.Overlay.HighlightConfig): Promise<void>;
938
+
939
+ highlightFrame(frameId: Protocol.Page.FrameId): void;
940
+ }
941
+
942
+ class DefaultHighlighter implements Highlighter {
943
+ readonly #model: OverlayModel;
944
+ constructor(model: OverlayModel) {
945
+ this.#model = model;
946
+ }
947
+
948
+ highlightInOverlay(data: HighlightData, highlightConfig: Protocol.Overlay.HighlightConfig): void {
949
+ const {node, deferredNode, object, selectorList} =
950
+ {node: undefined, deferredNode: undefined, object: undefined, selectorList: undefined, ...data};
951
+ const nodeId = node ? node.id : undefined;
952
+ const backendNodeId = deferredNode ? deferredNode.backendNodeId() : undefined;
953
+ const objectId = object ? object.objectId : undefined;
954
+ if (nodeId || backendNodeId || objectId) {
955
+ void this.#model.target().overlayAgent().invoke_highlightNode(
956
+ {highlightConfig, nodeId, backendNodeId, objectId, selector: selectorList});
957
+ } else {
958
+ void this.#model.target().overlayAgent().invoke_hideHighlight();
959
+ }
960
+ }
961
+
962
+ async setInspectMode(mode: Protocol.Overlay.InspectMode, highlightConfig: Protocol.Overlay.HighlightConfig):
963
+ Promise<void> {
964
+ await this.#model.target().overlayAgent().invoke_setInspectMode({mode, highlightConfig});
965
+ }
966
+
967
+ highlightFrame(frameId: Protocol.Page.FrameId): void {
968
+ void this.#model.target().overlayAgent().invoke_highlightFrame({
969
+ frameId,
970
+ contentColor: Common.Color.PageHighlight.Content.toProtocolRGBA(),
971
+ contentOutlineColor: Common.Color.PageHighlight.ContentOutline.toProtocolRGBA(),
972
+ });
973
+ }
974
+ }
975
+
976
+ export class SourceOrderHighlighter {
977
+ readonly #model: OverlayModel;
978
+ constructor(model: OverlayModel) {
979
+ this.#model = model;
980
+ }
981
+
982
+ highlightSourceOrderInOverlay(node: DOMNode, sourceOrderConfig: Protocol.Overlay.SourceOrderConfig): void {
983
+ this.#model.setSourceOrderActive(true);
984
+ this.#model.setShowViewportSizeOnResize(false);
985
+ void this.#model.getOverlayAgent().invoke_highlightSourceOrder({sourceOrderConfig, nodeId: node.id});
986
+ }
987
+
988
+ hideSourceOrderHighlight(): void {
989
+ this.#model.setSourceOrderActive(false);
990
+ this.#model.setShowViewportSizeOnResize(true);
991
+ void this.#model.clearHighlight();
992
+ }
993
+ }
994
+
995
+ SDKModel.register(OverlayModel, {capabilities: Capability.DOM, autostart: true});
996
+
997
+ export interface HighlightNodeData {
998
+ node: DOMNode;
999
+ selectorList?: string;
1000
+ }
1001
+
1002
+ export interface HighlightDeferredNode {
1003
+ deferredNode: DeferredDOMNode;
1004
+ }
1005
+
1006
+ export interface HighlightObjectData {
1007
+ object: RemoteObject;
1008
+ selectorList?: string;
1009
+ }
1010
+
1011
+ export type HighlightData = HighlightNodeData|HighlightDeferredNode|HighlightObjectData|{clear: boolean};