@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
|
@@ -0,0 +1,352 @@
|
|
|
1
|
+
import { TaskAction } from "../model/task.js";
|
|
2
|
+
import { GlobalTaskService } from "../services/global-task-service.js";
|
|
3
|
+
import { QueuePrefix, TaskStreamChannel } from "../model/channels.js";
|
|
4
|
+
import { ConsoleMessageType } from "../components/terminal-emulator/terminal-emulator.js";
|
|
5
|
+
import { TaskMockGenerator } from "../mocks/task-mock-generator.js";
|
|
6
|
+
import { ToastType } from "../model/toast.js";
|
|
7
|
+
export class GlobalTaskController extends EventTarget {
|
|
8
|
+
constructor(deps) {
|
|
9
|
+
super();
|
|
10
|
+
this.taskStreamSubscription = null;
|
|
11
|
+
this.tasks = new Map();
|
|
12
|
+
this.view = null;
|
|
13
|
+
this.consoleMessages = [];
|
|
14
|
+
this.mockMode = false;
|
|
15
|
+
this.mockGenerator = null;
|
|
16
|
+
this.taskCallbacks = new Map();
|
|
17
|
+
this.typeSubscriptions = new Map();
|
|
18
|
+
this.pendingTimeouts = new Set();
|
|
19
|
+
this.deps = deps;
|
|
20
|
+
this.bus = deps.bus;
|
|
21
|
+
}
|
|
22
|
+
setView(view) {
|
|
23
|
+
this.view = view;
|
|
24
|
+
}
|
|
25
|
+
init() {
|
|
26
|
+
if (!this.mockMode) {
|
|
27
|
+
this.taskStreamChannel = this.bus.createChannel(TaskStreamChannel);
|
|
28
|
+
const handler = this.taskStreamHandler();
|
|
29
|
+
this.taskStreamSubscription = this.taskStreamChannel.subscribe(handler);
|
|
30
|
+
this.bus.mapChannelToBrokerDestination(QueuePrefix + TaskStreamChannel, TaskStreamChannel);
|
|
31
|
+
this.loadInitialTasks();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
enableMockMode() {
|
|
35
|
+
this.mockMode = true;
|
|
36
|
+
if (!this.mockGenerator) {
|
|
37
|
+
this.mockGenerator = new TaskMockGenerator((message) => this.handleTaskMessage(message), (consoleMessage) => this.addConsoleMessage(consoleMessage));
|
|
38
|
+
}
|
|
39
|
+
this.mockGenerator.start();
|
|
40
|
+
}
|
|
41
|
+
disableMockMode() {
|
|
42
|
+
this.mockMode = false;
|
|
43
|
+
if (this.mockGenerator) {
|
|
44
|
+
this.mockGenerator.stop();
|
|
45
|
+
}
|
|
46
|
+
this.tasks.clear();
|
|
47
|
+
this.consoleMessages = [];
|
|
48
|
+
this.updateView();
|
|
49
|
+
}
|
|
50
|
+
async loadInitialTasks() {
|
|
51
|
+
try {
|
|
52
|
+
const response = await GlobalTaskService.getActiveTasks(this.deps.getBrokerId());
|
|
53
|
+
if (response.response) {
|
|
54
|
+
const taskList = response.response;
|
|
55
|
+
taskList.tasks.forEach(task => {
|
|
56
|
+
this.processTask(task);
|
|
57
|
+
});
|
|
58
|
+
this.updateView();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
console.error('Failed to load initial tasks:', error);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
taskStreamHandler() {
|
|
66
|
+
return (msg) => {
|
|
67
|
+
if (msg.payload) {
|
|
68
|
+
// The Ranch bus wraps the message, so the actual TaskMessage is at msg.payload.payload
|
|
69
|
+
const wrappedMessage = msg.payload;
|
|
70
|
+
if (wrappedMessage.payload) {
|
|
71
|
+
const taskMessage = wrappedMessage.payload;
|
|
72
|
+
this.handleTaskMessage(taskMessage);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
console.warn('[GlobalTaskController] Message payload has unexpected structure:', msg.payload);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
console.warn('[GlobalTaskController] Message has no payload:', msg);
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
handleTaskMessage(message) {
|
|
84
|
+
const task = message.task;
|
|
85
|
+
switch (message.action) {
|
|
86
|
+
case TaskAction.Create:
|
|
87
|
+
this.addTask(task);
|
|
88
|
+
this.addConsoleMessage({
|
|
89
|
+
type: ConsoleMessageType.Info,
|
|
90
|
+
message: `Task started: ${task.name}`,
|
|
91
|
+
timestamp: new Date().toISOString(),
|
|
92
|
+
metadata: {
|
|
93
|
+
taskId: task.id,
|
|
94
|
+
type: task.type
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
break;
|
|
98
|
+
case TaskAction.Update:
|
|
99
|
+
this.updateTask(task);
|
|
100
|
+
if (task.message) {
|
|
101
|
+
this.addConsoleMessage({
|
|
102
|
+
type: ConsoleMessageType.Info,
|
|
103
|
+
message: task.message,
|
|
104
|
+
timestamp: new Date().toISOString(),
|
|
105
|
+
metadata: {
|
|
106
|
+
taskId: task.id,
|
|
107
|
+
progress: task.progress || `${task.currentStep}/${task.totalSteps}`
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
break;
|
|
112
|
+
case TaskAction.Complete:
|
|
113
|
+
this.completeTask(task);
|
|
114
|
+
this.addConsoleMessage({
|
|
115
|
+
type: ConsoleMessageType.Success,
|
|
116
|
+
message: `Task completed: ${task.name}`,
|
|
117
|
+
timestamp: new Date().toISOString(),
|
|
118
|
+
metadata: {
|
|
119
|
+
taskId: task.id,
|
|
120
|
+
duration: this.formatDuration(task.startedAt, task.completedAt)
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
this.deps.sendToast({
|
|
124
|
+
id: crypto.randomUUID(),
|
|
125
|
+
type: ToastType.SUCCESS,
|
|
126
|
+
title: 'Task completed',
|
|
127
|
+
body: task.name
|
|
128
|
+
});
|
|
129
|
+
this.triggerTaskCallbacks(task.id, task);
|
|
130
|
+
this.notifyTypeSubscribers(task, TaskAction.Complete);
|
|
131
|
+
const completeTimeoutId = window.setTimeout(() => {
|
|
132
|
+
this.pendingTimeouts.delete(completeTimeoutId);
|
|
133
|
+
this.removeTask(task.id);
|
|
134
|
+
}, 30000);
|
|
135
|
+
this.pendingTimeouts.add(completeTimeoutId);
|
|
136
|
+
break;
|
|
137
|
+
case TaskAction.Fail:
|
|
138
|
+
this.failTask(task);
|
|
139
|
+
this.addConsoleMessage({
|
|
140
|
+
type: ConsoleMessageType.Error,
|
|
141
|
+
message: `Task failed: ${task.name} - ${task.error}`,
|
|
142
|
+
timestamp: new Date().toISOString(),
|
|
143
|
+
metadata: {
|
|
144
|
+
taskId: task.id,
|
|
145
|
+
error: task.error
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
this.deps.sendToast({
|
|
149
|
+
id: crypto.randomUUID(),
|
|
150
|
+
type: ToastType.ERROR,
|
|
151
|
+
title: 'Task failed',
|
|
152
|
+
body: `${task.name}: ${task.error || 'Unknown error'}`
|
|
153
|
+
});
|
|
154
|
+
this.triggerTaskCallbacks(task.id, task);
|
|
155
|
+
this.notifyTypeSubscribers(task, TaskAction.Fail);
|
|
156
|
+
const failTimeoutId = window.setTimeout(() => {
|
|
157
|
+
this.pendingTimeouts.delete(failTimeoutId);
|
|
158
|
+
this.removeTask(task.id);
|
|
159
|
+
}, 60000);
|
|
160
|
+
this.pendingTimeouts.add(failTimeoutId);
|
|
161
|
+
break;
|
|
162
|
+
}
|
|
163
|
+
this.updateView();
|
|
164
|
+
}
|
|
165
|
+
processTask(task) {
|
|
166
|
+
if (task.subtasks) {
|
|
167
|
+
task.subtasks.forEach(subtask => {
|
|
168
|
+
this.tasks.set(subtask.id, subtask);
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
this.tasks.set(task.id, task);
|
|
172
|
+
}
|
|
173
|
+
addTask(task) {
|
|
174
|
+
this.processTask(task);
|
|
175
|
+
this.updateView();
|
|
176
|
+
}
|
|
177
|
+
updateTask(task) {
|
|
178
|
+
const existingTask = this.tasks.get(task.id);
|
|
179
|
+
if (existingTask) {
|
|
180
|
+
Object.assign(existingTask, task);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
this.processTask(task);
|
|
184
|
+
}
|
|
185
|
+
this.updateView();
|
|
186
|
+
}
|
|
187
|
+
completeTask(task) {
|
|
188
|
+
const existingTask = this.tasks.get(task.id);
|
|
189
|
+
if (existingTask) {
|
|
190
|
+
existingTask.status = 'completed';
|
|
191
|
+
existingTask.progress = 100;
|
|
192
|
+
existingTask.completedAt = task.completedAt;
|
|
193
|
+
this.updateView();
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
failTask(task) {
|
|
197
|
+
const existingTask = this.tasks.get(task.id);
|
|
198
|
+
if (existingTask) {
|
|
199
|
+
existingTask.status = 'failed';
|
|
200
|
+
existingTask.error = task.error;
|
|
201
|
+
existingTask.completedAt = task.completedAt;
|
|
202
|
+
this.updateView();
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
removeTask(taskId) {
|
|
206
|
+
this.tasks.delete(taskId);
|
|
207
|
+
this.taskCallbacks.delete(taskId);
|
|
208
|
+
this.updateView();
|
|
209
|
+
}
|
|
210
|
+
addConsoleMessage(message) {
|
|
211
|
+
this.consoleMessages.push(message);
|
|
212
|
+
if (this.view) {
|
|
213
|
+
this.view.addConsoleMessage(message);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
updateView() {
|
|
217
|
+
if (this.view) {
|
|
218
|
+
const rootTasks = Array.from(this.tasks.values()).filter(t => !t.parentId);
|
|
219
|
+
const activeTasks = Array.from(this.tasks.values()).filter(t => t.status === 'active');
|
|
220
|
+
const overallProgress = this.calculateOverallProgress(activeTasks);
|
|
221
|
+
this.view.updateTasks(rootTasks, overallProgress);
|
|
222
|
+
this.view.updateConsoleMessages(this.consoleMessages);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
calculateOverallProgress(tasks) {
|
|
226
|
+
if (tasks.length === 0)
|
|
227
|
+
return 0; // No active tasks means 0% progress
|
|
228
|
+
let totalProgress = 0;
|
|
229
|
+
tasks.forEach(task => {
|
|
230
|
+
if (task.totalSteps > 0) {
|
|
231
|
+
totalProgress += (task.currentStep / task.totalSteps) * 100;
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
totalProgress += task.progress;
|
|
235
|
+
}
|
|
236
|
+
});
|
|
237
|
+
return Math.round(totalProgress / tasks.length);
|
|
238
|
+
}
|
|
239
|
+
formatDuration(startedAt, completedAt) {
|
|
240
|
+
const duration = completedAt - startedAt;
|
|
241
|
+
const seconds = Math.floor(duration / 1000);
|
|
242
|
+
const minutes = Math.floor(seconds / 60);
|
|
243
|
+
if (minutes > 0) {
|
|
244
|
+
return `${minutes}m ${seconds % 60}s`;
|
|
245
|
+
}
|
|
246
|
+
return `${seconds}s`;
|
|
247
|
+
}
|
|
248
|
+
getActiveTasks() {
|
|
249
|
+
return Array.from(this.tasks.values()).filter(t => t.status === 'active');
|
|
250
|
+
}
|
|
251
|
+
getAllTasks() {
|
|
252
|
+
return Array.from(this.tasks.values());
|
|
253
|
+
}
|
|
254
|
+
getConsoleMessages() {
|
|
255
|
+
return this.consoleMessages;
|
|
256
|
+
}
|
|
257
|
+
registerTaskCallback(taskId, callback) {
|
|
258
|
+
if (!this.taskCallbacks.has(taskId)) {
|
|
259
|
+
this.taskCallbacks.set(taskId, []);
|
|
260
|
+
}
|
|
261
|
+
this.taskCallbacks.get(taskId).push(callback);
|
|
262
|
+
}
|
|
263
|
+
unregisterTaskCallback(taskId, callback) {
|
|
264
|
+
if (!callback) {
|
|
265
|
+
this.taskCallbacks.delete(taskId);
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
const callbacks = this.taskCallbacks.get(taskId);
|
|
269
|
+
if (callbacks) {
|
|
270
|
+
const index = callbacks.indexOf(callback);
|
|
271
|
+
if (index > -1) {
|
|
272
|
+
callbacks.splice(index, 1);
|
|
273
|
+
}
|
|
274
|
+
if (callbacks.length === 0) {
|
|
275
|
+
this.taskCallbacks.delete(taskId);
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
triggerTaskCallbacks(taskId, task) {
|
|
281
|
+
const callbacks = this.taskCallbacks.get(taskId);
|
|
282
|
+
if (callbacks) {
|
|
283
|
+
callbacks.forEach(callback => {
|
|
284
|
+
try {
|
|
285
|
+
callback(task);
|
|
286
|
+
}
|
|
287
|
+
catch (error) {
|
|
288
|
+
console.error('Error in task callback:', error);
|
|
289
|
+
}
|
|
290
|
+
});
|
|
291
|
+
this.taskCallbacks.delete(taskId);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
waitForTask(taskId) {
|
|
295
|
+
return new Promise((resolve) => {
|
|
296
|
+
const existingTask = this.tasks.get(taskId);
|
|
297
|
+
if (existingTask && (existingTask.status === 'completed' || existingTask.status === 'failed')) {
|
|
298
|
+
resolve(existingTask);
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
this.registerTaskCallback(taskId, (task) => {
|
|
302
|
+
resolve(task);
|
|
303
|
+
});
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
subscribeToTaskType(taskType, callback, actions = [TaskAction.Complete, TaskAction.Fail]) {
|
|
307
|
+
const subscription = { taskType, actions, callback };
|
|
308
|
+
if (!this.typeSubscriptions.has(taskType)) {
|
|
309
|
+
this.typeSubscriptions.set(taskType, new Set());
|
|
310
|
+
}
|
|
311
|
+
this.typeSubscriptions.get(taskType).add(subscription);
|
|
312
|
+
return () => {
|
|
313
|
+
const subs = this.typeSubscriptions.get(taskType);
|
|
314
|
+
if (subs) {
|
|
315
|
+
subs.delete(subscription);
|
|
316
|
+
if (subs.size === 0) {
|
|
317
|
+
this.typeSubscriptions.delete(taskType);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
};
|
|
321
|
+
}
|
|
322
|
+
notifyTypeSubscribers(task, action) {
|
|
323
|
+
const subs = this.typeSubscriptions.get(task.type);
|
|
324
|
+
if (!subs)
|
|
325
|
+
return;
|
|
326
|
+
for (const sub of subs) {
|
|
327
|
+
if (sub.actions.includes(action)) {
|
|
328
|
+
try {
|
|
329
|
+
sub.callback(task);
|
|
330
|
+
}
|
|
331
|
+
catch (error) {
|
|
332
|
+
console.error(`Error in task type callback for ${task.type}:`, error);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
destroy() {
|
|
338
|
+
// Clear all pending timeouts
|
|
339
|
+
this.pendingTimeouts.forEach(id => clearTimeout(id));
|
|
340
|
+
this.pendingTimeouts.clear();
|
|
341
|
+
// Unsubscribe from task stream
|
|
342
|
+
this.taskStreamSubscription?.unsubscribe();
|
|
343
|
+
this.taskStreamSubscription = null;
|
|
344
|
+
this.typeSubscriptions.clear();
|
|
345
|
+
this.taskCallbacks.clear();
|
|
346
|
+
this.tasks.clear();
|
|
347
|
+
this.consoleMessages = [];
|
|
348
|
+
if (this.mockGenerator) {
|
|
349
|
+
this.mockGenerator.stop();
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
}
|
|
@@ -1,8 +1,30 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { Edge, GraphResponse, Node, VacuumResult } from "../model/graph.js";
|
|
2
|
+
import { RenderedNodeComponent } from "../components/model-renderer/rendered-node.js";
|
|
3
|
+
import type { ModelControllerDeps } from "../interfaces/doctor-interfaces.js";
|
|
3
4
|
export declare class ModelController extends EventTarget {
|
|
4
|
-
|
|
5
|
-
|
|
5
|
+
private readonly deps;
|
|
6
|
+
nodes: Node[];
|
|
7
|
+
edges: Edge[];
|
|
8
|
+
nodeMap: Map<string, Node>;
|
|
9
|
+
nodePathIndex: Map<string, Node>;
|
|
10
|
+
violationMap: Map<string, VacuumResult>;
|
|
11
|
+
filteredNodeMap: Map<string, Node>;
|
|
12
|
+
activeNode: Node;
|
|
13
|
+
renderedNodeComponent: RenderedNodeComponent;
|
|
14
|
+
changeNodeMap: Map<string, Node>;
|
|
15
|
+
changeNodePathIndex: Map<string, Node>;
|
|
16
|
+
changeViolationMap: Map<string, VacuumResult>;
|
|
17
|
+
changeReport: GraphResponse | null;
|
|
18
|
+
private _originalNodeMap;
|
|
19
|
+
private _originalNodePathIndex;
|
|
20
|
+
constructor(deps: ModelControllerDeps);
|
|
21
|
+
private populateViolationMap;
|
|
22
|
+
private buildNodeIndices;
|
|
6
23
|
fetchRefMap(currentPath?: string): void;
|
|
7
24
|
extractGraph(graph: GraphResponse): void;
|
|
25
|
+
updateChangeReport(changeReport: GraphResponse): void;
|
|
26
|
+
captureOriginalGraph(): void;
|
|
27
|
+
get originalNodeMap(): Map<string, Node> | null;
|
|
28
|
+
get originalNodePathIndex(): Map<string, Node> | null;
|
|
29
|
+
clearOriginalGraph(): void;
|
|
8
30
|
}
|
|
@@ -1,24 +1,52 @@
|
|
|
1
1
|
import { GraphBag } from "../components/the-doctor/the-doctor.js";
|
|
2
|
-
import { ModelService } from "../services/model-service";
|
|
3
|
-
import { ToastType } from "../model/toast";
|
|
2
|
+
import { ModelService } from "../services/model-service.js";
|
|
3
|
+
import { ToastType } from "../model/toast.js";
|
|
4
4
|
export class ModelController extends EventTarget {
|
|
5
|
-
constructor(
|
|
5
|
+
constructor(deps) {
|
|
6
6
|
super();
|
|
7
|
-
|
|
7
|
+
// original graph snapshot (pre-bundle)
|
|
8
|
+
this._originalNodeMap = null;
|
|
9
|
+
this._originalNodePathIndex = null;
|
|
10
|
+
this.deps = deps;
|
|
11
|
+
this.edges = [];
|
|
12
|
+
this.nodeMap = new Map();
|
|
13
|
+
this.nodePathIndex = new Map();
|
|
14
|
+
this.violationMap = new Map();
|
|
15
|
+
this.changeNodeMap = new Map();
|
|
16
|
+
this.changeNodePathIndex = new Map();
|
|
17
|
+
this.changeViolationMap = new Map();
|
|
18
|
+
this.filteredNodeMap = new Map();
|
|
19
|
+
this.changeReport = null;
|
|
20
|
+
}
|
|
21
|
+
populateViolationMap(violations, targetMap) {
|
|
22
|
+
if (!violations)
|
|
23
|
+
return;
|
|
24
|
+
for (const id in violations) {
|
|
25
|
+
if (Object.prototype.hasOwnProperty.call(violations, id)) {
|
|
26
|
+
targetMap.set(id, violations[id]);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
buildNodeIndices(nodes, idMap, pathMap) {
|
|
31
|
+
for (const node of nodes) {
|
|
32
|
+
idMap.set(node.id, node);
|
|
33
|
+
if (node.nodePath) {
|
|
34
|
+
pathMap.set(node.nodePath, node);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
8
37
|
}
|
|
9
38
|
fetchRefMap(currentPath = '') {
|
|
10
39
|
ModelService.fetchReferenceMap(currentPath).then((result) => {
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
|
|
16
|
-
this.doc.updateRefmapBag(currentPath, result);
|
|
40
|
+
this.deps.editor.clearDecorations();
|
|
41
|
+
this.deps.references = result;
|
|
42
|
+
this.deps.editor.links = result;
|
|
43
|
+
this.deps.editor.applyLinkDecorations();
|
|
44
|
+
this.deps.updateRefmapBag(currentPath, result);
|
|
17
45
|
}).catch((e) => {
|
|
18
46
|
console.error('an error occurred fetching the reference map', currentPath, e);
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
47
|
+
this.deps.editor.clearDecorations();
|
|
48
|
+
this.deps.editor.clearAllMarkers();
|
|
49
|
+
this.deps.sendToast({
|
|
22
50
|
id: crypto.randomUUID(),
|
|
23
51
|
type: ToastType.INFO,
|
|
24
52
|
title: "File not analyzed",
|
|
@@ -27,61 +55,69 @@ export class ModelController extends EventTarget {
|
|
|
27
55
|
});
|
|
28
56
|
}
|
|
29
57
|
extractGraph(graph) {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
58
|
+
this.deps.explorer.nodeLimitExceeded = false;
|
|
59
|
+
// wipe it all out.
|
|
60
|
+
this.nodes = [];
|
|
61
|
+
this.edges = [];
|
|
62
|
+
this.filteredNodeMap.clear();
|
|
63
|
+
this.nodeMap.clear();
|
|
64
|
+
this.nodePathIndex.clear();
|
|
65
|
+
this.violationMap.clear();
|
|
66
|
+
this.populateViolationMap(graph.violations, this.violationMap);
|
|
67
|
+
this.nodes = graph.nodes;
|
|
68
|
+
this.edges = graph.edges;
|
|
69
|
+
this.buildNodeIndices(graph.nodes ?? [], this.nodeMap, this.nodePathIndex);
|
|
70
|
+
for (const node of graph.nodes ?? []) {
|
|
71
|
+
if (node.filtered) {
|
|
72
|
+
this.filteredNodeMap.set(node.id, node);
|
|
73
|
+
}
|
|
74
|
+
if (this.activeNode?.id === node.id && this.renderedNodeComponent) {
|
|
75
|
+
this.renderedNodeComponent.node = node;
|
|
37
76
|
}
|
|
38
77
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
78
|
+
this.deps.graphBag?.set(GraphBag, graph);
|
|
79
|
+
this.deps.explorer.updateGraphResponse(graph);
|
|
80
|
+
this.deps.modelTree.nodeMap = this.nodeMap;
|
|
81
|
+
this.deps.modelTree.violationMap = this.violationMap;
|
|
82
|
+
if (this.renderedNodeComponent) {
|
|
83
|
+
this.renderedNodeComponent.violationMap = this.violationMap;
|
|
42
84
|
}
|
|
43
|
-
this.
|
|
44
|
-
|
|
45
|
-
this.doc.nodeIdMap.clear();
|
|
46
|
-
this.doc.nodeIdHashMap.clear();
|
|
47
|
-
const renderedNodes = new Map();
|
|
48
|
-
graph?.nodesRendered?.forEach((node) => {
|
|
49
|
-
this.doc.explorer.renderedNodeMap.set(node.id, node);
|
|
50
|
-
renderedNodes.set(node.id, node);
|
|
51
|
-
});
|
|
52
|
-
for (let i = 0; i < graph?.nodesRendered?.length; i++) {
|
|
53
|
-
this.doc.renderedNodeMap.set(graph.nodesRendered[i].id, graph.nodesRendered[i]);
|
|
85
|
+
if (this.nodeMap.has('root')) {
|
|
86
|
+
this.deps.modelTree.node = this.nodeMap.get('root');
|
|
54
87
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
this.doc.renderedNode.node = renderedNode;
|
|
72
|
-
}
|
|
88
|
+
}
|
|
89
|
+
// a new change report was selected.
|
|
90
|
+
updateChangeReport(changeReport) {
|
|
91
|
+
this.changeReport = changeReport;
|
|
92
|
+
// iterate through all the nodes in the change report and build a specific map, just for that report
|
|
93
|
+
// so our change explorer can always find everything it's looking for.
|
|
94
|
+
if (this.changeReport) {
|
|
95
|
+
this.changeNodeMap.clear();
|
|
96
|
+
this.changeNodePathIndex.clear();
|
|
97
|
+
this.changeViolationMap.clear();
|
|
98
|
+
this.populateViolationMap(this.changeReport.violations, this.changeViolationMap);
|
|
99
|
+
this.buildNodeIndices(this.changeReport.nodes, this.changeNodeMap, this.changeNodePathIndex);
|
|
100
|
+
// update the time vortex model tree, it maintains its own state.
|
|
101
|
+
if (this.deps.timeVortex?.tardisControl?.modelTree) {
|
|
102
|
+
this.deps.timeVortex.tardisControl.modelTree.nodeMap = this.changeNodeMap;
|
|
103
|
+
this.deps.timeVortex.tardisControl.modelTree.violationMap = this.changeViolationMap;
|
|
73
104
|
}
|
|
74
|
-
});
|
|
75
|
-
this.doc.graphBag?.set(GraphBag, graph);
|
|
76
|
-
this.doc.explorer.updateGraphResponse(graph);
|
|
77
|
-
if (graph && graph.nodes) {
|
|
78
|
-
this.doc.modelTree.node = graph?.nodesRendered[0]; // update tree
|
|
79
105
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
this.
|
|
106
|
+
}
|
|
107
|
+
captureOriginalGraph() {
|
|
108
|
+
if (this.nodeMap && this.nodePathIndex) {
|
|
109
|
+
this._originalNodeMap = new Map(this.nodeMap);
|
|
110
|
+
this._originalNodePathIndex = new Map(this.nodePathIndex);
|
|
85
111
|
}
|
|
86
112
|
}
|
|
113
|
+
get originalNodeMap() {
|
|
114
|
+
return this._originalNodeMap;
|
|
115
|
+
}
|
|
116
|
+
get originalNodePathIndex() {
|
|
117
|
+
return this._originalNodePathIndex;
|
|
118
|
+
}
|
|
119
|
+
clearOriginalGraph() {
|
|
120
|
+
this._originalNodeMap = null;
|
|
121
|
+
this._originalNodePathIndex = null;
|
|
122
|
+
}
|
|
87
123
|
}
|