@pb33f/cowboy-components 0.7.17 → 0.8.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 (540) hide show
  1. package/dist/_basePickBy-DtTwxTrV.js +151 -0
  2. package/dist/_baseUniq-C5Y4WFmx.js +614 -0
  3. package/dist/arc-a-7w7y90.js +83 -0
  4. package/dist/architecture-U656AL7Q-c_zxypEp.js +5 -0
  5. package/dist/architectureDiagram-VXUJARFQ-CIhQJ6xS.js +4661 -0
  6. package/dist/assets/elk-layout.worker-B71_NI2D.js +1 -0
  7. package/dist/assets/equalizer.worker-A8HFNy4g.js +1 -0
  8. package/dist/assets/graph-dependent.worker-BgWuMZsb.js +1 -0
  9. package/dist/assets/rule-documentation.worker-BCKuwSgZ.js +1 -0
  10. package/dist/assets/search-graph.worker-Cwqb-ecv.js +1 -0
  11. package/dist/assets/search-problems.worker-60kZqr0h.js +1 -0
  12. package/dist/blockDiagram-VD42YOAC-BLl5ID-l.js +2261 -0
  13. package/dist/c4Diagram-YG6GDRKO-BOGfb13x.js +1580 -0
  14. package/dist/channel-DYeI56io.js +5 -0
  15. package/dist/chunk-4BX2VUAB-BeHGB7ON.js +8 -0
  16. package/dist/chunk-55IACEB6-DgHUzWsw.js +8 -0
  17. package/dist/chunk-B4BG7PRW-Vs7GiQMf.js +1375 -0
  18. package/dist/chunk-DI55MBZ5-CHjdGXx0.js +1370 -0
  19. package/dist/chunk-FMBD7UC4-D-H9-bHN.js +19 -0
  20. package/dist/chunk-QN33PNHL-D7uE2r1Y.js +19 -0
  21. package/dist/chunk-QZHKN3VN-Cp3sUp7e.js +15 -0
  22. package/dist/chunk-TZMSLE5B-BmXGcXo9.js +64 -0
  23. package/dist/classDiagram-2ON5EDUG-9ilqiDEi.js +16 -0
  24. package/dist/classDiagram-v2-WZHVMYZB-9ilqiDEi.js +16 -0
  25. package/dist/clone-CybyMoa0.js +8 -0
  26. package/dist/components/attention-box/attention-box.css.js +8 -0
  27. package/dist/components/auth/login-button.js +1 -1
  28. package/dist/components/auth/login-panel.d.ts +4 -0
  29. package/dist/components/auth/login-panel.js +12 -4
  30. package/dist/components/auth/oauth-login.css.js +4 -0
  31. package/dist/components/auth/oauth-login.d.ts +2 -0
  32. package/dist/components/auth/oauth-login.js +12 -3
  33. package/dist/components/brokerable.d.ts +21 -0
  34. package/dist/components/brokerable.js +39 -0
  35. package/dist/components/bundle-toolbar/bundle-toolbar.css.js +110 -0
  36. package/dist/components/bundle-toolbar/bundle-toolbar.d.ts +21 -0
  37. package/dist/components/bundle-toolbar/bundle-toolbar.js +93 -0
  38. package/dist/components/changelog/changelog.css.js +2 -0
  39. package/dist/components/changelog/changelog.d.ts +2 -0
  40. package/dist/components/changelog/changelog.js +10 -1
  41. package/dist/components/changelog/release.css.js +5 -1
  42. package/dist/components/charts/beefy-chart.js +0 -2
  43. package/dist/components/charts/doughnut-chart.d.ts +5 -1
  44. package/dist/components/charts/doughnut-chart.js +20 -1
  45. package/dist/components/credit-ticker/credit-ticker.d.ts +3 -0
  46. package/dist/components/credit-ticker/credit-ticker.js +20 -4
  47. package/dist/components/details-drawer/details-drawer.css.d.ts +2 -0
  48. package/dist/components/{problem-list → details-drawer}/details-drawer.css.js +18 -3
  49. package/dist/components/details-drawer/generic-details-drawer.css.d.ts +1 -0
  50. package/dist/components/details-drawer/generic-details-drawer.css.js +219 -0
  51. package/dist/components/details-drawer/generic-details-drawer.d.ts +38 -0
  52. package/dist/components/details-drawer/generic-details-drawer.js +245 -0
  53. package/dist/components/details-drawer/handlers/diagram-handler.d.ts +35 -0
  54. package/dist/components/details-drawer/handlers/diagram-handler.js +248 -0
  55. package/dist/components/details-drawer/handlers/documentation-handler.d.ts +11 -0
  56. package/dist/components/details-drawer/handlers/documentation-handler.js +46 -0
  57. package/dist/components/details-drawer/handlers/example-handler.d.ts +18 -0
  58. package/dist/components/details-drawer/handlers/example-handler.js +146 -0
  59. package/dist/components/details-drawer/handlers/howto-handler.d.ts +11 -0
  60. package/dist/components/details-drawer/handlers/howto-handler.js +36 -0
  61. package/dist/components/details-drawer/handlers/markdown-handler.d.ts +12 -0
  62. package/dist/components/details-drawer/handlers/markdown-handler.js +54 -0
  63. package/dist/components/editor/editor-breadcrumb.css.js +1 -1
  64. package/dist/components/editor/editor.css.js +42 -0
  65. package/dist/components/editor/editor.d.ts +29 -3
  66. package/dist/components/editor/editor.js +495 -73
  67. package/dist/components/github/github-workspace-view.css.d.ts +2 -0
  68. package/dist/components/github/github-workspace-view.css.js +165 -0
  69. package/dist/components/github/github-workspace-view.d.ts +59 -0
  70. package/dist/components/github/github-workspace-view.js +525 -0
  71. package/dist/components/global-task/global-task-view.css.d.ts +2 -0
  72. package/dist/components/global-task/global-task-view.css.js +392 -0
  73. package/dist/components/global-task/global-task-view.d.ts +48 -0
  74. package/dist/components/global-task/global-task-view.js +359 -0
  75. package/dist/components/header/header.css.js +9 -1
  76. package/dist/components/http-method/http-method.css.js +5 -1
  77. package/dist/components/indeterminate-loader/indeterminate-loader.css.d.ts +2 -0
  78. package/dist/components/indeterminate-loader/indeterminate-loader.css.js +135 -0
  79. package/dist/components/indeterminate-loader/indeterminate-loader.d.ts +35 -0
  80. package/dist/components/indeterminate-loader/indeterminate-loader.js +201 -0
  81. package/dist/components/kv-view/kv-view.css.js +2 -0
  82. package/dist/components/kv-view/kv-view.js +0 -1
  83. package/dist/components/logo-wall/logo-wall.css.js +9 -0
  84. package/dist/components/manage-ruleset/manage-ruleset.css.js +14 -1
  85. package/dist/components/manage-ruleset/manage-ruleset.d.ts +1 -0
  86. package/dist/components/manage-ruleset/manage-ruleset.js +54 -22
  87. package/dist/components/manage-ruleset/rule-action.css.js +2 -0
  88. package/dist/components/manage-ruleset/rule-action.d.ts +10 -3
  89. package/dist/components/manage-ruleset/rule-action.js +118 -129
  90. package/dist/components/manage-ruleset/rule-input.d.ts +3 -1
  91. package/dist/components/manage-ruleset/rule-input.js +38 -34
  92. package/dist/components/manage-ruleset/rule.css.js +15 -1
  93. package/dist/components/manage-ruleset/rule.d.ts +4 -1
  94. package/dist/components/manage-ruleset/rule.js +44 -17
  95. package/dist/components/mermaid/mermaid-renderer.css.d.ts +1 -0
  96. package/dist/components/mermaid/mermaid-renderer.css.js +121 -0
  97. package/dist/components/mermaid/mermaid-renderer.d.ts +75 -0
  98. package/dist/components/mermaid/mermaid-renderer.js +485 -0
  99. package/dist/components/model-icon/doctor-icon.d.ts +9 -0
  100. package/dist/components/model-icon/doctor-icon.js +60 -0
  101. package/dist/components/model-icon/model-icon.d.ts +2 -1
  102. package/dist/components/model-icon/model-icon.js +13 -1
  103. package/dist/components/model-renderer/change.css.js +22 -8
  104. package/dist/components/model-renderer/changes.d.ts +1 -0
  105. package/dist/components/model-renderer/changes.js +47 -32
  106. package/dist/components/model-renderer/clickable-ref.d.ts +9 -3
  107. package/dist/components/model-renderer/clickable-ref.js +49 -10
  108. package/dist/components/model-renderer/components.d.ts +2 -0
  109. package/dist/components/model-renderer/components.js +196 -116
  110. package/dist/components/model-renderer/contact.js +2 -2
  111. package/dist/components/model-renderer/description.css.js +2 -0
  112. package/dist/components/model-renderer/document.d.ts +1 -0
  113. package/dist/components/model-renderer/document.js +14 -9
  114. package/dist/components/model-renderer/encoding.d.ts +2 -0
  115. package/dist/components/model-renderer/encoding.js +16 -7
  116. package/dist/components/model-renderer/example.css.js +5 -1
  117. package/dist/components/model-renderer/example.d.ts +4 -1
  118. package/dist/components/model-renderer/example.js +72 -118
  119. package/dist/components/model-renderer/extensions.d.ts +2 -0
  120. package/dist/components/model-renderer/extensions.js +11 -2
  121. package/dist/components/model-renderer/external-docs.d.ts +2 -0
  122. package/dist/components/model-renderer/external-docs.js +13 -4
  123. package/dist/components/model-renderer/has-changes.js +3 -3
  124. package/dist/components/model-renderer/header.d.ts +2 -0
  125. package/dist/components/model-renderer/header.js +27 -14
  126. package/dist/components/model-renderer/info.d.ts +2 -0
  127. package/dist/components/model-renderer/info.js +20 -7
  128. package/dist/components/model-renderer/link.d.ts +2 -0
  129. package/dist/components/model-renderer/link.js +27 -10
  130. package/dist/components/model-renderer/media-type.js +2 -2
  131. package/dist/components/model-renderer/model-badge.d.ts +11 -0
  132. package/dist/components/model-renderer/model-badge.js +59 -0
  133. package/dist/components/model-renderer/model-shared.css.js +14 -2
  134. package/dist/components/model-renderer/oauth-flows.js +4 -4
  135. package/dist/components/model-renderer/operation.d.ts +2 -1
  136. package/dist/components/model-renderer/operation.js +37 -16
  137. package/dist/components/model-renderer/param-location.js +3 -3
  138. package/dist/components/model-renderer/parameter.d.ts +2 -0
  139. package/dist/components/model-renderer/parameter.js +28 -15
  140. package/dist/components/model-renderer/path-item.d.ts +3 -0
  141. package/dist/components/model-renderer/path-item.js +52 -80
  142. package/dist/components/model-renderer/paths.d.ts +2 -0
  143. package/dist/components/model-renderer/paths.js +10 -3
  144. package/dist/components/model-renderer/problem-node.js +10 -10
  145. package/dist/components/model-renderer/rendered-node.css.js +35 -6
  146. package/dist/components/model-renderer/rendered-node.d.ts +14 -4
  147. package/dist/components/model-renderer/rendered-node.js +121 -58
  148. package/dist/components/model-renderer/rendered-property.js +4 -4
  149. package/dist/components/model-renderer/request-body.d.ts +2 -0
  150. package/dist/components/model-renderer/request-body.js +16 -9
  151. package/dist/components/model-renderer/response.d.ts +2 -0
  152. package/dist/components/model-renderer/response.js +35 -17
  153. package/dist/components/model-renderer/schema.css.js +10 -1
  154. package/dist/components/model-renderer/schema.d.ts +3 -2
  155. package/dist/components/model-renderer/schema.js +127 -129
  156. package/dist/components/model-renderer/security-scheme.js +3 -3
  157. package/dist/components/model-renderer/server.js +18 -8
  158. package/dist/components/model-renderer/tag.js +1 -1
  159. package/dist/components/model-tree/tree.css.js +21 -10
  160. package/dist/components/model-tree/tree.d.ts +39 -22
  161. package/dist/components/model-tree/tree.js +230 -167
  162. package/dist/components/paginator/paginator-navigator.css.js +9 -5
  163. package/dist/components/paginator/paginator-navigator.js +6 -6
  164. package/dist/components/paginator/paginator.css.js +2 -0
  165. package/dist/components/paginator/paginator.js +5 -8
  166. package/dist/components/percent-bar/percent-bar.css.js +133 -13
  167. package/dist/components/percent-bar/percent-bar.d.ts +2 -0
  168. package/dist/components/percent-bar/percent-bar.js +28 -24
  169. package/dist/components/premium-gate/premium-gate.css.d.ts +1 -0
  170. package/dist/components/premium-gate/premium-gate.css.js +117 -0
  171. package/dist/components/premium-gate/premium-gate.d.ts +49 -0
  172. package/dist/components/premium-gate/premium-gate.js +336 -0
  173. package/dist/components/problem-list/problem-list.css.js +72 -1
  174. package/dist/components/problem-list/problem-list.d.ts +17 -9
  175. package/dist/components/problem-list/problem-list.js +222 -226
  176. package/dist/components/problem-list/problem-mainview.css.js +12 -2
  177. package/dist/components/problem-list/problem-mainview.d.ts +3 -0
  178. package/dist/components/problem-list/problem-mainview.js +37 -17
  179. package/dist/components/problem-list/problem-toolbar.css.js +10 -7
  180. package/dist/components/problems-overview/diagnostic-evaluation.css.js +11 -1
  181. package/dist/components/problems-overview/diagnostic-evaluation.js +6 -7
  182. package/dist/components/problems-overview/document-statistic.css.js +6 -0
  183. package/dist/components/problems-overview/document-statistic.js +1 -1
  184. package/dist/components/problems-overview/problem-overview-group.js +5 -5
  185. package/dist/components/problems-overview/problem-statistic.css.js +24 -5
  186. package/dist/components/problems-overview/problem-statistic.js +15 -6
  187. package/dist/components/problems-overview/problem-statistics.css.js +4 -4
  188. package/dist/components/problems-overview/problem-statistics.js +29 -25
  189. package/dist/components/problems-overview/problems-overview.css.js +2 -2
  190. package/dist/components/property-view/property-view.css.js +2 -0
  191. package/dist/components/render-json-path/render-json-path.css.js +11 -3
  192. package/dist/components/render-json-path/render-json-path.js +3 -0
  193. package/dist/components/render-operation-path/render-operation-path.css.js +9 -0
  194. package/dist/components/render-operation-path/render-operation-path.js +7 -22
  195. package/dist/components/rodeo/rodeo.d.ts +1 -0
  196. package/dist/components/rodeo/rodeo.js +5 -0
  197. package/dist/components/rodeo/roundup.js +2 -2
  198. package/dist/components/rodeo/statistic.css.js +25 -2
  199. package/dist/components/rodeo/statistic.js +0 -4
  200. package/dist/components/shader-canvas/shader-canvas.css.d.ts +2 -0
  201. package/dist/components/shader-canvas/shader-canvas.css.js +66 -0
  202. package/dist/components/shader-canvas/shader-canvas.d.ts +36 -0
  203. package/dist/components/shader-canvas/shader-canvas.js +363 -0
  204. package/dist/components/shaders/flowing-waves-shader.d.ts +2 -0
  205. package/dist/components/shaders/flowing-waves-shader.js +70 -0
  206. package/dist/components/shaders/neon-canyon-shader.d.ts +2 -0
  207. package/dist/components/shaders/neon-canyon-shader.js +265 -0
  208. package/dist/components/shaders/neon-lines-shader.d.ts +2 -0
  209. package/dist/components/shaders/neon-lines-shader.js +181 -0
  210. package/dist/components/shaders/neon-squircles-shader.d.ts +2 -0
  211. package/dist/components/shaders/neon-squircles-shader.js +56 -0
  212. package/dist/components/shaders/retro-grid-shader.d.ts +2 -0
  213. package/dist/components/shaders/retro-grid-shader.js +53 -0
  214. package/dist/components/shaders/shader-base.d.ts +9 -0
  215. package/dist/components/shaders/shader-base.js +11 -0
  216. package/dist/components/terminal/terminal-example.css.js +4 -0
  217. package/dist/components/terminal/terminal-example.js +2 -3
  218. package/dist/components/terminal-emulator/terminal-emulator.css.js +12 -2
  219. package/dist/components/terminal-emulator/terminal-emulator.d.ts +7 -1
  220. package/dist/components/terminal-emulator/terminal-emulator.js +10 -5
  221. package/dist/components/the-doctor/doctor-controls-panel.css.d.ts +2 -0
  222. package/dist/components/the-doctor/doctor-controls-panel.css.js +53 -0
  223. package/dist/components/the-doctor/doctor-controls-panel.d.ts +20 -0
  224. package/dist/components/the-doctor/doctor-controls-panel.js +78 -0
  225. package/dist/components/the-doctor/doctor-editor-panel.css.d.ts +2 -0
  226. package/dist/components/the-doctor/doctor-editor-panel.css.js +209 -0
  227. package/dist/components/the-doctor/doctor-editor-panel.d.ts +41 -0
  228. package/dist/components/the-doctor/doctor-editor-panel.js +188 -0
  229. package/dist/components/the-doctor/doctor-navigator-panel.css.d.ts +2 -0
  230. package/dist/components/the-doctor/doctor-navigator-panel.css.js +134 -0
  231. package/dist/components/the-doctor/doctor-navigator-panel.d.ts +35 -0
  232. package/dist/components/the-doctor/doctor-navigator-panel.js +117 -0
  233. package/dist/components/the-doctor/doctor-sidebar-panel.css.d.ts +2 -0
  234. package/dist/components/the-doctor/doctor-sidebar-panel.css.js +143 -0
  235. package/dist/components/the-doctor/doctor-sidebar-panel.d.ts +31 -0
  236. package/dist/components/the-doctor/doctor-sidebar-panel.js +131 -0
  237. package/dist/components/the-doctor/doctor-url-overlay.css.d.ts +2 -0
  238. package/dist/components/the-doctor/doctor-url-overlay.css.js +59 -0
  239. package/dist/components/the-doctor/doctor-url-overlay.d.ts +23 -0
  240. package/dist/components/the-doctor/doctor-url-overlay.js +82 -0
  241. package/dist/components/the-doctor/nuke-workspace.js +4 -3
  242. package/dist/components/the-doctor/settings.css.js +2 -0
  243. package/dist/components/the-doctor/settings.js +5 -8
  244. package/dist/components/the-doctor/status-bar.d.ts +2 -2
  245. package/dist/components/the-doctor/status-bar.js +32 -31
  246. package/dist/components/the-doctor/the-doctor.css.js +47 -238
  247. package/dist/components/the-doctor/the-doctor.d.ts +149 -37
  248. package/dist/components/the-doctor/the-doctor.js +958 -528
  249. package/dist/components/the-doctor/upload-archive.css.js +8 -2
  250. package/dist/components/the-doctor/upload-archive.js +2 -2
  251. package/dist/components/theme-switcher/theme-switcher.js +5 -1
  252. package/dist/components/time-vortex/change-list-item.css.js +18 -4
  253. package/dist/components/time-vortex/change-list-item.d.ts +1 -0
  254. package/dist/components/time-vortex/change-list-item.js +4 -3
  255. package/dist/components/time-vortex/history-picker.css.js +60 -1
  256. package/dist/components/time-vortex/history-picker.d.ts +7 -1
  257. package/dist/components/time-vortex/history-picker.js +109 -5
  258. package/dist/components/time-vortex/tardis-control.css.js +339 -14
  259. package/dist/components/time-vortex/tardis-control.d.ts +31 -3
  260. package/dist/components/time-vortex/tardis-control.js +296 -58
  261. package/dist/components/time-vortex/time-vortex.d.ts +8 -2
  262. package/dist/components/time-vortex/time-vortex.js +54 -13
  263. package/dist/components/toast/toast-component.css.js +1 -0
  264. package/dist/components/toast/toast-component.d.ts +1 -0
  265. package/dist/components/toast/toast-component.js +23 -8
  266. package/dist/components/toast/toast-manager.d.ts +5 -0
  267. package/dist/components/toast/toast-manager.js +29 -7
  268. package/dist/components/visualizer/edge.d.ts +11 -1
  269. package/dist/components/visualizer/edge.js +27 -22
  270. package/dist/components/visualizer/equalizer.css.js +118 -76
  271. package/dist/components/visualizer/equalizer.d.ts +24 -45
  272. package/dist/components/visualizer/equalizer.js +262 -363
  273. package/dist/components/visualizer/explorer.d.ts +94 -14
  274. package/dist/components/visualizer/explorer.js +580 -393
  275. package/dist/components/visualizer/foreign-object.d.ts +12 -2
  276. package/dist/components/visualizer/foreign-object.js +21 -10
  277. package/dist/components/visualizer/key.js +12 -1
  278. package/dist/components/visualizer/nodes/callback.d.ts +2 -1
  279. package/dist/components/visualizer/nodes/callback.js +2 -2
  280. package/dist/components/visualizer/nodes/components.d.ts +2 -1
  281. package/dist/components/visualizer/nodes/components.js +2 -2
  282. package/dist/components/visualizer/nodes/contact.d.ts +2 -1
  283. package/dist/components/visualizer/nodes/contact.js +2 -2
  284. package/dist/components/visualizer/nodes/document.d.ts +2 -1
  285. package/dist/components/visualizer/nodes/document.js +2 -2
  286. package/dist/components/visualizer/nodes/graph-node.d.ts +14 -3
  287. package/dist/components/visualizer/nodes/graph-node.js +94 -43
  288. package/dist/components/visualizer/nodes/header.d.ts +2 -1
  289. package/dist/components/visualizer/nodes/header.js +2 -2
  290. package/dist/components/visualizer/nodes/info.d.ts +2 -1
  291. package/dist/components/visualizer/nodes/info.js +2 -2
  292. package/dist/components/visualizer/nodes/license.d.ts +2 -1
  293. package/dist/components/visualizer/nodes/license.js +2 -2
  294. package/dist/components/visualizer/nodes/link.d.ts +2 -1
  295. package/dist/components/visualizer/nodes/link.js +2 -2
  296. package/dist/components/visualizer/nodes/media-type.d.ts +2 -1
  297. package/dist/components/visualizer/nodes/media-type.js +2 -2
  298. package/dist/components/visualizer/nodes/operation.d.ts +2 -1
  299. package/dist/components/visualizer/nodes/operation.js +3 -4
  300. package/dist/components/visualizer/nodes/parameter.d.ts +3 -1
  301. package/dist/components/visualizer/nodes/parameter.js +3 -4
  302. package/dist/components/visualizer/nodes/path-item.d.ts +2 -1
  303. package/dist/components/visualizer/nodes/path-item.js +2 -2
  304. package/dist/components/visualizer/nodes/request-body.d.ts +2 -1
  305. package/dist/components/visualizer/nodes/request-body.js +2 -2
  306. package/dist/components/visualizer/nodes/response.d.ts +2 -1
  307. package/dist/components/visualizer/nodes/response.js +2 -2
  308. package/dist/components/visualizer/nodes/schema.d.ts +2 -1
  309. package/dist/components/visualizer/nodes/schema.js +64 -9
  310. package/dist/components/visualizer/nodes/security-scheme.d.ts +2 -1
  311. package/dist/components/visualizer/nodes/security-scheme.js +2 -2
  312. package/dist/components/visualizer/nodes/server.d.ts +2 -1
  313. package/dist/components/visualizer/nodes/server.js +3 -4
  314. package/dist/components/visualizer/nodes/tag.d.ts +2 -1
  315. package/dist/components/visualizer/nodes/tag.js +4 -5
  316. package/dist/components/visualizer/nodes/xml.d.ts +2 -1
  317. package/dist/components/visualizer/nodes/xml.js +2 -2
  318. package/dist/components/visualizer/orientation-controls.d.ts +6 -1
  319. package/dist/components/visualizer/orientation-controls.js +65 -7
  320. package/dist/components/visualizer/search.d.ts +2 -1
  321. package/dist/components/visualizer/search.js +22 -29
  322. package/dist/components/visualizer/shared.css.js +55 -18
  323. package/dist/components/visualizer/templates/svg-markers.d.ts +2 -0
  324. package/dist/components/visualizer/templates/svg-markers.js +73 -0
  325. package/dist/components/waiting-line/waiting-line.css.d.ts +2 -0
  326. package/dist/components/waiting-line/waiting-line.css.js +26 -0
  327. package/dist/components/waiting-line/waiting-line.d.ts +30 -0
  328. package/dist/components/waiting-line/waiting-line.js +424 -0
  329. package/dist/components/workspaces/workspace-view.css.js +89 -8
  330. package/dist/components/workspaces/workspace-view.d.ts +8 -1
  331. package/dist/components/workspaces/workspace-view.js +77 -25
  332. package/dist/controllers/auth-controller.d.ts +9 -0
  333. package/dist/controllers/auth-controller.js +12 -5
  334. package/dist/controllers/broker-controller.d.ts +30 -4
  335. package/dist/controllers/broker-controller.js +148 -25
  336. package/dist/controllers/bundle-controller.d.ts +21 -0
  337. package/dist/controllers/bundle-controller.js +122 -0
  338. package/dist/controllers/countdown-controller.d.ts +17 -0
  339. package/dist/controllers/countdown-controller.js +59 -0
  340. package/dist/controllers/diagnostic-controller.d.ts +18 -5
  341. package/dist/controllers/diagnostic-controller.js +206 -218
  342. package/dist/controllers/diagramatron-controller.d.ts +33 -0
  343. package/dist/controllers/diagramatron-controller.js +128 -0
  344. package/dist/controllers/docs-controller.d.ts +11 -5
  345. package/dist/controllers/docs-controller.js +97 -97
  346. package/dist/controllers/github-controller.d.ts +47 -0
  347. package/dist/controllers/github-controller.js +494 -0
  348. package/dist/controllers/global-task-controller.d.ts +46 -0
  349. package/dist/controllers/global-task-controller.js +352 -0
  350. package/dist/controllers/model-controller.d.ts +26 -4
  351. package/dist/controllers/model-controller.js +98 -62
  352. package/dist/controllers/node-clicker-controller.d.ts +121 -4
  353. package/dist/controllers/node-clicker-controller.js +526 -253
  354. package/dist/controllers/problem-controller.d.ts +11 -4
  355. package/dist/controllers/problem-controller.js +98 -39
  356. package/dist/controllers/rolodex-controller.d.ts +8 -3
  357. package/dist/controllers/rolodex-controller.js +117 -83
  358. package/dist/controllers/rule-controller.d.ts +12 -5
  359. package/dist/controllers/rule-controller.js +154 -161
  360. package/dist/controllers/spec-controller.d.ts +16 -4
  361. package/dist/controllers/spec-controller.js +91 -62
  362. package/dist/controllers/state-controller.d.ts +4 -3
  363. package/dist/controllers/state-controller.js +201 -154
  364. package/dist/controllers/tab-cache-controller.d.ts +29 -0
  365. package/dist/controllers/tab-cache-controller.js +68 -0
  366. package/dist/controllers/timeline-controller.d.ts +18 -0
  367. package/dist/controllers/timeline-controller.js +129 -0
  368. package/dist/controllers/wallet-controller.d.ts +3 -3
  369. package/dist/controllers/wallet-controller.js +22 -41
  370. package/dist/controllers/workspace-controller.d.ts +10 -4
  371. package/dist/controllers/workspace-controller.js +67 -22
  372. package/dist/cose-bilkent-S5V4N54A-2TG-C-n3.js +2608 -0
  373. package/dist/cowboy-components-BcyXo9oX.js +68425 -0
  374. package/dist/cowboy-components.css +1 -0
  375. package/dist/cowboy-components.umd.cjs +14050 -6577
  376. package/dist/css/alerts.css.js +2 -0
  377. package/dist/css/badges.css.js +2 -0
  378. package/dist/css/button.css.js +34 -1
  379. package/dist/css/cowboy-components.css +34 -0
  380. package/dist/css/dialog.css.js +11 -2
  381. package/dist/css/filter.css.js +17 -5
  382. package/dist/css/forms.css.js +14 -0
  383. package/dist/css/pb33f-theme.css +87 -16
  384. package/dist/css/syntax.css.js +5 -0
  385. package/dist/css/tabs.css.js +19 -2
  386. package/dist/css/tooltip.css.js +4 -0
  387. package/dist/cytoscape.esm-DfdJODL8.js +18735 -0
  388. package/dist/dagre-6UL2VRFP-BIlmTbhO.js +444 -0
  389. package/dist/defaultLocale-D7EN2tov.js +171 -0
  390. package/dist/diagram-PSM6KHXK-CeWby24E.js +531 -0
  391. package/dist/diagram-QEK2KX5R-DGonyVCK.js +217 -0
  392. package/dist/diagram-S2PKOQOG-mGn-y1uX.js +142 -0
  393. package/dist/erDiagram-Q2GNP2WA-BlBBw4Mz.js +841 -0
  394. package/dist/events/doctor.d.ts +63 -9
  395. package/dist/events/doctor.js +29 -1
  396. package/dist/events/drawer-events.d.ts +7 -0
  397. package/dist/events/drawer-events.js +3 -0
  398. package/dist/events/theme.d.ts +4 -0
  399. package/dist/events/theme.js +1 -0
  400. package/dist/factories/explorer-component-factory.d.ts +49 -0
  401. package/dist/factories/explorer-component-factory.js +205 -0
  402. package/dist/factories/state-controller-deps.factory.d.ts +88 -0
  403. package/dist/factories/state-controller-deps.factory.js +116 -0
  404. package/dist/flowDiagram-NV44I4VS-BlLzzy1C.js +1620 -0
  405. package/dist/ganttDiagram-LVOFAZNH-BoQtPC8k.js +2505 -0
  406. package/dist/gitGraph-F6HP7TQM-CShNSlrW.js +5 -0
  407. package/dist/gitGraphDiagram-NY62KEGX-BdpWBgHy.js +699 -0
  408. package/dist/graph-D9HS4Ahd.js +247 -0
  409. package/dist/helpers/event-wiring.d.ts +72 -0
  410. package/dist/helpers/event-wiring.js +58 -0
  411. package/dist/helpers/file-size-formatter.d.ts +3 -0
  412. package/dist/helpers/file-size-formatter.js +15 -0
  413. package/dist/helpers/filename-colorizer.d.ts +5 -0
  414. package/dist/helpers/filename-colorizer.js +30 -0
  415. package/dist/helpers/navigation-helper.d.ts +54 -0
  416. package/dist/helpers/navigation-helper.js +159 -0
  417. package/dist/helpers/typed-events.d.ts +1 -0
  418. package/dist/helpers/typed-events.js +3 -0
  419. package/dist/info-NVLQJR56-Bpi6I8up.js +5 -0
  420. package/dist/infoDiagram-F6ZHWCRC-DmhhbuMJ.js +24 -0
  421. package/dist/init-DjUOC4st.js +16 -0
  422. package/dist/interfaces/bundle-interfaces.d.ts +7 -0
  423. package/dist/interfaces/bundle-interfaces.js +1 -0
  424. package/dist/interfaces/doctor-interfaces.d.ts +506 -0
  425. package/dist/interfaces/doctor-interfaces.js +1 -0
  426. package/dist/journeyDiagram-XKPGCS4Q-CpkhK8vl.js +834 -0
  427. package/dist/kanban-definition-3W4ZIXB7-BFbucfYE.js +719 -0
  428. package/dist/katex-SsTUIUTC.js +11688 -0
  429. package/dist/layout-B8H1_UrM.js +1324 -0
  430. package/dist/linear-Bo0rJUSQ.js +259 -0
  431. package/dist/managers/drag-handler.d.ts +28 -0
  432. package/dist/managers/drag-handler.js +64 -0
  433. package/dist/managers/event-registration-manager.d.ts +17 -0
  434. package/dist/managers/event-registration-manager.js +34 -0
  435. package/dist/managers/expansion-manager.d.ts +58 -0
  436. package/dist/managers/expansion-manager.js +189 -0
  437. package/dist/managers/layout-filter-manager.d.ts +31 -0
  438. package/dist/managers/layout-filter-manager.js +109 -0
  439. package/dist/managers/panel-divider-manager.d.ts +33 -0
  440. package/dist/managers/panel-divider-manager.js +71 -0
  441. package/dist/managers/view-state-manager.d.ts +48 -0
  442. package/dist/managers/view-state-manager.js +101 -0
  443. package/dist/managers/viewport-manager.d.ts +53 -0
  444. package/dist/managers/viewport-manager.js +198 -0
  445. package/dist/mermaid-parser.core-BPror82d.js +12966 -0
  446. package/dist/mindmap-definition-VGOIOE7T-VAn-EShH.js +784 -0
  447. package/dist/mocks/task-mock-generator.d.ts +13 -0
  448. package/dist/mocks/task-mock-generator.js +200 -0
  449. package/dist/model/api-response.d.ts +2 -7
  450. package/dist/model/api-response.js +0 -2
  451. package/dist/model/bundle.d.ts +35 -0
  452. package/dist/model/bundle.js +1 -0
  453. package/dist/model/channels.d.ts +8 -1
  454. package/dist/model/channels.js +7 -0
  455. package/dist/model/drawer-content.d.ts +80 -0
  456. package/dist/model/drawer-content.js +14 -0
  457. package/dist/model/formable.js +22 -11
  458. package/dist/model/github.d.ts +125 -0
  459. package/dist/model/github.js +1 -0
  460. package/dist/model/graph.d.ts +15 -15
  461. package/dist/model/graph.js +24 -4
  462. package/dist/model/media-type.js +2 -2
  463. package/dist/model/node_type.d.ts +4 -0
  464. package/dist/model/node_type.js +4 -0
  465. package/dist/model/panel-state.d.ts +1 -0
  466. package/dist/model/rolodex.d.ts +3 -0
  467. package/dist/model/task.d.ts +50 -0
  468. package/dist/model/task.js +22 -0
  469. package/dist/model/timeline.d.ts +107 -1
  470. package/dist/model/tree-icon-config.d.ts +11 -0
  471. package/dist/model/tree-icon-config.js +46 -0
  472. package/dist/model/workspace.d.ts +2 -0
  473. package/dist/monacoeditorwork/css.worker.bundle.js +9 -7
  474. package/dist/monacoeditorwork/editor.worker.bundle.js +2 -0
  475. package/dist/monacoeditorwork/html.worker.bundle.js +9 -7
  476. package/dist/monacoeditorwork/json.worker.bundle.js +9 -7
  477. package/dist/monacoeditorwork/yaml.worker..bundle.js +72 -48
  478. package/dist/ordinal-DfAQgscy.js +61 -0
  479. package/dist/packet-BFZMPI3H-CXPCK9Q2.js +5 -0
  480. package/dist/pie-7BOR55EZ-CMcuUZ_S.js +5 -0
  481. package/dist/pieDiagram-ADFJNKIX-C0kdlQqn.js +161 -0
  482. package/dist/quadrantDiagram-AYHSOK5B-CRVq6wY3.js +1022 -0
  483. package/dist/radar-NHE76QYJ-CX_Gyp4h.js +5 -0
  484. package/dist/requirementDiagram-UZGBJVZJ-B8ZGgMKn.js +850 -0
  485. package/dist/sankeyDiagram-TZEHDZUN-CWAUJJue.js +810 -0
  486. package/dist/sequenceDiagram-WL72ISMW-nz81a4Cq.js +2511 -0
  487. package/dist/services/diagramatron-service.d.ts +20 -0
  488. package/dist/services/diagramatron-service.js +48 -0
  489. package/dist/services/doctor-events.d.ts +58 -0
  490. package/dist/services/doctor-events.js +33 -0
  491. package/dist/services/drawer-content-registry.d.ts +9 -0
  492. package/dist/services/drawer-content-registry.js +37 -0
  493. package/dist/services/github-service.d.ts +9 -0
  494. package/dist/services/github-service.js +166 -0
  495. package/dist/services/global-task-service.d.ts +6 -0
  496. package/dist/services/global-task-service.js +27 -0
  497. package/dist/services/header-service.d.ts +5 -3
  498. package/dist/services/header-service.js +13 -0
  499. package/dist/services/linting-service.d.ts +2 -0
  500. package/dist/services/linting-service.js +19 -2
  501. package/dist/services/mermaid-config-service.d.ts +53 -0
  502. package/dist/services/mermaid-config-service.js +519 -0
  503. package/dist/services/model-service.d.ts +12 -7
  504. package/dist/services/model-service.js +64 -11
  505. package/dist/services/rodeo-service.js +12 -12
  506. package/dist/services/timeline-service.d.ts +12 -2
  507. package/dist/services/timeline-service.js +329 -0
  508. package/dist/services/wallet-service.d.ts +1 -1
  509. package/dist/services/wallet-service.js +4 -1
  510. package/dist/services/workspace-service.js +16 -2
  511. package/dist/stateDiagram-FKZM4ZOC-3PFzJlcG.js +263 -0
  512. package/dist/stateDiagram-v2-4FDKWEC3-Bp46vM6_.js +16 -0
  513. package/dist/timeline-definition-IT6M3QCI-utm7jTLb.js +795 -0
  514. package/dist/treemap-KMMF4GRG-BvEKHn43.js +5 -0
  515. package/dist/utils/language-utils.d.ts +1 -0
  516. package/dist/utils/language-utils.js +23 -0
  517. package/dist/utils/lru-cache.d.ts +11 -0
  518. package/dist/utils/lru-cache.js +38 -0
  519. package/dist/utils/node-helpers.d.ts +6 -0
  520. package/dist/utils/node-helpers.js +62 -0
  521. package/dist/utils/path-utils.d.ts +5 -0
  522. package/dist/utils/path-utils.js +22 -0
  523. package/dist/workers/elk-layout.worker.d.ts +2 -0
  524. package/dist/workers/elk-layout.worker.js +31 -0
  525. package/dist/workers/equalizer.worker.d.ts +6 -1
  526. package/dist/workers/equalizer.worker.js +144 -195
  527. package/dist/workers/graph-dependent.worker.js +6 -6
  528. package/dist/workers/rule-documentation.worker.js +12 -48
  529. package/dist/workers/search-graph.worker.js +8 -23
  530. package/dist/xychartDiagram-PRI3JC2R-twqDKWMX.js +1340 -0
  531. package/package.json +17 -10
  532. package/dist/assets/equalizer.worker-DyLD5JTU.js +0 -1
  533. package/dist/assets/graph-dependent.worker-CpVhp0-T.js +0 -1
  534. package/dist/assets/rule-documentation.worker-B7xOWY5M.js +0 -1
  535. package/dist/assets/search-graph.worker-B9zqINrO.js +0 -1
  536. package/dist/assets/search-problems.worker-BAF8L2rX.js +0 -1
  537. package/dist/components/problem-list/details-drawer.d.ts +0 -34
  538. package/dist/components/problem-list/details-drawer.js +0 -200
  539. package/dist/style.css +0 -1
  540. /package/dist/components/{problem-list/details-drawer.css.d.ts → bundle-toolbar/bundle-toolbar.css.d.ts} +0 -0
