@pb33f/cowboy-components 0.7.18 → 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/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 -1
- package/dist/cowboy-components.umd.cjs +14117 -6601
- 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/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-B1FBgh0h.js +0 -1
- package/dist/assets/graph-dependent.worker-CxW1u577.js +0 -1
- package/dist/assets/rule-documentation.worker-B4_JKUg4.js +0 -1
- package/dist/assets/search-graph.worker-DJxOIWLn.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/components/{problem-list/details-drawer.css.d.ts → bundle-toolbar/bundle-toolbar.css.d.ts} +0 -0
|
@@ -10,7 +10,7 @@ import { RodeoService } from "../../services/rodeo-service.js";
|
|
|
10
10
|
import './statistic.js';
|
|
11
11
|
import '../terminal-emulator/terminal-emulator.js';
|
|
12
12
|
import roundupCss from "./roundup.css.js";
|
|
13
|
-
import { TerminalEmulator } from "../terminal-emulator/terminal-emulator";
|
|
13
|
+
import { TerminalEmulator, ConsoleMessageType } from "../terminal-emulator/terminal-emulator";
|
|
14
14
|
let RodeoRoundup = class RodeoRoundup extends LitElement {
|
|
15
15
|
constructor() {
|
|
16
16
|
super();
|
|
@@ -36,7 +36,7 @@ let RodeoRoundup = class RodeoRoundup extends LitElement {
|
|
|
36
36
|
}
|
|
37
37
|
pushConsoleEventInfoMessage(evt) {
|
|
38
38
|
const terminalMessage = {
|
|
39
|
-
type:
|
|
39
|
+
type: ConsoleMessageType.Info,
|
|
40
40
|
message: `event: ${evt.event}`,
|
|
41
41
|
metadata: evt.metadata,
|
|
42
42
|
timestamp: new Date().toString()
|
|
@@ -22,7 +22,9 @@ export default css `
|
|
|
22
22
|
height: 30px;
|
|
23
23
|
font-size: 1.2rem;
|
|
24
24
|
font-family: var(--font-stack-bold), serif;
|
|
25
|
-
color: var(--secondary-color)
|
|
25
|
+
color: var(--secondary-color);
|
|
26
|
+
text-transform: uppercase;
|
|
27
|
+
letter-spacing: 0.05em;
|
|
26
28
|
}
|
|
27
29
|
|
|
28
30
|
.title.small {
|
|
@@ -41,7 +43,11 @@ export default css `
|
|
|
41
43
|
color: var(--primary-color);
|
|
42
44
|
text-shadow: 0 0 20px var(--primary-color-lowalpha);
|
|
43
45
|
}
|
|
44
|
-
|
|
46
|
+
|
|
47
|
+
:host-context(html[theme="light"]) .value {
|
|
48
|
+
text-shadow: none;
|
|
49
|
+
}
|
|
50
|
+
|
|
45
51
|
.value.small {
|
|
46
52
|
font-size: 1rem;
|
|
47
53
|
font-family: var(--font-stack-bold), sans-serif;
|
|
@@ -61,11 +67,28 @@ export default css `
|
|
|
61
67
|
transform: scale(1);
|
|
62
68
|
}
|
|
63
69
|
}
|
|
70
|
+
|
|
71
|
+
@keyframes pulse-light {
|
|
72
|
+
0% {
|
|
73
|
+
transform: scale(1);
|
|
74
|
+
}
|
|
75
|
+
50% {
|
|
76
|
+
transform: scale(1.1);
|
|
77
|
+
}
|
|
78
|
+
100% {
|
|
79
|
+
transform: scale(1);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
64
83
|
/* The class that triggers the animation */
|
|
65
84
|
.pulse {
|
|
66
85
|
animation: pulse 200ms ease-out;
|
|
67
86
|
}
|
|
68
87
|
|
|
88
|
+
:host-context(html[theme="light"]) .pulse {
|
|
89
|
+
animation: pulse-light 200ms ease-out;
|
|
90
|
+
}
|
|
91
|
+
|
|
69
92
|
/* New keyframes for the border flash */
|
|
70
93
|
@keyframes borderFlash {
|
|
71
94
|
0% {
|
|
@@ -32,19 +32,15 @@ let Statistic = class Statistic extends LitElement {
|
|
|
32
32
|
}
|
|
33
33
|
updated(changedProperties) {
|
|
34
34
|
if (changedProperties.has('value')) {
|
|
35
|
-
// Animate the value text
|
|
36
35
|
const valueElement = this.shadowRoot?.querySelector('.value');
|
|
37
36
|
if (valueElement) {
|
|
38
37
|
valueElement.classList.remove('pulse');
|
|
39
|
-
//@ts-ignore
|
|
40
38
|
void valueElement.offsetWidth;
|
|
41
39
|
valueElement.classList.add('pulse');
|
|
42
40
|
}
|
|
43
|
-
// Animate the container border
|
|
44
41
|
const statisticElement = this.shadowRoot?.querySelector('.statistic');
|
|
45
42
|
if (statisticElement) {
|
|
46
43
|
statisticElement.classList.remove('border-flash');
|
|
47
|
-
//@ts-ignore
|
|
48
44
|
void statisticElement.offsetWidth;
|
|
49
45
|
statisticElement.classList.add('border-flash');
|
|
50
46
|
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
export default css `
|
|
3
|
+
:host {
|
|
4
|
+
display: block;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
position: relative;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
.shader-container {
|
|
11
|
+
width: 100%;
|
|
12
|
+
height: 100%;
|
|
13
|
+
position: relative;
|
|
14
|
+
background: #000;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
:host-context(html[theme="light"]) .shader-container {
|
|
18
|
+
background: #fff;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
canvas {
|
|
22
|
+
width: 100%;
|
|
23
|
+
height: 100%;
|
|
24
|
+
display: block;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.overlay-text {
|
|
28
|
+
position: absolute;
|
|
29
|
+
top: 50%;
|
|
30
|
+
left: 50%;
|
|
31
|
+
transform: translate(-50%, -50%);
|
|
32
|
+
color: var(--primary-color);
|
|
33
|
+
font-family: var(--font-stack-bold), monospace;
|
|
34
|
+
font-size: 1.8rem;
|
|
35
|
+
font-weight: bold;
|
|
36
|
+
text-transform: uppercase;
|
|
37
|
+
letter-spacing: 0.2em;
|
|
38
|
+
text-shadow:
|
|
39
|
+
/* Black shadow/glow for readability */
|
|
40
|
+
0 0 20px rgba(0, 0, 0, 0.9),
|
|
41
|
+
0 0 40px rgba(0, 0, 0, 0.8),
|
|
42
|
+
0 0 60px rgba(0, 0, 0, 0.7),
|
|
43
|
+
0 0 80px rgba(0, 0, 0, 0.6),
|
|
44
|
+
/* Primary color glow on top */
|
|
45
|
+
0 0 10px var(--primary-color),
|
|
46
|
+
0 0 20px var(--primary-color),
|
|
47
|
+
0 0 30px var(--primary-color);
|
|
48
|
+
pointer-events: none;
|
|
49
|
+
z-index: 10;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
:host-context(html[theme="light"]) .overlay-text {
|
|
53
|
+
color: #000;
|
|
54
|
+
text-shadow: none;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.fallback {
|
|
58
|
+
width: 100%;
|
|
59
|
+
height: 100%;
|
|
60
|
+
display: flex;
|
|
61
|
+
align-items: center;
|
|
62
|
+
justify-content: center;
|
|
63
|
+
color: var(--primary-color);
|
|
64
|
+
font-family: var(--font-stack), monospace;
|
|
65
|
+
}
|
|
66
|
+
`;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { LitElement, PropertyValues } from 'lit';
|
|
2
|
+
import { ShaderModule } from '../shaders/shader-base.js';
|
|
3
|
+
export declare class ShaderCanvas extends LitElement {
|
|
4
|
+
static styles: import("lit").CSSResult[];
|
|
5
|
+
shader: ShaderModule;
|
|
6
|
+
overlayText: string;
|
|
7
|
+
canvas: HTMLCanvasElement;
|
|
8
|
+
webglSupported: boolean;
|
|
9
|
+
private gl;
|
|
10
|
+
private program;
|
|
11
|
+
private animationId;
|
|
12
|
+
private startTime;
|
|
13
|
+
private uniforms;
|
|
14
|
+
private uniformLocations;
|
|
15
|
+
private observer;
|
|
16
|
+
private isWebGL2;
|
|
17
|
+
constructor();
|
|
18
|
+
connectedCallback(): void;
|
|
19
|
+
disconnectedCallback(): void;
|
|
20
|
+
firstUpdated(_changedProperties: PropertyValues): void;
|
|
21
|
+
updated(changedProperties: PropertyValues): void;
|
|
22
|
+
private initWebGL;
|
|
23
|
+
private setupShader;
|
|
24
|
+
private wrapShadertoyShader;
|
|
25
|
+
private isLightMode;
|
|
26
|
+
private updateColorsFromCSS;
|
|
27
|
+
private cssColorToRGB;
|
|
28
|
+
private setupUniforms;
|
|
29
|
+
private compileShader;
|
|
30
|
+
private resizeCanvas;
|
|
31
|
+
renderFrame: () => void;
|
|
32
|
+
private startAnimation;
|
|
33
|
+
private stopAnimation;
|
|
34
|
+
private cleanup;
|
|
35
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
36
|
+
}
|
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { html, LitElement } from 'lit';
|
|
8
|
+
import { customElement, property, query, state } from 'lit/decorators.js';
|
|
9
|
+
import shaderCanvasCss from './shader-canvas.css.js';
|
|
10
|
+
let ShaderCanvas = class ShaderCanvas extends LitElement {
|
|
11
|
+
constructor() {
|
|
12
|
+
super();
|
|
13
|
+
this.overlayText = 'no tasks discovered yet...';
|
|
14
|
+
this.webglSupported = true;
|
|
15
|
+
this.gl = null;
|
|
16
|
+
this.program = null;
|
|
17
|
+
this.animationId = null;
|
|
18
|
+
this.startTime = Date.now();
|
|
19
|
+
this.uniforms = {};
|
|
20
|
+
this.uniformLocations = {};
|
|
21
|
+
this.observer = null;
|
|
22
|
+
this.isWebGL2 = false;
|
|
23
|
+
this.renderFrame = () => {
|
|
24
|
+
if (!this.gl || !this.program) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const time = (Date.now() - this.startTime) / 1000;
|
|
28
|
+
// Update colors and light mode every frame to handle theme changes
|
|
29
|
+
this.updateColorsFromCSS();
|
|
30
|
+
// Update shader uniforms
|
|
31
|
+
if (this.shader?.onFrame) {
|
|
32
|
+
this.shader.onFrame(time, this.uniforms);
|
|
33
|
+
}
|
|
34
|
+
// Set uniforms
|
|
35
|
+
this.gl.useProgram(this.program);
|
|
36
|
+
Object.entries(this.uniformLocations).forEach(([name, location]) => {
|
|
37
|
+
const value = this.uniforms[name];
|
|
38
|
+
if (value !== undefined) {
|
|
39
|
+
if (Array.isArray(value)) {
|
|
40
|
+
const floatArray = value;
|
|
41
|
+
if (floatArray.length === 2) {
|
|
42
|
+
this.gl.uniform2fv(location, floatArray);
|
|
43
|
+
}
|
|
44
|
+
else if (floatArray.length === 3) {
|
|
45
|
+
this.gl.uniform3fv(location, floatArray);
|
|
46
|
+
}
|
|
47
|
+
else if (floatArray.length === 4) {
|
|
48
|
+
this.gl.uniform4fv(location, floatArray);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
this.gl.uniform1f(location, value);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
// Draw
|
|
57
|
+
this.gl.drawArrays(this.gl.TRIANGLES, 0, 6);
|
|
58
|
+
this.animationId = requestAnimationFrame(this.renderFrame);
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
connectedCallback() {
|
|
62
|
+
super.connectedCallback();
|
|
63
|
+
// Set up intersection observer for performance
|
|
64
|
+
this.observer = new IntersectionObserver((entries) => {
|
|
65
|
+
entries.forEach(entry => {
|
|
66
|
+
if (entry.isIntersecting) {
|
|
67
|
+
this.startAnimation();
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.stopAnimation();
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
this.observer.observe(this);
|
|
75
|
+
}
|
|
76
|
+
disconnectedCallback() {
|
|
77
|
+
super.disconnectedCallback();
|
|
78
|
+
if (this.observer) {
|
|
79
|
+
this.observer.disconnect();
|
|
80
|
+
this.observer = null;
|
|
81
|
+
}
|
|
82
|
+
this.stopAnimation();
|
|
83
|
+
this.cleanup();
|
|
84
|
+
}
|
|
85
|
+
firstUpdated(_changedProperties) {
|
|
86
|
+
super.firstUpdated(_changedProperties);
|
|
87
|
+
// Initialize WebGL after the canvas is rendered
|
|
88
|
+
if (this.shader && !this.gl) {
|
|
89
|
+
this.initWebGL();
|
|
90
|
+
// Animation will be started by IntersectionObserver
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
updated(changedProperties) {
|
|
94
|
+
super.updated(changedProperties);
|
|
95
|
+
if (changedProperties.has('shader') && this.shader && this.canvas && !this.gl) {
|
|
96
|
+
this.initWebGL();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
initWebGL() {
|
|
100
|
+
if (!this.canvas) {
|
|
101
|
+
console.error('Canvas not found');
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
this.cleanup();
|
|
105
|
+
try {
|
|
106
|
+
// Try WebGL 2.0 first, then fall back to WebGL 1.0
|
|
107
|
+
this.gl = this.canvas.getContext('webgl2');
|
|
108
|
+
if (this.gl) {
|
|
109
|
+
this.isWebGL2 = true;
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
// Fall back to WebGL 1.0
|
|
113
|
+
this.gl = this.canvas.getContext('webgl') || this.canvas.getContext('experimental-webgl');
|
|
114
|
+
this.isWebGL2 = false;
|
|
115
|
+
}
|
|
116
|
+
if (!this.gl) {
|
|
117
|
+
console.error('WebGL context not available');
|
|
118
|
+
this.webglSupported = false;
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
this.setupShader();
|
|
122
|
+
// Ensure canvas is properly sized after shader setup
|
|
123
|
+
requestAnimationFrame(() => {
|
|
124
|
+
this.resizeCanvas();
|
|
125
|
+
});
|
|
126
|
+
window.addEventListener('resize', this.resizeCanvas.bind(this));
|
|
127
|
+
}
|
|
128
|
+
catch (e) {
|
|
129
|
+
console.error('WebGL initialization failed:', e);
|
|
130
|
+
this.webglSupported = false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
setupShader() {
|
|
134
|
+
if (!this.gl || !this.shader) {
|
|
135
|
+
console.error('Missing GL or shader');
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
// Wrap Shadertoy-style shaders with proper WebGL 2.0 boilerplate
|
|
139
|
+
let processedFragShader = this.shader.fragmentShader;
|
|
140
|
+
if (this.isWebGL2 && !processedFragShader.includes('#version')) {
|
|
141
|
+
// This is likely a Shadertoy shader - wrap it
|
|
142
|
+
processedFragShader = this.wrapShadertoyShader(processedFragShader);
|
|
143
|
+
}
|
|
144
|
+
// Use WebGL 2.0 vertex shader if needed
|
|
145
|
+
let vertexShaderCode = this.shader.vertexShader;
|
|
146
|
+
if (this.isWebGL2 && !vertexShaderCode.includes('#version')) {
|
|
147
|
+
vertexShaderCode = `#version 300 es
|
|
148
|
+
in vec2 position;
|
|
149
|
+
void main() {
|
|
150
|
+
gl_Position = vec4(position, 0.0, 1.0);
|
|
151
|
+
}`;
|
|
152
|
+
}
|
|
153
|
+
const vertShader = this.compileShader(this.gl.VERTEX_SHADER, vertexShaderCode);
|
|
154
|
+
const fragShader = this.compileShader(this.gl.FRAGMENT_SHADER, processedFragShader);
|
|
155
|
+
if (!vertShader || !fragShader) {
|
|
156
|
+
console.error('Failed to compile shaders');
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
this.program = this.gl.createProgram();
|
|
160
|
+
this.gl.attachShader(this.program, vertShader);
|
|
161
|
+
this.gl.attachShader(this.program, fragShader);
|
|
162
|
+
this.gl.linkProgram(this.program);
|
|
163
|
+
if (!this.gl.getProgramParameter(this.program, this.gl.LINK_STATUS)) {
|
|
164
|
+
console.error('Shader program failed to link:', this.gl.getProgramInfoLog(this.program));
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
// Set up vertex buffer
|
|
168
|
+
const vertices = new Float32Array([
|
|
169
|
+
-1, -1, 1, -1, -1, 1,
|
|
170
|
+
-1, 1, 1, -1, 1, 1
|
|
171
|
+
]);
|
|
172
|
+
const buffer = this.gl.createBuffer();
|
|
173
|
+
this.gl.bindBuffer(this.gl.ARRAY_BUFFER, buffer);
|
|
174
|
+
this.gl.bufferData(this.gl.ARRAY_BUFFER, vertices, this.gl.STATIC_DRAW);
|
|
175
|
+
const positionLoc = this.gl.getAttribLocation(this.program, 'position');
|
|
176
|
+
this.gl.enableVertexAttribArray(positionLoc);
|
|
177
|
+
this.gl.vertexAttribPointer(positionLoc, 2, this.gl.FLOAT, false, 0, 0);
|
|
178
|
+
// Set up uniforms
|
|
179
|
+
this.gl.useProgram(this.program);
|
|
180
|
+
this.setupUniforms();
|
|
181
|
+
// Get CSS colors and convert to RGB
|
|
182
|
+
this.updateColorsFromCSS();
|
|
183
|
+
}
|
|
184
|
+
wrapShadertoyShader(shaderCode) {
|
|
185
|
+
// WebGL 2.0 wrapper for Shadertoy shaders
|
|
186
|
+
return `#version 300 es
|
|
187
|
+
precision highp float;
|
|
188
|
+
|
|
189
|
+
uniform float time;
|
|
190
|
+
uniform vec2 resolution;
|
|
191
|
+
uniform vec3 primaryColor;
|
|
192
|
+
uniform vec3 secondaryColor;
|
|
193
|
+
uniform vec3 tertiaryColor;
|
|
194
|
+
uniform float lightMode;
|
|
195
|
+
|
|
196
|
+
out vec4 fragColor;
|
|
197
|
+
|
|
198
|
+
// Shadertoy compatibility
|
|
199
|
+
#define iTime time
|
|
200
|
+
#define iResolution vec3(resolution, 1.0)
|
|
201
|
+
|
|
202
|
+
// Light mode colors for subtractive rendering (subtract from white)
|
|
203
|
+
// Higher values = darker result
|
|
204
|
+
vec3 getLightModeColor(int index) {
|
|
205
|
+
if (index == 0) return vec3(1.0); // black (subtract most)
|
|
206
|
+
if (index == 1) return vec3(0.6); // dark grey
|
|
207
|
+
return vec3(0.3); // light grey (subtract least)
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
${shaderCode}
|
|
211
|
+
|
|
212
|
+
void main() {
|
|
213
|
+
mainImage(fragColor, gl_FragCoord.xy);
|
|
214
|
+
}`;
|
|
215
|
+
}
|
|
216
|
+
isLightMode() {
|
|
217
|
+
return document.documentElement.getAttribute('theme') === 'light';
|
|
218
|
+
}
|
|
219
|
+
updateColorsFromCSS() {
|
|
220
|
+
if (!this.gl || !this.program)
|
|
221
|
+
return;
|
|
222
|
+
const styles = getComputedStyle(this);
|
|
223
|
+
const primaryRaw = styles.getPropertyValue('--primary-color');
|
|
224
|
+
const secondaryRaw = styles.getPropertyValue('--secondary-color');
|
|
225
|
+
const tertiaryRaw = styles.getPropertyValue('--tertiary-color');
|
|
226
|
+
const colors = {
|
|
227
|
+
primaryColor: this.cssColorToRGB(primaryRaw),
|
|
228
|
+
secondaryColor: this.cssColorToRGB(secondaryRaw),
|
|
229
|
+
tertiaryColor: this.cssColorToRGB(tertiaryRaw)
|
|
230
|
+
};
|
|
231
|
+
Object.entries(colors).forEach(([name, value]) => {
|
|
232
|
+
if (this.uniformLocations[name]) {
|
|
233
|
+
this.uniforms[name] = value;
|
|
234
|
+
}
|
|
235
|
+
});
|
|
236
|
+
this.uniforms.lightMode = this.isLightMode() ? 1.0 : 0.0;
|
|
237
|
+
}
|
|
238
|
+
cssColorToRGB(color) {
|
|
239
|
+
// Handle CSS variables and hex colors
|
|
240
|
+
const trimmed = color.trim();
|
|
241
|
+
// If it's empty or undefined, use default
|
|
242
|
+
if (!trimmed) {
|
|
243
|
+
return [0, 1, 1]; // cyan
|
|
244
|
+
}
|
|
245
|
+
// Handle hex colors
|
|
246
|
+
if (trimmed.startsWith('#')) {
|
|
247
|
+
let hex = trimmed.slice(1);
|
|
248
|
+
// Handle 3-digit hex
|
|
249
|
+
if (hex.length === 3) {
|
|
250
|
+
hex = hex.split('').map(c => c + c).join('');
|
|
251
|
+
}
|
|
252
|
+
const r = parseInt(hex.slice(0, 2), 16) / 255 || 0;
|
|
253
|
+
const g = parseInt(hex.slice(2, 4), 16) / 255 || 0;
|
|
254
|
+
const b = parseInt(hex.slice(4, 6), 16) / 255 || 0;
|
|
255
|
+
return [r, g, b];
|
|
256
|
+
}
|
|
257
|
+
// Handle rgb/rgba
|
|
258
|
+
const rgbMatch = trimmed.match(/rgba?\((\d+),\s*(\d+),\s*(\d+)/);
|
|
259
|
+
if (rgbMatch) {
|
|
260
|
+
return [
|
|
261
|
+
parseInt(rgbMatch[1]) / 255,
|
|
262
|
+
parseInt(rgbMatch[2]) / 255,
|
|
263
|
+
parseInt(rgbMatch[3]) / 255
|
|
264
|
+
];
|
|
265
|
+
}
|
|
266
|
+
// Default cyan if parsing fails
|
|
267
|
+
console.error('the doctor has an issue with color! could not parse color:', color);
|
|
268
|
+
return [0, 1, 1];
|
|
269
|
+
}
|
|
270
|
+
setupUniforms() {
|
|
271
|
+
if (!this.gl || !this.program || !this.shader)
|
|
272
|
+
return;
|
|
273
|
+
// Copy default uniforms
|
|
274
|
+
if (this.shader.uniforms) {
|
|
275
|
+
this.uniforms = { ...this.shader.uniforms };
|
|
276
|
+
}
|
|
277
|
+
// Get uniform locations
|
|
278
|
+
const numUniforms = this.gl.getProgramParameter(this.program, this.gl.ACTIVE_UNIFORMS);
|
|
279
|
+
for (let i = 0; i < numUniforms; i++) {
|
|
280
|
+
const info = this.gl.getActiveUniform(this.program, i);
|
|
281
|
+
if (info) {
|
|
282
|
+
const location = this.gl.getUniformLocation(this.program, info.name);
|
|
283
|
+
if (location) {
|
|
284
|
+
this.uniformLocations[info.name] = location;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
compileShader(type, source) {
|
|
290
|
+
if (!this.gl)
|
|
291
|
+
return null;
|
|
292
|
+
const shader = this.gl.createShader(type);
|
|
293
|
+
this.gl.shaderSource(shader, source);
|
|
294
|
+
this.gl.compileShader(shader);
|
|
295
|
+
if (!this.gl.getShaderParameter(shader, this.gl.COMPILE_STATUS)) {
|
|
296
|
+
console.error('Shader compilation failed:', this.gl.getShaderInfoLog(shader));
|
|
297
|
+
this.gl.deleteShader(shader);
|
|
298
|
+
return null;
|
|
299
|
+
}
|
|
300
|
+
return shader;
|
|
301
|
+
}
|
|
302
|
+
resizeCanvas() {
|
|
303
|
+
if (!this.canvas)
|
|
304
|
+
return;
|
|
305
|
+
const rect = this.canvas.getBoundingClientRect();
|
|
306
|
+
const maxDpr = this.shader?.lowResolution ? 1.0 : (window.devicePixelRatio || 1);
|
|
307
|
+
const dpr = Math.min(maxDpr, window.devicePixelRatio || 1);
|
|
308
|
+
this.canvas.width = rect.width * dpr;
|
|
309
|
+
this.canvas.height = rect.height * dpr;
|
|
310
|
+
if (this.gl) {
|
|
311
|
+
this.gl.viewport(0, 0, this.canvas.width, this.canvas.height);
|
|
312
|
+
this.uniforms.resolution = [this.canvas.width, this.canvas.height];
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
startAnimation() {
|
|
316
|
+
if (!this.animationId && this.isConnected) {
|
|
317
|
+
this.renderFrame();
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
stopAnimation() {
|
|
321
|
+
if (this.animationId) {
|
|
322
|
+
cancelAnimationFrame(this.animationId);
|
|
323
|
+
this.animationId = null;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
cleanup() {
|
|
327
|
+
this.stopAnimation();
|
|
328
|
+
if (this.gl && this.program) {
|
|
329
|
+
this.gl.deleteProgram(this.program);
|
|
330
|
+
this.program = null;
|
|
331
|
+
}
|
|
332
|
+
this.gl = null;
|
|
333
|
+
this.uniformLocations = {};
|
|
334
|
+
}
|
|
335
|
+
render() {
|
|
336
|
+
if (!this.webglSupported) {
|
|
337
|
+
return html `<div class="fallback">WebGL not supported</div>`;
|
|
338
|
+
}
|
|
339
|
+
return html `
|
|
340
|
+
<div class="shader-container">
|
|
341
|
+
<canvas></canvas>
|
|
342
|
+
<div class="overlay-text">${this.overlayText}</div>
|
|
343
|
+
</div>
|
|
344
|
+
`;
|
|
345
|
+
}
|
|
346
|
+
};
|
|
347
|
+
ShaderCanvas.styles = [shaderCanvasCss];
|
|
348
|
+
__decorate([
|
|
349
|
+
property({ type: Object })
|
|
350
|
+
], ShaderCanvas.prototype, "shader", void 0);
|
|
351
|
+
__decorate([
|
|
352
|
+
property({ type: String })
|
|
353
|
+
], ShaderCanvas.prototype, "overlayText", void 0);
|
|
354
|
+
__decorate([
|
|
355
|
+
query('canvas')
|
|
356
|
+
], ShaderCanvas.prototype, "canvas", void 0);
|
|
357
|
+
__decorate([
|
|
358
|
+
state()
|
|
359
|
+
], ShaderCanvas.prototype, "webglSupported", void 0);
|
|
360
|
+
ShaderCanvas = __decorate([
|
|
361
|
+
customElement('pb33f-shader-canvas')
|
|
362
|
+
], ShaderCanvas);
|
|
363
|
+
export { ShaderCanvas };
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { defaultVertexShader } from './shader-base';
|
|
2
|
+
export const flowingWavesShader = {
|
|
3
|
+
vertexShader: defaultVertexShader,
|
|
4
|
+
lowResolution: true,
|
|
5
|
+
// Flowing waves shader with pb33f colors
|
|
6
|
+
fragmentShader: `
|
|
7
|
+
vec3 tonemap(vec3 v) {
|
|
8
|
+
return mix(v, vec3(1.), smoothstep(1., 4., dot(v, vec3(1.))));
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
float f1(float x, float offset, float freq) {
|
|
12
|
+
return .4 * sin(0.523599 * x + offset) + .1 * sin(freq * x); // 0.523599 = radians(30)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
void mainImage( out vec4 fragColor, in vec2 fragCoord ) {
|
|
16
|
+
float scale = iResolution.y;
|
|
17
|
+
vec2 uv = (2. * fragCoord - iResolution.xy) / scale;
|
|
18
|
+
|
|
19
|
+
vec3 col = lightMode > 0.5 ? vec3(1.0) : vec3(0.0);
|
|
20
|
+
|
|
21
|
+
float offsets[3];
|
|
22
|
+
offsets[0] = 0.;
|
|
23
|
+
offsets[1] = 2.0944; // radians(120)
|
|
24
|
+
offsets[2] = 4.1888; // radians(240)
|
|
25
|
+
|
|
26
|
+
float freqs[3];
|
|
27
|
+
freqs[0] = 2.793; // radians(160)
|
|
28
|
+
freqs[1] = 3.717; // radians(213)
|
|
29
|
+
freqs[2] = 3.246; // radians(186)
|
|
30
|
+
|
|
31
|
+
for (int i = 0; i < 3; ++i) {
|
|
32
|
+
float x = uv.x + 4. * iTime;
|
|
33
|
+
float y = f1(x, offsets[i], freqs[i]);
|
|
34
|
+
float uv_x = min(uv.x, 1. + .4 * sin(3.665 * iTime + 2.0944 * float(i))); // 3.665 = radians(210)
|
|
35
|
+
|
|
36
|
+
float r = uv.x / 40.;
|
|
37
|
+
float d1 = length(vec2(uv_x, y) - uv) - r;
|
|
38
|
+
|
|
39
|
+
// Use pb33f colors or light mode grays
|
|
40
|
+
vec3 waveColor;
|
|
41
|
+
if (lightMode > 0.5) {
|
|
42
|
+
waveColor = getLightModeColor(i) * 2.5;
|
|
43
|
+
} else {
|
|
44
|
+
if (i == 0) waveColor = primaryColor * 2.;
|
|
45
|
+
else if (i == 1) waveColor = secondaryColor * 2.;
|
|
46
|
+
else waveColor = tertiaryColor * 1.5;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
float intensity = 1. / pow(max(1., d1 * scale), .8 + .1 * sin(4.276 * iTime + 2.0944 * float(i))); // 4.276 = radians(245)
|
|
50
|
+
if (lightMode > 0.5) {
|
|
51
|
+
col -= intensity * waveColor;
|
|
52
|
+
} else {
|
|
53
|
+
col += intensity * waveColor;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
fragColor = vec4(tonemap(col), 1.);
|
|
58
|
+
}
|
|
59
|
+
`,
|
|
60
|
+
uniforms: {
|
|
61
|
+
time: 0,
|
|
62
|
+
resolution: [800, 600],
|
|
63
|
+
primaryColor: [0, 1, 1], // Cyan
|
|
64
|
+
secondaryColor: [1, 0.4, 0.7], // Pink
|
|
65
|
+
tertiaryColor: [0.5, 0.5, 1]
|
|
66
|
+
},
|
|
67
|
+
onFrame: (time, uniforms) => {
|
|
68
|
+
uniforms.time = time;
|
|
69
|
+
}
|
|
70
|
+
};
|