@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.
- package/dist/_basePickBy-DtTwxTrV.js +151 -0
- package/dist/_baseUniq-C5Y4WFmx.js +614 -0
- package/dist/arc-a-7w7y90.js +83 -0
- package/dist/architecture-U656AL7Q-c_zxypEp.js +5 -0
- package/dist/architectureDiagram-VXUJARFQ-CIhQJ6xS.js +4661 -0
- package/dist/assets/elk-layout.worker-B71_NI2D.js +1 -0
- package/dist/assets/equalizer.worker-A8HFNy4g.js +1 -0
- package/dist/assets/graph-dependent.worker-BgWuMZsb.js +1 -0
- package/dist/assets/rule-documentation.worker-BCKuwSgZ.js +1 -0
- package/dist/assets/search-graph.worker-Cwqb-ecv.js +1 -0
- package/dist/assets/search-problems.worker-60kZqr0h.js +1 -0
- package/dist/blockDiagram-VD42YOAC-BLl5ID-l.js +2261 -0
- package/dist/c4Diagram-YG6GDRKO-BOGfb13x.js +1580 -0
- package/dist/channel-DYeI56io.js +5 -0
- package/dist/chunk-4BX2VUAB-BeHGB7ON.js +8 -0
- package/dist/chunk-55IACEB6-DgHUzWsw.js +8 -0
- package/dist/chunk-B4BG7PRW-Vs7GiQMf.js +1375 -0
- package/dist/chunk-DI55MBZ5-CHjdGXx0.js +1370 -0
- package/dist/chunk-FMBD7UC4-D-H9-bHN.js +19 -0
- package/dist/chunk-QN33PNHL-D7uE2r1Y.js +19 -0
- package/dist/chunk-QZHKN3VN-Cp3sUp7e.js +15 -0
- package/dist/chunk-TZMSLE5B-BmXGcXo9.js +64 -0
- package/dist/classDiagram-2ON5EDUG-9ilqiDEi.js +16 -0
- package/dist/classDiagram-v2-WZHVMYZB-9ilqiDEi.js +16 -0
- package/dist/clone-CybyMoa0.js +8 -0
- package/dist/components/attention-box/attention-box.css.js +8 -0
- package/dist/components/auth/login-button.js +1 -1
- package/dist/components/auth/login-panel.d.ts +4 -0
- package/dist/components/auth/login-panel.js +12 -4
- package/dist/components/auth/oauth-login.css.js +4 -0
- package/dist/components/auth/oauth-login.d.ts +2 -0
- package/dist/components/auth/oauth-login.js +12 -3
- package/dist/components/brokerable.d.ts +21 -0
- package/dist/components/brokerable.js +39 -0
- package/dist/components/bundle-toolbar/bundle-toolbar.css.js +110 -0
- package/dist/components/bundle-toolbar/bundle-toolbar.d.ts +21 -0
- package/dist/components/bundle-toolbar/bundle-toolbar.js +93 -0
- package/dist/components/changelog/changelog.css.js +2 -0
- package/dist/components/changelog/changelog.d.ts +2 -0
- package/dist/components/changelog/changelog.js +10 -1
- package/dist/components/changelog/release.css.js +5 -1
- package/dist/components/charts/beefy-chart.js +0 -2
- package/dist/components/charts/doughnut-chart.d.ts +5 -1
- package/dist/components/charts/doughnut-chart.js +20 -1
- package/dist/components/credit-ticker/credit-ticker.d.ts +3 -0
- package/dist/components/credit-ticker/credit-ticker.js +20 -4
- package/dist/components/details-drawer/details-drawer.css.d.ts +2 -0
- package/dist/components/{problem-list → details-drawer}/details-drawer.css.js +18 -3
- package/dist/components/details-drawer/generic-details-drawer.css.d.ts +1 -0
- package/dist/components/details-drawer/generic-details-drawer.css.js +219 -0
- package/dist/components/details-drawer/generic-details-drawer.d.ts +38 -0
- package/dist/components/details-drawer/generic-details-drawer.js +245 -0
- package/dist/components/details-drawer/handlers/diagram-handler.d.ts +35 -0
- package/dist/components/details-drawer/handlers/diagram-handler.js +248 -0
- package/dist/components/details-drawer/handlers/documentation-handler.d.ts +11 -0
- package/dist/components/details-drawer/handlers/documentation-handler.js +46 -0
- package/dist/components/details-drawer/handlers/example-handler.d.ts +18 -0
- package/dist/components/details-drawer/handlers/example-handler.js +146 -0
- package/dist/components/details-drawer/handlers/howto-handler.d.ts +11 -0
- package/dist/components/details-drawer/handlers/howto-handler.js +36 -0
- package/dist/components/details-drawer/handlers/markdown-handler.d.ts +12 -0
- package/dist/components/details-drawer/handlers/markdown-handler.js +54 -0
- package/dist/components/editor/editor-breadcrumb.css.js +1 -1
- package/dist/components/editor/editor.css.js +42 -0
- package/dist/components/editor/editor.d.ts +29 -3
- package/dist/components/editor/editor.js +495 -73
- package/dist/components/github/github-workspace-view.css.d.ts +2 -0
- package/dist/components/github/github-workspace-view.css.js +165 -0
- package/dist/components/github/github-workspace-view.d.ts +59 -0
- package/dist/components/github/github-workspace-view.js +525 -0
- package/dist/components/global-task/global-task-view.css.d.ts +2 -0
- package/dist/components/global-task/global-task-view.css.js +392 -0
- package/dist/components/global-task/global-task-view.d.ts +48 -0
- package/dist/components/global-task/global-task-view.js +359 -0
- package/dist/components/header/header.css.js +9 -1
- package/dist/components/http-method/http-method.css.js +5 -1
- package/dist/components/indeterminate-loader/indeterminate-loader.css.d.ts +2 -0
- package/dist/components/indeterminate-loader/indeterminate-loader.css.js +135 -0
- package/dist/components/indeterminate-loader/indeterminate-loader.d.ts +35 -0
- package/dist/components/indeterminate-loader/indeterminate-loader.js +201 -0
- package/dist/components/kv-view/kv-view.css.js +2 -0
- package/dist/components/kv-view/kv-view.js +0 -1
- package/dist/components/logo-wall/logo-wall.css.js +9 -0
- package/dist/components/manage-ruleset/manage-ruleset.css.js +14 -1
- package/dist/components/manage-ruleset/manage-ruleset.d.ts +1 -0
- package/dist/components/manage-ruleset/manage-ruleset.js +54 -22
- package/dist/components/manage-ruleset/rule-action.css.js +2 -0
- package/dist/components/manage-ruleset/rule-action.d.ts +10 -3
- package/dist/components/manage-ruleset/rule-action.js +118 -129
- package/dist/components/manage-ruleset/rule-input.d.ts +3 -1
- package/dist/components/manage-ruleset/rule-input.js +38 -34
- package/dist/components/manage-ruleset/rule.css.js +15 -1
- package/dist/components/manage-ruleset/rule.d.ts +4 -1
- package/dist/components/manage-ruleset/rule.js +44 -17
- package/dist/components/mermaid/mermaid-renderer.css.d.ts +1 -0
- package/dist/components/mermaid/mermaid-renderer.css.js +121 -0
- package/dist/components/mermaid/mermaid-renderer.d.ts +75 -0
- package/dist/components/mermaid/mermaid-renderer.js +485 -0
- package/dist/components/model-icon/doctor-icon.d.ts +9 -0
- package/dist/components/model-icon/doctor-icon.js +60 -0
- package/dist/components/model-icon/model-icon.d.ts +2 -1
- package/dist/components/model-icon/model-icon.js +13 -1
- package/dist/components/model-renderer/change.css.js +22 -8
- package/dist/components/model-renderer/changes.d.ts +1 -0
- package/dist/components/model-renderer/changes.js +47 -32
- package/dist/components/model-renderer/clickable-ref.d.ts +9 -3
- package/dist/components/model-renderer/clickable-ref.js +49 -10
- package/dist/components/model-renderer/components.d.ts +2 -0
- package/dist/components/model-renderer/components.js +196 -116
- package/dist/components/model-renderer/contact.js +2 -2
- package/dist/components/model-renderer/description.css.js +2 -0
- package/dist/components/model-renderer/document.d.ts +1 -0
- package/dist/components/model-renderer/document.js +14 -9
- package/dist/components/model-renderer/encoding.d.ts +2 -0
- package/dist/components/model-renderer/encoding.js +16 -7
- package/dist/components/model-renderer/example.css.js +5 -1
- package/dist/components/model-renderer/example.d.ts +4 -1
- package/dist/components/model-renderer/example.js +72 -118
- package/dist/components/model-renderer/extensions.d.ts +2 -0
- package/dist/components/model-renderer/extensions.js +11 -2
- package/dist/components/model-renderer/external-docs.d.ts +2 -0
- package/dist/components/model-renderer/external-docs.js +13 -4
- package/dist/components/model-renderer/has-changes.js +3 -3
- package/dist/components/model-renderer/header.d.ts +2 -0
- package/dist/components/model-renderer/header.js +27 -14
- package/dist/components/model-renderer/info.d.ts +2 -0
- package/dist/components/model-renderer/info.js +20 -7
- package/dist/components/model-renderer/link.d.ts +2 -0
- package/dist/components/model-renderer/link.js +27 -10
- package/dist/components/model-renderer/media-type.js +2 -2
- package/dist/components/model-renderer/model-badge.d.ts +11 -0
- package/dist/components/model-renderer/model-badge.js +59 -0
- package/dist/components/model-renderer/model-shared.css.js +14 -2
- package/dist/components/model-renderer/oauth-flows.js +4 -4
- package/dist/components/model-renderer/operation.d.ts +2 -1
- package/dist/components/model-renderer/operation.js +37 -16
- package/dist/components/model-renderer/param-location.js +3 -3
- package/dist/components/model-renderer/parameter.d.ts +2 -0
- package/dist/components/model-renderer/parameter.js +28 -15
- package/dist/components/model-renderer/path-item.d.ts +3 -0
- package/dist/components/model-renderer/path-item.js +52 -80
- package/dist/components/model-renderer/paths.d.ts +2 -0
- package/dist/components/model-renderer/paths.js +10 -3
- package/dist/components/model-renderer/problem-node.js +10 -10
- package/dist/components/model-renderer/rendered-node.css.js +35 -6
- package/dist/components/model-renderer/rendered-node.d.ts +14 -4
- package/dist/components/model-renderer/rendered-node.js +121 -58
- package/dist/components/model-renderer/rendered-property.js +4 -4
- package/dist/components/model-renderer/request-body.d.ts +2 -0
- package/dist/components/model-renderer/request-body.js +16 -9
- package/dist/components/model-renderer/response.d.ts +2 -0
- package/dist/components/model-renderer/response.js +35 -17
- package/dist/components/model-renderer/schema.css.js +10 -1
- package/dist/components/model-renderer/schema.d.ts +3 -2
- package/dist/components/model-renderer/schema.js +127 -129
- package/dist/components/model-renderer/security-scheme.js +3 -3
- package/dist/components/model-renderer/server.js +18 -8
- package/dist/components/model-renderer/tag.js +1 -1
- package/dist/components/model-tree/tree.css.js +21 -10
- package/dist/components/model-tree/tree.d.ts +39 -22
- package/dist/components/model-tree/tree.js +230 -167
- package/dist/components/paginator/paginator-navigator.css.js +9 -5
- package/dist/components/paginator/paginator-navigator.js +6 -6
- package/dist/components/paginator/paginator.css.js +2 -0
- package/dist/components/paginator/paginator.js +5 -8
- package/dist/components/percent-bar/percent-bar.css.js +133 -13
- package/dist/components/percent-bar/percent-bar.d.ts +2 -0
- package/dist/components/percent-bar/percent-bar.js +28 -24
- package/dist/components/premium-gate/premium-gate.css.d.ts +1 -0
- package/dist/components/premium-gate/premium-gate.css.js +117 -0
- package/dist/components/premium-gate/premium-gate.d.ts +49 -0
- package/dist/components/premium-gate/premium-gate.js +336 -0
- package/dist/components/problem-list/problem-list.css.js +72 -1
- package/dist/components/problem-list/problem-list.d.ts +17 -9
- package/dist/components/problem-list/problem-list.js +222 -226
- package/dist/components/problem-list/problem-mainview.css.js +12 -2
- package/dist/components/problem-list/problem-mainview.d.ts +3 -0
- package/dist/components/problem-list/problem-mainview.js +37 -17
- package/dist/components/problem-list/problem-toolbar.css.js +10 -7
- package/dist/components/problems-overview/diagnostic-evaluation.css.js +11 -1
- package/dist/components/problems-overview/diagnostic-evaluation.js +6 -7
- package/dist/components/problems-overview/document-statistic.css.js +6 -0
- package/dist/components/problems-overview/document-statistic.js +1 -1
- package/dist/components/problems-overview/problem-overview-group.js +5 -5
- package/dist/components/problems-overview/problem-statistic.css.js +24 -5
- package/dist/components/problems-overview/problem-statistic.js +15 -6
- package/dist/components/problems-overview/problem-statistics.css.js +4 -4
- package/dist/components/problems-overview/problem-statistics.js +29 -25
- package/dist/components/problems-overview/problems-overview.css.js +2 -2
- package/dist/components/property-view/property-view.css.js +2 -0
- package/dist/components/render-json-path/render-json-path.css.js +11 -3
- package/dist/components/render-json-path/render-json-path.js +3 -0
- package/dist/components/render-operation-path/render-operation-path.css.js +9 -0
- package/dist/components/render-operation-path/render-operation-path.js +7 -22
- package/dist/components/rodeo/rodeo.d.ts +1 -0
- package/dist/components/rodeo/rodeo.js +5 -0
- package/dist/components/rodeo/roundup.js +2 -2
- package/dist/components/rodeo/statistic.css.js +25 -2
- package/dist/components/rodeo/statistic.js +0 -4
- package/dist/components/shader-canvas/shader-canvas.css.d.ts +2 -0
- package/dist/components/shader-canvas/shader-canvas.css.js +66 -0
- package/dist/components/shader-canvas/shader-canvas.d.ts +36 -0
- package/dist/components/shader-canvas/shader-canvas.js +363 -0
- package/dist/components/shaders/flowing-waves-shader.d.ts +2 -0
- package/dist/components/shaders/flowing-waves-shader.js +70 -0
- package/dist/components/shaders/neon-canyon-shader.d.ts +2 -0
- package/dist/components/shaders/neon-canyon-shader.js +265 -0
- package/dist/components/shaders/neon-lines-shader.d.ts +2 -0
- package/dist/components/shaders/neon-lines-shader.js +181 -0
- package/dist/components/shaders/neon-squircles-shader.d.ts +2 -0
- package/dist/components/shaders/neon-squircles-shader.js +56 -0
- package/dist/components/shaders/retro-grid-shader.d.ts +2 -0
- package/dist/components/shaders/retro-grid-shader.js +53 -0
- package/dist/components/shaders/shader-base.d.ts +9 -0
- package/dist/components/shaders/shader-base.js +11 -0
- package/dist/components/terminal/terminal-example.css.js +4 -0
- package/dist/components/terminal/terminal-example.js +2 -3
- package/dist/components/terminal-emulator/terminal-emulator.css.js +12 -2
- package/dist/components/terminal-emulator/terminal-emulator.d.ts +7 -1
- package/dist/components/terminal-emulator/terminal-emulator.js +10 -5
- package/dist/components/the-doctor/doctor-controls-panel.css.d.ts +2 -0
- package/dist/components/the-doctor/doctor-controls-panel.css.js +53 -0
- package/dist/components/the-doctor/doctor-controls-panel.d.ts +20 -0
- package/dist/components/the-doctor/doctor-controls-panel.js +78 -0
- package/dist/components/the-doctor/doctor-editor-panel.css.d.ts +2 -0
- package/dist/components/the-doctor/doctor-editor-panel.css.js +209 -0
- package/dist/components/the-doctor/doctor-editor-panel.d.ts +41 -0
- package/dist/components/the-doctor/doctor-editor-panel.js +188 -0
- package/dist/components/the-doctor/doctor-navigator-panel.css.d.ts +2 -0
- package/dist/components/the-doctor/doctor-navigator-panel.css.js +134 -0
- package/dist/components/the-doctor/doctor-navigator-panel.d.ts +35 -0
- package/dist/components/the-doctor/doctor-navigator-panel.js +117 -0
- package/dist/components/the-doctor/doctor-sidebar-panel.css.d.ts +2 -0
- package/dist/components/the-doctor/doctor-sidebar-panel.css.js +143 -0
- package/dist/components/the-doctor/doctor-sidebar-panel.d.ts +31 -0
- package/dist/components/the-doctor/doctor-sidebar-panel.js +131 -0
- package/dist/components/the-doctor/doctor-url-overlay.css.d.ts +2 -0
- package/dist/components/the-doctor/doctor-url-overlay.css.js +59 -0
- package/dist/components/the-doctor/doctor-url-overlay.d.ts +23 -0
- package/dist/components/the-doctor/doctor-url-overlay.js +82 -0
- package/dist/components/the-doctor/nuke-workspace.js +4 -3
- package/dist/components/the-doctor/settings.css.js +2 -0
- package/dist/components/the-doctor/settings.js +5 -8
- package/dist/components/the-doctor/status-bar.d.ts +2 -2
- package/dist/components/the-doctor/status-bar.js +32 -31
- package/dist/components/the-doctor/the-doctor.css.js +47 -238
- package/dist/components/the-doctor/the-doctor.d.ts +149 -37
- package/dist/components/the-doctor/the-doctor.js +958 -528
- package/dist/components/the-doctor/upload-archive.css.js +8 -2
- package/dist/components/the-doctor/upload-archive.js +2 -2
- package/dist/components/theme-switcher/theme-switcher.js +5 -1
- package/dist/components/time-vortex/change-list-item.css.js +18 -4
- package/dist/components/time-vortex/change-list-item.d.ts +1 -0
- package/dist/components/time-vortex/change-list-item.js +4 -3
- package/dist/components/time-vortex/history-picker.css.js +60 -1
- package/dist/components/time-vortex/history-picker.d.ts +7 -1
- package/dist/components/time-vortex/history-picker.js +109 -5
- package/dist/components/time-vortex/tardis-control.css.js +339 -14
- package/dist/components/time-vortex/tardis-control.d.ts +31 -3
- package/dist/components/time-vortex/tardis-control.js +296 -58
- package/dist/components/time-vortex/time-vortex.d.ts +8 -2
- package/dist/components/time-vortex/time-vortex.js +54 -13
- package/dist/components/toast/toast-component.css.js +1 -0
- package/dist/components/toast/toast-component.d.ts +1 -0
- package/dist/components/toast/toast-component.js +23 -8
- package/dist/components/toast/toast-manager.d.ts +5 -0
- package/dist/components/toast/toast-manager.js +29 -7
- package/dist/components/visualizer/edge.d.ts +11 -1
- package/dist/components/visualizer/edge.js +27 -22
- package/dist/components/visualizer/equalizer.css.js +118 -76
- package/dist/components/visualizer/equalizer.d.ts +24 -45
- package/dist/components/visualizer/equalizer.js +262 -363
- package/dist/components/visualizer/explorer.d.ts +94 -14
- package/dist/components/visualizer/explorer.js +580 -393
- package/dist/components/visualizer/foreign-object.d.ts +12 -2
- package/dist/components/visualizer/foreign-object.js +21 -10
- package/dist/components/visualizer/key.js +12 -1
- package/dist/components/visualizer/nodes/callback.d.ts +2 -1
- package/dist/components/visualizer/nodes/callback.js +2 -2
- package/dist/components/visualizer/nodes/components.d.ts +2 -1
- package/dist/components/visualizer/nodes/components.js +2 -2
- package/dist/components/visualizer/nodes/contact.d.ts +2 -1
- package/dist/components/visualizer/nodes/contact.js +2 -2
- package/dist/components/visualizer/nodes/document.d.ts +2 -1
- package/dist/components/visualizer/nodes/document.js +2 -2
- package/dist/components/visualizer/nodes/graph-node.d.ts +14 -3
- package/dist/components/visualizer/nodes/graph-node.js +94 -43
- package/dist/components/visualizer/nodes/header.d.ts +2 -1
- package/dist/components/visualizer/nodes/header.js +2 -2
- package/dist/components/visualizer/nodes/info.d.ts +2 -1
- package/dist/components/visualizer/nodes/info.js +2 -2
- package/dist/components/visualizer/nodes/license.d.ts +2 -1
- package/dist/components/visualizer/nodes/license.js +2 -2
- package/dist/components/visualizer/nodes/link.d.ts +2 -1
- package/dist/components/visualizer/nodes/link.js +2 -2
- package/dist/components/visualizer/nodes/media-type.d.ts +2 -1
- package/dist/components/visualizer/nodes/media-type.js +2 -2
- package/dist/components/visualizer/nodes/operation.d.ts +2 -1
- package/dist/components/visualizer/nodes/operation.js +3 -4
- package/dist/components/visualizer/nodes/parameter.d.ts +3 -1
- package/dist/components/visualizer/nodes/parameter.js +3 -4
- package/dist/components/visualizer/nodes/path-item.d.ts +2 -1
- package/dist/components/visualizer/nodes/path-item.js +2 -2
- package/dist/components/visualizer/nodes/request-body.d.ts +2 -1
- package/dist/components/visualizer/nodes/request-body.js +2 -2
- package/dist/components/visualizer/nodes/response.d.ts +2 -1
- package/dist/components/visualizer/nodes/response.js +2 -2
- package/dist/components/visualizer/nodes/schema.d.ts +2 -1
- package/dist/components/visualizer/nodes/schema.js +64 -9
- package/dist/components/visualizer/nodes/security-scheme.d.ts +2 -1
- package/dist/components/visualizer/nodes/security-scheme.js +2 -2
- package/dist/components/visualizer/nodes/server.d.ts +2 -1
- package/dist/components/visualizer/nodes/server.js +3 -4
- package/dist/components/visualizer/nodes/tag.d.ts +2 -1
- package/dist/components/visualizer/nodes/tag.js +4 -5
- package/dist/components/visualizer/nodes/xml.d.ts +2 -1
- package/dist/components/visualizer/nodes/xml.js +2 -2
- package/dist/components/visualizer/orientation-controls.d.ts +6 -1
- package/dist/components/visualizer/orientation-controls.js +65 -7
- package/dist/components/visualizer/search.d.ts +2 -1
- package/dist/components/visualizer/search.js +22 -29
- package/dist/components/visualizer/shared.css.js +55 -18
- package/dist/components/visualizer/templates/svg-markers.d.ts +2 -0
- package/dist/components/visualizer/templates/svg-markers.js +73 -0
- package/dist/components/waiting-line/waiting-line.css.d.ts +2 -0
- package/dist/components/waiting-line/waiting-line.css.js +26 -0
- package/dist/components/waiting-line/waiting-line.d.ts +30 -0
- package/dist/components/waiting-line/waiting-line.js +424 -0
- package/dist/components/workspaces/workspace-view.css.js +89 -8
- package/dist/components/workspaces/workspace-view.d.ts +8 -1
- package/dist/components/workspaces/workspace-view.js +77 -25
- package/dist/controllers/auth-controller.d.ts +9 -0
- package/dist/controllers/auth-controller.js +12 -5
- package/dist/controllers/broker-controller.d.ts +30 -4
- package/dist/controllers/broker-controller.js +148 -25
- package/dist/controllers/bundle-controller.d.ts +21 -0
- package/dist/controllers/bundle-controller.js +122 -0
- package/dist/controllers/countdown-controller.d.ts +17 -0
- package/dist/controllers/countdown-controller.js +59 -0
- package/dist/controllers/diagnostic-controller.d.ts +18 -5
- package/dist/controllers/diagnostic-controller.js +206 -218
- package/dist/controllers/diagramatron-controller.d.ts +33 -0
- package/dist/controllers/diagramatron-controller.js +128 -0
- package/dist/controllers/docs-controller.d.ts +11 -5
- package/dist/controllers/docs-controller.js +97 -97
- package/dist/controllers/github-controller.d.ts +47 -0
- package/dist/controllers/github-controller.js +494 -0
- package/dist/controllers/global-task-controller.d.ts +46 -0
- package/dist/controllers/global-task-controller.js +352 -0
- package/dist/controllers/model-controller.d.ts +26 -4
- package/dist/controllers/model-controller.js +98 -62
- package/dist/controllers/node-clicker-controller.d.ts +121 -4
- package/dist/controllers/node-clicker-controller.js +526 -253
- package/dist/controllers/problem-controller.d.ts +11 -4
- package/dist/controllers/problem-controller.js +98 -39
- package/dist/controllers/rolodex-controller.d.ts +8 -3
- package/dist/controllers/rolodex-controller.js +117 -83
- package/dist/controllers/rule-controller.d.ts +12 -5
- package/dist/controllers/rule-controller.js +154 -161
- package/dist/controllers/spec-controller.d.ts +16 -4
- package/dist/controllers/spec-controller.js +91 -62
- package/dist/controllers/state-controller.d.ts +4 -3
- package/dist/controllers/state-controller.js +201 -154
- package/dist/controllers/tab-cache-controller.d.ts +29 -0
- package/dist/controllers/tab-cache-controller.js +68 -0
- package/dist/controllers/timeline-controller.d.ts +18 -0
- package/dist/controllers/timeline-controller.js +129 -0
- package/dist/controllers/wallet-controller.d.ts +3 -3
- package/dist/controllers/wallet-controller.js +22 -41
- package/dist/controllers/workspace-controller.d.ts +10 -4
- package/dist/controllers/workspace-controller.js +67 -22
- package/dist/cose-bilkent-S5V4N54A-2TG-C-n3.js +2608 -0
- package/dist/cowboy-components-BcyXo9oX.js +68425 -0
- package/dist/cowboy-components.css +1 -0
- package/dist/cowboy-components.umd.cjs +14050 -6577
- package/dist/css/alerts.css.js +2 -0
- package/dist/css/badges.css.js +2 -0
- package/dist/css/button.css.js +34 -1
- package/dist/css/cowboy-components.css +34 -0
- package/dist/css/dialog.css.js +11 -2
- package/dist/css/filter.css.js +17 -5
- package/dist/css/forms.css.js +14 -0
- package/dist/css/pb33f-theme.css +87 -16
- package/dist/css/syntax.css.js +5 -0
- package/dist/css/tabs.css.js +19 -2
- package/dist/css/tooltip.css.js +4 -0
- package/dist/cytoscape.esm-DfdJODL8.js +18735 -0
- package/dist/dagre-6UL2VRFP-BIlmTbhO.js +444 -0
- package/dist/defaultLocale-D7EN2tov.js +171 -0
- package/dist/diagram-PSM6KHXK-CeWby24E.js +531 -0
- package/dist/diagram-QEK2KX5R-DGonyVCK.js +217 -0
- package/dist/diagram-S2PKOQOG-mGn-y1uX.js +142 -0
- package/dist/erDiagram-Q2GNP2WA-BlBBw4Mz.js +841 -0
- package/dist/events/doctor.d.ts +63 -9
- package/dist/events/doctor.js +29 -1
- package/dist/events/drawer-events.d.ts +7 -0
- package/dist/events/drawer-events.js +3 -0
- package/dist/events/theme.d.ts +4 -0
- package/dist/events/theme.js +1 -0
- package/dist/factories/explorer-component-factory.d.ts +49 -0
- package/dist/factories/explorer-component-factory.js +205 -0
- package/dist/factories/state-controller-deps.factory.d.ts +88 -0
- package/dist/factories/state-controller-deps.factory.js +116 -0
- package/dist/flowDiagram-NV44I4VS-BlLzzy1C.js +1620 -0
- package/dist/ganttDiagram-LVOFAZNH-BoQtPC8k.js +2505 -0
- package/dist/gitGraph-F6HP7TQM-CShNSlrW.js +5 -0
- package/dist/gitGraphDiagram-NY62KEGX-BdpWBgHy.js +699 -0
- package/dist/graph-D9HS4Ahd.js +247 -0
- package/dist/helpers/event-wiring.d.ts +72 -0
- package/dist/helpers/event-wiring.js +58 -0
- package/dist/helpers/file-size-formatter.d.ts +3 -0
- package/dist/helpers/file-size-formatter.js +15 -0
- package/dist/helpers/filename-colorizer.d.ts +5 -0
- package/dist/helpers/filename-colorizer.js +30 -0
- package/dist/helpers/navigation-helper.d.ts +54 -0
- package/dist/helpers/navigation-helper.js +159 -0
- package/dist/helpers/typed-events.d.ts +1 -0
- package/dist/helpers/typed-events.js +3 -0
- package/dist/info-NVLQJR56-Bpi6I8up.js +5 -0
- package/dist/infoDiagram-F6ZHWCRC-DmhhbuMJ.js +24 -0
- package/dist/init-DjUOC4st.js +16 -0
- package/dist/interfaces/bundle-interfaces.d.ts +7 -0
- package/dist/interfaces/bundle-interfaces.js +1 -0
- package/dist/interfaces/doctor-interfaces.d.ts +506 -0
- package/dist/interfaces/doctor-interfaces.js +1 -0
- package/dist/journeyDiagram-XKPGCS4Q-CpkhK8vl.js +834 -0
- package/dist/kanban-definition-3W4ZIXB7-BFbucfYE.js +719 -0
- package/dist/katex-SsTUIUTC.js +11688 -0
- package/dist/layout-B8H1_UrM.js +1324 -0
- package/dist/linear-Bo0rJUSQ.js +259 -0
- package/dist/managers/drag-handler.d.ts +28 -0
- package/dist/managers/drag-handler.js +64 -0
- package/dist/managers/event-registration-manager.d.ts +17 -0
- package/dist/managers/event-registration-manager.js +34 -0
- package/dist/managers/expansion-manager.d.ts +58 -0
- package/dist/managers/expansion-manager.js +189 -0
- package/dist/managers/layout-filter-manager.d.ts +31 -0
- package/dist/managers/layout-filter-manager.js +109 -0
- package/dist/managers/panel-divider-manager.d.ts +33 -0
- package/dist/managers/panel-divider-manager.js +71 -0
- package/dist/managers/view-state-manager.d.ts +48 -0
- package/dist/managers/view-state-manager.js +101 -0
- package/dist/managers/viewport-manager.d.ts +53 -0
- package/dist/managers/viewport-manager.js +198 -0
- package/dist/mermaid-parser.core-BPror82d.js +12966 -0
- package/dist/mindmap-definition-VGOIOE7T-VAn-EShH.js +784 -0
- package/dist/mocks/task-mock-generator.d.ts +13 -0
- package/dist/mocks/task-mock-generator.js +200 -0
- package/dist/model/api-response.d.ts +2 -7
- package/dist/model/api-response.js +0 -2
- package/dist/model/bundle.d.ts +35 -0
- package/dist/model/bundle.js +1 -0
- package/dist/model/channels.d.ts +8 -1
- package/dist/model/channels.js +7 -0
- package/dist/model/drawer-content.d.ts +80 -0
- package/dist/model/drawer-content.js +14 -0
- package/dist/model/formable.js +22 -11
- package/dist/model/github.d.ts +125 -0
- package/dist/model/github.js +1 -0
- package/dist/model/graph.d.ts +15 -15
- package/dist/model/graph.js +24 -4
- package/dist/model/media-type.js +2 -2
- package/dist/model/node_type.d.ts +4 -0
- package/dist/model/node_type.js +4 -0
- package/dist/model/panel-state.d.ts +1 -0
- package/dist/model/rolodex.d.ts +3 -0
- package/dist/model/task.d.ts +50 -0
- package/dist/model/task.js +22 -0
- package/dist/model/timeline.d.ts +107 -1
- package/dist/model/tree-icon-config.d.ts +11 -0
- package/dist/model/tree-icon-config.js +46 -0
- package/dist/model/workspace.d.ts +2 -0
- package/dist/monacoeditorwork/css.worker.bundle.js +9 -7
- package/dist/monacoeditorwork/editor.worker.bundle.js +2 -0
- package/dist/monacoeditorwork/html.worker.bundle.js +9 -7
- package/dist/monacoeditorwork/json.worker.bundle.js +9 -7
- package/dist/monacoeditorwork/yaml.worker..bundle.js +72 -48
- package/dist/ordinal-DfAQgscy.js +61 -0
- package/dist/packet-BFZMPI3H-CXPCK9Q2.js +5 -0
- package/dist/pie-7BOR55EZ-CMcuUZ_S.js +5 -0
- package/dist/pieDiagram-ADFJNKIX-C0kdlQqn.js +161 -0
- package/dist/quadrantDiagram-AYHSOK5B-CRVq6wY3.js +1022 -0
- package/dist/radar-NHE76QYJ-CX_Gyp4h.js +5 -0
- package/dist/requirementDiagram-UZGBJVZJ-B8ZGgMKn.js +850 -0
- package/dist/sankeyDiagram-TZEHDZUN-CWAUJJue.js +810 -0
- package/dist/sequenceDiagram-WL72ISMW-nz81a4Cq.js +2511 -0
- package/dist/services/diagramatron-service.d.ts +20 -0
- package/dist/services/diagramatron-service.js +48 -0
- package/dist/services/doctor-events.d.ts +58 -0
- package/dist/services/doctor-events.js +33 -0
- package/dist/services/drawer-content-registry.d.ts +9 -0
- package/dist/services/drawer-content-registry.js +37 -0
- package/dist/services/github-service.d.ts +9 -0
- package/dist/services/github-service.js +166 -0
- package/dist/services/global-task-service.d.ts +6 -0
- package/dist/services/global-task-service.js +27 -0
- package/dist/services/header-service.d.ts +5 -3
- package/dist/services/header-service.js +13 -0
- package/dist/services/linting-service.d.ts +2 -0
- package/dist/services/linting-service.js +19 -2
- package/dist/services/mermaid-config-service.d.ts +53 -0
- package/dist/services/mermaid-config-service.js +519 -0
- package/dist/services/model-service.d.ts +12 -7
- package/dist/services/model-service.js +64 -11
- package/dist/services/rodeo-service.js +12 -12
- package/dist/services/timeline-service.d.ts +12 -2
- package/dist/services/timeline-service.js +329 -0
- package/dist/services/wallet-service.d.ts +1 -1
- package/dist/services/wallet-service.js +4 -1
- package/dist/services/workspace-service.js +16 -2
- package/dist/stateDiagram-FKZM4ZOC-3PFzJlcG.js +263 -0
- package/dist/stateDiagram-v2-4FDKWEC3-Bp46vM6_.js +16 -0
- package/dist/timeline-definition-IT6M3QCI-utm7jTLb.js +795 -0
- package/dist/treemap-KMMF4GRG-BvEKHn43.js +5 -0
- package/dist/utils/language-utils.d.ts +1 -0
- package/dist/utils/language-utils.js +23 -0
- package/dist/utils/lru-cache.d.ts +11 -0
- package/dist/utils/lru-cache.js +38 -0
- package/dist/utils/node-helpers.d.ts +6 -0
- package/dist/utils/node-helpers.js +62 -0
- package/dist/utils/path-utils.d.ts +5 -0
- package/dist/utils/path-utils.js +22 -0
- package/dist/workers/elk-layout.worker.d.ts +2 -0
- package/dist/workers/elk-layout.worker.js +31 -0
- package/dist/workers/equalizer.worker.d.ts +6 -1
- package/dist/workers/equalizer.worker.js +144 -195
- package/dist/workers/graph-dependent.worker.js +6 -6
- package/dist/workers/rule-documentation.worker.js +12 -48
- package/dist/workers/search-graph.worker.js +8 -23
- package/dist/xychartDiagram-PRI3JC2R-twqDKWMX.js +1340 -0
- package/package.json +17 -10
- package/dist/assets/equalizer.worker-DyLD5JTU.js +0 -1
- package/dist/assets/graph-dependent.worker-CpVhp0-T.js +0 -1
- package/dist/assets/rule-documentation.worker-B7xOWY5M.js +0 -1
- package/dist/assets/search-graph.worker-B9zqINrO.js +0 -1
- package/dist/assets/search-problems.worker-BAF8L2rX.js +0 -1
- package/dist/components/problem-list/details-drawer.d.ts +0 -34
- package/dist/components/problem-list/details-drawer.js +0 -200
- package/dist/style.css +0 -1
- /package/dist/components/{problem-list/details-drawer.css.d.ts → bundle-toolbar/bundle-toolbar.css.d.ts} +0 -0
|
@@ -1,73 +1,108 @@
|
|
|
1
|
-
import { AllRulesetBag, CustomRulesetBag, DefaultDocument, DefaultRulesetBag, DiagnosticBag, DocumentProblems, FunctionsBag, FunctionsSchemaBag, GraphBag, HowToFixBag, OWASPRulesetBag, PanelStateBag, ReferenceMapBag, RolodexResponseBag, RolodexStateBag, RuleConfigurationBag, SessionRulesetMapBag, SettingsBag } from "../components/the-doctor/the-doctor.js";
|
|
1
|
+
import { AllRulesetBag, CustomRulesetBag, DefaultDocument, DefaultRulesetBag, DiagnosticBag, DocumentProblems, FunctionsBag, FunctionsSchemaBag, GraphBag, HowToFixBag, OWASPRulesetBag, PanelStateBag, ReferenceMapBag, RolodexResponseBag, RolodexStateBag, RuleConfigurationBag, SessionRulesetMapBag, SessionRulesetYamlBag, SettingsBag } from "../components/the-doctor/the-doctor.js";
|
|
2
2
|
import { ModelService } from "../services/model-service.js";
|
|
3
|
+
import { DefaultMaxNodes } from "../components/visualizer/equalizer.js";
|
|
3
4
|
import { Problem } from "../model/problem.js";
|
|
4
|
-
import {
|
|
5
|
+
import { normalizeRolodexPath } from "../utils/path-utils.js";
|
|
6
|
+
import { RulesetService } from "../services/ruleset-service.js";
|
|
7
|
+
import { buildNodeMap, buildHashToNodeMap, collectAncestors, resolveNodeIdFromHash } from "../utils/node-helpers.js";
|
|
5
8
|
export class StateController extends EventTarget {
|
|
6
|
-
constructor(
|
|
9
|
+
constructor(deps) {
|
|
7
10
|
super();
|
|
8
|
-
this.
|
|
11
|
+
this.deps = deps;
|
|
9
12
|
}
|
|
10
13
|
loadState() {
|
|
11
14
|
// register a handler for settings bag changes.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
|
|
15
|
-
|
|
15
|
+
this.deps.settingsBag?.onAllChanges(this.deps.settingsChanged);
|
|
16
|
+
if (this.deps.settingsComponent) {
|
|
17
|
+
this.deps.settingsComponent.settingsBag = this.deps.settingsBag;
|
|
18
|
+
}
|
|
19
|
+
if (this.deps.settingsBag) {
|
|
20
|
+
this.deps.settingsChanged('', this.deps.settingsBag.get(SettingsBag));
|
|
21
|
+
}
|
|
22
|
+
this.deps.settingsComponent?.bootstrap?.();
|
|
23
|
+
this.deps.rolodexNeedsReset = true;
|
|
24
|
+
// Load panel state FIRST (before rolodex setup) to ensure divider positions
|
|
25
|
+
// are set before the split panels are created during render
|
|
26
|
+
if (this.deps.panelStateBag) {
|
|
27
|
+
const panelState = this.deps.panelStateBag.get(PanelStateBag);
|
|
28
|
+
if (panelState && panelState.explorerPanel && this.deps.splitPanelExplorer) {
|
|
29
|
+
this.deps.splitPanelExplorer.position = panelState.explorerPanel;
|
|
30
|
+
}
|
|
31
|
+
if (panelState && panelState.rolodexPanel) {
|
|
32
|
+
this.deps.rolodexDividerPosition = panelState.rolodexPanel;
|
|
33
|
+
}
|
|
34
|
+
if (panelState && panelState.inspectorPanel && this.deps.splitPanelInspector) {
|
|
35
|
+
this.deps.splitPanelInspector.position = panelState.inspectorPanel;
|
|
36
|
+
}
|
|
16
37
|
}
|
|
17
|
-
this.doc.settingsComponent.bootstrap();
|
|
18
|
-
this.doc.rolodexNeedsReset = true;
|
|
19
38
|
// load the rolodex
|
|
20
|
-
if (this.
|
|
21
|
-
const response = this.
|
|
22
|
-
if (response) {
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
39
|
+
if (this.deps.rolodexResponseBag) {
|
|
40
|
+
const response = this.deps.rolodexResponseBag.get(RolodexResponseBag);
|
|
41
|
+
if (response && this.deps.rolodexTree) {
|
|
42
|
+
this.deps.rolodexRoot = response.rolodexRoot;
|
|
43
|
+
this.deps.rolodexTree.isRolodex = true;
|
|
44
|
+
this.deps.rolodexTree.nodeMap = buildNodeMap(response.nodes);
|
|
45
|
+
this.deps.rolodexTree.node = response.rolodexRoot;
|
|
26
46
|
response.rolodexRoot.treeExpanded = true;
|
|
27
|
-
this.
|
|
47
|
+
this.deps.rolodexTree.childrenRendered.add(response.rolodexRoot.id);
|
|
48
|
+
this.deps.rolodexTree.expandedNodes.set(response.rolodexRoot.id, response.rolodexRoot);
|
|
49
|
+
this.deps.requestUpdate();
|
|
28
50
|
}
|
|
29
51
|
}
|
|
30
52
|
let skipDocBag = false;
|
|
31
53
|
const checkRefMap = (key) => {
|
|
32
|
-
let refMap = this.
|
|
54
|
+
let refMap = this.deps.referenceMapBag?.get(ReferenceMapBag);
|
|
33
55
|
if (refMap) {
|
|
34
|
-
// TODO: replace with
|
|
56
|
+
// TODO: replace with scheduled task to refresh the reference map
|
|
35
57
|
setTimeout(() => {
|
|
36
58
|
let refs = refMap?.references[key];
|
|
37
59
|
if (!refs) {
|
|
38
60
|
refs = refMap?.references[""]; // single file
|
|
39
61
|
}
|
|
40
|
-
if (refs) {
|
|
41
|
-
this.
|
|
42
|
-
this.
|
|
43
|
-
this.
|
|
62
|
+
if (refs && this.deps.editor) {
|
|
63
|
+
this.deps.references = refs;
|
|
64
|
+
this.deps.editor.links = refs;
|
|
65
|
+
this.deps.editor.applyLinkDecorations();
|
|
44
66
|
}
|
|
45
67
|
}, 5); // editor has not loaded yet, give it a second to breathe.
|
|
46
68
|
}
|
|
47
69
|
else {
|
|
48
70
|
ModelService.fetchReferenceMap().then((result) => {
|
|
49
|
-
this.
|
|
50
|
-
this.
|
|
51
|
-
|
|
71
|
+
this.deps.references = result;
|
|
72
|
+
if (this.deps.editor) {
|
|
73
|
+
this.deps.editor.links = result;
|
|
74
|
+
this.deps.editor.applyLinkDecorations();
|
|
75
|
+
}
|
|
52
76
|
}).catch(() => {
|
|
53
|
-
this.
|
|
54
|
-
|
|
77
|
+
if (this.deps.editor) {
|
|
78
|
+
this.deps.editor.clearDecorations();
|
|
79
|
+
this.deps.editor.clearAllMarkers();
|
|
80
|
+
}
|
|
55
81
|
});
|
|
56
82
|
}
|
|
57
83
|
};
|
|
58
|
-
if (this.
|
|
59
|
-
const state = this.
|
|
84
|
+
if (this.deps.rolodexStateBag) {
|
|
85
|
+
const state = this.deps.rolodexStateBag.get(RolodexStateBag);
|
|
60
86
|
if (state) {
|
|
61
|
-
|
|
62
|
-
this.
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
87
|
+
// Always reset to root on reload - ignore persisted activePath/activeNode
|
|
88
|
+
this.deps.rolodexActivePath = state.rootPath ?? "root";
|
|
89
|
+
this.deps.rolodexActiveHash = state.rootHash;
|
|
90
|
+
// load the root - prefer id, fall back to hash resolution
|
|
91
|
+
if (this.deps.rolodexTree) {
|
|
92
|
+
if (state.rootId) {
|
|
93
|
+
this.deps.rolodexTree.pendingNavigationId = state.rootId;
|
|
94
|
+
}
|
|
95
|
+
else if (state.rootHash && this.deps.rolodexTree.nodeMap) {
|
|
96
|
+
const resolvedId = resolveNodeIdFromHash(state.rootHash, this.deps.rolodexTree.nodeMap);
|
|
97
|
+
if (resolvedId) {
|
|
98
|
+
this.deps.rolodexTree.pendingNavigationId = resolvedId;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
66
101
|
}
|
|
67
102
|
if (state.rootPath) {
|
|
68
|
-
this.
|
|
69
|
-
if (state.
|
|
70
|
-
checkRefMap(state.
|
|
103
|
+
this.deps.rolodexRootPath = state.rootPath;
|
|
104
|
+
if (state.rootPath) {
|
|
105
|
+
checkRefMap(state.rootPath);
|
|
71
106
|
}
|
|
72
107
|
// ensure the session has a root selected
|
|
73
108
|
ModelService.selectRootPath(state.rootPath).then(() => {
|
|
@@ -77,181 +112,184 @@ export class StateController extends EventTarget {
|
|
|
77
112
|
});
|
|
78
113
|
}
|
|
79
114
|
if (state.rootHash)
|
|
80
|
-
this.
|
|
81
|
-
if (state.activePath) {
|
|
82
|
-
this.doc.rolodexTree.pendingNavigationPath = state.activePath;
|
|
83
|
-
this.doc.rolodexTree.requestUpdate();
|
|
84
|
-
}
|
|
85
|
-
if (state.activeNode) {
|
|
86
|
-
// load the content of the active node into the editor
|
|
87
|
-
if (state.activeLanguage) {
|
|
88
|
-
this.doc.editor.switchLanguage(state.activeLanguage);
|
|
89
|
-
}
|
|
90
|
-
this.doc.editor.setValue(state.activeNode.instance, true);
|
|
91
|
-
skipDocBag = true;
|
|
92
|
-
}
|
|
115
|
+
this.deps.rolodexRootHash = state.rootHash;
|
|
93
116
|
}
|
|
94
117
|
else {
|
|
95
|
-
this.
|
|
118
|
+
this.deps.rolodexActivePath = "root";
|
|
96
119
|
// refresh the refmap.
|
|
97
|
-
checkRefMap(this.
|
|
120
|
+
checkRefMap(this.deps.rolodexActivePath);
|
|
98
121
|
}
|
|
99
122
|
}
|
|
100
|
-
if (this.
|
|
101
|
-
const doc = this.
|
|
102
|
-
if (doc) {
|
|
103
|
-
this.
|
|
123
|
+
if (this.deps.docBag && !skipDocBag) {
|
|
124
|
+
const doc = this.deps.docBag.get(DefaultDocument);
|
|
125
|
+
if (doc && this.deps.editor) {
|
|
126
|
+
this.deps.editor.setValue(doc, true);
|
|
104
127
|
}
|
|
105
128
|
}
|
|
106
|
-
this.
|
|
107
|
-
if (this.
|
|
108
|
-
const markers = this.
|
|
129
|
+
this.deps.problemBag = this.deps.bagManager.getBag(DocumentProblems);
|
|
130
|
+
if (this.deps.problemBag) {
|
|
131
|
+
const markers = this.deps.problemBag.get(DocumentProblems);
|
|
109
132
|
if (markers) {
|
|
110
|
-
this.
|
|
133
|
+
this.deps.problems = markers;
|
|
111
134
|
for (let i = 0; i < markers.length; i++) {
|
|
112
135
|
markers[i] = Problem.reconstruct(markers[i]);
|
|
113
136
|
}
|
|
114
|
-
this.
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
137
|
+
this.deps.specController.updateProblems(markers);
|
|
138
|
+
this.deps.rolodexController.buildRolodexResultMap(markers);
|
|
139
|
+
const lookupPath = normalizeRolodexPath(this.deps.rolodexActivePath);
|
|
140
|
+
if (this.deps.rolodexProblemMap.size > 0 && this.deps.rolodexProblemMap.has(lookupPath)) {
|
|
141
|
+
const probs = this.deps.rolodexProblemMap.get(lookupPath);
|
|
142
|
+
if (probs && this.deps.editor) {
|
|
143
|
+
this.deps.editor.setMarkers(probs);
|
|
119
144
|
}
|
|
120
145
|
}
|
|
121
|
-
this.
|
|
122
|
-
|
|
146
|
+
if (this.deps.problemList) {
|
|
147
|
+
this.deps.problemList.problems = markers;
|
|
148
|
+
}
|
|
149
|
+
if (this.deps.problemsOverview && this.deps.problemList) {
|
|
150
|
+
this.deps.problemsOverview.problems = this.deps.problemList.problemItems;
|
|
151
|
+
}
|
|
123
152
|
}
|
|
124
153
|
}
|
|
125
|
-
this.
|
|
126
|
-
this.
|
|
127
|
-
if (this.
|
|
128
|
-
const stats = this.
|
|
129
|
-
if (stats) {
|
|
130
|
-
this.
|
|
154
|
+
this.deps.howToFixBag = this.deps.bagManager.getBag(HowToFixBag);
|
|
155
|
+
this.deps.diagnosticBag = this.deps.bagManager.getBag(DiagnosticBag);
|
|
156
|
+
if (this.deps.diagnosticBag) {
|
|
157
|
+
const stats = this.deps.diagnosticBag.get(DiagnosticBag);
|
|
158
|
+
if (stats && this.deps.problemsOverview) {
|
|
159
|
+
this.deps.problemsOverview.statistics = stats;
|
|
131
160
|
}
|
|
132
161
|
}
|
|
133
|
-
//
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
this.doc.modelController.extractGraph(graph);
|
|
138
|
-
}
|
|
162
|
+
// stale-while-revalidate: show cached graph for fast startup, then update with fresh API data
|
|
163
|
+
const cachedGraph = this.deps.graphBag?.get(GraphBag);
|
|
164
|
+
if (cachedGraph) {
|
|
165
|
+
this.deps.modelController.extractGraph(cachedGraph);
|
|
139
166
|
}
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
167
|
+
const maxNodes = this.deps.explorer?.equalizer?.maxNodes ?? DefaultMaxNodes;
|
|
168
|
+
ModelService.fetchLatestGraph(maxNodes).then((freshGraph) => {
|
|
169
|
+
this.deps.modelController.extractGraph(freshGraph);
|
|
170
|
+
}).catch((e) => {
|
|
171
|
+
if (!cachedGraph) {
|
|
172
|
+
console.error('failed to fetch graph and no cached data available', e);
|
|
145
173
|
}
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
this.doc.splitPanelRolodex.position = panelState.rolodexPanel;
|
|
149
|
-
}
|
|
150
|
-
this.doc.rolodexDividerPosition = panelState.rolodexPanel;
|
|
151
|
-
}
|
|
152
|
-
if (panelState && panelState.inspectorPanel) {
|
|
153
|
-
this.doc.splitPanelInspector.position = panelState.inspectorPanel;
|
|
174
|
+
else {
|
|
175
|
+
console.warn('using cached graph data - API fetch failed', e);
|
|
154
176
|
}
|
|
155
|
-
}
|
|
156
|
-
if (!this.doc.rolodexRoot) {
|
|
157
|
-
// this.importDisabled = false;
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
// this.importDisabled = true;
|
|
161
|
-
}
|
|
177
|
+
});
|
|
162
178
|
// extract rulesets from bags
|
|
163
179
|
const promises = [];
|
|
164
|
-
this.
|
|
165
|
-
if (this.
|
|
166
|
-
const ruleset = this.
|
|
180
|
+
this.deps.defaultRulesetBag = this.deps.bagManager.getBag(DefaultRulesetBag);
|
|
181
|
+
if (this.deps.defaultRulesetBag) {
|
|
182
|
+
const ruleset = this.deps.defaultRulesetBag.get(DefaultRulesetBag);
|
|
167
183
|
if (ruleset) {
|
|
168
|
-
this.
|
|
184
|
+
this.deps.defaultRuleset = ruleset;
|
|
169
185
|
}
|
|
170
186
|
else {
|
|
171
|
-
promises.push(this.
|
|
187
|
+
promises.push(this.deps.ruleController.fetchDefaultRuleset());
|
|
172
188
|
}
|
|
173
189
|
}
|
|
174
190
|
// OWASP ruleset
|
|
175
|
-
this.
|
|
176
|
-
if (this.
|
|
177
|
-
const ruleset = this.
|
|
191
|
+
this.deps.OWASPRulesetBag = this.deps.bagManager.getBag(OWASPRulesetBag);
|
|
192
|
+
if (this.deps.OWASPRulesetBag) {
|
|
193
|
+
const ruleset = this.deps.OWASPRulesetBag.get(OWASPRulesetBag);
|
|
178
194
|
if (ruleset) {
|
|
179
|
-
this.
|
|
195
|
+
this.deps.OWASPRuleset = ruleset;
|
|
180
196
|
}
|
|
181
197
|
else {
|
|
182
|
-
promises.push(this.
|
|
198
|
+
promises.push(this.deps.ruleController.fetchOWASPRuleset());
|
|
183
199
|
}
|
|
184
200
|
}
|
|
185
201
|
// All ruleset
|
|
186
|
-
this.
|
|
187
|
-
if (this.
|
|
188
|
-
const ruleset = this.
|
|
202
|
+
this.deps.allRulesetBag = this.deps.bagManager.getBag(AllRulesetBag);
|
|
203
|
+
if (this.deps.allRulesetBag) {
|
|
204
|
+
const ruleset = this.deps.allRulesetBag.get(AllRulesetBag);
|
|
189
205
|
if (ruleset) {
|
|
190
|
-
this.
|
|
206
|
+
this.deps.allRuleset = ruleset;
|
|
191
207
|
}
|
|
192
208
|
else {
|
|
193
|
-
promises.push(this.
|
|
209
|
+
promises.push(this.deps.ruleController.fetchAllRuleset());
|
|
194
210
|
}
|
|
195
211
|
}
|
|
196
212
|
// functions
|
|
197
|
-
this.
|
|
198
|
-
this.
|
|
199
|
-
if (this.
|
|
200
|
-
const functions = this.
|
|
213
|
+
this.deps.functionsBag = this.deps.bagManager.getBag(FunctionsBag);
|
|
214
|
+
this.deps.functionSchemaBag = this.deps.bagManager.getBag(FunctionsSchemaBag);
|
|
215
|
+
if (this.deps.functionsBag) {
|
|
216
|
+
const functions = this.deps.functionsBag.get(FunctionsBag);
|
|
201
217
|
if (functions) {
|
|
202
|
-
this.
|
|
218
|
+
this.deps.functions = functions;
|
|
203
219
|
}
|
|
204
220
|
else {
|
|
205
221
|
promises.push(this.fetchFunctions());
|
|
206
222
|
}
|
|
207
223
|
}
|
|
208
224
|
// custom ruleset
|
|
209
|
-
this.
|
|
210
|
-
if (this.
|
|
211
|
-
const ruleset = this.
|
|
225
|
+
this.deps.customRulesetBag = this.deps.bagManager.getBag(CustomRulesetBag);
|
|
226
|
+
if (this.deps.customRulesetBag) {
|
|
227
|
+
const ruleset = this.deps.customRulesetBag.get(CustomRulesetBag);
|
|
212
228
|
if (ruleset) {
|
|
213
|
-
this.
|
|
229
|
+
this.deps.customRuleset = ruleset;
|
|
214
230
|
}
|
|
215
231
|
}
|
|
216
232
|
// create rule configuration bag
|
|
217
|
-
this.
|
|
218
|
-
// create
|
|
219
|
-
this.
|
|
233
|
+
this.deps.ruleConfigBag = this.deps.bagManager.getBag(RuleConfigurationBag);
|
|
234
|
+
// create session ruleset map bag
|
|
235
|
+
this.deps.sessionRulesetMapBag = this.deps.bagManager.getBag(SessionRulesetMapBag);
|
|
236
|
+
// create session ruleset YAML bag for caching
|
|
237
|
+
this.deps.sessionRulesetYamlBag = this.deps.bagManager.getBag(SessionRulesetYamlBag);
|
|
220
238
|
// fire off all network requests, then configure the ruleset management.
|
|
221
239
|
Promise.all(promises).then(() => {
|
|
222
240
|
// configure rule management
|
|
223
|
-
this.
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
else {
|
|
232
|
-
this.doc.manageRuleset.rulesetConfig = { ruleMapping: new Map(), allRulesSwitch: true };
|
|
233
|
-
}
|
|
234
|
-
setTimeout(() => {
|
|
235
|
-
this.doc.manageRuleset.buildRulesets();
|
|
236
|
-
if (this.doc.customRuleset && this.doc.customRuleset.rules.size > 0) {
|
|
237
|
-
this.doc.manageRuleset.customRuleset = this.doc.customRuleset;
|
|
241
|
+
if (this.deps.manageRuleset) {
|
|
242
|
+
this.deps.manageRuleset.defaultRuleset = this.deps.defaultRuleset;
|
|
243
|
+
this.deps.manageRuleset.owaspRuleset = this.deps.OWASPRuleset;
|
|
244
|
+
this.deps.manageRuleset.allRuleset = this.deps.allRuleset;
|
|
245
|
+
this.deps.manageRuleset.functions = this.deps.functions;
|
|
246
|
+
const config = this.deps.ruleConfigBag?.get(RuleConfigurationBag);
|
|
247
|
+
if (config) {
|
|
248
|
+
this.deps.manageRuleset.rulesetConfig = config;
|
|
238
249
|
}
|
|
239
|
-
|
|
240
|
-
this.
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
this.
|
|
244
|
-
|
|
245
|
-
|
|
250
|
+
else {
|
|
251
|
+
this.deps.manageRuleset.rulesetConfig = { ruleMapping: new Map(), allRulesSwitch: true };
|
|
252
|
+
}
|
|
253
|
+
setTimeout(() => {
|
|
254
|
+
if (this.deps.manageRuleset) {
|
|
255
|
+
this.deps.manageRuleset.buildRulesets();
|
|
256
|
+
// Handle customRuleset - check works for both Map and plain object (after IndexedDB deserialization)
|
|
257
|
+
if (this.deps.customRuleset && this.deps.customRuleset.rules) {
|
|
258
|
+
const rulesCount = this.deps.customRuleset.rules instanceof Map
|
|
259
|
+
? this.deps.customRuleset.rules.size
|
|
260
|
+
: Object.keys(this.deps.customRuleset.rules).length;
|
|
261
|
+
if (rulesCount > 0) {
|
|
262
|
+
this.deps.manageRuleset.customRuleset = this.deps.customRuleset;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
// Try to fetch fresh YAML from API, fall back to cached if API fails
|
|
266
|
+
const cachedYaml = this.deps.sessionRulesetYamlBag?.get(SessionRulesetYamlBag);
|
|
267
|
+
this.deps.ruleController.fetchSessionRulesetAsYaml().then((result) => {
|
|
268
|
+
this.deps.rulesetEditor?.setValue(result, true);
|
|
269
|
+
this.deps.ruleController.fetchRulesetMap();
|
|
270
|
+
// Cache the fresh YAML
|
|
271
|
+
this.deps.sessionRulesetYamlBag?.set(SessionRulesetYamlBag, result);
|
|
272
|
+
}).catch((e) => {
|
|
273
|
+
// If API fails, try using cached YAML
|
|
274
|
+
if (cachedYaml) {
|
|
275
|
+
this.deps.rulesetEditor?.setValue(cachedYaml, true);
|
|
276
|
+
}
|
|
277
|
+
else {
|
|
278
|
+
this.deps.platformUnavailable(e);
|
|
279
|
+
}
|
|
280
|
+
});
|
|
281
|
+
}
|
|
282
|
+
}, 50);
|
|
283
|
+
}
|
|
246
284
|
});
|
|
247
285
|
// refresh state for how to fix.
|
|
248
|
-
this.
|
|
286
|
+
this.deps.docsController.fetchDocs();
|
|
249
287
|
}
|
|
250
288
|
async fetchFunctions() {
|
|
251
289
|
return new Promise(async (resolve) => {
|
|
252
290
|
RulesetService.getFunctions().then((result) => {
|
|
253
|
-
this.
|
|
254
|
-
this.
|
|
291
|
+
this.deps.functions = result;
|
|
292
|
+
this.deps.functionsBag?.set(FunctionsBag, result);
|
|
255
293
|
// extract schemas for each function
|
|
256
294
|
const promises = [];
|
|
257
295
|
result.forEach((functionId) => {
|
|
@@ -266,14 +304,23 @@ export class StateController extends EventTarget {
|
|
|
266
304
|
async fetchFunctionSchema(functionId) {
|
|
267
305
|
return new Promise(async (resolve) => {
|
|
268
306
|
RulesetService.getFunctionSchema(functionId).then((result) => {
|
|
269
|
-
let m = this.
|
|
307
|
+
let m = this.deps.functionSchemaBag?.get(FunctionsSchemaBag);
|
|
270
308
|
if (!m) {
|
|
271
309
|
m = new Map();
|
|
272
310
|
}
|
|
273
311
|
m.set(functionId, result);
|
|
274
|
-
this.
|
|
312
|
+
this.deps.functionSchemaBag?.set(FunctionsSchemaBag, m);
|
|
275
313
|
resolve(result);
|
|
276
314
|
});
|
|
277
315
|
});
|
|
278
316
|
}
|
|
317
|
+
expandAncestorsForNode(node, nodeMap) {
|
|
318
|
+
const hashToNode = buildHashToNodeMap(nodeMap);
|
|
319
|
+
const ancestors = collectAncestors(node, nodeMap, hashToNode);
|
|
320
|
+
for (const ancestor of ancestors) {
|
|
321
|
+
ancestor.treeExpanded = true;
|
|
322
|
+
this.deps.rolodexTree?.childrenRendered.add(ancestor.id);
|
|
323
|
+
this.deps.rolodexTree?.expandedNodes.set(ancestor.id, ancestor);
|
|
324
|
+
}
|
|
325
|
+
}
|
|
279
326
|
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ReactiveController, ReactiveControllerHost } from 'lit';
|
|
2
|
+
export interface TabCacheConfig {
|
|
3
|
+
maxCachedTabs?: number;
|
|
4
|
+
alwaysLoadedControlTabs?: string[];
|
|
5
|
+
alwaysLoadedEditorTabs?: string[];
|
|
6
|
+
heavyControlTabs?: string[];
|
|
7
|
+
heavyEditorTabs?: string[];
|
|
8
|
+
}
|
|
9
|
+
export declare class TabCacheController implements ReactiveController {
|
|
10
|
+
host: ReactiveControllerHost;
|
|
11
|
+
private loadedControlTabs;
|
|
12
|
+
private loadedEditorTabs;
|
|
13
|
+
private _maxCachedTabs;
|
|
14
|
+
private _controlTabAccessOrder;
|
|
15
|
+
private _editorTabAccessOrder;
|
|
16
|
+
private alwaysLoadedControlTabs;
|
|
17
|
+
private alwaysLoadedEditorTabs;
|
|
18
|
+
private heavyControlTabs;
|
|
19
|
+
private heavyEditorTabs;
|
|
20
|
+
constructor(host: ReactiveControllerHost, config?: TabCacheConfig);
|
|
21
|
+
hostConnected(): void;
|
|
22
|
+
hostDisconnected(): void;
|
|
23
|
+
markControlTabLoaded(tabName: string): void;
|
|
24
|
+
markEditorTabLoaded(tabName: string): void;
|
|
25
|
+
private _evictLRUControlTab;
|
|
26
|
+
private _evictLRUEditorTab;
|
|
27
|
+
shouldRenderControlTab(tabName: string): boolean;
|
|
28
|
+
shouldRenderEditorTab(tabName: string): boolean;
|
|
29
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
export class TabCacheController {
|
|
2
|
+
constructor(host, config = {}) {
|
|
3
|
+
this.loadedControlTabs = new Set();
|
|
4
|
+
this.loadedEditorTabs = new Set();
|
|
5
|
+
this._controlTabAccessOrder = [];
|
|
6
|
+
this._editorTabAccessOrder = [];
|
|
7
|
+
this.host = host;
|
|
8
|
+
this._maxCachedTabs = config.maxCachedTabs ?? 3;
|
|
9
|
+
this.alwaysLoadedControlTabs = config.alwaysLoadedControlTabs ?? ['overview'];
|
|
10
|
+
this.alwaysLoadedEditorTabs = config.alwaysLoadedEditorTabs ?? ['spec'];
|
|
11
|
+
this.heavyControlTabs = config.heavyControlTabs ?? ['ruleset'];
|
|
12
|
+
this.heavyEditorTabs = config.heavyEditorTabs ?? ['explorer'];
|
|
13
|
+
host.addController(this);
|
|
14
|
+
}
|
|
15
|
+
hostConnected() { }
|
|
16
|
+
hostDisconnected() {
|
|
17
|
+
this.loadedControlTabs.clear();
|
|
18
|
+
this.loadedEditorTabs.clear();
|
|
19
|
+
this._controlTabAccessOrder = [];
|
|
20
|
+
this._editorTabAccessOrder = [];
|
|
21
|
+
}
|
|
22
|
+
markControlTabLoaded(tabName) {
|
|
23
|
+
if (this.loadedControlTabs.has(tabName)) {
|
|
24
|
+
this._controlTabAccessOrder = this._controlTabAccessOrder.filter(t => t !== tabName);
|
|
25
|
+
this._controlTabAccessOrder.push(tabName);
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
this.loadedControlTabs.add(tabName);
|
|
29
|
+
this._controlTabAccessOrder.push(tabName);
|
|
30
|
+
this._evictLRUControlTab();
|
|
31
|
+
this.host.requestUpdate();
|
|
32
|
+
}
|
|
33
|
+
markEditorTabLoaded(tabName) {
|
|
34
|
+
if (this.loadedEditorTabs.has(tabName)) {
|
|
35
|
+
this._editorTabAccessOrder = this._editorTabAccessOrder.filter(t => t !== tabName);
|
|
36
|
+
this._editorTabAccessOrder.push(tabName);
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
this.loadedEditorTabs.add(tabName);
|
|
40
|
+
this._editorTabAccessOrder.push(tabName);
|
|
41
|
+
this._evictLRUEditorTab();
|
|
42
|
+
this.host.requestUpdate();
|
|
43
|
+
}
|
|
44
|
+
_evictLRUControlTab() {
|
|
45
|
+
const heavyLoaded = this._controlTabAccessOrder.filter(t => this.heavyControlTabs.includes(t));
|
|
46
|
+
if (heavyLoaded.length > this._maxCachedTabs) {
|
|
47
|
+
const lruTab = heavyLoaded[0];
|
|
48
|
+
this.loadedControlTabs.delete(lruTab);
|
|
49
|
+
this._controlTabAccessOrder = this._controlTabAccessOrder.filter(t => t !== lruTab);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
_evictLRUEditorTab() {
|
|
53
|
+
const heavyLoaded = this._editorTabAccessOrder.filter(t => this.heavyEditorTabs.includes(t));
|
|
54
|
+
if (heavyLoaded.length > this._maxCachedTabs) {
|
|
55
|
+
const lruTab = heavyLoaded[0];
|
|
56
|
+
this.loadedEditorTabs.delete(lruTab);
|
|
57
|
+
this._editorTabAccessOrder = this._editorTabAccessOrder.filter(t => t !== lruTab);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
shouldRenderControlTab(tabName) {
|
|
61
|
+
return this.alwaysLoadedControlTabs.includes(tabName) ||
|
|
62
|
+
this.loadedControlTabs.has(tabName);
|
|
63
|
+
}
|
|
64
|
+
shouldRenderEditorTab(tabName) {
|
|
65
|
+
return this.alwaysLoadedEditorTabs.includes(tabName) ||
|
|
66
|
+
this.loadedEditorTabs.has(tabName);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { TimelineControllerDeps } from "../interfaces/doctor-interfaces.js";
|
|
2
|
+
export interface ToolsCompareResult {
|
|
3
|
+
success: boolean;
|
|
4
|
+
totalChanges?: number;
|
|
5
|
+
error?: string;
|
|
6
|
+
}
|
|
7
|
+
export declare class TimelineController extends EventTarget {
|
|
8
|
+
private readonly deps;
|
|
9
|
+
private unsubscribePrChange?;
|
|
10
|
+
constructor(deps: TimelineControllerDeps);
|
|
11
|
+
init(): void;
|
|
12
|
+
private handlePrChangeCompleted;
|
|
13
|
+
destroy(): void;
|
|
14
|
+
loadRevisionViolations(changeId: string): Promise<void>;
|
|
15
|
+
restoreLiveViolations(): void;
|
|
16
|
+
private restoreLiveGraph;
|
|
17
|
+
toolsCompare(specContent: string): Promise<ToolsCompareResult>;
|
|
18
|
+
}
|