@@ -4,8 +4,10 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
4
4
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
5
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
6
  };
7
- import { customElement, query, state } from "lit/decorators.js";
7
+ import { customElement, property, query, state } from "lit/decorators.js";
8
8
  import { html } from "lit";
9
+ import { unsafeHTML } from "lit/directives/unsafe-html.js";
10
+ import { keyed } from "lit/directives/keyed.js";
9
11
  import tardisControlCss from "./tardis-control.css";
10
12
  import { TimelineService } from "../../services/timeline-service.js";
11
13
  import { ChangesComponent } from "../model-renderer/changes.js";
@@ -19,26 +21,91 @@ import { TimelineView } from "./timeline-view.js";
19
21
  import panelsCss from "../../css/panels.css.js";
20
22
  import scrollbarCss from "../../css/scrollbar.css.js";
21
23
  import { ToastType } from "../../model/toast.js";
22
- import { AddToast, ExplorerNodeClicked, LoadRenderedNodeIntoInspector } from "../../events/doctor.js";
23
- import '../charts/beefy-chart';
24
+ import { AddToast, ExplorerNodeClicked, LoadRenderedNodeIntoInspector, ShowTimelineSummary } from "../../events/doctor.js";
25
+ import { CountdownController } from "../../controllers/countdown-controller.js";
26
+ import '../charts/beefy-chart.js';
24
27
  import '../charts/doughnut-chart.js';
