devtools-tracing 1.1.1 → 1.2.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 (528) hide show
  1. package/.claude/settings.local.json +14 -0
  2. package/dist/index.d.ts +4 -0
  3. package/dist/index.js +28854 -0
  4. package/package.json +11 -8
  5. package/generate.ts +0 -649
  6. package/index.ts +0 -17
  7. package/lib/extension-api/ExtensionAPI.d.ts +0 -357
  8. package/lib/front_end/core/common/App.ts +0 -7
  9. package/lib/front_end/core/common/AppProvider.ts +0 -32
  10. package/lib/front_end/core/common/Base64.ts +0 -47
  11. package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
  12. package/lib/front_end/core/common/Color.ts +0 -2506
  13. package/lib/front_end/core/common/ColorConverter.ts +0 -402
  14. package/lib/front_end/core/common/ColorUtils.ts +0 -252
  15. package/lib/front_end/core/common/Console.ts +0 -114
  16. package/lib/front_end/core/common/Debouncer.ts +0 -15
  17. package/lib/front_end/core/common/EventTarget.ts +0 -52
  18. package/lib/front_end/core/common/Gzip.ts +0 -74
  19. package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
  20. package/lib/front_end/core/common/Lazy.ts +0 -31
  21. package/lib/front_end/core/common/Linkifier.ts +0 -55
  22. package/lib/front_end/core/common/MapWithDefault.ts +0 -26
  23. package/lib/front_end/core/common/Mutex.ts +0 -55
  24. package/lib/front_end/core/common/Object.ts +0 -145
  25. package/lib/front_end/core/common/ParsedURL.ts +0 -554
  26. package/lib/front_end/core/common/Progress.ts +0 -180
  27. package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
  28. package/lib/front_end/core/common/ResolverBase.ts +0 -85
  29. package/lib/front_end/core/common/ResourceType.ts +0 -588
  30. package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
  31. package/lib/front_end/core/common/Revealer.ts +0 -192
  32. package/lib/front_end/core/common/Runnable.ts +0 -41
  33. package/lib/front_end/core/common/SegmentedRange.ts +0 -87
  34. package/lib/front_end/core/common/SettingRegistration.ts +0 -339
  35. package/lib/front_end/core/common/Settings.ts +0 -1497
  36. package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
  37. package/lib/front_end/core/common/StringOutputStream.ts +0 -26
  38. package/lib/front_end/core/common/TextDictionary.ts +0 -48
  39. package/lib/front_end/core/common/Throttler.ts +0 -99
  40. package/lib/front_end/core/common/Trie.ts +0 -152
  41. package/lib/front_end/core/common/Worker.ts +0 -60
  42. package/lib/front_end/core/common/common.ts +0 -81
  43. package/lib/front_end/core/host/AidaClient.ts +0 -733
  44. package/lib/front_end/core/host/GdpClient.ts +0 -316
  45. package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
  46. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
  47. package/lib/front_end/core/host/Platform.ts +0 -76
  48. package/lib/front_end/core/host/ResourceLoader.ts +0 -282
  49. package/lib/front_end/core/host/UserMetrics.ts +0 -1230
  50. package/lib/front_end/core/host/host.ts +0 -23
  51. package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
  52. package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
  53. package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
  54. package/lib/front_end/core/i18n/i18n.ts +0 -17
  55. package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
  56. package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
  57. package/lib/front_end/core/i18n/locales.js +0 -14
  58. package/lib/front_end/core/i18n/time-utilities.ts +0 -174
  59. package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
  60. package/lib/front_end/core/platform/Brand.ts +0 -23
  61. package/lib/front_end/core/platform/Constructor.ts +0 -10
  62. package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
  63. package/lib/front_end/core/platform/DateUtilities.ts +0 -15
  64. package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
  65. package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
  66. package/lib/front_end/core/platform/MapUtilities.ts +0 -95
  67. package/lib/front_end/core/platform/MimeType.ts +0 -175
  68. package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
  69. package/lib/front_end/core/platform/StringUtilities.ts +0 -588
  70. package/lib/front_end/core/platform/Timing.ts +0 -17
  71. package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
  72. package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
  73. package/lib/front_end/core/platform/UIString.ts +0 -39
  74. package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
  75. package/lib/front_end/core/platform/platform.ts +0 -45
  76. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
  77. package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
  78. package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
  79. package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
  80. package/lib/front_end/core/root/Runtime.ts +0 -609
  81. package/lib/front_end/core/root/root.ts +0 -6
  82. package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
  83. package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
  84. package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
  85. package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
  86. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
  87. package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
  88. package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
  89. package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
  90. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
  91. package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
  92. package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
  93. package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
  94. package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
  95. package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
  96. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
  97. package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
  98. package/lib/front_end/core/sdk/CSSRule.ts +0 -465
  99. package/lib/front_end/core/sdk/CSSScope.ts +0 -30
  100. package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
  101. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
  102. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
  103. package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
  104. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
  105. package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
  106. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
  107. package/lib/front_end/core/sdk/Connections.ts +0 -293
  108. package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
  109. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
  110. package/lib/front_end/core/sdk/Cookie.ts +0 -319
  111. package/lib/front_end/core/sdk/CookieModel.ts +0 -239
  112. package/lib/front_end/core/sdk/CookieParser.ts +0 -185
  113. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
  114. package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
  115. package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
  116. package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
  117. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
  118. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
  119. package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
  120. package/lib/front_end/core/sdk/FrameManager.ts +0 -259
  121. package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
  122. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
  123. package/lib/front_end/core/sdk/IOModel.ts +0 -91
  124. package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
  125. package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
  126. package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
  127. package/lib/front_end/core/sdk/LogModel.ts +0 -56
  128. package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
  129. package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
  130. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
  131. package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
  132. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
  133. package/lib/front_end/core/sdk/PageLoad.ts +0 -35
  134. package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
  135. package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
  136. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
  137. package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
  138. package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
  139. package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
  140. package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
  141. package/lib/front_end/core/sdk/Resource.ts +0 -232
  142. package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
  143. package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
  144. package/lib/front_end/core/sdk/SDKModel.ts +0 -65
  145. package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
  146. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
  147. package/lib/front_end/core/sdk/Script.ts +0 -534
  148. package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
  149. package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
  150. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
  151. package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
  152. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
  153. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
  154. package/lib/front_end/core/sdk/SourceMap.ts +0 -867
  155. package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
  156. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
  157. package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
  158. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
  159. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
  160. package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
  161. package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
  162. package/lib/front_end/core/sdk/Target.ts +0 -332
  163. package/lib/front_end/core/sdk/TargetManager.ts +0 -453
  164. package/lib/front_end/core/sdk/TraceObject.ts +0 -61
  165. package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
  166. package/lib/front_end/core/sdk/sdk.ts +0 -174
  167. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
  168. package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
  169. package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
  170. package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
  171. package/lib/front_end/generated/protocol.ts +0 -22014
  172. package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
  173. package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
  174. package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
  175. package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
  176. package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
  177. package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
  178. package/lib/front_end/models/bindings/FileUtils.ts +0 -228
  179. package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
  180. package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
  181. package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
  182. package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
  183. package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
  184. package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
  185. package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
  186. package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
  187. package/lib/front_end/models/bindings/TempFile.ts +0 -67
  188. package/lib/front_end/models/bindings/bindings.ts +0 -39
  189. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
  190. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
  191. package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
  192. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
  193. package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
  194. package/lib/front_end/models/formatter/formatter.ts +0 -8
  195. package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
  196. package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
  197. package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
  198. package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
  199. package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
  200. package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
  201. package/lib/front_end/models/stack_trace/Trie.ts +0 -163
  202. package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
  203. package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
  204. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
  205. package/lib/front_end/models/text_utils/ContentData.ts +0 -199
  206. package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
  207. package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
  208. package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
  209. package/lib/front_end/models/text_utils/Text.ts +0 -90
  210. package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
  211. package/lib/front_end/models/text_utils/TextRange.ts +0 -266
  212. package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
  213. package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
  214. package/lib/front_end/models/text_utils/text_utils.ts +0 -27
  215. package/lib/front_end/models/trace/EntityMapper.ts +0 -141
  216. package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
  217. package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
  218. package/lib/front_end/models/trace/ModelImpl.ts +0 -236
  219. package/lib/front_end/models/trace/Name.ts +0 -136
  220. package/lib/front_end/models/trace/Processor.ts +0 -652
  221. package/lib/front_end/models/trace/Styles.ts +0 -1138
  222. package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
  223. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
  224. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
  225. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
  226. package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
  227. package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
  228. package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
  229. package/lib/front_end/models/trace/extras/extras.ts +0 -11
  230. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
  231. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
  232. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
  233. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
  234. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
  235. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
  236. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
  237. package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
  238. package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
  239. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
  240. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
  241. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
  242. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
  243. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
  244. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
  245. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
  246. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
  247. package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
  248. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
  249. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
  250. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
  251. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
  252. package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
  253. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
  254. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
  255. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
  256. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
  257. package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
  258. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
  259. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
  260. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
  261. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
  262. package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
  263. package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
  264. package/lib/front_end/models/trace/handlers/types.ts +0 -75
  265. package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
  266. package/lib/front_end/models/trace/helpers/Network.ts +0 -129
  267. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
  268. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
  269. package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
  270. package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
  271. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
  272. package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
  273. package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
  274. package/lib/front_end/models/trace/insights/Cache.ts +0 -269
  275. package/lib/front_end/models/trace/insights/Common.ts +0 -453
  276. package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
  277. package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
  278. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
  279. package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
  280. package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
  281. package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
  282. package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
  283. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
  284. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
  285. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
  286. package/lib/front_end/models/trace/insights/Models.ts +0 -22
  287. package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
  288. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
  289. package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
  290. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
  291. package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
  292. package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
  293. package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
  294. package/lib/front_end/models/trace/insights/insights.ts +0 -10
  295. package/lib/front_end/models/trace/insights/types.ts +0 -157
  296. package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
  297. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
  298. package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
  299. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
  300. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
  301. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
  302. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
  303. package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
  304. package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
  305. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
  306. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
  307. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
  308. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
  309. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
  310. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
  311. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
  312. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
  313. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
  314. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
  315. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
  316. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
  317. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
  318. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
  319. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
  320. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
  321. package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
  322. package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
  323. package/lib/front_end/models/trace/trace.ts +0 -33
  324. package/lib/front_end/models/trace/types/Configuration.ts +0 -110
  325. package/lib/front_end/models/trace/types/Extensions.ts +0 -136
  326. package/lib/front_end/models/trace/types/File.ts +0 -281
  327. package/lib/front_end/models/trace/types/Overlays.ts +0 -138
  328. package/lib/front_end/models/trace/types/Timing.ts +0 -30
  329. package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
  330. package/lib/front_end/models/trace/types/types.ts +0 -10
  331. package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
  332. package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
  333. package/lib/front_end/models/workspace/FileManager.ts +0 -97
  334. package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
  335. package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
  336. package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
  337. package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
  338. package/lib/front_end/models/workspace/workspace.ts +0 -17
  339. package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
  340. package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
  341. package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
  342. package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
  343. package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
  344. package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
  345. package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
  346. package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
  347. package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
  348. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
  349. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
  350. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
  351. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
  352. package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
  353. package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
  354. package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
  355. package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
  356. package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
  357. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
  358. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
  359. package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
  360. package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
  361. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
  362. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
  363. package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
  364. package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
  365. package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
  366. package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
  367. package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
  368. package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
  369. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
  370. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
  371. package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
  372. package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
  373. package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
  374. package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
  375. package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
  376. package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
  377. package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
  378. package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
  379. package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
  380. package/lib/front_end/third_party/codemirror.next/package.json +0 -43
  381. package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
  382. package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
  383. package/lib/front_end/third_party/i18n/LICENSE +0 -202
  384. package/lib/front_end/third_party/i18n/README.chromium +0 -15
  385. package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
  386. package/lib/front_end/third_party/i18n/i18n.ts +0 -11
  387. package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
  388. package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
  389. package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
  390. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
  391. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
  392. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
  393. package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
  394. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
  395. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
  396. package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
  397. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
  398. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
  399. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
  400. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
  401. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
  402. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
  403. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
  404. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
  405. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
  406. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
  407. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
  408. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
  409. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
  410. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
  411. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
  412. package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
  413. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
  414. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
  415. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
  416. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
  417. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
  418. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
  419. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
  420. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
  421. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
  422. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
  423. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
  424. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
  425. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
  426. package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
  427. package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
  428. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
  429. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
  430. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
  431. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
  432. package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
  433. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
  434. package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
  435. package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
  436. package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
  437. package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
  438. package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
  439. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
  440. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
  441. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
  442. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
  443. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
  444. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
  445. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
  446. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
  447. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
  448. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
  449. package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
  450. package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
  451. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
  452. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
  453. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
  454. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
  455. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
  456. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
  457. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
  458. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
  459. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
  460. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
  461. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
  462. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
  463. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
  464. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
  465. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
  466. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
  467. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
  468. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
  469. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
  470. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
  471. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
  472. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
  473. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
  474. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
  475. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
  476. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
  477. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
  478. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
  479. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
  480. package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
  481. package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
  482. package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
  483. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
  484. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
  485. package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
  486. package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
  487. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
  488. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
  489. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
  490. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
  491. package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
  492. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
  493. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
  494. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
  495. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
  496. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
  497. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
  498. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
  499. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
  500. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
  501. package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
  502. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
  503. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
  504. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
  505. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
  506. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
  507. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
  508. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
  509. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
  510. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
  511. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
  512. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
  513. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
  514. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
  515. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
  516. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
  517. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
  518. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
  519. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
  520. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
  521. package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
  522. package/lib/front_end/third_party/third-party-web/package.json +0 -8
  523. package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
  524. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
  525. package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
  526. package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
  527. package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
  528. package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
