@n-dx/web 0.1.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/LICENSE +96 -0
- package/README.md +5 -0
- package/build.js +243 -0
- package/dist/cli/index.d.ts +8 -0
- package/dist/cli/index.js +50 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/landing/index.html +325 -0
- package/dist/landing/landing.d.ts +38 -0
- package/dist/landing/landing.js +299 -0
- package/dist/landing/landing.js.map +1 -0
- package/dist/public.d.ts +55 -0
- package/dist/public.js +51 -0
- package/dist/public.js.map +1 -0
- package/dist/schema/features.d.ts +28 -0
- package/dist/schema/features.js +9 -0
- package/dist/schema/features.js.map +1 -0
- package/dist/schema/v1.d.ts +317 -0
- package/dist/schema/v1.js +3 -0
- package/dist/schema/v1.js.map +1 -0
- package/dist/server/aggregation-cache.d.ts +105 -0
- package/dist/server/aggregation-cache.js +163 -0
- package/dist/server/aggregation-cache.js.map +1 -0
- package/dist/server/concurrent-execution-metrics.d.ts +103 -0
- package/dist/server/concurrent-execution-metrics.js +253 -0
- package/dist/server/concurrent-execution-metrics.js.map +1 -0
- package/dist/server/domain-gateway.d.ts +18 -0
- package/dist/server/domain-gateway.js +19 -0
- package/dist/server/domain-gateway.js.map +1 -0
- package/dist/server/incremental-task-usage.d.ts +92 -0
- package/dist/server/incremental-task-usage.js +251 -0
- package/dist/server/incremental-task-usage.js.map +1 -0
- package/dist/server/index.d.ts +39 -0
- package/dist/server/index.js +36 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/port.d.ts +96 -0
- package/dist/server/port.js +134 -0
- package/dist/server/port.js.map +1 -0
- package/dist/server/pr-markdown-refresh-diagnostics.d.ts +59 -0
- package/dist/server/pr-markdown-refresh-diagnostics.js +429 -0
- package/dist/server/pr-markdown-refresh-diagnostics.js.map +1 -0
- package/dist/server/prd-io.d.ts +40 -0
- package/dist/server/prd-io.js +66 -0
- package/dist/server/prd-io.js.map +1 -0
- package/dist/server/process-memory-tracker.d.ts +79 -0
- package/dist/server/process-memory-tracker.js +194 -0
- package/dist/server/process-memory-tracker.js.map +1 -0
- package/dist/server/register-scheduler.d.ts +53 -0
- package/dist/server/register-scheduler.js +36 -0
- package/dist/server/register-scheduler.js.map +1 -0
- package/dist/server/rex-gateway.d.ts +39 -0
- package/dist/server/rex-gateway.js +47 -0
- package/dist/server/rex-gateway.js.map +1 -0
- package/dist/server/routes-adaptive.d.ts +21 -0
- package/dist/server/routes-adaptive.js +659 -0
- package/dist/server/routes-adaptive.js.map +1 -0
- package/dist/server/routes-config.d.ts +47 -0
- package/dist/server/routes-config.js +222 -0
- package/dist/server/routes-config.js.map +1 -0
- package/dist/server/routes-data.d.ts +14 -0
- package/dist/server/routes-data.js +129 -0
- package/dist/server/routes-data.js.map +1 -0
- package/dist/server/routes-features.d.ts +14 -0
- package/dist/server/routes-features.js +245 -0
- package/dist/server/routes-features.js.map +1 -0
- package/dist/server/routes-hench.d.ts +116 -0
- package/dist/server/routes-hench.js +2016 -0
- package/dist/server/routes-hench.js.map +1 -0
- package/dist/server/routes-integrations.d.ts +23 -0
- package/dist/server/routes-integrations.js +277 -0
- package/dist/server/routes-integrations.js.map +1 -0
- package/dist/server/routes-mcp.d.ts +31 -0
- package/dist/server/routes-mcp.js +175 -0
- package/dist/server/routes-mcp.js.map +1 -0
- package/dist/server/routes-notion.d.ts +23 -0
- package/dist/server/routes-notion.js +723 -0
- package/dist/server/routes-notion.js.map +1 -0
- package/dist/server/routes-project.d.ts +47 -0
- package/dist/server/routes-project.js +128 -0
- package/dist/server/routes-project.js.map +1 -0
- package/dist/server/routes-rex/analysis.d.ts +11 -0
- package/dist/server/routes-rex/analysis.js +583 -0
- package/dist/server/routes-rex/analysis.js.map +1 -0
- package/dist/server/routes-rex/execution.d.ts +37 -0
- package/dist/server/routes-rex/execution.js +355 -0
- package/dist/server/routes-rex/execution.js.map +1 -0
- package/dist/server/routes-rex/health.d.ts +8 -0
- package/dist/server/routes-rex/health.js +136 -0
- package/dist/server/routes-rex/health.js.map +1 -0
- package/dist/server/routes-rex/index.d.ts +35 -0
- package/dist/server/routes-rex/index.js +72 -0
- package/dist/server/routes-rex/index.js.map +1 -0
- package/dist/server/routes-rex/items.d.ts +8 -0
- package/dist/server/routes-rex/items.js +359 -0
- package/dist/server/routes-rex/items.js.map +1 -0
- package/dist/server/routes-rex/prune.d.ts +11 -0
- package/dist/server/routes-rex/prune.js +379 -0
- package/dist/server/routes-rex/prune.js.map +1 -0
- package/dist/server/routes-rex/reads.d.ts +9 -0
- package/dist/server/routes-rex/reads.js +119 -0
- package/dist/server/routes-rex/reads.js.map +1 -0
- package/dist/server/routes-rex/requirements.d.ts +10 -0
- package/dist/server/routes-rex/requirements.js +408 -0
- package/dist/server/routes-rex/requirements.js.map +1 -0
- package/dist/server/routes-rex/shared.d.ts +37 -0
- package/dist/server/routes-rex/shared.js +73 -0
- package/dist/server/routes-rex/shared.js.map +1 -0
- package/dist/server/routes-search.d.ts +26 -0
- package/dist/server/routes-search.js +82 -0
- package/dist/server/routes-search.js.map +1 -0
- package/dist/server/routes-sourcevision.d.ts +18 -0
- package/dist/server/routes-sourcevision.js +444 -0
- package/dist/server/routes-sourcevision.js.map +1 -0
- package/dist/server/routes-static.d.ts +20 -0
- package/dist/server/routes-static.js +168 -0
- package/dist/server/routes-static.js.map +1 -0
- package/dist/server/routes-status.d.ts +58 -0
- package/dist/server/routes-status.js +191 -0
- package/dist/server/routes-status.js.map +1 -0
- package/dist/server/routes-token-usage.d.ts +63 -0
- package/dist/server/routes-token-usage.js +720 -0
- package/dist/server/routes-token-usage.js.map +1 -0
- package/dist/server/routes-validation.d.ts +10 -0
- package/dist/server/routes-validation.js +365 -0
- package/dist/server/routes-validation.js.map +1 -0
- package/dist/server/routes-workflow.d.ts +15 -0
- package/dist/server/routes-workflow.js +498 -0
- package/dist/server/routes-workflow.js.map +1 -0
- package/dist/server/search-index.d.ts +111 -0
- package/dist/server/search-index.js +348 -0
- package/dist/server/search-index.js.map +1 -0
- package/dist/server/shared-types.d.ts +65 -0
- package/dist/server/shared-types.js +31 -0
- package/dist/server/shared-types.js.map +1 -0
- package/dist/server/start.d.ts +68 -0
- package/dist/server/start.js +568 -0
- package/dist/server/start.js.map +1 -0
- package/dist/server/task-usage.d.ts +17 -0
- package/dist/server/task-usage.js +20 -0
- package/dist/server/task-usage.js.map +1 -0
- package/dist/server/types.d.ts +27 -0
- package/dist/server/types.js +26 -0
- package/dist/server/types.js.map +1 -0
- package/dist/server/usage-cleanup-scheduler.d.ts +107 -0
- package/dist/server/usage-cleanup-scheduler.js +232 -0
- package/dist/server/usage-cleanup-scheduler.js.map +1 -0
- package/dist/server/websocket.d.ts +131 -0
- package/dist/server/websocket.js +512 -0
- package/dist/server/websocket.js.map +1 -0
- package/dist/shared/data-files.d.ts +17 -0
- package/dist/shared/data-files.js +18 -0
- package/dist/shared/data-files.js.map +1 -0
- package/dist/shared/index.d.ts +9 -0
- package/dist/shared/index.js +9 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/view-id.d.ts +8 -0
- package/dist/shared/view-id.js +9 -0
- package/dist/shared/view-id.js.map +1 -0
- package/dist/viewer/Hench-F.png +0 -0
- package/dist/viewer/Rex-F.png +0 -0
- package/dist/viewer/SourceVision-F.png +0 -0
- package/dist/viewer/SourceVision.png +0 -0
- package/dist/viewer/api.d.ts +19 -0
- package/dist/viewer/api.js +17 -0
- package/dist/viewer/api.js.map +1 -0
- package/dist/viewer/bootstrap.d.ts +13 -0
- package/dist/viewer/bootstrap.js +40 -0
- package/dist/viewer/bootstrap.js.map +1 -0
- package/dist/viewer/components/active-tasks-panel.d.ts +36 -0
- package/dist/viewer/components/active-tasks-panel.js +183 -0
- package/dist/viewer/components/active-tasks-panel.js.map +1 -0
- package/dist/viewer/components/breadcrumb.d.ts +21 -0
- package/dist/viewer/components/breadcrumb.js +117 -0
- package/dist/viewer/components/breadcrumb.js.map +1 -0
- package/dist/viewer/components/concurrency-panel.d.ts +18 -0
- package/dist/viewer/components/concurrency-panel.js +175 -0
- package/dist/viewer/components/concurrency-panel.js.map +1 -0
- package/dist/viewer/components/config-footer.d.ts +11 -0
- package/dist/viewer/components/config-footer.js +132 -0
- package/dist/viewer/components/config-footer.js.map +1 -0
- package/dist/viewer/components/constants.d.ts +10 -0
- package/dist/viewer/components/constants.js +11 -0
- package/dist/viewer/components/constants.js.map +1 -0
- package/dist/viewer/components/copy-link-button.d.ts +30 -0
- package/dist/viewer/components/copy-link-button.js +74 -0
- package/dist/viewer/components/copy-link-button.js.map +1 -0
- package/dist/viewer/components/crash-recovery-banner.d.ts +28 -0
- package/dist/viewer/components/crash-recovery-banner.js +47 -0
- package/dist/viewer/components/crash-recovery-banner.js.map +1 -0
- package/dist/viewer/components/data-display/collapsible-section.d.ts +14 -0
- package/dist/viewer/components/data-display/collapsible-section.js +66 -0
- package/dist/viewer/components/data-display/collapsible-section.js.map +1 -0
- package/dist/viewer/components/data-display/findings-list.d.ts +13 -0
- package/dist/viewer/components/data-display/findings-list.js +136 -0
- package/dist/viewer/components/data-display/findings-list.js.map +1 -0
- package/dist/viewer/components/data-display/health-gauge.d.ts +37 -0
- package/dist/viewer/components/data-display/health-gauge.js +62 -0
- package/dist/viewer/components/data-display/health-gauge.js.map +1 -0
- package/dist/viewer/components/data-display/mini-charts.d.ts +36 -0
- package/dist/viewer/components/data-display/mini-charts.js +124 -0
- package/dist/viewer/components/data-display/mini-charts.js.map +1 -0
- package/dist/viewer/components/data-display/tree-view.d.ts +18 -0
- package/dist/viewer/components/data-display/tree-view.js +107 -0
- package/dist/viewer/components/data-display/tree-view.js.map +1 -0
- package/dist/viewer/components/data-display/zone-map.d.ts +28 -0
- package/dist/viewer/components/data-display/zone-map.js +197 -0
- package/dist/viewer/components/data-display/zone-map.js.map +1 -0
- package/dist/viewer/components/degradation-banner.d.ts +28 -0
- package/dist/viewer/components/degradation-banner.js +47 -0
- package/dist/viewer/components/degradation-banner.js.map +1 -0
- package/dist/viewer/components/detail-panel.d.ts +12 -0
- package/dist/viewer/components/detail-panel.js +166 -0
- package/dist/viewer/components/detail-panel.js.map +1 -0
- package/dist/viewer/components/elapsed-time.d.ts +38 -0
- package/dist/viewer/components/elapsed-time.js +35 -0
- package/dist/viewer/components/elapsed-time.js.map +1 -0
- package/dist/viewer/components/faq.d.ts +12 -0
- package/dist/viewer/components/faq.js +237 -0
- package/dist/viewer/components/faq.js.map +1 -0
- package/dist/viewer/components/favicon.d.ts +30 -0
- package/dist/viewer/components/favicon.js +90 -0
- package/dist/viewer/components/favicon.js.map +1 -0
- package/dist/viewer/components/guide.d.ts +5 -0
- package/dist/viewer/components/guide.js +116 -0
- package/dist/viewer/components/guide.js.map +1 -0
- package/dist/viewer/components/index.d.ts +37 -0
- package/dist/viewer/components/index.js +46 -0
- package/dist/viewer/components/index.js.map +1 -0
- package/dist/viewer/components/logos.d.ts +42 -0
- package/dist/viewer/components/logos.js +46 -0
- package/dist/viewer/components/logos.js.map +1 -0
- package/dist/viewer/components/memory-panel.d.ts +19 -0
- package/dist/viewer/components/memory-panel.js +181 -0
- package/dist/viewer/components/memory-panel.js.map +1 -0
- package/dist/viewer/components/memory-warning.d.ts +23 -0
- package/dist/viewer/components/memory-warning.js +42 -0
- package/dist/viewer/components/memory-warning.js.map +1 -0
- package/dist/viewer/components/notion-schema-wizard.d.ts +16 -0
- package/dist/viewer/components/notion-schema-wizard.js +263 -0
- package/dist/viewer/components/notion-schema-wizard.js.map +1 -0
- package/dist/viewer/components/polling-suspension-indicator.d.ts +24 -0
- package/dist/viewer/components/polling-suspension-indicator.js +31 -0
- package/dist/viewer/components/polling-suspension-indicator.js.map +1 -0
- package/dist/viewer/components/prd-tree/add-item-form.d.ts +31 -0
- package/dist/viewer/components/prd-tree/add-item-form.js +231 -0
- package/dist/viewer/components/prd-tree/add-item-form.js.map +1 -0
- package/dist/viewer/components/prd-tree/analyze-panel.d.ts +13 -0
- package/dist/viewer/components/prd-tree/analyze-panel.js +245 -0
- package/dist/viewer/components/prd-tree/analyze-panel.js.map +1 -0
- package/dist/viewer/components/prd-tree/batch-import-panel.d.ts +34 -0
- package/dist/viewer/components/prd-tree/batch-import-panel.js +415 -0
- package/dist/viewer/components/prd-tree/batch-import-panel.js.map +1 -0
- package/dist/viewer/components/prd-tree/bulk-actions.d.ts +19 -0
- package/dist/viewer/components/prd-tree/bulk-actions.js +90 -0
- package/dist/viewer/components/prd-tree/bulk-actions.js.map +1 -0
- package/dist/viewer/components/prd-tree/compute.d.ts +32 -0
- package/dist/viewer/components/prd-tree/compute.js +129 -0
- package/dist/viewer/components/prd-tree/compute.js.map +1 -0
- package/dist/viewer/components/prd-tree/delete-confirmation.d.ts +23 -0
- package/dist/viewer/components/prd-tree/delete-confirmation.js +83 -0
- package/dist/viewer/components/prd-tree/delete-confirmation.js.map +1 -0
- package/dist/viewer/components/prd-tree/execution-panel.d.ts +14 -0
- package/dist/viewer/components/prd-tree/execution-panel.js +291 -0
- package/dist/viewer/components/prd-tree/execution-panel.js.map +1 -0
- package/dist/viewer/components/prd-tree/facet-filter.d.ts +40 -0
- package/dist/viewer/components/prd-tree/facet-filter.js +188 -0
- package/dist/viewer/components/prd-tree/facet-filter.js.map +1 -0
- package/dist/viewer/components/prd-tree/index.d.ts +24 -0
- package/dist/viewer/components/prd-tree/index.js +16 -0
- package/dist/viewer/components/prd-tree/index.js.map +1 -0
- package/dist/viewer/components/prd-tree/inline-add-form.d.ts +32 -0
- package/dist/viewer/components/prd-tree/inline-add-form.js +175 -0
- package/dist/viewer/components/prd-tree/inline-add-form.js.map +1 -0
- package/dist/viewer/components/prd-tree/inline-status-picker.d.ts +31 -0
- package/dist/viewer/components/prd-tree/inline-status-picker.js +110 -0
- package/dist/viewer/components/prd-tree/inline-status-picker.js.map +1 -0
- package/dist/viewer/components/prd-tree/lazy-children.d.ts +40 -0
- package/dist/viewer/components/prd-tree/lazy-children.js +73 -0
- package/dist/viewer/components/prd-tree/lazy-children.js.map +1 -0
- package/dist/viewer/components/prd-tree/levels.d.ts +31 -0
- package/dist/viewer/components/prd-tree/levels.js +72 -0
- package/dist/viewer/components/prd-tree/levels.js.map +1 -0
- package/dist/viewer/components/prd-tree/listener-lifecycle.d.ts +105 -0
- package/dist/viewer/components/prd-tree/listener-lifecycle.js +173 -0
- package/dist/viewer/components/prd-tree/listener-lifecycle.js.map +1 -0
- package/dist/viewer/components/prd-tree/merge-preview.d.ts +25 -0
- package/dist/viewer/components/prd-tree/merge-preview.js +181 -0
- package/dist/viewer/components/prd-tree/merge-preview.js.map +1 -0
- package/dist/viewer/components/prd-tree/prd-tree.d.ts +91 -0
- package/dist/viewer/components/prd-tree/prd-tree.js +565 -0
- package/dist/viewer/components/prd-tree/prd-tree.js.map +1 -0
- package/dist/viewer/components/prd-tree/proposal-editor.d.ts +44 -0
- package/dist/viewer/components/prd-tree/proposal-editor.js +438 -0
- package/dist/viewer/components/prd-tree/proposal-editor.js.map +1 -0
- package/dist/viewer/components/prd-tree/prune-confirmation.d.ts +25 -0
- package/dist/viewer/components/prd-tree/prune-confirmation.js +336 -0
- package/dist/viewer/components/prd-tree/prune-confirmation.js.map +1 -0
- package/dist/viewer/components/prd-tree/prune-diff-tree.d.ts +39 -0
- package/dist/viewer/components/prd-tree/prune-diff-tree.js +319 -0
- package/dist/viewer/components/prd-tree/prune-diff-tree.js.map +1 -0
- package/dist/viewer/components/prd-tree/reorganize-panel.d.ts +16 -0
- package/dist/viewer/components/prd-tree/reorganize-panel.js +213 -0
- package/dist/viewer/components/prd-tree/reorganize-panel.js.map +1 -0
- package/dist/viewer/components/prd-tree/smart-add-input.d.ts +19 -0
- package/dist/viewer/components/prd-tree/smart-add-input.js +383 -0
- package/dist/viewer/components/prd-tree/smart-add-input.js.map +1 -0
- package/dist/viewer/components/prd-tree/status-filter.d.ts +40 -0
- package/dist/viewer/components/prd-tree/status-filter.js +131 -0
- package/dist/viewer/components/prd-tree/status-filter.js.map +1 -0
- package/dist/viewer/components/prd-tree/task-detail.d.ts +41 -0
- package/dist/viewer/components/prd-tree/task-detail.js +1205 -0
- package/dist/viewer/components/prd-tree/task-detail.js.map +1 -0
- package/dist/viewer/components/prd-tree/task-utilization.d.ts +7 -0
- package/dist/viewer/components/prd-tree/task-utilization.js +25 -0
- package/dist/viewer/components/prd-tree/task-utilization.js.map +1 -0
- package/dist/viewer/components/prd-tree/tree-differ.d.ts +59 -0
- package/dist/viewer/components/prd-tree/tree-differ.js +200 -0
- package/dist/viewer/components/prd-tree/tree-differ.js.map +1 -0
- package/dist/viewer/components/prd-tree/tree-event-delegate.d.ts +70 -0
- package/dist/viewer/components/prd-tree/tree-event-delegate.js +176 -0
- package/dist/viewer/components/prd-tree/tree-event-delegate.js.map +1 -0
- package/dist/viewer/components/prd-tree/tree-search.d.ts +65 -0
- package/dist/viewer/components/prd-tree/tree-search.js +178 -0
- package/dist/viewer/components/prd-tree/tree-search.js.map +1 -0
- package/dist/viewer/components/prd-tree/tree-utils.d.ts +38 -0
- package/dist/viewer/components/prd-tree/tree-utils.js +107 -0
- package/dist/viewer/components/prd-tree/tree-utils.js.map +1 -0
- package/dist/viewer/components/prd-tree/types.d.ts +93 -0
- package/dist/viewer/components/prd-tree/types.js +16 -0
- package/dist/viewer/components/prd-tree/types.js.map +1 -0
- package/dist/viewer/components/prd-tree/virtual-scroll.d.ts +119 -0
- package/dist/viewer/components/prd-tree/virtual-scroll.js +169 -0
- package/dist/viewer/components/prd-tree/virtual-scroll.js.map +1 -0
- package/dist/viewer/components/progressive-loader.d.ts +114 -0
- package/dist/viewer/components/progressive-loader.js +225 -0
- package/dist/viewer/components/progressive-loader.js.map +1 -0
- package/dist/viewer/components/refresh-queue-status.d.ts +20 -0
- package/dist/viewer/components/refresh-queue-status.js +65 -0
- package/dist/viewer/components/refresh-queue-status.js.map +1 -0
- package/dist/viewer/components/rex-task-link.d.ts +50 -0
- package/dist/viewer/components/rex-task-link.js +218 -0
- package/dist/viewer/components/rex-task-link.js.map +1 -0
- package/dist/viewer/components/search-filter.d.ts +20 -0
- package/dist/viewer/components/search-filter.js +28 -0
- package/dist/viewer/components/search-filter.js.map +1 -0
- package/dist/viewer/components/search-overlay.d.ts +31 -0
- package/dist/viewer/components/search-overlay.js +472 -0
- package/dist/viewer/components/search-overlay.js.map +1 -0
- package/dist/viewer/components/sidebar.d.ts +18 -0
- package/dist/viewer/components/sidebar.js +357 -0
- package/dist/viewer/components/sidebar.js.map +1 -0
- package/dist/viewer/components/status-indicators.d.ts +63 -0
- package/dist/viewer/components/status-indicators.js +136 -0
- package/dist/viewer/components/status-indicators.js.map +1 -0
- package/dist/viewer/components/theme-toggle.d.ts +8 -0
- package/dist/viewer/components/theme-toggle.js +28 -0
- package/dist/viewer/components/theme-toggle.js.map +1 -0
- package/dist/viewer/components/throttle-controls.d.ts +18 -0
- package/dist/viewer/components/throttle-controls.js +304 -0
- package/dist/viewer/components/throttle-controls.js.map +1 -0
- package/dist/viewer/components/ws-health-panel.d.ts +18 -0
- package/dist/viewer/components/ws-health-panel.js +250 -0
- package/dist/viewer/components/ws-health-panel.js.map +1 -0
- package/dist/viewer/components/zone-slideout.d.ts +17 -0
- package/dist/viewer/components/zone-slideout.js +162 -0
- package/dist/viewer/components/zone-slideout.js.map +1 -0
- package/dist/viewer/crash/crash-detector.d.ts +69 -0
- package/dist/viewer/crash/crash-detector.js +239 -0
- package/dist/viewer/crash/crash-detector.js.map +1 -0
- package/dist/viewer/crash/index.d.ts +7 -0
- package/dist/viewer/crash/index.js +8 -0
- package/dist/viewer/crash/index.js.map +1 -0
- package/dist/viewer/deployed-mode.d.ts +37 -0
- package/dist/viewer/deployed-mode.js +94 -0
- package/dist/viewer/deployed-mode.js.map +1 -0
- package/dist/viewer/external.d.ts +17 -0
- package/dist/viewer/external.js +17 -0
- package/dist/viewer/external.js.map +1 -0
- package/dist/viewer/graph/index.d.ts +9 -0
- package/dist/viewer/graph/index.js +12 -0
- package/dist/viewer/graph/index.js.map +1 -0
- package/dist/viewer/graph/physics.d.ts +96 -0
- package/dist/viewer/graph/physics.js +366 -0
- package/dist/viewer/graph/physics.js.map +1 -0
- package/dist/viewer/graph/renderer.d.ts +184 -0
- package/dist/viewer/graph/renderer.js +1438 -0
- package/dist/viewer/graph/renderer.js.map +1 -0
- package/dist/viewer/hooks/index.d.ts +27 -0
- package/dist/viewer/hooks/index.js +28 -0
- package/dist/viewer/hooks/index.js.map +1 -0
- package/dist/viewer/hooks/use-app-data.d.ts +31 -0
- package/dist/viewer/hooks/use-app-data.js +152 -0
- package/dist/viewer/hooks/use-app-data.js.map +1 -0
- package/dist/viewer/hooks/use-crash-recovery.d.ts +50 -0
- package/dist/viewer/hooks/use-crash-recovery.js +76 -0
- package/dist/viewer/hooks/use-crash-recovery.js.map +1 -0
- package/dist/viewer/hooks/use-delete-actions.d.ts +48 -0
- package/dist/viewer/hooks/use-delete-actions.js +103 -0
- package/dist/viewer/hooks/use-delete-actions.js.map +1 -0
- package/dist/viewer/hooks/use-dom-performance-monitor.d.ts +68 -0
- package/dist/viewer/hooks/use-dom-performance-monitor.js +71 -0
- package/dist/viewer/hooks/use-dom-performance-monitor.js.map +1 -0
- package/dist/viewer/hooks/use-facet-state.d.ts +32 -0
- package/dist/viewer/hooks/use-facet-state.js +119 -0
- package/dist/viewer/hooks/use-facet-state.js.map +1 -0
- package/dist/viewer/hooks/use-feature-toggle.d.ts +18 -0
- package/dist/viewer/hooks/use-feature-toggle.js +57 -0
- package/dist/viewer/hooks/use-feature-toggle.js.map +1 -0
- package/dist/viewer/hooks/use-file-edges.d.ts +23 -0
- package/dist/viewer/hooks/use-file-edges.js +221 -0
- package/dist/viewer/hooks/use-file-edges.js.map +1 -0
- package/dist/viewer/hooks/use-graceful-degradation.d.ts +30 -0
- package/dist/viewer/hooks/use-graceful-degradation.js +45 -0
- package/dist/viewer/hooks/use-graceful-degradation.js.map +1 -0
- package/dist/viewer/hooks/use-item-selection.d.ts +49 -0
- package/dist/viewer/hooks/use-item-selection.js +117 -0
- package/dist/viewer/hooks/use-item-selection.js.map +1 -0
- package/dist/viewer/hooks/use-memory-monitor.d.ts +39 -0
- package/dist/viewer/hooks/use-memory-monitor.js +73 -0
- package/dist/viewer/hooks/use-memory-monitor.js.map +1 -0
- package/dist/viewer/hooks/use-pan-zoom.d.ts +33 -0
- package/dist/viewer/hooks/use-pan-zoom.js +110 -0
- package/dist/viewer/hooks/use-pan-zoom.js.map +1 -0
- package/dist/viewer/hooks/use-persistent-filter.d.ts +24 -0
- package/dist/viewer/hooks/use-persistent-filter.js +37 -0
- package/dist/viewer/hooks/use-persistent-filter.js.map +1 -0
- package/dist/viewer/hooks/use-polling-suspension.d.ts +32 -0
- package/dist/viewer/hooks/use-polling-suspension.js +41 -0
- package/dist/viewer/hooks/use-polling-suspension.js.map +1 -0
- package/dist/viewer/hooks/use-polling.d.ts +39 -0
- package/dist/viewer/hooks/use-polling.js +55 -0
- package/dist/viewer/hooks/use-polling.js.map +1 -0
- package/dist/viewer/hooks/use-prd-actions.d.ts +126 -0
- package/dist/viewer/hooks/use-prd-actions.js +250 -0
- package/dist/viewer/hooks/use-prd-actions.js.map +1 -0
- package/dist/viewer/hooks/use-prd-data.d.ts +45 -0
- package/dist/viewer/hooks/use-prd-data.js +159 -0
- package/dist/viewer/hooks/use-prd-data.js.map +1 -0
- package/dist/viewer/hooks/use-prd-deep-link.d.ts +45 -0
- package/dist/viewer/hooks/use-prd-deep-link.js +60 -0
- package/dist/viewer/hooks/use-prd-deep-link.js.map +1 -0
- package/dist/viewer/hooks/use-prd-websocket.d.ts +47 -0
- package/dist/viewer/hooks/use-prd-websocket.js +139 -0
- package/dist/viewer/hooks/use-prd-websocket.js.map +1 -0
- package/dist/viewer/hooks/use-project-metadata.d.ts +25 -0
- package/dist/viewer/hooks/use-project-metadata.js +55 -0
- package/dist/viewer/hooks/use-project-metadata.js.map +1 -0
- package/dist/viewer/hooks/use-project-status.d.ts +60 -0
- package/dist/viewer/hooks/use-project-status.js +133 -0
- package/dist/viewer/hooks/use-project-status.js.map +1 -0
- package/dist/viewer/hooks/use-refresh-throttle.d.ts +45 -0
- package/dist/viewer/hooks/use-refresh-throttle.js +52 -0
- package/dist/viewer/hooks/use-refresh-throttle.js.map +1 -0
- package/dist/viewer/hooks/use-route-state.d.ts +18 -0
- package/dist/viewer/hooks/use-route-state.js +115 -0
- package/dist/viewer/hooks/use-route-state.js.map +1 -0
- package/dist/viewer/hooks/use-subzone-edges.d.ts +21 -0
- package/dist/viewer/hooks/use-subzone-edges.js +147 -0
- package/dist/viewer/hooks/use-subzone-edges.js.map +1 -0
- package/dist/viewer/hooks/use-tab-visibility.d.ts +31 -0
- package/dist/viewer/hooks/use-tab-visibility.js +43 -0
- package/dist/viewer/hooks/use-tab-visibility.js.map +1 -0
- package/dist/viewer/hooks/use-tick.d.ts +43 -0
- package/dist/viewer/hooks/use-tick.js +76 -0
- package/dist/viewer/hooks/use-tick.js.map +1 -0
- package/dist/viewer/hooks/use-toast.d.ts +24 -0
- package/dist/viewer/hooks/use-toast.js +26 -0
- package/dist/viewer/hooks/use-toast.js.map +1 -0
- package/dist/viewer/hooks/use-zone-drag.d.ts +30 -0
- package/dist/viewer/hooks/use-zone-drag.js +60 -0
- package/dist/viewer/hooks/use-zone-drag.js.map +1 -0
- package/dist/viewer/index.html +36 -0
- package/dist/viewer/loader.d.ts +33 -0
- package/dist/viewer/loader.js +195 -0
- package/dist/viewer/loader.js.map +1 -0
- package/dist/viewer/main.d.ts +1 -0
- package/dist/viewer/main.js +121 -0
- package/dist/viewer/main.js.map +1 -0
- package/dist/viewer/messaging/call-rate-limiter.d.ts +50 -0
- package/dist/viewer/messaging/call-rate-limiter.js +103 -0
- package/dist/viewer/messaging/call-rate-limiter.js.map +1 -0
- package/dist/viewer/messaging/fetch-pipeline.d.ts +58 -0
- package/dist/viewer/messaging/fetch-pipeline.js +58 -0
- package/dist/viewer/messaging/fetch-pipeline.js.map +1 -0
- package/dist/viewer/messaging/index.d.ts +43 -0
- package/dist/viewer/messaging/index.js +46 -0
- package/dist/viewer/messaging/index.js.map +1 -0
- package/dist/viewer/messaging/message-coalescer.d.ts +96 -0
- package/dist/viewer/messaging/message-coalescer.js +121 -0
- package/dist/viewer/messaging/message-coalescer.js.map +1 -0
- package/dist/viewer/messaging/message-throttle.d.ts +95 -0
- package/dist/viewer/messaging/message-throttle.js +147 -0
- package/dist/viewer/messaging/message-throttle.js.map +1 -0
- package/dist/viewer/messaging/request-dedup.d.ts +43 -0
- package/dist/viewer/messaging/request-dedup.js +55 -0
- package/dist/viewer/messaging/request-dedup.js.map +1 -0
- package/dist/viewer/messaging/ws-pipeline.d.ts +85 -0
- package/dist/viewer/messaging/ws-pipeline.js +68 -0
- package/dist/viewer/messaging/ws-pipeline.js.map +1 -0
- package/dist/viewer/n-dx.png +0 -0
- package/dist/viewer/performance/dom-performance-monitor.d.ts +157 -0
- package/dist/viewer/performance/dom-performance-monitor.js +341 -0
- package/dist/viewer/performance/dom-performance-monitor.js.map +1 -0
- package/dist/viewer/performance/dom-update-gate.d.ts +122 -0
- package/dist/viewer/performance/dom-update-gate.js +229 -0
- package/dist/viewer/performance/dom-update-gate.js.map +1 -0
- package/dist/viewer/performance/graceful-degradation.d.ts +73 -0
- package/dist/viewer/performance/graceful-degradation.js +152 -0
- package/dist/viewer/performance/graceful-degradation.js.map +1 -0
- package/dist/viewer/performance/index.d.ts +14 -0
- package/dist/viewer/performance/index.js +20 -0
- package/dist/viewer/performance/index.js.map +1 -0
- package/dist/viewer/performance/memory-monitor.d.ts +78 -0
- package/dist/viewer/performance/memory-monitor.js +218 -0
- package/dist/viewer/performance/memory-monitor.js.map +1 -0
- package/dist/viewer/performance/refresh-throttle.d.ts +90 -0
- package/dist/viewer/performance/refresh-throttle.js +266 -0
- package/dist/viewer/performance/refresh-throttle.js.map +1 -0
- package/dist/viewer/performance/response-buffer-gate.d.ts +108 -0
- package/dist/viewer/performance/response-buffer-gate.js +170 -0
- package/dist/viewer/performance/response-buffer-gate.js.map +1 -0
- package/dist/viewer/performance/update-batcher.d.ts +79 -0
- package/dist/viewer/performance/update-batcher.js +119 -0
- package/dist/viewer/performance/update-batcher.js.map +1 -0
- package/dist/viewer/polling/batched-tick-dispatcher.d.ts +83 -0
- package/dist/viewer/polling/batched-tick-dispatcher.js +183 -0
- package/dist/viewer/polling/batched-tick-dispatcher.js.map +1 -0
- package/dist/viewer/polling/index.d.ts +13 -0
- package/dist/viewer/polling/index.js +16 -0
- package/dist/viewer/polling/index.js.map +1 -0
- package/dist/viewer/polling/polling-manager.d.ts +82 -0
- package/dist/viewer/polling/polling-manager.js +254 -0
- package/dist/viewer/polling/polling-manager.js.map +1 -0
- package/dist/viewer/polling/polling-restart.d.ts +45 -0
- package/dist/viewer/polling/polling-restart.js +98 -0
- package/dist/viewer/polling/polling-restart.js.map +1 -0
- package/dist/viewer/polling/polling-state.d.ts +182 -0
- package/dist/viewer/polling/polling-state.js +306 -0
- package/dist/viewer/polling/polling-state.js.map +1 -0
- package/dist/viewer/polling/tab-visibility.d.ts +112 -0
- package/dist/viewer/polling/tab-visibility.js +276 -0
- package/dist/viewer/polling/tab-visibility.js.map +1 -0
- package/dist/viewer/polling/tick-timer.d.ts +70 -0
- package/dist/viewer/polling/tick-timer.js +168 -0
- package/dist/viewer/polling/tick-timer.js.map +1 -0
- package/dist/viewer/polling/tick-visibility-gate.d.ts +92 -0
- package/dist/viewer/polling/tick-visibility-gate.js +146 -0
- package/dist/viewer/polling/tick-visibility-gate.js.map +1 -0
- package/dist/viewer/route-state.d.ts +8 -0
- package/dist/viewer/route-state.js +77 -0
- package/dist/viewer/route-state.js.map +1 -0
- package/dist/viewer/schema-compat.d.ts +17 -0
- package/dist/viewer/schema-compat.js +49 -0
- package/dist/viewer/schema-compat.js.map +1 -0
- package/dist/viewer/types.d.ts +66 -0
- package/dist/viewer/types.js +2 -0
- package/dist/viewer/types.js.map +1 -0
- package/dist/viewer/usage/constants.d.ts +14 -0
- package/dist/viewer/usage/constants.js +14 -0
- package/dist/viewer/usage/constants.js.map +1 -0
- package/dist/viewer/usage/index.d.ts +7 -0
- package/dist/viewer/usage/index.js +8 -0
- package/dist/viewer/usage/index.js.map +1 -0
- package/dist/viewer/utils.d.ts +25 -0
- package/dist/viewer/utils.js +48 -0
- package/dist/viewer/utils.js.map +1 -0
- package/dist/viewer/validate.d.ts +23 -0
- package/dist/viewer/validate.js +275 -0
- package/dist/viewer/validate.js.map +1 -0
- package/dist/viewer/views/analysis.d.ts +10 -0
- package/dist/viewer/views/analysis.js +109 -0
- package/dist/viewer/views/analysis.js.map +1 -0
- package/dist/viewer/views/architecture.d.ts +10 -0
- package/dist/viewer/views/architecture.js +44 -0
- package/dist/viewer/views/architecture.js.map +1 -0
- package/dist/viewer/views/domain-hench.d.ts +13 -0
- package/dist/viewer/views/domain-hench.js +14 -0
- package/dist/viewer/views/domain-hench.js.map +1 -0
- package/dist/viewer/views/domain-rex.d.ts +17 -0
- package/dist/viewer/views/domain-rex.js +18 -0
- package/dist/viewer/views/domain-rex.js.map +1 -0
- package/dist/viewer/views/domain-settings.d.ts +12 -0
- package/dist/viewer/views/domain-settings.js +13 -0
- package/dist/viewer/views/domain-settings.js.map +1 -0
- package/dist/viewer/views/domain-sourcevision.d.ts +20 -0
- package/dist/viewer/views/domain-sourcevision.js +21 -0
- package/dist/viewer/views/domain-sourcevision.js.map +1 -0
- package/dist/viewer/views/enrichment-thresholds.d.ts +11 -0
- package/dist/viewer/views/enrichment-thresholds.js +12 -0
- package/dist/viewer/views/enrichment-thresholds.js.map +1 -0
- package/dist/viewer/views/feature-toggles.d.ts +13 -0
- package/dist/viewer/views/feature-toggles.js +185 -0
- package/dist/viewer/views/feature-toggles.js.map +1 -0
- package/dist/viewer/views/files.d.ts +13 -0
- package/dist/viewer/views/files.js +174 -0
- package/dist/viewer/views/files.js.map +1 -0
- package/dist/viewer/views/graph.d.ts +12 -0
- package/dist/viewer/views/graph.js +316 -0
- package/dist/viewer/views/graph.js.map +1 -0
- package/dist/viewer/views/hench-config.d.ts +39 -0
- package/dist/viewer/views/hench-config.js +473 -0
- package/dist/viewer/views/hench-config.js.map +1 -0
- package/dist/viewer/views/hench-runs.d.ts +19 -0
- package/dist/viewer/views/hench-runs.js +460 -0
- package/dist/viewer/views/hench-runs.js.map +1 -0
- package/dist/viewer/views/hench-templates.d.ts +17 -0
- package/dist/viewer/views/hench-templates.js +262 -0
- package/dist/viewer/views/hench-templates.js.map +1 -0
- package/dist/viewer/views/integration-config.d.ts +73 -0
- package/dist/viewer/views/integration-config.js +524 -0
- package/dist/viewer/views/integration-config.js.map +1 -0
- package/dist/viewer/views/notion-config.d.ts +16 -0
- package/dist/viewer/views/notion-config.js +357 -0
- package/dist/viewer/views/notion-config.js.map +1 -0
- package/dist/viewer/views/overview.d.ts +10 -0
- package/dist/viewer/views/overview.js +187 -0
- package/dist/viewer/views/overview.js.map +1 -0
- package/dist/viewer/views/pr-markdown.d.ts +3 -0
- package/dist/viewer/views/pr-markdown.js +350 -0
- package/dist/viewer/views/pr-markdown.js.map +1 -0
- package/dist/viewer/views/prd.d.ts +34 -0
- package/dist/viewer/views/prd.js +257 -0
- package/dist/viewer/views/prd.js.map +1 -0
- package/dist/viewer/views/problems.d.ts +8 -0
- package/dist/viewer/views/problems.js +50 -0
- package/dist/viewer/views/problems.js.map +1 -0
- package/dist/viewer/views/rex-dashboard.d.ts +14 -0
- package/dist/viewer/views/rex-dashboard.js +334 -0
- package/dist/viewer/views/rex-dashboard.js.map +1 -0
- package/dist/viewer/views/routes.d.ts +8 -0
- package/dist/viewer/views/routes.js +216 -0
- package/dist/viewer/views/routes.js.map +1 -0
- package/dist/viewer/views/sourcevision-tabs.d.ts +18 -0
- package/dist/viewer/views/sourcevision-tabs.js +14 -0
- package/dist/viewer/views/sourcevision-tabs.js.map +1 -0
- package/dist/viewer/views/suggestions.d.ts +8 -0
- package/dist/viewer/views/suggestions.js +36 -0
- package/dist/viewer/views/suggestions.js.map +1 -0
- package/dist/viewer/views/task-audit.d.ts +18 -0
- package/dist/viewer/views/task-audit.js +413 -0
- package/dist/viewer/views/task-audit.js.map +1 -0
- package/dist/viewer/views/token-usage.d.ts +10 -0
- package/dist/viewer/views/token-usage.js +410 -0
- package/dist/viewer/views/token-usage.js.map +1 -0
- package/dist/viewer/views/validation.d.ts +11 -0
- package/dist/viewer/views/validation.js +475 -0
- package/dist/viewer/views/validation.js.map +1 -0
- package/dist/viewer/views/view-registry.d.ts +27 -0
- package/dist/viewer/views/view-registry.js +70 -0
- package/dist/viewer/views/view-registry.js.map +1 -0
- package/dist/viewer/views/workflow-optimization.d.ts +12 -0
- package/dist/viewer/views/workflow-optimization.js +311 -0
- package/dist/viewer/views/workflow-optimization.js.map +1 -0
- package/dist/viewer/views/zone-types.d.ts +69 -0
- package/dist/viewer/views/zone-types.js +5 -0
- package/dist/viewer/views/zone-types.js.map +1 -0
- package/dist/viewer/views/zones.d.ts +50 -0
- package/dist/viewer/views/zones.js +1438 -0
- package/dist/viewer/views/zones.js.map +1 -0
- package/dist/viewer/visualization/colors.d.ts +16 -0
- package/dist/viewer/visualization/colors.js +31 -0
- package/dist/viewer/visualization/colors.js.map +1 -0
- package/dist/viewer/visualization/flow.d.ts +54 -0
- package/dist/viewer/visualization/flow.js +123 -0
- package/dist/viewer/visualization/flow.js.map +1 -0
- package/dist/viewer/visualization/index.d.ts +34 -0
- package/dist/viewer/visualization/index.js +40 -0
- package/dist/viewer/visualization/index.js.map +1 -0
- package/dist/viewer/visualization/metrics.d.ts +8 -0
- package/dist/viewer/visualization/metrics.js +16 -0
- package/dist/viewer/visualization/metrics.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { h } from "preact";
|
|
2
|
+
import { useState, useMemo } from "preact/hooks";
|
|
3
|
+
import { getZoneColorByIndex, basename } from "../../utils.js";
|
|
4
|
+
export function ZoneMap({ zones, crossings, selectedZone, onZoneClick }) {
|
|
5
|
+
const [hoveredZone, setHoveredZone] = useState(null);
|
|
6
|
+
// Calculate zone metrics for sizing
|
|
7
|
+
const zoneMetrics = useMemo(() => {
|
|
8
|
+
const metrics = new Map();
|
|
9
|
+
for (const z of zones) {
|
|
10
|
+
metrics.set(z.id, {
|
|
11
|
+
files: z.files.length,
|
|
12
|
+
incoming: 0,
|
|
13
|
+
outgoing: 0,
|
|
14
|
+
cohesion: z.cohesion,
|
|
15
|
+
coupling: z.coupling,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
for (const c of crossings) {
|
|
19
|
+
const from = metrics.get(c.fromZone);
|
|
20
|
+
const to = metrics.get(c.toZone);
|
|
21
|
+
if (from)
|
|
22
|
+
from.outgoing++;
|
|
23
|
+
if (to)
|
|
24
|
+
to.incoming++;
|
|
25
|
+
}
|
|
26
|
+
return metrics;
|
|
27
|
+
}, [zones, crossings]);
|
|
28
|
+
// Group crossings by zone pairs for connection rendering
|
|
29
|
+
const connectionCounts = useMemo(() => {
|
|
30
|
+
const counts = new Map();
|
|
31
|
+
for (const c of crossings) {
|
|
32
|
+
const key = [c.fromZone, c.toZone].sort().join(":");
|
|
33
|
+
counts.set(key, (counts.get(key) || 0) + 1);
|
|
34
|
+
}
|
|
35
|
+
return counts;
|
|
36
|
+
}, [crossings]);
|
|
37
|
+
// Get unique zone pairs with connections
|
|
38
|
+
const connections = useMemo(() => {
|
|
39
|
+
const pairs = [];
|
|
40
|
+
const seen = new Set();
|
|
41
|
+
for (const c of crossings) {
|
|
42
|
+
const key = [c.fromZone, c.toZone].sort().join(":");
|
|
43
|
+
if (seen.has(key))
|
|
44
|
+
continue;
|
|
45
|
+
seen.add(key);
|
|
46
|
+
const reverseKey = `${c.toZone}:${c.fromZone}`;
|
|
47
|
+
const forwardCount = crossings.filter(x => x.fromZone === c.fromZone && x.toZone === c.toZone).length;
|
|
48
|
+
const reverseCount = crossings.filter(x => x.fromZone === c.toZone && x.toZone === c.fromZone).length;
|
|
49
|
+
pairs.push({
|
|
50
|
+
from: c.fromZone,
|
|
51
|
+
to: c.toZone,
|
|
52
|
+
count: forwardCount + reverseCount,
|
|
53
|
+
bidirectional: forwardCount > 0 && reverseCount > 0,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
return pairs.sort((a, b) => b.count - a.count);
|
|
57
|
+
}, [crossings]);
|
|
58
|
+
// Calculate grid layout
|
|
59
|
+
const cols = Math.ceil(Math.sqrt(zones.length));
|
|
60
|
+
const rows = Math.ceil(zones.length / cols);
|
|
61
|
+
const maxFiles = Math.max(...zones.map(z => z.files.length), 1);
|
|
62
|
+
return h("div", { class: "zone-map" }, h("div", { class: "zone-map-header" }, h("h4", null, "Architecture Map"), h("div", { class: "zone-map-legend" }, h("span", { class: "legend-item" }, h("span", { class: "legend-dot", style: "background: var(--green)" }), "High cohesion"), h("span", { class: "legend-item" }, h("span", { class: "legend-dot", style: "background: var(--orange)" }), "Bidirectional"), h("span", { class: "legend-item" }, h("span", { class: "legend-line" }), "Dependency"))), h("div", {
|
|
63
|
+
class: "zone-map-grid",
|
|
64
|
+
style: `grid-template-columns: repeat(${cols}, 1fr)`,
|
|
65
|
+
}, zones.map((zone, i) => {
|
|
66
|
+
const color = getZoneColorByIndex(i);
|
|
67
|
+
const metrics = zoneMetrics.get(zone.id);
|
|
68
|
+
const isSelected = selectedZone === zone.id;
|
|
69
|
+
const isHovered = hoveredZone === zone.id;
|
|
70
|
+
const isHighlighted = isSelected || isHovered;
|
|
71
|
+
// Scale box size by file count
|
|
72
|
+
const sizeScale = 0.7 + (zone.files.length / maxFiles) * 0.3;
|
|
73
|
+
// Health indicator color
|
|
74
|
+
const healthColor = zone.cohesion >= 0.7 ? "var(--green)"
|
|
75
|
+
: zone.cohesion >= 0.4 ? "var(--orange)"
|
|
76
|
+
: "var(--red)";
|
|
77
|
+
// Coupling indicator
|
|
78
|
+
const couplingLevel = zone.coupling >= 0.5 ? "high" : zone.coupling >= 0.3 ? "mid" : "low";
|
|
79
|
+
return h("div", {
|
|
80
|
+
key: zone.id,
|
|
81
|
+
class: `zone-map-node ${isSelected ? "selected" : ""} ${isHovered ? "hovered" : ""}`,
|
|
82
|
+
style: `
|
|
83
|
+
--zone-color: ${color};
|
|
84
|
+
transform: scale(${isHighlighted ? 1.05 : sizeScale});
|
|
85
|
+
border-color: ${isHighlighted ? color : "var(--border)"};
|
|
86
|
+
`,
|
|
87
|
+
onClick: () => onZoneClick?.(zone.id),
|
|
88
|
+
onMouseEnter: () => setHoveredZone(zone.id),
|
|
89
|
+
onMouseLeave: () => setHoveredZone(null),
|
|
90
|
+
}, h("div", { class: "zone-map-node-header" }, h("span", { class: "zone-map-node-dot", style: `background: ${color}` }), h("span", { class: "zone-map-node-name" }, zone.name)), h("div", { class: "zone-map-node-body" }, h("div", { class: "zone-map-node-stat" }, h("span", { class: "stat-value" }, zone.files.length), h("span", { class: "stat-label" }, "files")), h("div", { class: "zone-map-node-health" }, h("span", {
|
|
91
|
+
class: "health-dot",
|
|
92
|
+
style: `background: ${healthColor}`,
|
|
93
|
+
title: `Cohesion: ${zone.cohesion.toFixed(2)}`,
|
|
94
|
+
}), h("span", {
|
|
95
|
+
class: `coupling-indicator ${couplingLevel}`,
|
|
96
|
+
title: `Coupling: ${zone.coupling.toFixed(2)}`,
|
|
97
|
+
}, zone.coupling > 0.3 ? "\u26A0" : ""))), zone.subZones && zone.subZones.length > 0
|
|
98
|
+
? h("div", { class: "zone-map-node-subzones" }, h("span", { class: "subzone-badge" }, `${zone.subZones.length} sub-zones`))
|
|
99
|
+
: null, metrics && (metrics.incoming > 0 || metrics.outgoing > 0)
|
|
100
|
+
? h("div", { class: "zone-map-node-io" }, h("span", { class: "io-in", title: "Incoming deps" }, "\u2190", metrics.incoming), h("span", { class: "io-out", title: "Outgoing deps" }, metrics.outgoing, "\u2192"))
|
|
101
|
+
: null);
|
|
102
|
+
})),
|
|
103
|
+
// Connection summary
|
|
104
|
+
connections.length > 0
|
|
105
|
+
? h("div", { class: "zone-map-connections" }, h("h5", null, "Zone Dependencies"), h("div", { class: "connection-list" }, connections.slice(0, 10).map(conn => {
|
|
106
|
+
const fromZone = zones.find(z => z.id === conn.from);
|
|
107
|
+
const toZone = zones.find(z => z.id === conn.to);
|
|
108
|
+
if (!fromZone || !toZone)
|
|
109
|
+
return null;
|
|
110
|
+
const fromIdx = zones.indexOf(fromZone);
|
|
111
|
+
const toIdx = zones.indexOf(toZone);
|
|
112
|
+
return h("div", {
|
|
113
|
+
key: `${conn.from}-${conn.to}`,
|
|
114
|
+
class: `connection-item ${conn.bidirectional ? "bidirectional" : ""}`,
|
|
115
|
+
}, h("span", {
|
|
116
|
+
class: "connection-zone",
|
|
117
|
+
style: `--zone-color: ${getZoneColorByIndex(fromIdx)}`,
|
|
118
|
+
}, fromZone.name), h("span", { class: "connection-arrow" }, conn.bidirectional ? "\u21C4" : "\u2192"), h("span", {
|
|
119
|
+
class: "connection-zone",
|
|
120
|
+
style: `--zone-color: ${getZoneColorByIndex(toIdx)}`,
|
|
121
|
+
}, toZone.name), h("span", { class: "connection-count" }, conn.count));
|
|
122
|
+
}), connections.length > 10
|
|
123
|
+
? h("div", { class: "connection-more" }, `+${connections.length - 10} more connections`)
|
|
124
|
+
: null))
|
|
125
|
+
: null);
|
|
126
|
+
}
|
|
127
|
+
export function ZoneDetail({ zone, crossings, allZones, onClose, onFileClick }) {
|
|
128
|
+
const [showFiles, setShowFiles] = useState(false);
|
|
129
|
+
// Get connections for this zone
|
|
130
|
+
const incoming = crossings.filter(c => c.toZone === zone.id);
|
|
131
|
+
const outgoing = crossings.filter(c => c.fromZone === zone.id);
|
|
132
|
+
// Group by source/target zone
|
|
133
|
+
const incomingByZone = groupBy(incoming, c => c.fromZone);
|
|
134
|
+
const outgoingByZone = groupBy(outgoing, c => c.toZone);
|
|
135
|
+
const zoneIdx = allZones.indexOf(zone);
|
|
136
|
+
const color = getZoneColorByIndex(zoneIdx);
|
|
137
|
+
return h("div", { class: "zone-detail-overlay" }, h("div", { class: "zone-detail-panel", style: `--zone-color: ${color}` }, h("div", { class: "zone-detail-header" }, h("h3", null, zone.name), h("button", { class: "close-btn", onClick: onClose }, "\u2715")), h("p", { class: "zone-detail-desc" }, zone.description),
|
|
138
|
+
// Metrics row
|
|
139
|
+
h("div", { class: "zone-detail-metrics" }, h("div", { class: "metric" }, h("span", { class: "metric-val" }, zone.files.length), h("span", { class: "metric-lbl" }, "files")), h("div", { class: "metric" }, h("span", {
|
|
140
|
+
class: "metric-val",
|
|
141
|
+
style: `color: ${zone.cohesion >= 0.7 ? "var(--green)" : zone.cohesion >= 0.4 ? "var(--orange)" : "var(--red)"}`,
|
|
142
|
+
}, zone.cohesion.toFixed(2)), h("span", { class: "metric-lbl" }, "cohesion")), h("div", { class: "metric" }, h("span", {
|
|
143
|
+
class: "metric-val",
|
|
144
|
+
style: `color: ${zone.coupling <= 0.3 ? "var(--green)" : zone.coupling <= 0.5 ? "var(--orange)" : "var(--red)"}`,
|
|
145
|
+
}, zone.coupling.toFixed(2)), h("span", { class: "metric-lbl" }, "coupling"))),
|
|
146
|
+
// Entry points
|
|
147
|
+
zone.entryPoints.length > 0
|
|
148
|
+
? h("div", { class: "zone-detail-section" }, h("h4", null, "Entry Points"), h("ul", { class: "entry-point-list" }, zone.entryPoints.slice(0, 5).map(ep => h("li", { key: ep, class: "mono-sm" }, basename(ep))), zone.entryPoints.length > 5
|
|
149
|
+
? h("li", { class: "more" }, `+${zone.entryPoints.length - 5} more`)
|
|
150
|
+
: null))
|
|
151
|
+
: null,
|
|
152
|
+
// Insights
|
|
153
|
+
zone.insights && zone.insights.length > 0
|
|
154
|
+
? h("div", { class: "zone-detail-section" }, h("h4", null, "Insights"), h("ul", { class: "insight-list" }, zone.insights.slice(0, 5).map((ins, i) => h("li", { key: i }, ins)), zone.insights.length > 5
|
|
155
|
+
? h("li", { class: "more" }, `+${zone.insights.length - 5} more`)
|
|
156
|
+
: null))
|
|
157
|
+
: null,
|
|
158
|
+
// Dependencies
|
|
159
|
+
(Object.keys(incomingByZone).length > 0 || Object.keys(outgoingByZone).length > 0)
|
|
160
|
+
? h("div", { class: "zone-detail-section" }, h("h4", null, "Dependencies"), h("div", { class: "dep-grid" }, Object.keys(outgoingByZone).length > 0
|
|
161
|
+
? h("div", { class: "dep-col" }, h("span", { class: "dep-label" }, "Depends on:"), ...Object.entries(outgoingByZone).slice(0, 5).map(([zoneId, items]) => {
|
|
162
|
+
const targetZone = allZones.find(z => z.id === zoneId);
|
|
163
|
+
return h("div", { key: zoneId, class: "dep-item" }, targetZone?.name || zoneId, h("span", { class: "dep-count" }, items.length));
|
|
164
|
+
}))
|
|
165
|
+
: null, Object.keys(incomingByZone).length > 0
|
|
166
|
+
? h("div", { class: "dep-col" }, h("span", { class: "dep-label" }, "Used by:"), ...Object.entries(incomingByZone).slice(0, 5).map(([zoneId, items]) => {
|
|
167
|
+
const sourceZone = allZones.find(z => z.id === zoneId);
|
|
168
|
+
return h("div", { key: zoneId, class: "dep-item" }, sourceZone?.name || zoneId, h("span", { class: "dep-count" }, items.length));
|
|
169
|
+
}))
|
|
170
|
+
: null))
|
|
171
|
+
: null,
|
|
172
|
+
// Files toggle
|
|
173
|
+
h("div", { class: "zone-detail-section" }, h("button", {
|
|
174
|
+
class: "toggle-files-btn",
|
|
175
|
+
onClick: () => setShowFiles(!showFiles),
|
|
176
|
+
}, showFiles ? "Hide files" : `Show ${zone.files.length} files`), showFiles
|
|
177
|
+
? h("ul", { class: "file-list" }, zone.files.map(f => h("li", {
|
|
178
|
+
key: f,
|
|
179
|
+
class: "file-item mono-sm",
|
|
180
|
+
onClick: onFileClick ? () => onFileClick(f) : undefined,
|
|
181
|
+
}, f, zone.entryPoints.includes(f)
|
|
182
|
+
? h("span", { class: "entry-badge" }, "entry")
|
|
183
|
+
: null)))
|
|
184
|
+
: null)));
|
|
185
|
+
}
|
|
186
|
+
// Helper
|
|
187
|
+
function groupBy(items, key) {
|
|
188
|
+
const result = {};
|
|
189
|
+
for (const item of items) {
|
|
190
|
+
const k = key(item);
|
|
191
|
+
if (!result[k])
|
|
192
|
+
result[k] = [];
|
|
193
|
+
result[k].push(item);
|
|
194
|
+
}
|
|
195
|
+
return result;
|
|
196
|
+
}
|
|
197
|
+
//# sourceMappingURL=zone-map.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zone-map.js","sourceRoot":"","sources":["../../../../src/viewer/components/data-display/zone-map.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Degradation notification banner component.
|
|
3
|
+
*
|
|
4
|
+
* Informs the user when features have been automatically disabled due to
|
|
5
|
+
* memory pressure. Explains what's disabled and why, and provides a button
|
|
6
|
+
* to dismiss the notice. Shows only when degradation is active (tier > normal)
|
|
7
|
+
* and the memory warning banner is NOT already visible (to avoid stacking).
|
|
8
|
+
*/
|
|
9
|
+
import type { MemoryLevel, DegradableFeature } from "../performance/index.js";
|
|
10
|
+
export interface DegradationBannerProps {
|
|
11
|
+
/** Current degradation tier. */
|
|
12
|
+
tier: MemoryLevel;
|
|
13
|
+
/** Whether degradation is active (tier !== "normal"). */
|
|
14
|
+
isDegraded: boolean;
|
|
15
|
+
/** Human-readable summary message. */
|
|
16
|
+
summary: string;
|
|
17
|
+
/** Set of disabled features. */
|
|
18
|
+
disabledFeatures: ReadonlySet<DegradableFeature>;
|
|
19
|
+
/** Whether this banner should be visible. */
|
|
20
|
+
visible: boolean;
|
|
21
|
+
/** Called when the user dismisses the banner. */
|
|
22
|
+
onDismiss: () => void;
|
|
23
|
+
}
|
|
24
|
+
export declare function DegradationBanner({ tier, isDegraded, summary, disabledFeatures, visible, onDismiss, }: DegradationBannerProps): import("preact").VNode<import("preact").ClassAttributes<HTMLElement> & {
|
|
25
|
+
class: string;
|
|
26
|
+
role: "status";
|
|
27
|
+
"aria-live": "polite";
|
|
28
|
+
}> | null;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Degradation notification banner component.
|
|
3
|
+
*
|
|
4
|
+
* Informs the user when features have been automatically disabled due to
|
|
5
|
+
* memory pressure. Explains what's disabled and why, and provides a button
|
|
6
|
+
* to dismiss the notice. Shows only when degradation is active (tier > normal)
|
|
7
|
+
* and the memory warning banner is NOT already visible (to avoid stacking).
|
|
8
|
+
*/
|
|
9
|
+
import { h } from "preact";
|
|
10
|
+
/** Human-readable names for degradable features. */
|
|
11
|
+
const FEATURE_LABELS = {
|
|
12
|
+
autoRefresh: "Auto-refresh",
|
|
13
|
+
deferredLoading: "Background loading",
|
|
14
|
+
graphRendering: "Graph view",
|
|
15
|
+
animations: "Animations",
|
|
16
|
+
detailPanel: "Detail panel",
|
|
17
|
+
};
|
|
18
|
+
const TIER_ICON = {
|
|
19
|
+
normal: "",
|
|
20
|
+
elevated: "\u26A1", // lightning bolt
|
|
21
|
+
warning: "\u26A0\uFE0F", // warning sign
|
|
22
|
+
critical: "\uD83D\uDED1", // stop sign
|
|
23
|
+
};
|
|
24
|
+
export function DegradationBanner({ tier, isDegraded, summary, disabledFeatures, visible, onDismiss, }) {
|
|
25
|
+
if (!visible || !isDegraded || tier === "normal")
|
|
26
|
+
return null;
|
|
27
|
+
const icon = TIER_ICON[tier];
|
|
28
|
+
const tierClass = tier === "critical"
|
|
29
|
+
? "degradation-banner degradation-critical"
|
|
30
|
+
: tier === "warning"
|
|
31
|
+
? "degradation-banner degradation-warning"
|
|
32
|
+
: "degradation-banner degradation-elevated";
|
|
33
|
+
const featureList = Array.from(disabledFeatures)
|
|
34
|
+
.map((f) => FEATURE_LABELS[f])
|
|
35
|
+
.join(", ");
|
|
36
|
+
return h("div", {
|
|
37
|
+
class: tierClass,
|
|
38
|
+
role: "status",
|
|
39
|
+
"aria-live": "polite",
|
|
40
|
+
}, h("div", { class: "degradation-content" }, h("span", { class: "degradation-icon", "aria-hidden": "true" }, icon), h("div", { class: "degradation-text" }, h("strong", null, "Reduced functionality"), h("p", { class: "degradation-summary" }, summary), h("p", { class: "degradation-features" }, `Disabled: ${featureList}`)), h("button", {
|
|
41
|
+
class: "degradation-dismiss",
|
|
42
|
+
onClick: onDismiss,
|
|
43
|
+
"aria-label": "Dismiss degradation notice",
|
|
44
|
+
type: "button",
|
|
45
|
+
}, "\u2715")));
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=degradation-banner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"degradation-banner.js","sourceRoot":"","sources":["../../../src/viewer/components/degradation-banner.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAkB3B,oDAAoD;AACpD,MAAM,cAAc,GAAsC;IACxD,WAAW,EAAE,cAAc;IAC3B,eAAe,EAAE,oBAAoB;IACrC,cAAc,EAAE,YAAY;IAC5B,UAAU,EAAE,YAAY;IACxB,WAAW,EAAE,cAAc;CAC5B,CAAC;AAEF,MAAM,SAAS,GAAgC;IAC7C,MAAM,EAAE,EAAE;IACV,QAAQ,EAAE,QAAQ,EAAQ,iBAAiB;IAC3C,OAAO,EAAE,cAAc,EAAG,eAAe;IACzC,QAAQ,EAAE,cAAc,EAAE,YAAY;CACvC,CAAC;AAEF,MAAM,UAAU,iBAAiB,CAAC,EAChC,IAAI,EACJ,UAAU,EACV,OAAO,EACP,gBAAgB,EAChB,OAAO,EACP,SAAS,GACc;IACvB,IAAI,CAAC,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE9D,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;IAC7B,MAAM,SAAS,GACb,IAAI,KAAK,UAAU;QACjB,CAAC,CAAC,yCAAyC;QAC3C,CAAC,CAAC,IAAI,KAAK,SAAS;YAClB,CAAC,CAAC,wCAAwC;YAC1C,CAAC,CAAC,yCAAyC,CAAC;IAElD,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC;SAC7C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;SAC7B,IAAI,CAAC,IAAI,CAAC,CAAC;IAEd,OAAO,CAAC,CACN,KAAK,EACL;QACE,KAAK,EAAE,SAAS;QAChB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,QAAQ;KACtB,EACD,CAAC,CACC,KAAK,EACL,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAChC,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,EAAE,EAAE,IAAI,CAAC,EACrE,CAAC,CACC,KAAK,EACL,EAAE,KAAK,EAAE,kBAAkB,EAAE,EAC7B,CAAC,CAAC,QAAQ,EAAE,IAAI,EAAE,uBAAuB,CAAC,EAC1C,CAAC,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,OAAO,CAAC,EACjD,CAAC,CACC,GAAG,EACH,EAAE,KAAK,EAAE,sBAAsB,EAAE,EACjC,aAAa,WAAW,EAAE,CAC3B,CACF,EACD,CAAC,CACC,QAAQ,EACR;QACE,KAAK,EAAE,qBAAqB;QAC5B,OAAO,EAAE,SAAS;QAClB,YAAY,EAAE,4BAA4B;QAC1C,IAAI,EAAE,QAAQ;KACf,EACD,QAAQ,CACT,CACF,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { LoadedData, NavigateTo, DetailItem } from "../types.js";
|
|
2
|
+
import type { VNode } from "preact";
|
|
3
|
+
interface DetailPanelProps {
|
|
4
|
+
detail: DetailItem | null;
|
|
5
|
+
data?: LoadedData;
|
|
6
|
+
navigateTo?: NavigateTo;
|
|
7
|
+
onClose: () => void;
|
|
8
|
+
/** Optional custom content renderer for PRD details (injected from PRDView). */
|
|
9
|
+
prdDetailContent?: VNode<any> | null;
|
|
10
|
+
}
|
|
11
|
+
export declare function DetailPanel({ detail, data, navigateTo, onClose, prdDetailContent }: DetailPanelProps): VNode<import("preact").Attributes> | null;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { h, Fragment } from "preact";
|
|
2
|
+
import { useEffect } from "preact/hooks";
|
|
3
|
+
import { meterClass, getZoneColorByIndex } from "../visualization/index.js";
|
|
4
|
+
import { basename } from "../utils.js";
|
|
5
|
+
export function DetailPanel({ detail, data, navigateTo, onClose, prdDetailContent }) {
|
|
6
|
+
// Close on Escape
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
if (!detail)
|
|
9
|
+
return;
|
|
10
|
+
const handleKey = (e) => {
|
|
11
|
+
if (e.key === "Escape")
|
|
12
|
+
onClose();
|
|
13
|
+
};
|
|
14
|
+
document.addEventListener("keydown", handleKey);
|
|
15
|
+
return () => document.removeEventListener("keydown", handleKey);
|
|
16
|
+
}, [detail, onClose]);
|
|
17
|
+
if (!detail)
|
|
18
|
+
return null;
|
|
19
|
+
let content;
|
|
20
|
+
if (detail.type === "prd" && prdDetailContent) {
|
|
21
|
+
content = prdDetailContent;
|
|
22
|
+
}
|
|
23
|
+
else if (detail.type === "file") {
|
|
24
|
+
content = renderFileDetail(detail, data, navigateTo, onClose);
|
|
25
|
+
}
|
|
26
|
+
else if (detail.type === "zone") {
|
|
27
|
+
content = renderZoneDetail(detail, data, navigateTo);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
content = renderGenericDetail(detail);
|
|
31
|
+
}
|
|
32
|
+
return h(Fragment, null,
|
|
33
|
+
// Mobile backdrop
|
|
34
|
+
h("div", {
|
|
35
|
+
class: "detail-backdrop",
|
|
36
|
+
onClick: onClose,
|
|
37
|
+
"aria-hidden": "true",
|
|
38
|
+
}), h("div", {
|
|
39
|
+
class: "detail-panel open",
|
|
40
|
+
role: "complementary",
|
|
41
|
+
"aria-label": "Item details",
|
|
42
|
+
}, h("div", {
|
|
43
|
+
class: "detail-header",
|
|
44
|
+
}, h("h3", { title: detail.title || "Details" }, detail.title || "Details"), h("button", {
|
|
45
|
+
class: "detail-close",
|
|
46
|
+
onClick: onClose,
|
|
47
|
+
"aria-label": "Close detail panel",
|
|
48
|
+
title: "Close (Esc)",
|
|
49
|
+
}, "\u2715", h("span", { class: "sr-only" }, "Close"))), content));
|
|
50
|
+
}
|
|
51
|
+
function renderFileDetail(detail, data, navigateTo, onClose) {
|
|
52
|
+
const path = detail.path;
|
|
53
|
+
const imports = data?.imports;
|
|
54
|
+
const zones = data?.zones;
|
|
55
|
+
// Find zone membership
|
|
56
|
+
let fileZone = null;
|
|
57
|
+
if (zones) {
|
|
58
|
+
for (let i = 0; i < zones.zones.length; i++) {
|
|
59
|
+
const z = zones.zones[i];
|
|
60
|
+
if (z.files.includes(path)) {
|
|
61
|
+
fileZone = { id: z.id, name: z.name, color: getZoneColorByIndex(i) };
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
// Incoming and outgoing imports
|
|
67
|
+
const incoming = imports?.edges.filter((e) => e.to === path).map((e) => e.from) ?? [];
|
|
68
|
+
const outgoing = imports?.edges.filter((e) => e.from === path).map((e) => e.to) ?? [];
|
|
69
|
+
return h(Fragment, null,
|
|
70
|
+
// Path in monospace
|
|
71
|
+
h("div", { class: "detail-code" }, path),
|
|
72
|
+
// File metadata
|
|
73
|
+
detail.language ? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Language"), h("span", null, detail.language)) : null, detail.size ? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Size"), h("span", null, detail.size)) : null, detail.lines ? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Lines"), h("span", null, String(detail.lines))) : null, detail.role ? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Role"), h("span", null, detail.role)) : null, detail.category ? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Category"), h("span", null, detail.category)) : null,
|
|
74
|
+
// Zone badge
|
|
75
|
+
fileZone
|
|
76
|
+
? h("div", { class: "detail-row" }, h("span", { class: "label" }, "Zone"), h("span", { class: "zone-badge", style: `--zone-color: ${fileZone.color}` }, fileZone.name))
|
|
77
|
+
: null,
|
|
78
|
+
// Incoming imports
|
|
79
|
+
incoming.length > 0
|
|
80
|
+
? h("div", { class: "mt-12" }, h("div", { class: "label mb-6" }, `Imported by (${incoming.length})`), h("div", { class: "detail-import-list" }, incoming.slice(0, 10).map((f) => h("div", { key: f, class: "detail-import-item", title: f }, basename(f))), incoming.length > 10
|
|
81
|
+
? h("div", { class: "detail-import-item text-dim" }, `... and ${incoming.length - 10} more`)
|
|
82
|
+
: null))
|
|
83
|
+
: null,
|
|
84
|
+
// Outgoing imports
|
|
85
|
+
outgoing.length > 0
|
|
86
|
+
? h("div", { class: "mt-12" }, h("div", { class: "label mb-6" }, `Imports (${outgoing.length})`), h("div", { class: "detail-import-list" }, outgoing.slice(0, 10).map((f) => h("div", { key: f, class: "detail-import-item", title: f }, basename(f))), outgoing.length > 10
|
|
87
|
+
? h("div", { class: "detail-import-item text-dim" }, `... and ${outgoing.length - 10} more`)
|
|
88
|
+
: null))
|
|
89
|
+
: null,
|
|
90
|
+
// Navigation button
|
|
91
|
+
navigateTo
|
|
92
|
+
? h("button", {
|
|
93
|
+
class: "detail-nav-btn",
|
|
94
|
+
onClick: () => navigateTo("graph", { file: path }),
|
|
95
|
+
}, "\u2B95 View in Graph")
|
|
96
|
+
: null);
|
|
97
|
+
}
|
|
98
|
+
function renderZoneDetail(detail, data, navigateTo) {
|
|
99
|
+
const zoneId = detail.zoneId || detail.id;
|
|
100
|
+
const zones = data?.zones;
|
|
101
|
+
const zone = zones?.zones.find((z) => z.id === zoneId);
|
|
102
|
+
const cohesion = parseFloat(detail.cohesion ?? String(zone?.cohesion ?? 0));
|
|
103
|
+
const coupling = parseFloat(detail.coupling ?? String(zone?.coupling ?? 0));
|
|
104
|
+
// Scoped findings
|
|
105
|
+
const scopedFindings = zones?.findings?.filter((f) => f.scope === zoneId) ?? [];
|
|
106
|
+
return h(Fragment, null, detail.description
|
|
107
|
+
? h("p", { class: "section-sub" }, detail.description)
|
|
108
|
+
: null,
|
|
109
|
+
// File count
|
|
110
|
+
h("div", { class: "detail-row" }, h("span", { class: "label" }, "Files"), h("span", null, String(detail.files))),
|
|
111
|
+
// Entry points
|
|
112
|
+
zone && zone.entryPoints.length > 0
|
|
113
|
+
? h("div", { class: "mt-8" }, h("div", { class: "label" }, "Entry Points"), h("div", { class: "detail-import-list" }, zone.entryPoints.map((ep) => h("div", { key: ep, class: "detail-import-item", title: ep }, basename(ep)))))
|
|
114
|
+
: null,
|
|
115
|
+
// Cohesion meter
|
|
116
|
+
h("div", { class: "mt-12" }, h("div", { class: "detail-row" }, h("span", { class: "label" }, "Cohesion"), h("span", null, cohesion.toFixed(2))), h("div", { class: "meter" }, h("div", {
|
|
117
|
+
class: `meter-fill ${meterClass(cohesion)}`,
|
|
118
|
+
style: `width: ${cohesion * 100}%`,
|
|
119
|
+
}))),
|
|
120
|
+
// Coupling meter
|
|
121
|
+
h("div", { class: "mt-8" }, h("div", { class: "detail-row" }, h("span", { class: "label" }, "Coupling"), h("span", null, coupling.toFixed(2))), h("div", { class: "meter" }, h("div", {
|
|
122
|
+
class: `meter-fill ${meterClass(coupling, true)}`,
|
|
123
|
+
style: `width: ${coupling * 100}%`,
|
|
124
|
+
}))),
|
|
125
|
+
// Scoped findings
|
|
126
|
+
scopedFindings.length > 0
|
|
127
|
+
? h("div", { class: "mt-12" }, h("div", { class: "label mb-6" }, `Findings (${scopedFindings.length})`), scopedFindings.slice(0, 5).map((f, i) => h("div", { key: i, class: "detail-finding-item" }, f.text)), scopedFindings.length > 5
|
|
128
|
+
? h("div", { class: "detail-more" }, `... and ${scopedFindings.length - 5} more`)
|
|
129
|
+
: null)
|
|
130
|
+
: null,
|
|
131
|
+
// Navigation buttons
|
|
132
|
+
navigateTo
|
|
133
|
+
? h("div", { class: "detail-nav-group" }, h("button", {
|
|
134
|
+
class: "detail-nav-btn",
|
|
135
|
+
onClick: () => navigateTo("files", { zone: zoneId }),
|
|
136
|
+
}, "\u2630 View in Files"), h("button", {
|
|
137
|
+
class: "detail-nav-btn",
|
|
138
|
+
onClick: () => navigateTo("problems"),
|
|
139
|
+
}, "\u26A0 View Problems"), h("button", {
|
|
140
|
+
class: "detail-nav-btn",
|
|
141
|
+
onClick: () => navigateTo("suggestions"),
|
|
142
|
+
}, "\u2728 View Suggestions"))
|
|
143
|
+
: null);
|
|
144
|
+
}
|
|
145
|
+
function renderGenericDetail(detail) {
|
|
146
|
+
const entries = Object.entries(detail).filter(([k, v]) => k !== "type" && v !== undefined && v !== null);
|
|
147
|
+
return h(Fragment, null, entries.map(([key, value]) => {
|
|
148
|
+
if (key === "title")
|
|
149
|
+
return null;
|
|
150
|
+
const displayValue = Array.isArray(value)
|
|
151
|
+
? value.length > 5
|
|
152
|
+
? `${value.slice(0, 5).join(", ")}... (${value.length} total)`
|
|
153
|
+
: value.join(", ")
|
|
154
|
+
: typeof value === "object"
|
|
155
|
+
? JSON.stringify(value)
|
|
156
|
+
: String(value);
|
|
157
|
+
return h("div", { key, class: "detail-row" }, h("span", { class: "label" }, formatKey(key)), h("span", null, displayValue));
|
|
158
|
+
}));
|
|
159
|
+
}
|
|
160
|
+
function formatKey(key) {
|
|
161
|
+
return key
|
|
162
|
+
.replace(/([A-Z])/g, " $1")
|
|
163
|
+
.replace(/^./, (s) => s.toUpperCase())
|
|
164
|
+
.trim();
|
|
165
|
+
}
|
|
166
|
+
//# sourceMappingURL=detail-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail-panel.js","sourceRoot":"","sources":["../../../src/viewer/components/detail-panel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ElapsedTime — memoized component for live-ticking elapsed time display.
|
|
3
|
+
*
|
|
4
|
+
* Isolates the 1-second tick re-renders from parent components. When the
|
|
5
|
+
* shared tick timer fires, only this small component re-renders — the
|
|
6
|
+
* parent card (which may contain links, badges, metadata chips, etc.)
|
|
7
|
+
* is unaffected.
|
|
8
|
+
*
|
|
9
|
+
* Usage:
|
|
10
|
+
* ```tsx
|
|
11
|
+
* // Before: useTick inside the card triggers full card re-render every second
|
|
12
|
+
* // const elapsed = useTick(run.startedAt, formatElapsed);
|
|
13
|
+
* // return h("span", null, elapsed);
|
|
14
|
+
*
|
|
15
|
+
* // After: only the ElapsedTime component re-renders
|
|
16
|
+
* // return h(ElapsedTime, { startedAt: run.startedAt, formatter: formatElapsed });
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export interface ElapsedTimeProps {
|
|
20
|
+
/** ISO 8601 timestamp of when the timer began. */
|
|
21
|
+
startedAt: string;
|
|
22
|
+
/** Pure function that converts a start timestamp to a display string. */
|
|
23
|
+
formatter: (startedAt: string) => string;
|
|
24
|
+
/** Optional CSS class for the wrapping <span>. */
|
|
25
|
+
class?: string;
|
|
26
|
+
/** Optional title attribute for tooltip. */
|
|
27
|
+
title?: string;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Renders a live-updating elapsed time string. The tick timer state is
|
|
31
|
+
* confined to this component, so parent components avoid re-rendering
|
|
32
|
+
* on every 1-second tick.
|
|
33
|
+
*/
|
|
34
|
+
export declare function ElapsedTime({ startedAt, formatter, class: className, title }: ElapsedTimeProps): import("preact").VNode<import("preact").ClassAttributes<HTMLElement> & {
|
|
35
|
+
class: string | undefined;
|
|
36
|
+
title: string | undefined;
|
|
37
|
+
"data-elapsed": boolean;
|
|
38
|
+
}>;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ElapsedTime — memoized component for live-ticking elapsed time display.
|
|
3
|
+
*
|
|
4
|
+
* Isolates the 1-second tick re-renders from parent components. When the
|
|
5
|
+
* shared tick timer fires, only this small component re-renders — the
|
|
6
|
+
* parent card (which may contain links, badges, metadata chips, etc.)
|
|
7
|
+
* is unaffected.
|
|
8
|
+
*
|
|
9
|
+
* Usage:
|
|
10
|
+
* ```tsx
|
|
11
|
+
* // Before: useTick inside the card triggers full card re-render every second
|
|
12
|
+
* // const elapsed = useTick(run.startedAt, formatElapsed);
|
|
13
|
+
* // return h("span", null, elapsed);
|
|
14
|
+
*
|
|
15
|
+
* // After: only the ElapsedTime component re-renders
|
|
16
|
+
* // return h(ElapsedTime, { startedAt: run.startedAt, formatter: formatElapsed });
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
import { h } from "preact";
|
|
20
|
+
import { useTick } from "../hooks/index.js";
|
|
21
|
+
// ── Component ────────────────────────────────────────────────────────
|
|
22
|
+
/**
|
|
23
|
+
* Renders a live-updating elapsed time string. The tick timer state is
|
|
24
|
+
* confined to this component, so parent components avoid re-rendering
|
|
25
|
+
* on every 1-second tick.
|
|
26
|
+
*/
|
|
27
|
+
export function ElapsedTime({ startedAt, formatter, class: className, title }) {
|
|
28
|
+
const display = useTick(startedAt, formatter);
|
|
29
|
+
return h("span", {
|
|
30
|
+
class: className ?? undefined,
|
|
31
|
+
title: title ?? undefined,
|
|
32
|
+
"data-elapsed": true, // marker for testing / styling
|
|
33
|
+
}, display);
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=elapsed-time.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"elapsed-time.js","sourceRoot":"","sources":["../../../src/viewer/components/elapsed-time.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAC3B,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAe5C,wEAAwE;AAExE;;;;GAIG;AACH,MAAM,UAAU,WAAW,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAoB;IAC7F,MAAM,OAAO,GAAG,OAAO,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAE9C,OAAO,CAAC,CAAC,MAAM,EAAE;QACf,KAAK,EAAE,SAAS,IAAI,SAAS;QAC7B,KAAK,EAAE,KAAK,IAAI,SAAS;QACzB,cAAc,EAAE,IAAI,EAAE,+BAA+B;KACtD,EAAE,OAAO,CAAC,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global FAQ button — lives in the sidebar footer toolbar (bottom-left).
|
|
3
|
+
* Opens the full FAQ modal without view-contextual auto-expansion.
|
|
4
|
+
*/
|
|
5
|
+
export declare function GlobalFAQ(): import("preact").VNode<import("preact").Attributes>;
|
|
6
|
+
/**
|
|
7
|
+
* Header FAQ button — contextual entry point in the content area header.
|
|
8
|
+
* Auto-expands the FAQ section relevant to the current view.
|
|
9
|
+
*/
|
|
10
|
+
export declare function HeaderFAQ({ view }: {
|
|
11
|
+
view: string;
|
|
12
|
+
}): import("preact").VNode<import("preact").Attributes>;
|