25
28
  import './change-list-item.js';
29
+ import { ModelTree } from "../model-tree/tree.js";
30
+ import Prism from "prismjs";
31
+ import 'prismjs/components/prism-yaml';
32
+ import 'prismjs/components/prism-json';
33
+ import prismCss from "../../css/prism.css.js";
34
+ import chromaSyntaxCss from "../../css/chroma-synxtax.css.js";
35
+ import changelogCss from "../changelog/changelog.css.js";
36
+ import hrCss from "../../css/hr.css.js";
37
+ import buttonCss from "../../css/button.css.js";
26
38
  let TardisControl = class TardisControl extends Colorful {
27
39
  constructor() {
28
40
  super();
29
- this.explorer = new ExplorerComponent();
30
- this.explorer.renderEqualizer = false;
31
- this.explorer.equalizer.renderEqualizer = false;
41
+ this.markdownReport = '';
42
+ this.mdDownloadLoading = false;
43
+ this._changeLabels = ['MODIFIED', 'ADDED', 'REMOVED'];
44
+ this._breakingLabels = ['BREAKING', 'NON-BREAKING'];
45
+ this._changeDataset = [];
46
+ this._breakingDataset = [];
47
+ this._lastSpecSummaryId = null;
48
+ // Doc will be set via property binding
49
+ this.explorer = null; // Will be initialized when doc is set
32
50
  this.timelineView = new TimelineView();
51
+ this.modelTree = new ModelTree();
52
+ this.modelTree.changesEnabled = true;
33
53
  this.loading = false;
34
- //@ts-ignore
35
- this.addEventListener(ExplorerNodeClicked, this.explorerNodeClicked.bind(this));
54
+ this.boundExplorerNodeClicked = this.explorerNodeClicked.bind(this);
55
+ this.addEventListener(ExplorerNodeClicked, this.boundExplorerNodeClicked);
56
+ }
57
+ connectedCallback() {
58
+ super.connectedCallback();
59
+ if (this.diffEditor) {
60
+ this.diffEditor.diffMode = true;
61
+ }
62
+ }
63
+ disconnectedCallback() {
64
+ super.disconnectedCallback();
65
+ if (this._highlightTimeout) {
66
+ clearTimeout(this._highlightTimeout);
67
+ }
68
+ if (this.countdownController) {
69
+ this.countdownController.stop();
70
+ this.countdownController = undefined;
71
+ }
72
+ this.removeEventListener(ExplorerNodeClicked, this.boundExplorerNodeClicked);
73
+ }
74
+ handleEphemeralExpired() {
75
+ if (this.countdownController) {
76
+ this.countdownController.stop();
77
+ this.countdownController = undefined;
78
+ }
79
+ this.dispatchEvent(new Event(ShowTimelineSummary, {
80
+ bubbles: true,
81
+ composed: true,
82
+ }));
83
+ }
84
+ firstUpdated() {
85
+ // Don't auto-fetch - let the doctor control when we start
86
+ // The doctor will call fetchHistory() when it's ready
87
+ // Enable diff mode on the diff editor once it's set
88
+ setTimeout(() => {
89
+ if (this.diffEditor) {
90
+ this.diffEditor.diffMode = true;
91
+ // Content will be populated when user selects a change
92
+ }
93
+ }, 100);
94
+ }
95
+ updated(changedProperties) {
96
+ super.updated(changedProperties);
97
+ if (changedProperties.has('doc') && this.doc && !this.explorer) {
98
+ this.explorer = new ExplorerComponent(this.doc);
99
+ this.explorer.renderEqualizer = false;
100
+ this.explorer.equalizer.renderEqualizer = false;
101
+ this.explorer.embeddedMode = true;
102
+ }
36
103
  }
37
104
  explorerNodeClicked(evt) {
38
105
  evt.stopPropagation();
39
106
  // we only have a select number of nodes for this change, so instead of bubbling up to the doctor
40
- if (this.changeReport) {
41
- this.changeReport.nodesRendered.forEach((node) => {
107
+ if (this.doc.modelController.changeReport) {
108
+ this.doc.modelController.changeReport.nodes.forEach((node) => {
42
109
  if (node.id == evt.detail.nodeId) {
43
110
  // load up this rendered node and send to the inspector panel for rendering.
44
111
  this.dispatchEvent(new CustomEvent(LoadRenderedNodeIntoInspector, {
@@ -49,11 +116,62 @@ let TardisControl = class TardisControl extends Colorful {
49
116
  }
50
117
  }));
51
118
  this.explorer.activeNode = node;
52
- this.explorer.buildLayout();
119
+ this.explorer.buildGraph();
53
120
  }
54
121
  });
55
122
  }
56
123
  }
124
+ highlightCodeBlocks() {
125
+ const codeBlocks = this.shadowRoot?.querySelectorAll('pre code');
126
+ if (codeBlocks) {
127
+ codeBlocks.forEach((block) => {
128
+ Prism.highlightElement(block);
129
+ });
130
+ }
131
+ }
132
+ downloadFile(content, filename, mimeType) {
133
+ const blob = new Blob([content], { type: mimeType });
134
+ const url = URL.createObjectURL(blob);
135
+ const a = document.createElement('a');
136
+ a.href = url;
137
+ a.download = filename;
138
+ document.body.appendChild(a);
139
+ a.click();
140
+ document.body.removeChild(a);
141
+ setTimeout(() => URL.revokeObjectURL(url), 1000);
142
+ }
143
+ downloadHtmlReport() {
144
+ if (!this.markdownReport)
145
+ return;
146
+ this.downloadFile(this.markdownReport, 'report.html', 'text/html');
147
+ }
148
+ async downloadMarkdownReport() {
149
+ if (!this.specSummary?.changeId)
150
+ return;
151
+ this.mdDownloadLoading = true;
152
+ try {
153
+ const markdown = await TimelineService.fetchMarkdownSource(this.specSummary.changeId);
154
+ this.downloadFile(markdown, 'report.md', 'text/markdown');
155
+ }
156
+ catch (e) {
157
+ const errorMsg = e?.detail || e?.message || 'Unknown error';
158
+ this.dispatchEvent(new CustomEvent(AddToast, {
159
+ bubbles: true,
160
+ composed: true,
161
+ detail: {
162
+ toast: {
163
+ type: ToastType.ERROR,
164
+ id: "md-download-error",
165
+ body: `Failed to download markdown report: ${errorMsg}`,
166
+ title: "Download failed",
167
+ }
168
+ }
169
+ }));
170
+ }
171
+ finally {
172
+ this.mdDownloadLoading = false;
173
+ }
174
+ }
57
175
  fetchHistory() {
58
176
  this.loading = true;
59
177
  TimelineService.fetchHistory().then((history) => {
@@ -81,35 +199,41 @@ let TardisControl = class TardisControl extends Colorful {
81
199
  type: ToastType.ERROR,
82
200
  id: "timeline-error",
83
201
  body: e.detail,
84
- title: "timeline error",
202
+ title: "timeline error yeah!",
85
203
  }
86
204
  }
87
205
  }));
88
206
  });
89
207
  }