@@ -1,1128 +0,0 @@
1
- // Copyright 2010 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 ProtocolProxyApi from '../../generated/protocol-proxy-api.js';
6
- import type * as Protocol from '../../generated/protocol.js';
7
- import * as TextUtils from '../../models/text_utils/text_utils.js';
8
- import * as Common from '../common/common.js';
9
- import * as Host from '../host/host.js';
10
- import * as Platform from '../platform/platform.js';
11
- import * as Root from '../root/root.js';
12
-
13
- import {CSSFontFace} from './CSSFontFace.js';
14
- import {CSSMatchedStyles} from './CSSMatchedStyles.js';
15
- import {CSSMedia} from './CSSMedia.js';
16
- import {cssMetadata} from './CSSMetadata.js';
17
- import {CSSStyleRule} from './CSSRule.js';
18
- import {CSSStyleDeclaration, Type} from './CSSStyleDeclaration.js';
19
- import {CSSStyleSheetHeader} from './CSSStyleSheetHeader.js';
20
- import {DOMModel, type DOMNode} from './DOMModel.js';
21
- import {
22
- Events as ResourceTreeModelEvents,
23
- PrimaryPageChangeType,
24
- type ResourceTreeFrame,
25
- ResourceTreeModel,
26
- } from './ResourceTreeModel.js';
27
- import {SDKModel} from './SDKModel.js';
28
- import {SourceMapManager} from './SourceMapManager.js';
29
- import {Capability, type Target} from './Target.js';
30
-
31
- export const enum ColorScheme {
32
- LIGHT = 'light',
33
- DARK = 'dark',
34
- }
35
-
36
- export interface LayoutProperties {
37
- isFlex: boolean;
38
- isGrid: boolean;
39
- isSubgrid: boolean;
40
- isMasonry: boolean;
41
- isContainer: boolean;
42
- hasScroll: boolean;
43
- }
44
-
45
- export class CSSModel extends SDKModel<EventTypes> {
46
- readonly agent: ProtocolProxyApi.CSSApi;
47
- readonly #domModel: DOMModel;
48
- readonly #fontFaces = new Map<string, CSSFontFace>();
49
- readonly #originalStyleSheetText = new Map<CSSStyleSheetHeader, Promise<string|null>>();
50
- readonly #resourceTreeModel: ResourceTreeModel|null;
51
- readonly #sourceMapManager: SourceMapManager<CSSStyleSheetHeader>;
52
- readonly #styleLoader: ComputedStyleLoader;
53
- readonly #stylePollingThrottler = new Common.Throttler.Throttler(StylePollingInterval);
54
- readonly #styleSheetIdsForURL =
55
- new Map<Platform.DevToolsPath.UrlString, Map<string, Set<Protocol.CSS.StyleSheetId>>>();
56
- readonly #styleSheetIdToHeader = new Map<Protocol.CSS.StyleSheetId, CSSStyleSheetHeader>();
57
- #cachedMatchedCascadeNode: DOMNode|null = null;
58
- #cachedMatchedCascadePromise: Promise<CSSMatchedStyles|null>|null = null;
59
- #cssPropertyTracker: CSSPropertyTracker|null = null;
60
- #isCSSPropertyTrackingEnabled = false;
61
- #isEnabled = false;
62
- #isRuleUsageTrackingEnabled = false;
63
- #isTrackingRequestPending = false;
64
- #colorScheme: ColorScheme|undefined;
65
-
66
- constructor(target: Target) {
67
- super(target);
68
- this.#domModel = (target.model(DOMModel) as DOMModel);
69
- this.#sourceMapManager = new SourceMapManager(target);
70
- this.agent = target.cssAgent();
71
- this.#styleLoader = new ComputedStyleLoader(this);
72
- this.#resourceTreeModel = target.model(ResourceTreeModel);
73
- if (this.#resourceTreeModel) {
74
- this.#resourceTreeModel.addEventListener(
75
- ResourceTreeModelEvents.PrimaryPageChanged, this.onPrimaryPageChanged, this);
76
- }
77
- target.registerCSSDispatcher(new CSSDispatcher(this));
78
- if (!target.suspended()) {
79
- void this.enable();
80
- }
81
-
82
- this.#sourceMapManager.setEnabled(
83
- Common.Settings.Settings.instance().moduleSetting<boolean>('css-source-maps-enabled').get());
84
- Common.Settings.Settings.instance()
85
- .moduleSetting<boolean>('css-source-maps-enabled')
86
- .addChangeListener(event => this.#sourceMapManager.setEnabled(event.data));
87
- }
88
-
89
- async colorScheme(): Promise<ColorScheme|undefined> {
90
- if (!this.#colorScheme) {
91
- const colorSchemeResponse = await this.domModel()?.target().runtimeAgent().invoke_evaluate(
92
- {expression: 'window.matchMedia && window.matchMedia("(prefers-color-scheme: dark)").matches'});
93
- if (colorSchemeResponse && !colorSchemeResponse.exceptionDetails && !colorSchemeResponse.getError()) {
94
- this.#colorScheme = colorSchemeResponse.result.value ? ColorScheme.DARK : ColorScheme.LIGHT;
95
- }
96
- }
97
- return this.#colorScheme;
98
- }
99
-
100
- async resolveValues(propertyName: string|undefined, nodeId: Protocol.DOM.NodeId, ...values: string[]):
101
- Promise<string[]|null> {
102
- if (propertyName && cssMetadata().getLonghands(propertyName)?.length) {
103
- return null;
104
- }
105
- const response = await this.agent.invoke_resolveValues({values, nodeId, propertyName});
106
- if (response.getError()) {
107
- return null;
108
- }
109
- return response.results;
110
- }
111
-
112
- headersForSourceURL(sourceURL: Platform.DevToolsPath.UrlString): CSSStyleSheetHeader[] {
113
- const headers = [];
114
- for (const headerId of this.getStyleSheetIdsForURL(sourceURL)) {
115
- const header = this.styleSheetHeaderForId(headerId);
116
- if (header) {
117
- headers.push(header);
118
- }
119
- }
120
- return headers;
121
- }
122
-
123
- createRawLocationsByURL(
124
- sourceURL: Platform.DevToolsPath.UrlString, lineNumber: number,
125
- columnNumber: number|undefined = 0): CSSLocation[] {
126
- const headers = this.headersForSourceURL(sourceURL);
127
- headers.sort(stylesheetComparator);
128
- const endIndex = Platform.ArrayUtilities.upperBound(
129
- headers, undefined, (_, header) => lineNumber - header.startLine || columnNumber - header.startColumn);
130
- if (!endIndex) {
131
- return [];
132
- }
133
- const locations = [];
134
- const last = headers[endIndex - 1];
135
- for (let index = endIndex - 1;
136
- index >= 0 && headers[index].startLine === last.startLine && headers[index].startColumn === last.startColumn;
137
- --index) {
138
- if (headers[index].containsLocation(lineNumber, columnNumber)) {
139
- locations.push(new CSSLocation(headers[index], lineNumber, columnNumber));
140
- }
141
- }
142
-
143
- return locations;
144
- function stylesheetComparator(a: CSSStyleSheetHeader, b: CSSStyleSheetHeader): number {
145
- return a.startLine - b.startLine || a.startColumn - b.startColumn || a.id.localeCompare(b.id);
146
- }
147
- }
148
-
149
- sourceMapManager(): SourceMapManager<CSSStyleSheetHeader> {
150
- return this.#sourceMapManager;
151
- }
152
-
153
- static readableLayerName(text: string): string {
154
- return text || '<anonymous>';
155
- }
156
-
157
- static trimSourceURL(text: string): string {
158
- let sourceURLIndex = text.lastIndexOf('/*# sourceURL=');
159
- if (sourceURLIndex === -1) {
160
- sourceURLIndex = text.lastIndexOf('/*@ sourceURL=');
161
- if (sourceURLIndex === -1) {
162
- return text;
163
- }
164
- }
165
- const sourceURLLineIndex = text.lastIndexOf('\n', sourceURLIndex);
166
- if (sourceURLLineIndex === -1) {
167
- return text;
168
- }
169
- const sourceURLLine = text.substr(sourceURLLineIndex + 1).split('\n', 1)[0];
170
- const sourceURLRegex = /[\x20\t]*\/\*[#@] sourceURL=[\x20\t]*([^\s]*)[\x20\t]*\*\/[\x20\t]*$/;
171
- if (sourceURLLine.search(sourceURLRegex) === -1) {
172
- return text;
173
- }
174
- return text.substr(0, sourceURLLineIndex) + text.substr(sourceURLLineIndex + sourceURLLine.length + 1);
175
- }
176
-
177
- domModel(): DOMModel {
178
- return this.#domModel;
179
- }
180
-
181
- async trackComputedStyleUpdatesForNode(nodeId: Protocol.DOM.NodeId|undefined): Promise<void> {
182
- await this.agent.invoke_trackComputedStyleUpdatesForNode({nodeId});
183
- }
184
-
185
- async setStyleText(
186
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange, text: string,
187
- majorChange: boolean): Promise<boolean> {
188
- try {
189
- await this.ensureOriginalStyleSheetText(styleSheetId);
190
-
191
- const {styles} =
192
- await this.agent.invoke_setStyleTexts({edits: [{styleSheetId, range: range.serializeToObject(), text}]});
193
- if (!styles || styles.length !== 1) {
194
- return false;
195
- }
196
-
197
- this.#domModel.markUndoableState(!majorChange);
198
- const edit = new Edit(styleSheetId, range, text, styles[0]);
199
- this.fireStyleSheetChanged(styleSheetId, edit);
200
- return true;
201
- } catch (e) {
202
- console.error(e);
203
- return false;
204
- }
205
- }
206
-
207
- async setSelectorText(styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange, text: string):
208
- Promise<boolean> {
209
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
210
-
211
- try {
212
- await this.ensureOriginalStyleSheetText(styleSheetId);
213
- const {selectorList} = await this.agent.invoke_setRuleSelector({styleSheetId, range, selector: text});
214
-
215
- if (!selectorList) {
216
- return false;
217
- }
218
- this.#domModel.markUndoableState();
219
- const edit = new Edit(styleSheetId, range, text, selectorList);
220
- this.fireStyleSheetChanged(styleSheetId, edit);
221
- return true;
222
- } catch (e) {
223
- console.error(e);
224
- return false;
225
- }
226
- }
227
-
228
- async setPropertyRulePropertyName(
229
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange, text: string): Promise<boolean> {
230
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
231
-
232
- try {
233
- await this.ensureOriginalStyleSheetText(styleSheetId);
234
- const {propertyName} =
235
- await this.agent.invoke_setPropertyRulePropertyName({styleSheetId, range, propertyName: text});
236
-
237
- if (!propertyName) {
238
- return false;
239
- }
240
- this.#domModel.markUndoableState();
241
- const edit = new Edit(styleSheetId, range, text, propertyName);
242
- this.fireStyleSheetChanged(styleSheetId, edit);
243
- return true;
244
- } catch (e) {
245
- console.error(e);
246
- return false;
247
- }
248
- }
249
-
250
- async setKeyframeKey(styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange, text: string):
251
- Promise<boolean> {
252
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
253
-
254
- try {
255
- await this.ensureOriginalStyleSheetText(styleSheetId);
256
- const {keyText} = await this.agent.invoke_setKeyframeKey({styleSheetId, range, keyText: text});
257
-
258
- if (!keyText) {
259
- return false;
260
- }
261
- this.#domModel.markUndoableState();
262
- const edit = new Edit(styleSheetId, range, text, keyText);
263
- this.fireStyleSheetChanged(styleSheetId, edit);
264
- return true;
265
- } catch (e) {
266
- console.error(e);
267
- return false;
268
- }
269
- }
270
-
271
- startCoverage(): Promise<Protocol.ProtocolResponseWithError> {
272
- this.#isRuleUsageTrackingEnabled = true;
273
- return this.agent.invoke_startRuleUsageTracking();
274
- }
275
-
276
- async takeCoverageDelta(): Promise<{
277
- timestamp: number,
278
- coverage: Protocol.CSS.RuleUsage[],
279
- }> {
280
- const r = await this.agent.invoke_takeCoverageDelta();
281
- const timestamp = (r?.timestamp) || 0;
282
- const coverage = (r?.coverage) || [];
283
- return {timestamp, coverage};
284
- }
285
-
286
- setLocalFontsEnabled(enabled: boolean): Promise<Protocol.ProtocolResponseWithError> {
287
- return this.agent.invoke_setLocalFontsEnabled({
288
- enabled,
289
- });
290
- }
291
-
292
- async stopCoverage(): Promise<void> {
293
- this.#isRuleUsageTrackingEnabled = false;
294
- await this.agent.invoke_stopRuleUsageTracking();
295
- }
296
-
297
- async getMediaQueries(): Promise<CSSMedia[]> {
298
- const {medias} = await this.agent.invoke_getMediaQueries();
299
- return medias ? CSSMedia.parseMediaArrayPayload(this, medias) : [];
300
- }
301
-
302
- async getRootLayer(nodeId: Protocol.DOM.NodeId): Promise<Protocol.CSS.CSSLayerData> {
303
- const {rootLayer} = await this.agent.invoke_getLayersForNode({nodeId});
304
- return rootLayer;
305
- }
306
-
307
- isEnabled(): boolean {
308
- return this.#isEnabled;
309
- }
310
-
311
- private async enable(): Promise<void> {
312
- await this.agent.invoke_enable();
313
- this.#isEnabled = true;
314
- if (this.#isRuleUsageTrackingEnabled) {
315
- await this.startCoverage();
316
- }
317
- this.dispatchEventToListeners(Events.ModelWasEnabled);
318
- }
319
-
320
- async getAnimatedStylesForNode(nodeId: Protocol.DOM.NodeId):
321
- Promise<Protocol.CSS.GetAnimatedStylesForNodeResponse|null> {
322
- const response = await this.agent.invoke_getAnimatedStylesForNode({nodeId});
323
- if (response.getError()) {
324
- return null;
325
- }
326
-
327
- return response;
328
- }
329
-
330
- async getMatchedStyles(nodeId: Protocol.DOM.NodeId): Promise<CSSMatchedStyles|null> {
331
- const node = this.#domModel.nodeForId(nodeId);
332
- if (!node) {
333
- return null;
334
- }
335
-
336
- const shouldGetAnimatedStyles = Root.Runtime.hostConfig.devToolsAnimationStylesInStylesTab?.enabled;
337
- const [matchedStylesResponse, animatedStylesResponse] = await Promise.all([
338
- this.agent.invoke_getMatchedStylesForNode({nodeId}),
339
- shouldGetAnimatedStyles ? this.agent.invoke_getAnimatedStylesForNode({nodeId}) : undefined,
340
- ]);
341
-
342
- if (matchedStylesResponse.getError()) {
343
- return null;
344
- }
345
-
346
- const payload = {
347
- cssModel: this,
348
- node,
349
- inlinePayload: matchedStylesResponse.inlineStyle || null,
350
- attributesPayload: matchedStylesResponse.attributesStyle || null,
351
- matchedPayload: matchedStylesResponse.matchedCSSRules || [],
352
- pseudoPayload: matchedStylesResponse.pseudoElements || [],
353
- inheritedPayload: matchedStylesResponse.inherited || [],
354
- inheritedPseudoPayload: matchedStylesResponse.inheritedPseudoElements || [],
355
- animationsPayload: matchedStylesResponse.cssKeyframesRules || [],
356
- parentLayoutNodeId: matchedStylesResponse.parentLayoutNodeId,
357
- positionTryRules: matchedStylesResponse.cssPositionTryRules || [],
358
- propertyRules: matchedStylesResponse.cssPropertyRules ?? [],
359
- functionRules: matchedStylesResponse.cssFunctionRules ?? [],
360
- cssPropertyRegistrations: matchedStylesResponse.cssPropertyRegistrations ?? [],
361
- fontPaletteValuesRule: matchedStylesResponse.cssFontPaletteValuesRule,
362
- activePositionFallbackIndex: matchedStylesResponse.activePositionFallbackIndex ?? -1,
363
- animationStylesPayload: animatedStylesResponse?.animationStyles || [],
364
- inheritedAnimatedPayload: animatedStylesResponse?.inherited || [],
365
- transitionsStylePayload: animatedStylesResponse?.transitionsStyle || null,
366
- };
367
- return await CSSMatchedStyles.create(payload);
368
- }
369
-
370
- async getClassNames(styleSheetId: Protocol.CSS.StyleSheetId): Promise<string[]> {
371
- const {classNames} = await this.agent.invoke_collectClassNames({styleSheetId});
372
- return classNames || [];
373
- }
374
-
375
- async getComputedStyle(nodeId: Protocol.DOM.NodeId): Promise<Map<string, string>|null> {
376
- if (!this.isEnabled()) {
377
- await this.enable();
378
- }
379
- return await this.#styleLoader.computedStylePromise(nodeId);
380
- }
381
-
382
- async getLayoutPropertiesFromComputedStyle(nodeId: Protocol.DOM.NodeId): Promise<LayoutProperties|null> {
383
- const styles = await this.getComputedStyle(nodeId);
384
- if (!styles) {
385
- return null;
386
- }
387
-
388
- const display = styles.get('display');
389
- const isFlex = display === 'flex' || display === 'inline-flex';
390
- const isGrid = display === 'grid' || display === 'inline-grid';
391
- const isSubgrid = (isGrid &&
392
- (styles.get('grid-template-columns')?.startsWith('subgrid') ||
393
- styles.get('grid-template-rows')?.startsWith('subgrid'))) ??
394
- false;
395
- const isMasonry = display === 'masonry' || display === 'inline-masonry';
396
- const containerType = styles.get('container-type');
397
- const isContainer = Boolean(containerType) && containerType !== '' && containerType !== 'normal';
398
- const hasScroll = Boolean(styles.get('scroll-snap-type')) && styles.get('scroll-snap-type') !== 'none';
399
-
400
- return {
401
- isFlex,
402
- isGrid,
403
- isSubgrid,
404
- isMasonry,
405
- isContainer,
406
- hasScroll,
407
- };
408
- }
409
-
410
- async getEnvironmentVariales(): Promise<Record<string, string>> {
411
- const response = await this.agent.invoke_getEnvironmentVariables();
412
- if (response.getError()) {
413
- return {};
414
- }
415
- return response.environmentVariables;
416
- }
417
-
418
- async getBackgroundColors(nodeId: Protocol.DOM.NodeId): Promise<ContrastInfo|null> {
419
- const response = await this.agent.invoke_getBackgroundColors({nodeId});
420
- if (response.getError()) {
421
- return null;
422
- }
423
-
424
- return {
425
- backgroundColors: response.backgroundColors || null,
426
- computedFontSize: response.computedFontSize || '',
427
- computedFontWeight: response.computedFontWeight || '',
428
- };
429
- }
430
-
431
- async getPlatformFonts(nodeId: Protocol.DOM.NodeId): Promise<Protocol.CSS.PlatformFontUsage[]|null> {
432
- const {fonts} = await this.agent.invoke_getPlatformFontsForNode({nodeId});
433
- return fonts;
434
- }
435
-
436
- allStyleSheets(): CSSStyleSheetHeader[] {
437
- const values = [...this.#styleSheetIdToHeader.values()];
438
- function styleSheetComparator(a: CSSStyleSheetHeader, b: CSSStyleSheetHeader): number {
439
- if (a.sourceURL < b.sourceURL) {
440
- return -1;
441
- }
442
- if (a.sourceURL > b.sourceURL) {
443
- return 1;
444
- }
445
- return a.startLine - b.startLine || a.startColumn - b.startColumn;
446
- }
447
- values.sort(styleSheetComparator);
448
-
449
- return values;
450
- }
451
-
452
- async getInlineStyles(nodeId: Protocol.DOM.NodeId): Promise<InlineStyleResult|null> {
453
- const response = await this.agent.invoke_getInlineStylesForNode({nodeId});
454
-
455
- if (response.getError() || !response.inlineStyle) {
456
- return null;
457
- }
458
- const inlineStyle = new CSSStyleDeclaration(this, null, response.inlineStyle, Type.Inline);
459
- const attributesStyle = response.attributesStyle ?
460
- new CSSStyleDeclaration(this, null, response.attributesStyle, Type.Attributes) :
461
- null;
462
- return new InlineStyleResult(inlineStyle, attributesStyle);
463
- }
464
-
465
- forceStartingStyle(node: DOMNode, forced: boolean): boolean {
466
- void this.agent.invoke_forceStartingStyle({nodeId: node.id, forced});
467
- this.dispatchEventToListeners(Events.StartingStylesStateForced, node);
468
- return true;
469
- }
470
-
471
- forcePseudoState(node: DOMNode, pseudoClass: string, enable: boolean): boolean {
472
- const forcedPseudoClasses = node.marker<string[]>(PseudoStateMarker) || [];
473
- const hasPseudoClass = forcedPseudoClasses.includes(pseudoClass);
474
- if (enable) {
475
- if (hasPseudoClass) {
476
- return false;
477
- }
478
- forcedPseudoClasses.push(pseudoClass);
479
- node.setMarker(PseudoStateMarker, forcedPseudoClasses);
480
- } else {
481
- if (!hasPseudoClass) {
482
- return false;
483
- }
484
- Platform.ArrayUtilities.removeElement(forcedPseudoClasses, pseudoClass);
485
- if (forcedPseudoClasses.length) {
486
- node.setMarker(PseudoStateMarker, forcedPseudoClasses);
487
- } else {
488
- node.setMarker(PseudoStateMarker, null);
489
- }
490
- }
491
-
492
- if (node.id === undefined) {
493
- return false;
494
- }
495
- void this.agent.invoke_forcePseudoState({nodeId: node.id, forcedPseudoClasses});
496
- this.dispatchEventToListeners(Events.PseudoStateForced, {node, pseudoClass, enable});
497
- return true;
498
- }
499
-
500
- pseudoState(node: DOMNode): string[]|null {
501
- return node.marker(PseudoStateMarker) || [];
502
- }
503
-
504
- async setMediaText(
505
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange,
506
- newMediaText: string): Promise<boolean> {
507
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
508
-
509
- try {
510
- await this.ensureOriginalStyleSheetText(styleSheetId);
511
- const {media} = await this.agent.invoke_setMediaText({styleSheetId, range, text: newMediaText});
512
-
513
- if (!media) {
514
- return false;
515
- }
516
- this.#domModel.markUndoableState();
517
- const edit = new Edit(styleSheetId, range, newMediaText, media);
518
- this.fireStyleSheetChanged(styleSheetId, edit);
519
- return true;
520
- } catch (e) {
521
- console.error(e);
522
- return false;
523
- }
524
- }
525
-
526
- async setContainerQueryText(
527
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange,
528
- newContainerQueryText: string): Promise<boolean> {
529
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
530
-
531
- try {
532
- await this.ensureOriginalStyleSheetText(styleSheetId);
533
- const {containerQuery} =
534
- await this.agent.invoke_setContainerQueryText({styleSheetId, range, text: newContainerQueryText});
535
-
536
- if (!containerQuery) {
537
- return false;
538
- }
539
- this.#domModel.markUndoableState();
540
- const edit = new Edit(styleSheetId, range, newContainerQueryText, containerQuery);
541
- this.fireStyleSheetChanged(styleSheetId, edit);
542
- return true;
543
- } catch (e) {
544
- console.error(e);
545
- return false;
546
- }
547
- }
548
-
549
- async setSupportsText(
550
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange,
551
- newSupportsText: string): Promise<boolean> {
552
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
553
-
554
- try {
555
- await this.ensureOriginalStyleSheetText(styleSheetId);
556
- const {supports} = await this.agent.invoke_setSupportsText({styleSheetId, range, text: newSupportsText});
557
-
558
- if (!supports) {
559
- return false;
560
- }
561
- this.#domModel.markUndoableState();
562
- const edit = new Edit(styleSheetId, range, newSupportsText, supports);
563
- this.fireStyleSheetChanged(styleSheetId, edit);
564
- return true;
565
- } catch (e) {
566
- console.error(e);
567
- return false;
568
- }
569
- }
570
-
571
- async setScopeText(
572
- styleSheetId: Protocol.CSS.StyleSheetId, range: TextUtils.TextRange.TextRange,
573
- newScopeText: string): Promise<boolean> {
574
- Host.userMetrics.actionTaken(Host.UserMetrics.Action.StyleRuleEdited);
575
-
576
- try {
577
- await this.ensureOriginalStyleSheetText(styleSheetId);
578
- const {scope} = await this.agent.invoke_setScopeText({styleSheetId, range, text: newScopeText});
579
-
580
- if (!scope) {
581
- return false;
582
- }
583
- this.#domModel.markUndoableState();
584
- const edit = new Edit(styleSheetId, range, newScopeText, scope);
585
- this.fireStyleSheetChanged(styleSheetId, edit);
586
- return true;
587
- } catch (e) {
588
- console.error(e);
589
- return false;
590
- }
591
- }
592
-
593
- async addRule(styleSheetId: Protocol.CSS.StyleSheetId, ruleText: string, ruleLocation: TextUtils.TextRange.TextRange):
594
- Promise<CSSStyleRule|null> {
595
- try {
596
- await this.ensureOriginalStyleSheetText(styleSheetId);
597
- const {rule} = await this.agent.invoke_addRule({styleSheetId, ruleText, location: ruleLocation});
598
-
599
- if (!rule) {
600
- return null;
601
- }
602
- this.#domModel.markUndoableState();
603
- const edit = new Edit(styleSheetId, ruleLocation, ruleText, rule);
604
- this.fireStyleSheetChanged(styleSheetId, edit);
605
- return new CSSStyleRule(this, rule);
606
- } catch (e) {
607
- console.error(e);
608
- return null;
609
- }
610
- }
611
-
612
- async requestViaInspectorStylesheet(maybeFrameId?: Protocol.Page.FrameId|null): Promise<CSSStyleSheetHeader|null> {
613
- const frameId = maybeFrameId ||
614
- (this.#resourceTreeModel && this.#resourceTreeModel.mainFrame ? this.#resourceTreeModel.mainFrame.id : null);
615
- const headers = [...this.#styleSheetIdToHeader.values()];
616
- const styleSheetHeader = headers.find(header => header.frameId === frameId && header.isViaInspector());
617
- if (styleSheetHeader) {
618
- return styleSheetHeader;
619
- }
620
- if (!frameId) {
621
- return null;
622
- }
623
-
624
- try {
625
- return await this.createInspectorStylesheet(frameId);
626
- } catch (e) {
627
- console.error(e);
628
- return null;
629
- }
630
- }
631
-
632
- async createInspectorStylesheet(frameId: Protocol.Page.FrameId, force = false): Promise<CSSStyleSheetHeader|null> {
633
- const result = await this.agent.invoke_createStyleSheet({frameId, force});
634
- if (result.getError()) {
635
- throw new Error(result.getError());
636
- }
637
- return this.#styleSheetIdToHeader.get(result.styleSheetId) || null;
638
- }
639
-
640
- mediaQueryResultChanged(): void {
641
- this.#colorScheme = undefined;
642
- this.dispatchEventToListeners(Events.MediaQueryResultChanged);
643
- }
644
-
645
- fontsUpdated(fontFace?: Protocol.CSS.FontFace|null): void {
646
- if (fontFace) {
647
- this.#fontFaces.set(fontFace.src, new CSSFontFace(fontFace));
648
- }
649
- this.dispatchEventToListeners(Events.FontsUpdated);
650
- }
651
-
652
- fontFaces(): CSSFontFace[] {
653
- return [...this.#fontFaces.values()];
654
- }
655
-
656
- fontFaceForSource(src: string): CSSFontFace|undefined {
657
- return this.#fontFaces.get(src);
658
- }
659
-
660
- styleSheetHeaderForId(id: Protocol.CSS.StyleSheetId): CSSStyleSheetHeader|null {
661
- return this.#styleSheetIdToHeader.get(id) || null;
662
- }
663
-
664
- styleSheetHeaders(): CSSStyleSheetHeader[] {
665
- return [...this.#styleSheetIdToHeader.values()];
666
- }
667
-
668
- fireStyleSheetChanged(styleSheetId: Protocol.CSS.StyleSheetId, edit?: Edit): void {
669
- this.dispatchEventToListeners(Events.StyleSheetChanged, {styleSheetId, edit});
670
- }
671
-
672
- private ensureOriginalStyleSheetText(styleSheetId: Protocol.CSS.StyleSheetId): Promise<string|null> {
673
- const header = this.styleSheetHeaderForId(styleSheetId);
674
- if (!header) {
675
- return Promise.resolve(null);
676
- }
677
- let promise = this.#originalStyleSheetText.get(header);
678
- if (!promise) {
679
- promise = this.getStyleSheetText(header.id);
680
- this.#originalStyleSheetText.set(header, promise);
681
- this.originalContentRequestedForTest(header);
682
- }
683
- return promise;
684
- }
685
-
686
- private originalContentRequestedForTest(_header: CSSStyleSheetHeader): void {
687
- }
688
-
689
- originalStyleSheetText(header: CSSStyleSheetHeader): Promise<string|null> {
690
- return this.ensureOriginalStyleSheetText(header.id);
691
- }
692
-
693
- getAllStyleSheetHeaders(): Iterable<CSSStyleSheetHeader> {
694
- return this.#styleSheetIdToHeader.values();
695
- }
696
-
697
- computedStyleUpdated(nodeId: Protocol.DOM.NodeId): void {
698
- this.dispatchEventToListeners(Events.ComputedStyleUpdated, {nodeId});
699
- }
700
-
701
- styleSheetAdded(header: Protocol.CSS.CSSStyleSheetHeader): void {
702
- console.assert(!this.#styleSheetIdToHeader.get(header.styleSheetId));
703
- if (header.loadingFailed) {
704
- // When the stylesheet fails to load, treat it as a constructed stylesheet. Failed sheets can still be modified
705
- // from JS, in which case CSS.styleSheetChanged events are sent. So as to not confuse CSSModel clients we don't
706
- // just discard the failed sheet here. Treating the failed sheet as a constructed stylesheet lets us keep track
707
- // of it cleanly.
708
- header.hasSourceURL = false;
709
- header.isConstructed = true;
710
- header.isInline = false;
711
- header.isMutable = false;
712
- header.sourceURL = '';
713
- header.sourceMapURL = undefined;
714
- }
715
- const styleSheetHeader = new CSSStyleSheetHeader(this, header);
716
- this.#styleSheetIdToHeader.set(header.styleSheetId, styleSheetHeader);
717
- const url = styleSheetHeader.resourceURL();
718
- let frameIdToStyleSheetIds = this.#styleSheetIdsForURL.get(url);
719
- if (!frameIdToStyleSheetIds) {
720
- frameIdToStyleSheetIds = new Map();
721
- this.#styleSheetIdsForURL.set(url, frameIdToStyleSheetIds);
722
- }
723
- if (frameIdToStyleSheetIds) {
724
- let styleSheetIds = frameIdToStyleSheetIds.get(styleSheetHeader.frameId);
725
- if (!styleSheetIds) {
726
- styleSheetIds = new Set();
727
- frameIdToStyleSheetIds.set(styleSheetHeader.frameId, styleSheetIds);
728
- }
729
- styleSheetIds.add(styleSheetHeader.id);
730
- }
731
- this.#sourceMapManager.attachSourceMap(styleSheetHeader, styleSheetHeader.sourceURL, styleSheetHeader.sourceMapURL);
732
- this.dispatchEventToListeners(Events.StyleSheetAdded, styleSheetHeader);
733
- }
734
-
735
- styleSheetRemoved(id: Protocol.CSS.StyleSheetId): void {
736
- const header = this.#styleSheetIdToHeader.get(id);
737
- console.assert(Boolean(header));
738
- if (!header) {
739
- return;
740
- }
741
- this.#styleSheetIdToHeader.delete(id);
742
- const url = header.resourceURL();
743
- const frameIdToStyleSheetIds = this.#styleSheetIdsForURL.get(url);
744
- console.assert(
745
- Boolean(frameIdToStyleSheetIds), 'No frameId to styleSheetId map is available for given style sheet URL.');
746
- if (frameIdToStyleSheetIds) {
747
- const stylesheetIds = frameIdToStyleSheetIds.get(header.frameId);
748
- if (stylesheetIds) {
749
- stylesheetIds.delete(id);
750
- if (!stylesheetIds.size) {
751
- frameIdToStyleSheetIds.delete(header.frameId);
752
- if (!frameIdToStyleSheetIds.size) {
753
- this.#styleSheetIdsForURL.delete(url);
754
- }
755
- }
756
- }
757
- }
758
- this.#originalStyleSheetText.delete(header);
759
- this.#sourceMapManager.detachSourceMap(header);
760
- this.dispatchEventToListeners(Events.StyleSheetRemoved, header);
761
- }
762
-
763
- getStyleSheetIdsForURL(url: Platform.DevToolsPath.UrlString): Protocol.CSS.StyleSheetId[] {
764
- const frameIdToStyleSheetIds = this.#styleSheetIdsForURL.get(url);
765
- if (!frameIdToStyleSheetIds) {
766
- return [];
767
- }
768
-
769
- const result = [];
770
- for (const styleSheetIds of frameIdToStyleSheetIds.values()) {
771
- result.push(...styleSheetIds);
772
- }
773
- return result;
774
- }
775
-
776
- async setStyleSheetText(styleSheetId: Protocol.CSS.StyleSheetId, newText: string, majorChange: boolean):
777
- Promise<string|null> {
778
- const header = this.#styleSheetIdToHeader.get(styleSheetId);
779
- if (!header) {
780
- return 'Unknown stylesheet in CSS.setStyleSheetText';
781
- }
782
- newText = CSSModel.trimSourceURL(newText);
783
- if (header.hasSourceURL) {
784
- newText += '\n/*# sourceURL=' + header.sourceURL + ' */';
785
- }
786
-
787
- await this.ensureOriginalStyleSheetText(styleSheetId);
788
- const response = await this.agent.invoke_setStyleSheetText({styleSheetId: header.id, text: newText});
789
- const sourceMapURL = response.sourceMapURL as Platform.DevToolsPath.UrlString;
790
-
791
- this.#sourceMapManager.detachSourceMap(header);
792
- header.setSourceMapURL(sourceMapURL);
793
- this.#sourceMapManager.attachSourceMap(header, header.sourceURL, header.sourceMapURL);
794
- if (sourceMapURL === null) {
795
- return 'Error in CSS.setStyleSheetText';
796
- }
797
- this.#domModel.markUndoableState(!majorChange);
798
- this.fireStyleSheetChanged(styleSheetId);
799
- return null;
800
- }
801
-
802
- async getStyleSheetText(styleSheetId: Protocol.CSS.StyleSheetId): Promise<string|null> {
803
- const response = await this.agent.invoke_getStyleSheetText({styleSheetId});
804
- if (response.getError()) {
805
- return null;
806
- }
807
- const {text} = response;
808
- return text && CSSModel.trimSourceURL(text);
809
- }
810
-
811
- private async onPrimaryPageChanged(
812
- event: Common.EventTarget.EventTargetEvent<{frame: ResourceTreeFrame, type: PrimaryPageChangeType}>):
813
- Promise<void> {
814
- // If the main frame was restored from the back-forward cache, the order of CDP
815
- // is different from the regular navigations. In this case, events about CSS
816
- // stylesheet has already been received and they are mixed with the previous page
817
- // stylesheets. Therefore, we re-enable the CSS agent to get fresh events.
818
- // For the regular navigations, we can just clear the local data because events about
819
- // stylesheets will arrive later.
820
- if (event.data.frame.backForwardCacheDetails.restoredFromCache) {
821
- await this.suspendModel();
822
- await this.resumeModel();
823
- } else if (event.data.type !== PrimaryPageChangeType.ACTIVATION) {
824
- this.resetStyleSheets();
825
- this.resetFontFaces();
826
- }
827
- }
828
-
829
- private resetStyleSheets(): void {
830
- const headers = [...this.#styleSheetIdToHeader.values()];
831
- this.#styleSheetIdsForURL.clear();
832
- this.#styleSheetIdToHeader.clear();
833
- for (const header of headers) {
834
- this.#sourceMapManager.detachSourceMap(header);
835
- this.dispatchEventToListeners(Events.StyleSheetRemoved, header);
836
- }
837
- }
838
-
839
- private resetFontFaces(): void {
840
- this.#fontFaces.clear();
841
- }
842
-
843
- override async suspendModel(): Promise<void> {
844
- this.#isEnabled = false;
845
- await this.agent.invoke_disable();
846
- this.resetStyleSheets();
847
- this.resetFontFaces();
848
- }
849
-
850
- override async resumeModel(): Promise<void> {
851
- return await this.enable();
852
- }
853
-
854
- setEffectivePropertyValueForNode(nodeId: Protocol.DOM.NodeId, propertyName: string, value: string): void {
855
- void this.agent.invoke_setEffectivePropertyValueForNode({nodeId, propertyName, value});
856
- }
857
-
858
- cachedMatchedCascadeForNode(node: DOMNode): Promise<CSSMatchedStyles|null> {
859
- if (this.#cachedMatchedCascadeNode !== node) {
860
- this.discardCachedMatchedCascade();
861
- }
862
- this.#cachedMatchedCascadeNode = node;
863
- if (!this.#cachedMatchedCascadePromise) {
864
- if (node.id) {
865
- this.#cachedMatchedCascadePromise = this.getMatchedStyles(node.id);
866
- } else {
867
- return Promise.resolve(null);
868
- }
869
- }
870
- return this.#cachedMatchedCascadePromise;
871
- }
872
-
873
- discardCachedMatchedCascade(): void {
874
- this.#cachedMatchedCascadeNode = null;
875
- this.#cachedMatchedCascadePromise = null;
876
- }
877
-
878
- createCSSPropertyTracker(propertiesToTrack: Protocol.CSS.CSSComputedStyleProperty[]): CSSPropertyTracker {
879
- const cssPropertyTracker = new CSSPropertyTracker(this, propertiesToTrack);
880
- return cssPropertyTracker;
881
- }
882
-
883
- enableCSSPropertyTracker(cssPropertyTracker: CSSPropertyTracker): void {
884
- const propertiesToTrack = cssPropertyTracker.getTrackedProperties();
885
- if (propertiesToTrack.length === 0) {
886
- return;
887
- }
888
- void this.agent.invoke_trackComputedStyleUpdates({propertiesToTrack});
889
- this.#isCSSPropertyTrackingEnabled = true;
890
- this.#cssPropertyTracker = cssPropertyTracker;
891
- void this.pollComputedStyleUpdates();
892
- }
893
-
894
- // Since we only support one tracker at a time, this call effectively disables
895
- // style tracking.
896
- disableCSSPropertyTracker(): void {
897
- this.#isCSSPropertyTrackingEnabled = false;
898
- this.#cssPropertyTracker = null;
899
- // Sending an empty list to the backend signals the close of style tracking
900
- void this.agent.invoke_trackComputedStyleUpdates({propertiesToTrack: []});
901
- }
902
-
903
- private async pollComputedStyleUpdates(): Promise<void> {
904
- if (this.#isTrackingRequestPending) {
905
- return;
906
- }
907
-
908
- if (this.#isCSSPropertyTrackingEnabled) {
909
- this.#isTrackingRequestPending = true;
910
- const result = await this.agent.invoke_takeComputedStyleUpdates();
911
- this.#isTrackingRequestPending = false;
912
-
913
- if (result.getError() || !result.nodeIds || !this.#isCSSPropertyTrackingEnabled) {
914
- return;
915
- }
916
-
917
- if (this.#cssPropertyTracker) {
918
- this.#cssPropertyTracker.dispatchEventToListeners(
919
- CSSPropertyTrackerEvents.TRACKED_CSS_PROPERTIES_UPDATED,
920
- result.nodeIds.map(nodeId => this.#domModel.nodeForId(nodeId)));
921
- }
922
- }
923
-
924
- if (this.#isCSSPropertyTrackingEnabled) {
925
- void this.#stylePollingThrottler.schedule(this.pollComputedStyleUpdates.bind(this));
926
- }
927
- }
928
-
929
- override dispose(): void {
930
- this.disableCSSPropertyTracker();
931
- super.dispose();
932
- this.dispatchEventToListeners(Events.ModelDisposed, this);
933
- }
934
-
935
- getAgent(): ProtocolProxyApi.CSSApi {
936
- return this.agent;
937
- }
938
- }
939
-
940
- export enum Events {
941
- /* eslint-disable @typescript-eslint/naming-convention -- Used by web_tests. */
942
- FontsUpdated = 'FontsUpdated',
943
- MediaQueryResultChanged = 'MediaQueryResultChanged',
944
- ModelWasEnabled = 'ModelWasEnabled',
945
- ModelDisposed = 'ModelDisposed',
946
- PseudoStateForced = 'PseudoStateForced',
947
- StartingStylesStateForced = 'StartingStylesStateForced',
948
- StyleSheetAdded = 'StyleSheetAdded',
949
- StyleSheetChanged = 'StyleSheetChanged',
950
- StyleSheetRemoved = 'StyleSheetRemoved',
951
- ComputedStyleUpdated = 'ComputedStyleUpdated',
952
- /* eslint-enable @typescript-eslint/naming-convention */
953
- }
954
-
955
- export interface StyleSheetChangedEvent {
956
- styleSheetId: Protocol.CSS.StyleSheetId;
957
- edit?: Edit;
958
- }
959
-
960
- export interface PseudoStateForcedEvent {
961
- node: DOMNode;
962
- pseudoClass: string;
963
- enable: boolean;
964
- }
965
-
966
- export interface ComputedStyleUpdatedEvent {
967
- nodeId: Protocol.DOM.NodeId;
968
- }
969
-
970
- export interface EventTypes {
971
- [Events.FontsUpdated]: void;
972
- [Events.MediaQueryResultChanged]: void;
973
- [Events.ModelWasEnabled]: void;
974
- [Events.ModelDisposed]: CSSModel;
975
- [Events.PseudoStateForced]: PseudoStateForcedEvent;
976
- [Events.StartingStylesStateForced]: DOMNode;
977
- [Events.StyleSheetAdded]: CSSStyleSheetHeader;
978
- [Events.StyleSheetChanged]: StyleSheetChangedEvent;
979
- [Events.StyleSheetRemoved]: CSSStyleSheetHeader;
980
- [Events.ComputedStyleUpdated]: ComputedStyleUpdatedEvent;
981
- }
982
-
983
- const PseudoStateMarker = 'pseudo-state-marker';
984
-
985
- export class Edit {
986
- styleSheetId: string;
987
- oldRange: TextUtils.TextRange.TextRange;
988
- newRange: TextUtils.TextRange.TextRange;
989
- newText: string;
990
- payload: Object|null;
991
- constructor(styleSheetId: string, oldRange: TextUtils.TextRange.TextRange, newText: string, payload: Object|null) {
992
- this.styleSheetId = styleSheetId;
993
- this.oldRange = oldRange;
994
- this.newRange = TextUtils.TextRange.TextRange.fromEdit(oldRange, newText);
995
- this.newText = newText;
996
- this.payload = payload;
997
- }
998
- }
999
-
1000
- export class CSSLocation {
1001
- readonly #cssModel: CSSModel;
1002
- styleSheetId: Protocol.CSS.StyleSheetId;
1003
- url: Platform.DevToolsPath.UrlString;
1004
- lineNumber: number;
1005
- columnNumber: number;
1006
- constructor(header: CSSStyleSheetHeader, lineNumber: number, columnNumber?: number) {
1007
- this.#cssModel = header.cssModel();
1008
- this.styleSheetId = header.id;
1009
- this.url = header.resourceURL();
1010
- this.lineNumber = lineNumber;
1011
- this.columnNumber = columnNumber || 0;
1012
- }
1013
-
1014
- cssModel(): CSSModel {
1015
- return this.#cssModel;
1016
- }
1017
-
1018
- header(): CSSStyleSheetHeader|null {
1019
- return this.#cssModel.styleSheetHeaderForId(this.styleSheetId);
1020
- }
1021
- }
1022
-
1023
- class CSSDispatcher implements ProtocolProxyApi.CSSDispatcher {
1024
- readonly #cssModel: CSSModel;
1025
- constructor(cssModel: CSSModel) {
1026
- this.#cssModel = cssModel;
1027
- }
1028
-
1029
- mediaQueryResultChanged(): void {
1030
- this.#cssModel.mediaQueryResultChanged();
1031
- }
1032
-
1033
- fontsUpdated({font}: Protocol.CSS.FontsUpdatedEvent): void {
1034
- this.#cssModel.fontsUpdated(font);
1035
- }
1036
-
1037
- styleSheetChanged({styleSheetId}: Protocol.CSS.StyleSheetChangedEvent): void {
1038
- this.#cssModel.fireStyleSheetChanged(styleSheetId);
1039
- }
1040
-
1041
- styleSheetAdded({header}: Protocol.CSS.StyleSheetAddedEvent): void {
1042
- this.#cssModel.styleSheetAdded(header);
1043
- }
1044
-
1045
- styleSheetRemoved({styleSheetId}: Protocol.CSS.StyleSheetRemovedEvent): void {
1046
- this.#cssModel.styleSheetRemoved(styleSheetId);
1047
- }
1048
-
1049
- computedStyleUpdated({nodeId}: Protocol.CSS.ComputedStyleUpdatedEvent): void {
1050
- this.#cssModel.computedStyleUpdated(nodeId);
1051
- }
1052
- }
1053
-
1054
- class ComputedStyleLoader {
1055
- #cssModel: CSSModel;
1056
- #nodeIdToPromise = new Map<number, Promise<Map<string, string>|null>>();
1057
- constructor(cssModel: CSSModel) {
1058
- this.#cssModel = cssModel;
1059
- }
1060
-
1061
- computedStylePromise(nodeId: Protocol.DOM.NodeId): Promise<Map<string, string>|null> {
1062
- let promise = this.#nodeIdToPromise.get(nodeId);
1063
- if (promise) {
1064
- return promise;
1065
- }
1066
- promise = this.#cssModel.getAgent().invoke_getComputedStyleForNode({nodeId}).then(({computedStyle}) => {
1067
- this.#nodeIdToPromise.delete(nodeId);
1068
- if (!computedStyle?.length) {
1069
- return null;
1070
- }
1071
- const result = new Map<string, string>();
1072
- for (const property of computedStyle) {
1073
- result.set(property.name, property.value);
1074
- }
1075
- return result;
1076
- });
1077
- this.#nodeIdToPromise.set(nodeId, promise);
1078
- return promise;
1079
- }
1080
- }
1081
-
1082
- export class InlineStyleResult {
1083
- inlineStyle: CSSStyleDeclaration|null;
1084
- attributesStyle: CSSStyleDeclaration|null;
1085
- constructor(inlineStyle: CSSStyleDeclaration|null, attributesStyle: CSSStyleDeclaration|null) {
1086
- this.inlineStyle = inlineStyle;
1087
- this.attributesStyle = attributesStyle;
1088
- }
1089
- }
1090
-
1091
- export class CSSPropertyTracker extends Common.ObjectWrapper.ObjectWrapper<CSSPropertyTrackerEventTypes> {
1092
- readonly #cssModel: CSSModel;
1093
- readonly #properties: Protocol.CSS.CSSComputedStyleProperty[];
1094
- constructor(cssModel: CSSModel, propertiesToTrack: Protocol.CSS.CSSComputedStyleProperty[]) {
1095
- super();
1096
- this.#cssModel = cssModel;
1097
- this.#properties = propertiesToTrack;
1098
- }
1099
-
1100
- start(): void {
1101
- this.#cssModel.enableCSSPropertyTracker(this);
1102
- }
1103
-
1104
- stop(): void {
1105
- this.#cssModel.disableCSSPropertyTracker();
1106
- }
1107
-
1108
- getTrackedProperties(): Protocol.CSS.CSSComputedStyleProperty[] {
1109
- return this.#properties;
1110
- }
1111
- }
1112
-
1113
- const StylePollingInterval = 1000; // throttling interval for style polling, in milliseconds
1114
-
1115
- export const enum CSSPropertyTrackerEvents {
1116
- TRACKED_CSS_PROPERTIES_UPDATED = 'TrackedCSSPropertiesUpdated',
1117
- }
1118
-
1119
- export interface CSSPropertyTrackerEventTypes {
1120
- [CSSPropertyTrackerEvents.TRACKED_CSS_PROPERTIES_UPDATED]: Array<DOMNode|null>;
1121
- }
1122
-
1123
- SDKModel.register(CSSModel, {capabilities: Capability.DOM, autostart: true});
1124
- export interface ContrastInfo {
1125
- backgroundColors: string[]|null;
1126
- computedFontSize: string;
1127
- computedFontWeight: string;
1128
- }