90
- renderSummaryForMultiChange() {
91
- if (this.specSummary?.totalChanges <= 1) {
92
- return html ``;
208
+ updateChartData() {
209
+ const currentId = this.specSummary?.changeId ?? null;
210
+ if (currentId === this._lastSpecSummaryId) {
211
+ return;
93
212
  }
94
- const labels = ['Modified', 'Added', 'Removed'];
95
- const breakingLabels = ['Breaking', 'Non-Breaking'];
96
- const dataSet = [
213
+ this._lastSpecSummaryId = currentId;
214
+ this._changeDataset = [
97
215
  {
98
- labels: labels,
216
+ labels: this._changeLabels,
99
217
  data: [this.specSummary?.modifications, this.specSummary?.additions, this.specSummary?.removals]
100
218
  }
101
219
  ];
102
- const breakingDataSet = [
220
+ this._breakingDataset = [
103
221
  {
104
- labels: breakingLabels,
222
+ labels: this._breakingLabels,
105
223
  data: [this.specSummary?.breakingChanges, this.specSummary?.totalChanges]
106
224
  }
107
225
  ];
226
+ }
227
+ renderSummaryForMultiChange() {
228
+ if (this.specSummary?.totalChanges <= 1) {
229
+ return html ``;
230
+ }
231
+ this.updateChartData();
108
232
  let breakingChart = html ``;
109
233
  if (this.specSummary?.totalChanges > 1) {
110
234
  breakingChart = html `
111
235
  <pb33f-doughnut-chart id="breaking-doughnut" showLegend breakingChanges width=290 height=130
112
- .datasets=${breakingDataSet} .labels=${breakingLabels}
236
+ .datasets=${this._breakingDataset} .labels=${this._breakingLabels}
113
237
  style="padding-left: 10px; padding-top: 10px"></pb33f-doughnut-chart>`;
114
238
  }
115
239
  const timelineItem = new SpecSummaryTimelineItem();
@@ -119,9 +243,9 @@ let TardisControl = class TardisControl extends Colorful {
119
243
  }
120
244
  return html `
121
245
 
122
- <div style="width:100%; padding: 10px; display: flex">
246
+ <div style="width:100%; padding: 10px; display: flex; justify-content: center">
123
247
  <pb33f-doughnut-chart id="change-doughnut" showLegend changesChart width=290 height=130
124
- .datasets=${dataSet} .labels=${labels}
248
+ .datasets=${this._changeDataset} .labels=${this._changeLabels}
125
249
  style="padding-left: 10px; padding-top: 10px"></pb33f-doughnut-chart>
126
250
  ${breakingChart}
127
251
  </div>
@@ -140,7 +264,7 @@ let TardisControl = class TardisControl extends Colorful {
140
264
 
141
265
 
142
266
  </div>`;
143
- if (!this.changeReport && !this.history) {
267
+ if (!this.doc.modelController.changeReport && !this.history) {
144
268
  return html `
145
269
  <div class="pb33f-loader">
146
270
  <div class="spin"></div>
@@ -149,7 +273,7 @@ let TardisControl = class TardisControl extends Colorful {
149
273
  <div style="padding-left: 38px;">(Make some changes / edits to the OpenAPI Spec)</div>
150
274
  </div>`;
151
275
  }
152
- if (!this.changeReport && this.history) {
276
+ if (!this.doc.modelController.changeReport && this.history) {
153
277
  return html `
154
278
  ${this.loading ? loading : ''}
155
279
  <div class="timeline-view">
@@ -158,9 +282,9 @@ let TardisControl = class TardisControl extends Colorful {
158
282
  `;
159
283
  }
160
284
  let changelist = [];
161
- this.changeReport?.changes?.forEach(change => {
285
+ this.doc.modelController.changeReport?.changes?.forEach(change => {
162
286
  const ch = new ChangesComponent([change]);
163
- ch.addPadding = true;
287
+ //ch.addPadding = true
164
288
  ch.renderChangeCountBar = false;
165
289
  ch.renderBreakingBar = true;
166
290
  ch.renderMeta = true;
@@ -173,23 +297,54 @@ let TardisControl = class TardisControl extends Colorful {
173
297
  this.breakingDoughnut?.refresh();
174
298
  }
175
299
  const userTimeZone = Intl.DateTimeFormat().resolvedOptions().timeZone;
300
+ // locate the root node from the changeReport nodes
301
+ let rootNode = null;
302
+ if (this.doc.modelController.changeReport && this.doc.modelController.changeReport.nodes) {
303
+ for (let i = 0; i < this.doc.modelController.changeReport.nodes.length; i++) {
304
+ if (this.doc.modelController.changeReport.nodes[i].id == 'root') {
305
+ rootNode = this.doc.modelController.changeReport.nodes[i];
306
+ break;
307
+ }
308
+ }
309
+ }
310
+ this.modelTree.expand = true;
311
+ this.modelTree.node = rootNode;
312
+ //<pb33f-model-tree expand .node=${rootNode}
313
+ // class="change-tree" style="padding-top: 10px;"></pb33f-model-tree>
176
314
  const changeTreeContainer = html `
177
315
  <div class="change-tree-container scroller" slot="start">
178
- <pb33f-model-tree expand .node=${this.changeReport?.nodeChangeTree}
179
- class="change-tree" style="padding-top: 10px;"></pb33f-model-tree>
316
+ ${this.modelTree}
180
317
  </div>`;
181
318
  let changesView = html `${changeTreeContainer}`;
182
- if (this.changeReport && this.changeReport.changes && this.changeReport.changes?.length > 1) {
319
+ if (this.doc.modelController.changeReport &&
320
+ this.doc.modelController.changeReport.changes &&
321
+ this.doc.modelController.changeReport.changes?.length > 1) {
183
322
  changesView = html `
184
323
  <sl-split-panel position-in-pixels="350" id="tardis-change-navigator-split-panel"
185
324
  class="tardis-change-navigator-split-panel">
186
325
  <sl-icon id="split-divider" slot="divider" name="grip-vertical"
187
- class="divider-vert"></sl-icon>
326
+ class="divider-vert" aria-hidden="true"></sl-icon>
188
327
 
189
328
  ${changeTreeContainer}
190
329
  <div style="position: relative; width: 100%" slot="end"> ${changeSummary}</div>
191
330
  </sl-split-panel>`;
192
331
  }
332
+ const isPr = this.specSummary?.gitPrNumber !== undefined && this.specSummary.gitPrNumber !== null;
333
+ const isEphemeral = this.specSummary?.isEphemeral !== undefined && this.specSummary.isEphemeral;
334
+ let warningBanner = html ``;
335
+ if (isPr) {
336
+ warningBanner = html `
337
+ <div class="pr-banner">
338
+ PR: <a href="${this.specSummary?.gitPrUrl}" class="pr-url" target="_blank">#${this.specSummary?.gitPrNumber}: ${this.specSummary?.gitPrTitle}</a>
339
+ </div>`;
340
+ }
341
+ if (!isPr && isEphemeral && this.countdownController && !this.countdownController.isExpired) {
342
+ const criticalClass = this.countdownController.isCritical ? 'critical' : '';
343
+ warningBanner = html `
344
+ <div class="warn-banner ${criticalClass}">
345
+ <strong>Temporary Comparison:</strong> ${this.countdownController.formattedTime} before deletion
346
+ </div>`;
347
+ }
193
348
  return html `
194
349
  ${this.loading ? loading : ''}
195
350
  <header>
@@ -204,26 +359,60 @@ let TardisControl = class TardisControl extends Colorful {
204
359
  <div class="changes-container">
205
360
 
206
361
  <sl-split-panel position-in-pixels="300" vertical id="tardis-split-panel" class="tardis-split-panel">
207
- <sl-icon id="split-divider" slot="divider" name="grip-horizontal" class="divider-horiz"></sl-icon>
362
+ <sl-icon id="split-divider" slot="divider" name="grip-horizontal" class="divider-horiz" aria-hidden="true"></sl-icon>
208
363
  <div class="editor" slot="start">
209
-
210
-
211
364
  <div class="change-navigator">
212
365
  ${changesView}
213
366
  </div>
214
367
  </div>
215
- <div class="editor" slot="end">
216
-
368
+ <div class="editor" slot="end" style="overflow: hidden; height: 100%; z-index: 1">
369
+ ${warningBanner}
217
370
  <sl-tab-group class="tab-group time-vortex">
371
+ <sl-tab slot="nav" panel="report" class="tab" id="report-view">
372
+ Change Report
373
+ </sl-tab>
218
374
  <sl-tab slot="nav" panel="changelist" class="tab" id="changelist-view">
219
- Changelog
375
+ Changed Items
376
+ </sl-tab>
377
+ <sl-tab slot="nav" panel="list" class="tab" id="list-view">
378
+ Change List
220
379
  </sl-tab>
221
380
  <sl-tab slot="nav" panel="graph" class="tab" id="graph-view">
222
381
  Explore Changes
223
382
  </sl-tab>
224
- <sl-tab slot="nav" panel="list" class="tab" id="list-view">
225
- List
383
+ <sl-tab slot="nav" panel="diff" class="tab" id="diff-view">
384
+ View Diff
226
385
  </sl-tab>
386
+
387
+ <sl-tab-panel name="report" class="tab-panel">
388
+ ${this.specSummary?.changeId ? html `
389
+ <div class="report-download-controls">
390
+ <sl-button
391
+ class="slim"
392
+ size="small"
393
+ variant="default"
394
+ ?disabled=${!this.markdownReport}
395
+ @click=${this.downloadHtmlReport}>
396
+ <sl-icon slot="prefix" name="download" aria-hidden="true"></sl-icon>
397
+ HTML
398
+ </sl-button>
399
+ <sl-button
400
+ class="slim"
401
+ size="small"
402
+ variant="default"
403
+ ?loading=${this.mdDownloadLoading}
404
+ @click=${this.downloadMarkdownReport}>
405
+ <sl-icon slot="prefix" name="download" aria-hidden="true"></sl-icon>
406
+ MD
407
+ </sl-button>
408
+ </div>
409
+ ` : html ``}
410
+ <div class="markdown-report">
411
+ ${this.specSummary?.changeId ?
412
+ keyed(this.specSummary.changeId, html `${this.markdownReport ? unsafeHTML(this.markdownReport) : html `<div class="pb33f-loader"><div class="spin"></div>Loading report...</div>`}`)
413
+ : html ``}
414
+ </div>
415
+ </sl-tab-panel>
227
416
  <sl-tab-panel name="changelist" class="tab-panel changelist-panel">
228
417
  <div class="change-list">
229
418
  <pb33f-paginator-navigation label="Changes" hideSparks
@@ -234,26 +423,66 @@ let TardisControl = class TardisControl extends Colorful {
234
423
  ${this.explorer}
235
424
  </sl-tab-panel>
236
425
  <sl-tab-panel name="list" class="tab-panel">
237
- <pb33f-change-list .changes=${this.changeReport?.changes}></pb33f-change-list>
426
+ <pb33f-change-list
427
+ .changes=${this.doc.modelController.changeReport?.changes}></pb33f-change-list>
428
+ </sl-tab-panel>
429
+ <sl-tab-panel name="diff" class="tab-panel">
430
+ <!-- EDITOR -->
431
+ <slot name="diff-editor"></slot>
432
+ <!-- EDITOR -->
238
433
  </sl-tab-panel>
239
-
240
434
  </sl-tab-group>
241
435
  </div>
242
436
  </div>`;
243
437
  }
244
438
  showSummaryOnly() {
245
439
  this.specSummary = null;
246
- this.changeReport = null;
440
+ this.doc.modelController.changeReport = null;
247
441
  return;
248
442
  }
443
+ showDiffTab() {
444
+ if (this.tabGroup) {
445
+ this.tabGroup.show('diff');
446
+ }
447
+ }
249
448
  set summary(summary) {
250
449
  this.specSummary = summary;
450
+ if (this.countdownController) {
451
+ this.countdownController.stop();
452
+ this.countdownController = undefined;
453
+ }
454
+ if (summary.isEphemeral && summary.ephemeralExpiresAt) {
455
+ this.countdownController = new CountdownController(this, summary.ephemeralExpiresAt, () => this.handleEphemeralExpired());
456
+ }
251
457
  if (summary.changeId) {
252
458
  this.loading = true;
253
- TimelineService.fetchChange(summary.changeId)
254
- .then(this.handleChange.bind(this))
459
+ this.markdownReport = '';
460
+ // Fetch change report, spec diffs, and markdown report in parallel
461
+ Promise.all([
462
+ TimelineService.fetchChange(summary.changeId),
463
+ TimelineService.fetchOriginalSpec(summary.changeId),
464
+ TimelineService.fetchModifiedSpec(summary.changeId),
465
+ TimelineService.fetchMarkdownReport(summary.changeId)
466
+ ])
467
+ .then(([changeResponse, originalSpec, modifiedSpec, markdownReport]) => {
468
+ this.handleChange(changeResponse);
469
+ if (this.diffEditor) {
470
+ this.diffEditor.setValue(originalSpec);
471
+ this.diffEditor.setDiffValue(modifiedSpec);
472
+ }
473
+ // keyed directive will detect changeId change and re-render unsafeHTML content
474
+ this.markdownReport = markdownReport;
475
+ // prism highlighting must run after dom renders, hence the delay
476
+ this._highlightTimeout = window.setTimeout(() => {
477
+ this.highlightCodeBlocks();
478
+ }, 100);
479
+ })
255
480
  .catch((e) => {
256
481
  this.loading = false;
482
+ let message = 'Unable to fetch revision, something went wrong.';
483
+ if (e.detail) {
484
+ message += ': ' + e.detail;
485
+ }
257
486
  this.dispatchEvent(new CustomEvent(AddToast, {
258
487
  bubbles: true,
259
488
  composed: true,
@@ -261,8 +490,8 @@ let TardisControl = class TardisControl extends Colorful {
261
490
  toast: {
262
491
  type: ToastType.ERROR,
263
492
  id: "timeline-error",
264
- body: e.detail,
265
- title: "timeline error",
493
+ body: message,
494
+ title: "Tardis failure",
266
495
  }
267
496
  }
268
497
  }));
@@ -270,20 +499,17 @@ let TardisControl = class TardisControl extends Colorful {
270
499
  }
271
500
  }
272
501
  handleChange(resp) {
273
- this.changeReport = resp;
274
- this.explorer.updateGraphResponse(resp);
275
- this.explorer.buildGraph();
502
+ this.doc.modelController.updateChangeReport(resp);
503
+ if (this.explorer) {
504
+ this.explorer.updateGraphResponse(resp);
505
+ this.explorer.buildGraph();
506
+ }
507
+ this.modelTree.triggerTreeClick('timeline');
276
508
  this.loading = false;
277
509
  }
278
510
  };
279
- TardisControl.styles = [specSummaryTimelineItemCss,
280
- tardisControlCss, spinnerCss, tabsCss, panelsCss, scrollbarCss];
281
- __decorate([
282
- state()
283
- ], TardisControl.prototype, "changeReport", void 0);
284
- __decorate([
285
- state()
286
- ], TardisControl.prototype, "changeGraph", void 0);
511
+ TardisControl.styles = [specSummaryTimelineItemCss, buttonCss,
512
+ spinnerCss, tabsCss, panelsCss, scrollbarCss, prismCss, chromaSyntaxCss, hrCss, changelogCss, tardisControlCss];
287
513
  __decorate([
288
514
  state()
289
515
  ], TardisControl.prototype, "history", void 0);
@@ -299,6 +525,18 @@ __decorate([
299
525
  __decorate([
300
526
  query('pb33f-doughnut-chart#breaking-doughnut')
301
527
  ], TardisControl.prototype, "breakingDoughnut", void 0);
528
+ __decorate([
529
+ query('sl-tab-group.time-vortex')
530
+ ], TardisControl.prototype, "tabGroup", void 0);
531
+ __decorate([
532
+ property()
533
+ ], TardisControl.prototype, "doc", void 0);
534
+ __decorate([
535
+ state()
536
+ ], TardisControl.prototype, "markdownReport", void 0);
537
+ __decorate([
538
+ state()
539
+ ], TardisControl.prototype, "mdDownloadLoading", void 0);
302
540
  TardisControl = __decorate([
303
541
  customElement("pb33f-tardis-control")
304
542
  ], TardisControl);
@@ -1,6 +1,7 @@
1
1
  import { LitElement } from "lit";
2
2
  import { TheDoctor } from "../the-doctor/the-doctor.js";
3
3
  import { HistoryPicker } from "./history-picker.js";
4
+ import { SpecSummary } from "../../model/timeline.js";
4
5
  import { TardisControl } from "./tardis-control.js";
5
6
  import { RevisionClickedEvent } from "../../events/doctor.js";
6
7
  export declare class TimeVortex extends LitElement {
@@ -9,9 +10,14 @@ export declare class TimeVortex extends LitElement {
9
10
  historyPicker: HistoryPicker;
10
11
  tardisControl: TardisControl;
11
12
  doctor: TheDoctor;
12
- constructor();
13
- checkHistory(): void;
13
+ constructor(doc: TheDoctor);
14
+ firstUpdated(): void;
15
+ setTardisControl(control: TardisControl): void;
16
+ getHistorySummary(): Promise<SpecSummary[]>;
14
17
  updated(): void;
15
18
  revisionClicked(evt: CustomEvent<RevisionClickedEvent>): void;
19
+ private processRevisionClick;
16
20
  showTimelineSummary(): void;
21
+ private processShowSummary;
22
+ private ensureTardisControlReady;
17
23
  }
@@ -8,31 +8,44 @@ import { LitElement } from "lit";
8
8
  import { customElement, state } from "lit/decorators.js";
9
9
  import { HistoryPicker } from "./history-picker.js";
10
10
  import { TimelineService } from "../../services/timeline-service.js";
11
- import { TardisControl } from "./tardis-control.js";
12
11
  import { ToastType } from "../../model/toast.js";
13
- import { AddToast, RevisionClicked, ShowTimelineSummary, TimelineHistoryRefresh } from "../../events/doctor.js";
12
+ import { ActiveView, AddToast, RevisionClicked, ShowTimelineSummary, TimelineHistoryRefresh } from "../../events/doctor.js";
13
+ import { typedEventHandler } from "../../helpers/typed-events.js";
14
14
  let TimeVortex = class TimeVortex extends LitElement {
15
- constructor() {
15
+ constructor(doc) {
16
16
  super();
17
+ this.doctor = doc;
17
18
  this.pickerVisible = false;
18
19
  this.skipChanges = false;
19
20
  this.historyPicker = new HistoryPicker();
20
- this.tardisControl = new TardisControl();
21
- this.addEventListener(TimelineHistoryRefresh, this.checkHistory);
22
- //@ts-ignore
23
- this.historyPicker.addEventListener(RevisionClicked, (evt) => {
21
+ //this.tardisControl = new TardisControl(this.doctor);
22
+ this.addEventListener(TimelineHistoryRefresh, this.getHistorySummary);
23
+ this.historyPicker.addEventListener(RevisionClicked, typedEventHandler((evt) => {
24
24
  this.revisionClicked(evt);
25
- });
25
+ }));
26
26
  this.historyPicker.addEventListener(ShowTimelineSummary, this.showTimelineSummary.bind(this));
27
27
  }
28
- checkHistory() {
29
- TimelineService.getSummary().then((summaries) => {
28
+ firstUpdated() {
29
+ }
30
+ setTardisControl(control) {
31
+ this.tardisControl = control;
32
+ this.tardisControl.doc = this.doctor;
33
+ // this.tardisControl.fetchHistory()
34
+ }
35
+ getHistorySummary() {
36
+ return TimelineService.getSummary().then((summaries) => {
30
37
  if (summaries.length > 0) {
31
38
  this.pickerVisible = true;
32
39
  this.historyPicker.specSummary = summaries;
33
- if (this.doctor)
34
- this.doctor.requestUpdate();
35
40
  }
41
+ else {
42
+ this.pickerVisible = false;
43
+ this.historyPicker.specSummary = [];
44
+ }
45
+ if (this.doctor) {
46
+ this.doctor.requestUpdate();
47
+ }
48
+ return summaries;
36
49
  }).catch((e) => {
37
50
  this.dispatchEvent(new CustomEvent(AddToast, {
38
51
  bubbles: true,
@@ -46,22 +59,50 @@ let TimeVortex = class TimeVortex extends LitElement {
46
59
  }
47
60
  }
48
61
  }));
62
+ return [];
49
63
  });
50
- this.tardisControl.fetchHistory();
51
64
  }
52
65
  updated() {
53
66
  this.historyPicker.skipChanges = this.skipChanges;
54
67
  }
55
68
  revisionClicked(evt) {
69
+ if (!this.tardisControl) {
70
+ this.ensureTardisControlReady(() => this.processRevisionClick(evt));
71
+ return;
72
+ }
73
+ this.processRevisionClick(evt);
74
+ }
75
+ processRevisionClick(evt) {
56
76
  this.tardisControl.specSummary = evt.detail.specSummary;
57
77
  this.doctor.selectTardis();
58
78
  this.tardisControl.summary = evt.detail.specSummary;
79
+ if (evt.detail.specSummary.changeId) {
80
+ this.doctor.timelineController.loadRevisionViolations(evt.detail.specSummary.changeId);
81
+ }
59
82
  }
60
83
  showTimelineSummary() {
84
+ if (!this.tardisControl) {
85
+ this.ensureTardisControlReady(() => this.processShowSummary());
86
+ return;
87
+ }
88
+ this.processShowSummary();
89
+ }
90
+ processShowSummary() {
61
91
  this.tardisControl.showSummaryOnly();
62
92
  this.tardisControl.fetchHistory();
63
93
  this.doctor.selectTardis();
64
94
  }
95
+ ensureTardisControlReady(callback) {
96
+ this.doctor.markEditorTabLoaded(ActiveView.Tardis);
97
+ this.doctor.editorPanel?.showTab(ActiveView.Tardis);
98
+ this.doctor.updateComplete.then(() => {
99
+ this.doctor.updateComplete.then(() => {
100
+ if (this.tardisControl) {
101
+ callback();
102
+ }
103
+ });
104
+ });
105
+ }
65
106
  };
66
107
  __decorate([
67
108
  state()
@@ -16,6 +16,7 @@ export default css `
16
16
  margin-bottom: 10px;
17
17
  pointer-events: all;
18
18
  z-index: 101;
19
+ box-shadow: 5px 5px 0 var(--font-color-sub3);
19
20
  }
20
21
 
21
22
  .details {