nuclie 1.0.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 +21 -0
- package/README.md +516 -0
- package/dist/ai/analyzer.d.ts +29 -0
- package/dist/ai/analyzer.js +202 -0
- package/dist/ai/chat/cli.d.ts +3 -0
- package/dist/ai/chat/cli.js +38 -0
- package/dist/ai/client.d.ts +17 -0
- package/dist/ai/client.js +68 -0
- package/dist/ai/cloud/api.d.ts +28 -0
- package/dist/ai/cloud/api.js +118 -0
- package/dist/ai/cloud/modelSync.d.ts +18 -0
- package/dist/ai/cloud/modelSync.js +104 -0
- package/dist/ai/cloud/telemetry.d.ts +14 -0
- package/dist/ai/cloud/telemetry.js +23 -0
- package/dist/ai/config.d.ts +14 -0
- package/dist/ai/config.js +9 -0
- package/dist/ai/core/errorMemory.d.ts +14 -0
- package/dist/ai/core/errorMemory.js +36 -0
- package/dist/ai/dashboard/cli.d.ts +3 -0
- package/dist/ai/dashboard/cli.js +32 -0
- package/dist/ai/healer/applier.d.ts +9 -0
- package/dist/ai/healer/applier.js +74 -0
- package/dist/ai/healer/cli.d.ts +3 -0
- package/dist/ai/healer/cli.js +57 -0
- package/dist/ai/healer/collector.d.ts +16 -0
- package/dist/ai/healer/collector.js +41 -0
- package/dist/ai/healer/fixer.d.ts +12 -0
- package/dist/ai/healer/fixer.js +40 -0
- package/dist/ai/healer/llm.d.ts +9 -0
- package/dist/ai/healer/llm.js +20 -0
- package/dist/ai/healer/parser.d.ts +16 -0
- package/dist/ai/healer/parser.js +67 -0
- package/dist/ai/learning/evolver.d.ts +8 -0
- package/dist/ai/learning/evolver.js +24 -0
- package/dist/ai/llm/fixGenerator.d.ts +9 -0
- package/dist/ai/llm/fixGenerator.js +21 -0
- package/dist/ai/llm/ollama.d.ts +10 -0
- package/dist/ai/llm/ollama.js +56 -0
- package/dist/ai/local/fixStore.d.ts +19 -0
- package/dist/ai/local/fixStore.js +105 -0
- package/dist/ai/optimizer/analyzer.d.ts +9 -0
- package/dist/ai/optimizer/analyzer.js +65 -0
- package/dist/ai/optimizer/engine.d.ts +16 -0
- package/dist/ai/optimizer/engine.js +51 -0
- package/dist/ai/optimizer/llm.d.ts +8 -0
- package/dist/ai/optimizer/llm.js +14 -0
- package/dist/ai/optimizer/profiler.d.ts +11 -0
- package/dist/ai/optimizer/profiler.js +111 -0
- package/dist/ai/optimizer/rules.d.ts +12 -0
- package/dist/ai/optimizer/rules.js +37 -0
- package/dist/ai/patterns/common.d.ts +8 -0
- package/dist/ai/patterns/common.js +181 -0
- package/dist/ai/reporter/assembler.d.ts +11 -0
- package/dist/ai/reporter/assembler.js +10 -0
- package/dist/ai/reporter/generator.d.ts +4 -0
- package/dist/ai/reporter/generator.js +42 -0
- package/dist/ai/reporter/narrator.d.ts +8 -0
- package/dist/ai/reporter/narrator.js +29 -0
- package/dist/ai/schema.d.ts +104 -0
- package/dist/ai/schema.js +45 -0
- package/dist/ai/telemetry.d.ts +14 -0
- package/dist/ai/telemetry.js +96 -0
- package/dist/audit/a11y.d.ts +5 -0
- package/dist/audit/a11y.js +123 -0
- package/dist/audit/best-practices.d.ts +5 -0
- package/dist/audit/best-practices.js +68 -0
- package/dist/audit/build-integration.d.ts +59 -0
- package/dist/audit/build-integration.js +138 -0
- package/dist/audit/core.d.ts +62 -0
- package/dist/audit/core.js +327 -0
- package/dist/audit/index.d.ts +4 -0
- package/dist/audit/index.js +60 -0
- package/dist/audit/perf.d.ts +5 -0
- package/dist/audit/perf.js +69 -0
- package/dist/audit/seo.d.ts +5 -0
- package/dist/audit/seo.js +63 -0
- package/dist/audit/types.d.ts +35 -0
- package/dist/audit/types.js +1 -0
- package/dist/audit-stub/types.d.ts +25 -0
- package/dist/audit-stub/types.js +1 -0
- package/dist/build/bundle-stats.d.ts +2 -0
- package/dist/build/bundle-stats.js +42 -0
- package/dist/build/bundler.d.ts +46 -0
- package/dist/build/bundler.js +31 -0
- package/dist/build/index.d.ts +36 -0
- package/dist/build/index.js +69 -0
- package/dist/build/pipeline.d.ts +31 -0
- package/dist/build/pipeline.js +68 -0
- package/dist/builder/server.d.ts +11 -0
- package/dist/builder/server.js +253 -0
- package/dist/cache/incremental.d.ts +75 -0
- package/dist/cache/incremental.js +200 -0
- package/dist/cache/index.d.ts +17 -0
- package/dist/cache/index.js +186 -0
- package/dist/cache/rocksdb.d.ts +18 -0
- package/dist/cache/rocksdb.js +63 -0
- package/dist/cli/css-cli.d.ts +5 -0
- package/dist/cli/css-cli.js +112 -0
- package/dist/cli/inspect.d.ts +1 -0
- package/dist/cli/inspect.js +94 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +586 -0
- package/dist/commands/analyze.d.ts +1 -0
- package/dist/commands/analyze.js +295 -0
- package/dist/commands/doctor.d.ts +21 -0
- package/dist/commands/doctor.js +364 -0
- package/dist/commands/ssr.d.ts +12 -0
- package/dist/commands/ssr.js +30 -0
- package/dist/commands/verify.d.ts +38 -0
- package/dist/commands/verify.js +459 -0
- package/dist/config/index.d.ts +145 -0
- package/dist/config/index.js +227 -0
- package/dist/config/live-config.d.ts +22 -0
- package/dist/config/live-config.js +88 -0
- package/dist/core/__tests__/permissions.test.d.ts +1 -0
- package/dist/core/__tests__/permissions.test.js +16 -0
- package/dist/core/__tests__/universal-transformer.test.d.ts +1 -0
- package/dist/core/__tests__/universal-transformer.test.js +27 -0
- package/dist/core/build/globalOptimizer.d.ts +8 -0
- package/dist/core/build/globalOptimizer.js +21 -0
- package/dist/core/build/incremental.d.ts +13 -0
- package/dist/core/build/incremental.js +29 -0
- package/dist/core/bundler-rolldown.d.ts +42 -0
- package/dist/core/bundler-rolldown.js +100 -0
- package/dist/core/cache/lazy-init.d.ts +50 -0
- package/dist/core/cache/lazy-init.js +153 -0
- package/dist/core/cache-manager.d.ts +51 -0
- package/dist/core/cache-manager.js +149 -0
- package/dist/core/css/engine.d.ts +37 -0
- package/dist/core/css/engine.js +113 -0
- package/dist/core/css-framework-detector.d.ts +10 -0
- package/dist/core/css-framework-detector.js +169 -0
- package/dist/core/detection/files.d.ts +2 -0
- package/dist/core/detection/files.js +77 -0
- package/dist/core/detection/index.d.ts +8 -0
- package/dist/core/detection/index.js +39 -0
- package/dist/core/detection/resolver.d.ts +2 -0
- package/dist/core/detection/resolver.js +116 -0
- package/dist/core/detection/scanner.d.ts +4 -0
- package/dist/core/detection/scanner.js +145 -0
- package/dist/core/detection/types.d.ts +33 -0
- package/dist/core/detection/types.js +12 -0
- package/dist/core/engine/cache.d.ts +18 -0
- package/dist/core/engine/cache.js +72 -0
- package/dist/core/engine/config.d.ts +11 -0
- package/dist/core/engine/config.js +158 -0
- package/dist/core/engine/emit.d.ts +8 -0
- package/dist/core/engine/emit.js +60 -0
- package/dist/core/engine/events.d.ts +13 -0
- package/dist/core/engine/events.js +35 -0
- package/dist/core/engine/execute.d.ts +5 -0
- package/dist/core/engine/execute.js +226 -0
- package/dist/core/engine/hash.d.ts +8 -0
- package/dist/core/engine/hash.js +39 -0
- package/dist/core/engine/index.d.ts +49 -0
- package/dist/core/engine/index.js +156 -0
- package/dist/core/engine/optimize.d.ts +2 -0
- package/dist/core/engine/optimize.js +99 -0
- package/dist/core/engine/plan.d.ts +9 -0
- package/dist/core/engine/plan.js +196 -0
- package/dist/core/engine/types.d.ts +120 -0
- package/dist/core/engine/types.js +1 -0
- package/dist/core/errors/hero-errors.d.ts +57 -0
- package/dist/core/errors/hero-errors.js +269 -0
- package/dist/core/framework-detector.d.ts +20 -0
- package/dist/core/framework-detector.js +148 -0
- package/dist/core/graph/js-graph-analyzer.d.ts +51 -0
- package/dist/core/graph/js-graph-analyzer.js +178 -0
- package/dist/core/graph/serializer.d.ts +7 -0
- package/dist/core/graph/serializer.js +24 -0
- package/dist/core/interop/analyze.d.ts +8 -0
- package/dist/core/interop/analyze.js +82 -0
- package/dist/core/interop/analyze_ast.d.ts +9 -0
- package/dist/core/interop/analyze_ast.js +174 -0
- package/dist/core/interop/index.d.ts +19 -0
- package/dist/core/interop/index.js +36 -0
- package/dist/core/interop/resolve.d.ts +9 -0
- package/dist/core/interop/resolve.js +55 -0
- package/dist/core/interop/types.d.ts +28 -0
- package/dist/core/interop/types.js +2 -0
- package/dist/core/interop/wrapper.d.ts +11 -0
- package/dist/core/interop/wrapper.js +50 -0
- package/dist/core/parser-bun.d.ts +54 -0
- package/dist/core/parser-bun.js +86 -0
- package/dist/core/permissions.d.ts +16 -0
- package/dist/core/permissions.js +47 -0
- package/dist/core/pipeline/framework-pipeline.d.ts +71 -0
- package/dist/core/pipeline/framework-pipeline.js +113 -0
- package/dist/core/plugins/index.d.ts +5 -0
- package/dist/core/plugins/index.js +5 -0
- package/dist/core/plugins/manager.d.ts +30 -0
- package/dist/core/plugins/manager.js +123 -0
- package/dist/core/plugins/sandbox_js.d.ts +9 -0
- package/dist/core/plugins/sandbox_js.js +37 -0
- package/dist/core/plugins/sandbox_wasm.d.ts +10 -0
- package/dist/core/plugins/sandbox_wasm.js +68 -0
- package/dist/core/plugins/types.d.ts +37 -0
- package/dist/core/plugins/types.js +2 -0
- package/dist/core/plugins/validation.d.ts +8 -0
- package/dist/core/plugins/validation.js +30 -0
- package/dist/core/sandbox.d.ts +9 -0
- package/dist/core/sandbox.js +79 -0
- package/dist/core/steps/css-optimization.d.ts +65 -0
- package/dist/core/steps/css-optimization.js +318 -0
- package/dist/core/steps.d.ts +7 -0
- package/dist/core/steps.js +17 -0
- package/dist/core/transform/batchTransformer.d.ts +12 -0
- package/dist/core/transform/batchTransformer.js +24 -0
- package/dist/core/transform/transformer.d.ts +9 -0
- package/dist/core/transform/transformer.js +189 -0
- package/dist/core/universal-transformer.d.ts +81 -0
- package/dist/core/universal-transformer.js +780 -0
- package/dist/create/index.d.ts +25 -0
- package/dist/create/index.js +584 -0
- package/dist/create/ui.d.ts +13 -0
- package/dist/create/ui.js +218 -0
- package/dist/create-nuclie/cli.d.ts +7 -0
- package/dist/create-nuclie/cli.js +73 -0
- package/dist/create-nuclie/templates.d.ts +18 -0
- package/dist/create-nuclie/templates.js +73 -0
- package/dist/create-nuclie.d.ts +2 -0
- package/dist/create-nuclie.js +7 -0
- package/dist/dashboard/metrics.d.ts +31 -0
- package/dist/dashboard/metrics.js +59 -0
- package/dist/dashboard/server/router.d.ts +52 -0
- package/dist/dashboard/server/router.js +36 -0
- package/dist/dev/__tests__/preBundler.test.d.ts +1 -0
- package/dist/dev/__tests__/preBundler.test.js +51 -0
- package/dist/dev/configWatcher.d.ts +10 -0
- package/dist/dev/configWatcher.js +42 -0
- package/dist/dev/devServer.d.ts +2 -0
- package/dist/dev/devServer.js +1398 -0
- package/dist/dev/devServer.minimal.d.ts +8 -0
- package/dist/dev/devServer.minimal.js +122 -0
- package/dist/dev/federation-dev.d.ts +14 -0
- package/dist/dev/federation-dev.js +69 -0
- package/dist/dev/hmr-engine.d.ts +12 -0
- package/dist/dev/hmr-engine.js +66 -0
- package/dist/dev/hmr-v2.d.ts +40 -0
- package/dist/dev/hmr-v2.js +87 -0
- package/dist/dev/hmrThrottle.d.ts +13 -0
- package/dist/dev/hmrThrottle.js +56 -0
- package/dist/dev/overlay/overlay-client.d.ts +7 -0
- package/dist/dev/overlay/overlay-client.js +53 -0
- package/dist/dev/overlay/overlay-ui.d.ts +17 -0
- package/dist/dev/overlay/overlay-ui.js +133 -0
- package/dist/dev/preBundler.d.ts +17 -0
- package/dist/dev/preBundler.js +343 -0
- package/dist/dev/statusHandler.d.ts +11 -0
- package/dist/dev/statusHandler.js +44 -0
- package/dist/dev/types.d.ts +30 -0
- package/dist/dev/types.js +1 -0
- package/dist/dev/watcher.d.ts +11 -0
- package/dist/dev/watcher.js +40 -0
- package/dist/dev-server-manual.d.ts +5 -0
- package/dist/dev-server-manual.js +24 -0
- package/dist/dev-server.d.ts +25 -0
- package/dist/dev-server.js +255 -0
- package/dist/env/api.d.ts +27 -0
- package/dist/env/api.js +36 -0
- package/dist/fix/ast-transforms.d.ts +81 -0
- package/dist/fix/ast-transforms.js +449 -0
- package/dist/hmr/classifier.d.ts +51 -0
- package/dist/hmr/classifier.js +232 -0
- package/dist/hmr/index.d.ts +5 -0
- package/dist/hmr/index.js +5 -0
- package/dist/hmr/overlay.d.ts +39 -0
- package/dist/hmr/overlay.js +285 -0
- package/dist/index.d.ts +46 -0
- package/dist/index.js +57 -0
- package/dist/init/bootstrap.d.ts +1 -0
- package/dist/init/bootstrap.js +106 -0
- package/dist/init/index.d.ts +1 -0
- package/dist/init/index.js +74 -0
- package/dist/init/templates.d.ts +2 -0
- package/dist/init/templates.js +227 -0
- package/dist/main.d.ts +1 -0
- package/dist/main.js +3 -0
- package/dist/marketplace/client.d.ts +25 -0
- package/dist/marketplace/client.js +73 -0
- package/dist/marketplace/db.d.ts +24 -0
- package/dist/marketplace/db.js +57 -0
- package/dist/marketplace/plugin-adapter.d.ts +14 -0
- package/dist/marketplace/plugin-adapter.js +85 -0
- package/dist/marketplace/server.d.ts +66 -0
- package/dist/marketplace/server.js +97 -0
- package/dist/meta-frameworks/base-router.d.ts +63 -0
- package/dist/meta-frameworks/base-router.js +259 -0
- package/dist/meta-frameworks/index.d.ts +8 -0
- package/dist/meta-frameworks/index.js +8 -0
- package/dist/meta-frameworks/nextjs/router.d.ts +35 -0
- package/dist/meta-frameworks/nextjs/router.js +176 -0
- package/dist/meta-frameworks/nuxt/router.d.ts +22 -0
- package/dist/meta-frameworks/nuxt/router.js +84 -0
- package/dist/meta-frameworks/remix/router.d.ts +28 -0
- package/dist/meta-frameworks/remix/router.js +136 -0
- package/dist/meta-frameworks/ssr/react-renderer.d.ts +24 -0
- package/dist/meta-frameworks/ssr/react-renderer.js +53 -0
- package/dist/meta-frameworks/ssr/server.d.ts +92 -0
- package/dist/meta-frameworks/ssr/server.js +312 -0
- package/dist/meta-frameworks/ssr/vue-renderer.d.ts +11 -0
- package/dist/meta-frameworks/ssr/vue-renderer.js +35 -0
- package/dist/meta-frameworks/types.d.ts +76 -0
- package/dist/meta-frameworks/types.js +5 -0
- package/dist/migrate/analyzer.d.ts +46 -0
- package/dist/migrate/analyzer.js +254 -0
- package/dist/migrate/cli.d.ts +10 -0
- package/dist/migrate/cli.js +63 -0
- package/dist/migrate/generator.d.ts +32 -0
- package/dist/migrate/generator.js +214 -0
- package/dist/native/cache.d.ts +86 -0
- package/dist/native/cache.js +154 -0
- package/dist/native/index.d.ts +4 -0
- package/dist/native/index.js +56 -0
- package/dist/native/orchestrator.d.ts +78 -0
- package/dist/native/orchestrator.js +107 -0
- package/dist/native/wasm.d.ts +22 -0
- package/dist/native/wasm.js +33 -0
- package/dist/nuclie_native.node +0 -0
- package/dist/plugins/assets.d.ts +2 -0
- package/dist/plugins/assets.js +50 -0
- package/dist/plugins/compat/adapter.d.ts +33 -0
- package/dist/plugins/compat/adapter.js +102 -0
- package/dist/plugins/compat/deferred.d.ts +17 -0
- package/dist/plugins/compat/deferred.js +28 -0
- package/dist/plugins/compat/index.d.ts +11 -0
- package/dist/plugins/compat/index.js +11 -0
- package/dist/plugins/compat/rollup.d.ts +19 -0
- package/dist/plugins/compat/rollup.js +76 -0
- package/dist/plugins/compat/tier-a.d.ts +60 -0
- package/dist/plugins/compat/tier-a.js +132 -0
- package/dist/plugins/compat/tier-b.d.ts +34 -0
- package/dist/plugins/compat/tier-b.js +90 -0
- package/dist/plugins/compat/tier-c.d.ts +48 -0
- package/dist/plugins/compat/tier-c.js +49 -0
- package/dist/plugins/compat/webpack.d.ts +26 -0
- package/dist/plugins/compat/webpack.js +77 -0
- package/dist/plugins/core/linker.d.ts +8 -0
- package/dist/plugins/core/linker.js +51 -0
- package/dist/plugins/css/bootstrap.d.ts +25 -0
- package/dist/plugins/css/bootstrap.js +110 -0
- package/dist/plugins/css/bulma.d.ts +23 -0
- package/dist/plugins/css/bulma.js +75 -0
- package/dist/plugins/css/css-modules.d.ts +19 -0
- package/dist/plugins/css/css-modules.js +96 -0
- package/dist/plugins/css/css-optimizer.d.ts +43 -0
- package/dist/plugins/css/css-optimizer.js +155 -0
- package/dist/plugins/css/emotion.d.ts +35 -0
- package/dist/plugins/css/emotion.js +109 -0
- package/dist/plugins/css/less.d.ts +6 -0
- package/dist/plugins/css/less.js +33 -0
- package/dist/plugins/css/material.d.ts +24 -0
- package/dist/plugins/css/material.js +97 -0
- package/dist/plugins/css/postcss.d.ts +2 -0
- package/dist/plugins/css/postcss.js +96 -0
- package/dist/plugins/css/sass.d.ts +6 -0
- package/dist/plugins/css/sass.js +36 -0
- package/dist/plugins/css/styled-components.d.ts +33 -0
- package/dist/plugins/css/styled-components.js +94 -0
- package/dist/plugins/css/stylus.d.ts +6 -0
- package/dist/plugins/css/stylus.js +41 -0
- package/dist/plugins/css/tailwind.d.ts +9 -0
- package/dist/plugins/css/tailwind.js +132 -0
- package/dist/plugins/css-in-js.d.ts +10 -0
- package/dist/plugins/css-in-js.js +24 -0
- package/dist/plugins/edge.d.ts +7 -0
- package/dist/plugins/edge.js +38 -0
- package/dist/plugins/esbuildAdapter.d.ts +3 -0
- package/dist/plugins/esbuildAdapter.js +77 -0
- package/dist/plugins/federation_next.d.ts +16 -0
- package/dist/plugins/federation_next.js +78 -0
- package/dist/plugins/framework-plugins.d.ts +3 -0
- package/dist/plugins/framework-plugins.js +40 -0
- package/dist/plugins/frameworks/index.d.ts +8 -0
- package/dist/plugins/frameworks/index.js +10 -0
- package/dist/plugins/frameworks/lit.d.ts +36 -0
- package/dist/plugins/frameworks/lit.js +114 -0
- package/dist/plugins/frameworks/react.d.ts +38 -0
- package/dist/plugins/frameworks/react.js +144 -0
- package/dist/plugins/frameworks/solid.d.ts +36 -0
- package/dist/plugins/frameworks/solid.js +108 -0
- package/dist/plugins/frameworks/svelte.d.ts +43 -0
- package/dist/plugins/frameworks/svelte.js +144 -0
- package/dist/plugins/frameworks/vue.d.ts +43 -0
- package/dist/plugins/frameworks/vue.js +240 -0
- package/dist/plugins/governance.d.ts +36 -0
- package/dist/plugins/governance.js +50 -0
- package/dist/plugins/html.d.ts +2 -0
- package/dist/plugins/html.js +49 -0
- package/dist/plugins/implementations/analytics.d.ts +7 -0
- package/dist/plugins/implementations/analytics.js +15 -0
- package/dist/plugins/implementations/apollo.d.ts +7 -0
- package/dist/plugins/implementations/apollo.js +15 -0
- package/dist/plugins/implementations/audit.d.ts +7 -0
- package/dist/plugins/implementations/audit.js +30 -0
- package/dist/plugins/implementations/auto-fix.d.ts +7 -0
- package/dist/plugins/implementations/auto-fix.js +15 -0
- package/dist/plugins/implementations/avif.d.ts +7 -0
- package/dist/plugins/implementations/avif.js +27 -0
- package/dist/plugins/implementations/babel.d.ts +7 -0
- package/dist/plugins/implementations/babel.js +15 -0
- package/dist/plugins/implementations/bundle-analyzer.d.ts +7 -0
- package/dist/plugins/implementations/bundle-analyzer.js +21 -0
- package/dist/plugins/implementations/bundle-size.d.ts +7 -0
- package/dist/plugins/implementations/bundle-size.js +21 -0
- package/dist/plugins/implementations/checker.d.ts +7 -0
- package/dist/plugins/implementations/checker.js +15 -0
- package/dist/plugins/implementations/chromatic.d.ts +7 -0
- package/dist/plugins/implementations/chromatic.js +15 -0
- package/dist/plugins/implementations/cloudflare.d.ts +7 -0
- package/dist/plugins/implementations/cloudflare.js +15 -0
- package/dist/plugins/implementations/code-split.d.ts +7 -0
- package/dist/plugins/implementations/code-split.js +21 -0
- package/dist/plugins/implementations/compression.d.ts +7 -0
- package/dist/plugins/implementations/compression.js +21 -0
- package/dist/plugins/implementations/copy.d.ts +7 -0
- package/dist/plugins/implementations/copy.js +15 -0
- package/dist/plugins/implementations/critical-css.d.ts +7 -0
- package/dist/plugins/implementations/critical-css.js +25 -0
- package/dist/plugins/implementations/crypto-sign.d.ts +7 -0
- package/dist/plugins/implementations/crypto-sign.js +30 -0
- package/dist/plugins/implementations/css-framework.d.ts +7 -0
- package/dist/plugins/implementations/css-framework.js +25 -0
- package/dist/plugins/implementations/css.d.ts +7 -0
- package/dist/plugins/implementations/css.js +25 -0
- package/dist/plugins/implementations/cypress.d.ts +7 -0
- package/dist/plugins/implementations/cypress.js +15 -0
- package/dist/plugins/implementations/determinism.d.ts +7 -0
- package/dist/plugins/implementations/determinism.js +21 -0
- package/dist/plugins/implementations/edge.d.ts +8 -0
- package/dist/plugins/implementations/edge.js +35 -0
- package/dist/plugins/implementations/env-validation.d.ts +7 -0
- package/dist/plugins/implementations/env-validation.js +30 -0
- package/dist/plugins/implementations/eslint.d.ts +7 -0
- package/dist/plugins/implementations/eslint.js +15 -0
- package/dist/plugins/implementations/federation.d.ts +7 -0
- package/dist/plugins/implementations/federation.js +15 -0
- package/dist/plugins/implementations/file.d.ts +7 -0
- package/dist/plugins/implementations/file.js +27 -0
- package/dist/plugins/implementations/font-subset.d.ts +7 -0
- package/dist/plugins/implementations/font-subset.js +27 -0
- package/dist/plugins/implementations/fonts.d.ts +7 -0
- package/dist/plugins/implementations/fonts.js +27 -0
- package/dist/plugins/implementations/formatjs.d.ts +7 -0
- package/dist/plugins/implementations/formatjs.js +18 -0
- package/dist/plugins/implementations/graphql.d.ts +7 -0
- package/dist/plugins/implementations/graphql.js +15 -0
- package/dist/plugins/implementations/hmr-classify.d.ts +7 -0
- package/dist/plugins/implementations/hmr-classify.js +21 -0
- package/dist/plugins/implementations/html.d.ts +7 -0
- package/dist/plugins/implementations/html.js +15 -0
- package/dist/plugins/implementations/i18n.d.ts +7 -0
- package/dist/plugins/implementations/i18n.js +15 -0
- package/dist/plugins/implementations/icon.d.ts +7 -0
- package/dist/plugins/implementations/icon.js +27 -0
- package/dist/plugins/implementations/imagemin.d.ts +7 -0
- package/dist/plugins/implementations/imagemin.js +27 -0
- package/dist/plugins/implementations/inspect.d.ts +7 -0
- package/dist/plugins/implementations/inspect.js +15 -0
- package/dist/plugins/implementations/jest.d.ts +7 -0
- package/dist/plugins/implementations/jest.js +19 -0
- package/dist/plugins/implementations/jotai.d.ts +8 -0
- package/dist/plugins/implementations/jotai.js +35 -0
- package/dist/plugins/implementations/lazy-load.d.ts +7 -0
- package/dist/plugins/implementations/lazy-load.js +21 -0
- package/dist/plugins/implementations/legacy.d.ts +7 -0
- package/dist/plugins/implementations/legacy.js +15 -0
- package/dist/plugins/implementations/lighthouse.d.ts +7 -0
- package/dist/plugins/implementations/lighthouse.js +21 -0
- package/dist/plugins/implementations/manifest.d.ts +7 -0
- package/dist/plugins/implementations/manifest.js +15 -0
- package/dist/plugins/implementations/markdown.d.ts +7 -0
- package/dist/plugins/implementations/markdown.js +15 -0
- package/dist/plugins/implementations/md.d.ts +7 -0
- package/dist/plugins/implementations/md.js +15 -0
- package/dist/plugins/implementations/mdx.d.ts +7 -0
- package/dist/plugins/implementations/mdx.js +15 -0
- package/dist/plugins/implementations/meta-tags.d.ts +7 -0
- package/dist/plugins/implementations/meta-tags.js +15 -0
- package/dist/plugins/implementations/mini-css-extract-plugin.d.ts +7 -0
- package/dist/plugins/implementations/mini-css-extract-plugin.js +25 -0
- package/dist/plugins/implementations/mobx.d.ts +8 -0
- package/dist/plugins/implementations/mobx.js +35 -0
- package/dist/plugins/implementations/mock.d.ts +7 -0
- package/dist/plugins/implementations/mock.js +15 -0
- package/dist/plugins/implementations/msw.d.ts +7 -0
- package/dist/plugins/implementations/msw.js +19 -0
- package/dist/plugins/implementations/nanostores.d.ts +7 -0
- package/dist/plugins/implementations/nanostores.js +18 -0
- package/dist/plugins/implementations/netlify.d.ts +7 -0
- package/dist/plugins/implementations/netlify.js +15 -0
- package/dist/plugins/implementations/observability.d.ts +7 -0
- package/dist/plugins/implementations/observability.js +15 -0
- package/dist/plugins/implementations/og-image.d.ts +7 -0
- package/dist/plugins/implementations/og-image.js +15 -0
- package/dist/plugins/implementations/pages.d.ts +7 -0
- package/dist/plugins/implementations/pages.js +15 -0
- package/dist/plugins/implementations/pinia.d.ts +8 -0
- package/dist/plugins/implementations/pinia.js +35 -0
- package/dist/plugins/implementations/plausible.d.ts +7 -0
- package/dist/plugins/implementations/plausible.js +18 -0
- package/dist/plugins/implementations/playwright.d.ts +7 -0
- package/dist/plugins/implementations/playwright.js +15 -0
- package/dist/plugins/implementations/postcss.d.ts +7 -0
- package/dist/plugins/implementations/postcss.js +25 -0
- package/dist/plugins/implementations/posthog.d.ts +7 -0
- package/dist/plugins/implementations/posthog.js +18 -0
- package/dist/plugins/implementations/prebundle.d.ts +7 -0
- package/dist/plugins/implementations/prebundle.js +21 -0
- package/dist/plugins/implementations/prefetch.d.ts +7 -0
- package/dist/plugins/implementations/prefetch.js +21 -0
- package/dist/plugins/implementations/preload.d.ts +7 -0
- package/dist/plugins/implementations/preload.js +21 -0
- package/dist/plugins/implementations/prisma.d.ts +7 -0
- package/dist/plugins/implementations/prisma.js +15 -0
- package/dist/plugins/implementations/pwa.d.ts +7 -0
- package/dist/plugins/implementations/pwa.js +15 -0
- package/dist/plugins/implementations/qr-code.d.ts +7 -0
- package/dist/plugins/implementations/qr-code.js +19 -0
- package/dist/plugins/implementations/razorpay.d.ts +7 -0
- package/dist/plugins/implementations/razorpay.js +19 -0
- package/dist/plugins/implementations/react-i18next.d.ts +7 -0
- package/dist/plugins/implementations/react-i18next.js +18 -0
- package/dist/plugins/implementations/react-query.d.ts +8 -0
- package/dist/plugins/implementations/react-query.js +35 -0
- package/dist/plugins/implementations/react.d.ts +8 -0
- package/dist/plugins/implementations/react.js +35 -0
- package/dist/plugins/implementations/recoil.d.ts +8 -0
- package/dist/plugins/implementations/recoil.js +35 -0
- package/dist/plugins/implementations/redux.d.ts +8 -0
- package/dist/plugins/implementations/redux.js +35 -0
- package/dist/plugins/implementations/relay.d.ts +7 -0
- package/dist/plugins/implementations/relay.js +15 -0
- package/dist/plugins/implementations/repro.d.ts +7 -0
- package/dist/plugins/implementations/repro.js +15 -0
- package/dist/plugins/implementations/robots.d.ts +7 -0
- package/dist/plugins/implementations/robots.js +15 -0
- package/dist/plugins/implementations/root-cause.d.ts +7 -0
- package/dist/plugins/implementations/root-cause.js +15 -0
- package/dist/plugins/implementations/rss.d.ts +7 -0
- package/dist/plugins/implementations/rss.js +15 -0
- package/dist/plugins/implementations/sass.d.ts +7 -0
- package/dist/plugins/implementations/sass.js +25 -0
- package/dist/plugins/implementations/sentry.d.ts +7 -0
- package/dist/plugins/implementations/sentry.js +15 -0
- package/dist/plugins/implementations/sitemap.d.ts +7 -0
- package/dist/plugins/implementations/sitemap.js +15 -0
- package/dist/plugins/implementations/solid.d.ts +8 -0
- package/dist/plugins/implementations/solid.js +35 -0
- package/dist/plugins/implementations/sprite.d.ts +7 -0
- package/dist/plugins/implementations/sprite.js +27 -0
- package/dist/plugins/implementations/ssr.d.ts +8 -0
- package/dist/plugins/implementations/ssr.js +35 -0
- package/dist/plugins/implementations/storybook.d.ts +7 -0
- package/dist/plugins/implementations/storybook.js +15 -0
- package/dist/plugins/implementations/stripe.d.ts +7 -0
- package/dist/plugins/implementations/stripe.js +19 -0
- package/dist/plugins/implementations/style.d.ts +7 -0
- package/dist/plugins/implementations/style.js +25 -0
- package/dist/plugins/implementations/svelte.d.ts +8 -0
- package/dist/plugins/implementations/svelte.js +35 -0
- package/dist/plugins/implementations/tailwind.d.ts +7 -0
- package/dist/plugins/implementations/tailwind.js +25 -0
- package/dist/plugins/implementations/tanstack-query.d.ts +7 -0
- package/dist/plugins/implementations/tanstack-query.js +18 -0
- package/dist/plugins/implementations/terser.d.ts +7 -0
- package/dist/plugins/implementations/terser.js +21 -0
- package/dist/plugins/implementations/testing-library-react.d.ts +7 -0
- package/dist/plugins/implementations/testing-library-react.js +19 -0
- package/dist/plugins/implementations/testing-library.d.ts +7 -0
- package/dist/plugins/implementations/testing-library.js +15 -0
- package/dist/plugins/implementations/tree-shake.d.ts +7 -0
- package/dist/plugins/implementations/tree-shake.js +21 -0
- package/dist/plugins/implementations/trpc.d.ts +7 -0
- package/dist/plugins/implementations/trpc.js +15 -0
- package/dist/plugins/implementations/ts.d.ts +7 -0
- package/dist/plugins/implementations/ts.js +15 -0
- package/dist/plugins/implementations/typescript.d.ts +7 -0
- package/dist/plugins/implementations/typescript.js +15 -0
- package/dist/plugins/implementations/unocss.d.ts +7 -0
- package/dist/plugins/implementations/unocss.js +25 -0
- package/dist/plugins/implementations/upi-payment.d.ts +7 -0
- package/dist/plugins/implementations/upi-payment.js +19 -0
- package/dist/plugins/implementations/url.d.ts +7 -0
- package/dist/plugins/implementations/url.js +27 -0
- package/dist/plugins/implementations/vercel.d.ts +7 -0
- package/dist/plugins/implementations/vercel.js +15 -0
- package/dist/plugins/implementations/visualizer.d.ts +7 -0
- package/dist/plugins/implementations/visualizer.js +15 -0
- package/dist/plugins/implementations/vite-svg-loader.d.ts +7 -0
- package/dist/plugins/implementations/vite-svg-loader.js +27 -0
- package/dist/plugins/implementations/vitest.d.ts +7 -0
- package/dist/plugins/implementations/vitest.js +15 -0
- package/dist/plugins/implementations/vue-i18n-next.d.ts +7 -0
- package/dist/plugins/implementations/vue-i18n-next.js +18 -0
- package/dist/plugins/implementations/vue-i18n.d.ts +7 -0
- package/dist/plugins/implementations/vue-i18n.js +15 -0
- package/dist/plugins/implementations/vue-layouts.d.ts +8 -0
- package/dist/plugins/implementations/vue-layouts.js +35 -0
- package/dist/plugins/implementations/vue.d.ts +8 -0
- package/dist/plugins/implementations/vue.js +35 -0
- package/dist/plugins/implementations/vuex.d.ts +8 -0
- package/dist/plugins/implementations/vuex.js +35 -0
- package/dist/plugins/implementations/wasm-sandbox.d.ts +7 -0
- package/dist/plugins/implementations/wasm-sandbox.js +30 -0
- package/dist/plugins/implementations/webp.d.ts +7 -0
- package/dist/plugins/implementations/webp.js +27 -0
- package/dist/plugins/implementations/windicss.d.ts +7 -0
- package/dist/plugins/implementations/windicss.js +25 -0
- package/dist/plugins/implementations/workbox.d.ts +7 -0
- package/dist/plugins/implementations/workbox.js +15 -0
- package/dist/plugins/implementations/xstate.d.ts +7 -0
- package/dist/plugins/implementations/xstate.js +18 -0
- package/dist/plugins/implementations/zod.d.ts +7 -0
- package/dist/plugins/implementations/zod.js +15 -0
- package/dist/plugins/implementations/zustand-devtools.d.ts +7 -0
- package/dist/plugins/implementations/zustand-devtools.js +18 -0
- package/dist/plugins/implementations/zustand.d.ts +8 -0
- package/dist/plugins/implementations/zustand.js +35 -0
- package/dist/plugins/index.d.ts +49 -0
- package/dist/plugins/index.js +117 -0
- package/dist/plugins/js-transform.d.ts +2 -0
- package/dist/plugins/js-transform.js +49 -0
- package/dist/plugins/json.d.ts +2 -0
- package/dist/plugins/json.js +34 -0
- package/dist/plugins/pluginWorker.mjs +95 -0
- package/dist/plugins/ported/adapter.d.ts +92 -0
- package/dist/plugins/ported/adapter.js +226 -0
- package/dist/plugins/registry.d.ts +51 -0
- package/dist/plugins/registry.js +151 -0
- package/dist/plugins/reporter.d.ts +5 -0
- package/dist/plugins/reporter.js +47 -0
- package/dist/plugins/samplePlugin.mjs +4 -0
- package/dist/plugins/sandbox.d.ts +12 -0
- package/dist/plugins/sandbox.js +126 -0
- package/dist/plugins/signer.d.ts +53 -0
- package/dist/plugins/signer.js +109 -0
- package/dist/plugins/static.d.ts +2 -0
- package/dist/plugins/static.js +47 -0
- package/dist/plugins/svelte.d.ts +7 -0
- package/dist/plugins/svelte.js +27 -0
- package/dist/plugins/testSandbox.d.ts +1 -0
- package/dist/plugins/testSandbox.js +14 -0
- package/dist/plugins/verify.d.ts +3 -0
- package/dist/plugins/verify.js +113 -0
- package/dist/plugins/vue.d.ts +7 -0
- package/dist/plugins/vue.js +86 -0
- package/dist/plugins/wasm-runtime.d.ts +15 -0
- package/dist/plugins/wasm-runtime.js +33 -0
- package/dist/plugins/wasm.d.ts +5 -0
- package/dist/plugins/wasm.js +44 -0
- package/dist/polyfills/corejs.d.ts +9 -0
- package/dist/polyfills/corejs.js +18 -0
- package/dist/presets/core.d.ts +111 -0
- package/dist/presets/core.js +239 -0
- package/dist/presets/frameworks.d.ts +34 -0
- package/dist/presets/frameworks.js +270 -0
- package/dist/presets/index.d.ts +8 -0
- package/dist/presets/index.js +3 -0
- package/dist/presets/infrastructure.d.ts +2 -0
- package/dist/presets/infrastructure.js +33 -0
- package/dist/presets/spa.d.ts +2 -0
- package/dist/presets/spa.js +15 -0
- package/dist/presets/ssg.d.ts +2 -0
- package/dist/presets/ssg.js +9 -0
- package/dist/presets/ssr.d.ts +2 -0
- package/dist/presets/ssr.js +13 -0
- package/dist/repro/dashboard.d.ts +83 -0
- package/dist/repro/dashboard.js +251 -0
- package/dist/repro/github.d.ts +26 -0
- package/dist/repro/github.js +73 -0
- package/dist/resolve/css-precedence.d.ts +16 -0
- package/dist/resolve/css-precedence.js +56 -0
- package/dist/resolve/graph.d.ts +48 -0
- package/dist/resolve/graph.js +232 -0
- package/dist/resolve/utils.d.ts +13 -0
- package/dist/resolve/utils.js +53 -0
- package/dist/runtime/client.d.ts +9 -0
- package/dist/runtime/client.js +218 -0
- package/dist/runtime/error-overlay.d.ts +15 -0
- package/dist/runtime/error-overlay.js +327 -0
- package/dist/runtime/federation-fallback.d.ts +67 -0
- package/dist/runtime/federation-fallback.js +225 -0
- package/dist/runtime/federation.d.ts +27 -0
- package/dist/runtime/federation.js +210 -0
- package/dist/runtime/federation_runtime.js +90 -0
- package/dist/runtime/hmr-client.d.ts +5 -0
- package/dist/runtime/hmr-client.js +70 -0
- package/dist/security/anomaly.d.ts +41 -0
- package/dist/security/anomaly.js +77 -0
- package/dist/server/security-headers.d.ts +37 -0
- package/dist/server/security-headers.js +110 -0
- package/dist/ssr/adapters/edge.d.ts +12 -0
- package/dist/ssr/adapters/edge.js +26 -0
- package/dist/ssr/adapters/index.d.ts +23 -0
- package/dist/ssr/adapters/index.js +58 -0
- package/dist/ssr/app-router.d.ts +24 -0
- package/dist/ssr/app-router.js +70 -0
- package/dist/ssr/edge/handlers.d.ts +24 -0
- package/dist/ssr/edge/handlers.js +48 -0
- package/dist/ssr/image.d.ts +24 -0
- package/dist/ssr/image.js +38 -0
- package/dist/ssr/isr.d.ts +14 -0
- package/dist/ssr/isr.js +29 -0
- package/dist/ssr/rsc.d.ts +19 -0
- package/dist/ssr/rsc.js +33 -0
- package/dist/ssr/streaming.d.ts +31 -0
- package/dist/ssr/streaming.js +78 -0
- package/dist/ssr/universal-engine.d.ts +36 -0
- package/dist/ssr/universal-engine.js +139 -0
- package/dist/templates/manager.d.ts +28 -0
- package/dist/templates/manager.js +162 -0
- package/dist/templates/starters/angular-spa.d.ts +6 -0
- package/dist/templates/starters/angular-spa.js +149 -0
- package/dist/templates/starters/edge.d.ts +6 -0
- package/dist/templates/starters/edge.js +93 -0
- package/dist/templates/starters/fintech.d.ts +6 -0
- package/dist/templates/starters/fintech.js +211 -0
- package/dist/templates/starters/monorepo.d.ts +6 -0
- package/dist/templates/starters/monorepo.js +133 -0
- package/dist/templates/starters/nextjs-app.d.ts +13 -0
- package/dist/templates/starters/nextjs-app.js +116 -0
- package/dist/templates/starters/preact-spa.d.ts +6 -0
- package/dist/templates/starters/preact-spa.js +97 -0
- package/dist/templates/starters/premium-dashboard.d.ts +6 -0
- package/dist/templates/starters/premium-dashboard.js +762 -0
- package/dist/templates/starters/react-spa.d.ts +6 -0
- package/dist/templates/starters/react-spa.js +152 -0
- package/dist/templates/starters/react-ssr.d.ts +6 -0
- package/dist/templates/starters/react-ssr.js +190 -0
- package/dist/templates/starters/remix-app.d.ts +12 -0
- package/dist/templates/starters/remix-app.js +108 -0
- package/dist/templates/starters/solid-spa.d.ts +6 -0
- package/dist/templates/starters/solid-spa.js +158 -0
- package/dist/templates/starters/svelte-spa.d.ts +6 -0
- package/dist/templates/starters/svelte-spa.js +147 -0
- package/dist/templates/starters/vue-spa.d.ts +6 -0
- package/dist/templates/starters/vue-spa.js +136 -0
- package/dist/test/api.d.ts +58 -0
- package/dist/test/api.js +154 -0
- package/dist/test/coverage.d.ts +1 -0
- package/dist/test/coverage.js +134 -0
- package/dist/test/determinism.d.ts +1 -0
- package/dist/test/determinism.js +122 -0
- package/dist/test/regression.d.ts +1 -0
- package/dist/test/regression.js +30 -0
- package/dist/test/runner.d.ts +1 -0
- package/dist/test/runner.js +159 -0
- package/dist/test-server.d.ts +1 -0
- package/dist/test-server.js +22 -0
- package/dist/ui/terminal-warnings.d.ts +10 -0
- package/dist/ui/terminal-warnings.js +26 -0
- package/dist/ui/types.d.ts +13 -0
- package/dist/ui/types.js +5 -0
- package/dist/ui/warning-detector.d.ts +46 -0
- package/dist/ui/warning-detector.js +178 -0
- package/dist/ui/warning-library.d.ts +51 -0
- package/dist/ui/warning-library.js +283 -0
- package/dist/utils/interactive.d.ts +2 -0
- package/dist/utils/interactive.js +37 -0
- package/dist/utils/logger.d.ts +26 -0
- package/dist/utils/logger.js +130 -0
- package/dist/utils/path-normalize.d.ts +24 -0
- package/dist/utils/path-normalize.js +37 -0
- package/dist/visual/chart-generator.d.ts +11 -0
- package/dist/visual/chart-generator.js +30 -0
- package/dist/visual/client/renderer.d.ts +31 -0
- package/dist/visual/client/renderer.js +98 -0
- package/dist/visual/federation-editor.d.ts +1 -0
- package/dist/visual/federation-editor.js +231 -0
- package/dist/visual/graph-engine.d.ts +38 -0
- package/dist/visual/graph-engine.js +64 -0
- package/dist/visual/graph-ui.d.ts +2 -0
- package/dist/visual/graph-ui.js +119 -0
- package/dist/visual/graph-visualizer.d.ts +69 -0
- package/dist/visual/graph-visualizer.js +282 -0
- package/dist/visual/root-cause.d.ts +83 -0
- package/dist/visual/root-cause.js +265 -0
- package/package.json +169 -0
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Nuclie Dependency Graph Renderer
|
|
3
|
+
* Implementation: Three.js (WebGL/WebGPU)
|
|
4
|
+
* Day 16: WebGPU Visualizer v2 Lock
|
|
5
|
+
*/
|
|
6
|
+
import * as THREE from 'three';
|
|
7
|
+
export class GraphRenderer {
|
|
8
|
+
constructor(containerId) {
|
|
9
|
+
this.nodesMesh = null;
|
|
10
|
+
// Config
|
|
11
|
+
this.NODE_SIZE = 2;
|
|
12
|
+
this.COLOR_HUB = 0xff0000;
|
|
13
|
+
this.COLOR_LEAF = 0x00ff00;
|
|
14
|
+
const el = document.getElementById(containerId);
|
|
15
|
+
if (!el)
|
|
16
|
+
throw new Error(`Container #${containerId} not found`);
|
|
17
|
+
this.container = el;
|
|
18
|
+
// Init Three.js
|
|
19
|
+
this.scene = new THREE.Scene();
|
|
20
|
+
this.scene.background = new THREE.Color(0x000011); // Dark Blue/Black
|
|
21
|
+
this.camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 10000);
|
|
22
|
+
this.camera.position.z = 1000;
|
|
23
|
+
this.renderer = new THREE.WebGLRenderer({ antialias: true, alpha: true });
|
|
24
|
+
this.renderer.setSize(window.innerWidth, window.innerHeight);
|
|
25
|
+
this.renderer.setPixelRatio(window.devicePixelRatio);
|
|
26
|
+
this.container.appendChild(this.renderer.domElement);
|
|
27
|
+
// Lights
|
|
28
|
+
const ambientLight = new THREE.AmbientLight(0xbbbbbb);
|
|
29
|
+
this.scene.add(ambientLight);
|
|
30
|
+
const directionalLight = new THREE.DirectionalLight(0xffffff, 0.6);
|
|
31
|
+
directionalLight.position.set(1, 1, 1);
|
|
32
|
+
this.scene.add(directionalLight);
|
|
33
|
+
// Resize Listener
|
|
34
|
+
window.addEventListener('resize', this.onWindowResize.bind(this));
|
|
35
|
+
// Start Loop
|
|
36
|
+
this.animate();
|
|
37
|
+
}
|
|
38
|
+
onWindowResize() {
|
|
39
|
+
this.camera.aspect = window.innerWidth / window.innerHeight;
|
|
40
|
+
this.camera.updateProjectionMatrix();
|
|
41
|
+
this.renderer.setSize(window.innerWidth, window.innerHeight);
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Load Graph Data and generate GPU Instanced Mesh
|
|
45
|
+
* This is highly optimized for 10k+ nodes (1 draw call)
|
|
46
|
+
*/
|
|
47
|
+
loadData(data) {
|
|
48
|
+
// Cleanup old
|
|
49
|
+
if (this.nodesMesh) {
|
|
50
|
+
this.scene.remove(this.nodesMesh);
|
|
51
|
+
this.nodesMesh.geometry.dispose();
|
|
52
|
+
this.nodesMesh.material.dispose();
|
|
53
|
+
}
|
|
54
|
+
const geometry = new THREE.SphereGeometry(this.NODE_SIZE, 8, 8); // Low poly spheres
|
|
55
|
+
const material = new THREE.MeshLambertMaterial({ color: 0xffffff });
|
|
56
|
+
this.nodesMesh = new THREE.InstancedMesh(geometry, material, data.nodes.length);
|
|
57
|
+
const dummy = new THREE.Object3D();
|
|
58
|
+
const color = new THREE.Color();
|
|
59
|
+
for (let i = 0; i < data.nodes.length; i++) {
|
|
60
|
+
const node = data.nodes[i];
|
|
61
|
+
// Position (Mock random layout if not pre-calculated, usually pre-calc in Worker)
|
|
62
|
+
// In layout-engine we generate positions, here we apply them.
|
|
63
|
+
// Assuming data.nodes has x,y,z
|
|
64
|
+
const x = (Math.random() - 0.5) * 2000;
|
|
65
|
+
const y = (Math.random() - 0.5) * 2000;
|
|
66
|
+
const z = (Math.random() - 0.5) * 2000;
|
|
67
|
+
dummy.position.set(x, y, z);
|
|
68
|
+
dummy.updateMatrix();
|
|
69
|
+
this.nodesMesh.setMatrixAt(i, dummy.matrix);
|
|
70
|
+
// Color based on metrics
|
|
71
|
+
if (node.importers && node.importers.length > 50) {
|
|
72
|
+
color.setHex(this.COLOR_HUB);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
color.setHex(this.COLOR_LEAF);
|
|
76
|
+
}
|
|
77
|
+
this.nodesMesh.setColorAt(i, color);
|
|
78
|
+
}
|
|
79
|
+
this.nodesMesh.instanceMatrix.needsUpdate = true;
|
|
80
|
+
this.nodesMesh.instanceColor.needsUpdate = true;
|
|
81
|
+
this.scene.add(this.nodesMesh);
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Highlight optimization hints (e.g. pulse red nodes)
|
|
85
|
+
*/
|
|
86
|
+
highlightHints(hints) {
|
|
87
|
+
// Implementation: update instanceColor for specific IDs
|
|
88
|
+
console.log(`Highlighting ${hints.length} optimization opportunities`);
|
|
89
|
+
}
|
|
90
|
+
animate() {
|
|
91
|
+
requestAnimationFrame(this.animate.bind(this));
|
|
92
|
+
// Slow rotation
|
|
93
|
+
if (this.nodesMesh) {
|
|
94
|
+
this.nodesMesh.rotation.y += 0.001;
|
|
95
|
+
}
|
|
96
|
+
this.renderer.render(this.scene, this.camera);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getEditorHtml(config: any): string;
|
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
export function getEditorHtml(config) {
|
|
2
|
+
const remotes = config.federation?.remotes || {};
|
|
3
|
+
const exposes = config.federation?.exposes || {};
|
|
4
|
+
const shared = config.federation?.shared || {};
|
|
5
|
+
return `
|
|
6
|
+
<!DOCTYPE html>
|
|
7
|
+
<html lang="en">
|
|
8
|
+
<head>
|
|
9
|
+
<meta charset="UTF-8">
|
|
10
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
11
|
+
<title>Nuclie Federation Editor</title>
|
|
12
|
+
<style>
|
|
13
|
+
:root {
|
|
14
|
+
--bg: #0f172a;
|
|
15
|
+
--surface: #1e293b;
|
|
16
|
+
--primary: #3b82f6;
|
|
17
|
+
--text: #f8fafc;
|
|
18
|
+
--text-dim: #94a3b8;
|
|
19
|
+
--border: #334155;
|
|
20
|
+
}
|
|
21
|
+
body {
|
|
22
|
+
font-family: 'Inter', system-ui, sans-serif;
|
|
23
|
+
background: var(--bg);
|
|
24
|
+
color: var(--text);
|
|
25
|
+
margin: 0;
|
|
26
|
+
display: flex;
|
|
27
|
+
height: 100vh;
|
|
28
|
+
}
|
|
29
|
+
.sidebar {
|
|
30
|
+
width: 300px;
|
|
31
|
+
background: var(--surface);
|
|
32
|
+
border-right: 1px solid var(--border);
|
|
33
|
+
padding: 20px;
|
|
34
|
+
display: flex;
|
|
35
|
+
flex-direction: column;
|
|
36
|
+
gap: 20px;
|
|
37
|
+
}
|
|
38
|
+
.main {
|
|
39
|
+
flex: 1;
|
|
40
|
+
padding: 40px;
|
|
41
|
+
overflow-y: auto;
|
|
42
|
+
}
|
|
43
|
+
h1, h2, h3 { margin: 0; }
|
|
44
|
+
.card {
|
|
45
|
+
background: var(--surface);
|
|
46
|
+
border: 1px solid var(--border);
|
|
47
|
+
border-radius: 8px;
|
|
48
|
+
padding: 16px;
|
|
49
|
+
margin-bottom: 16px;
|
|
50
|
+
}
|
|
51
|
+
.section-title {
|
|
52
|
+
color: var(--text-dim);
|
|
53
|
+
font-size: 0.875rem;
|
|
54
|
+
text-transform: uppercase;
|
|
55
|
+
letter-spacing: 0.05em;
|
|
56
|
+
margin-bottom: 10px;
|
|
57
|
+
}
|
|
58
|
+
.item {
|
|
59
|
+
display: flex;
|
|
60
|
+
justify-content: space-between;
|
|
61
|
+
align-items: center;
|
|
62
|
+
padding: 8px;
|
|
63
|
+
background: rgba(255,255,255,0.05);
|
|
64
|
+
border-radius: 4px;
|
|
65
|
+
margin-bottom: 8px;
|
|
66
|
+
cursor: grab;
|
|
67
|
+
}
|
|
68
|
+
.item:active { cursor: grabbing; }
|
|
69
|
+
.badge {
|
|
70
|
+
background: var(--primary);
|
|
71
|
+
color: white;
|
|
72
|
+
padding: 2px 6px;
|
|
73
|
+
border-radius: 4px;
|
|
74
|
+
font-size: 0.75rem;
|
|
75
|
+
}
|
|
76
|
+
.drop-zone {
|
|
77
|
+
border: 2px dashed var(--border);
|
|
78
|
+
border-radius: 8px;
|
|
79
|
+
padding: 40px;
|
|
80
|
+
text-align: center;
|
|
81
|
+
color: var(--text-dim);
|
|
82
|
+
transition: all 0.2s;
|
|
83
|
+
}
|
|
84
|
+
.drop-zone.drag-over {
|
|
85
|
+
border-color: var(--primary);
|
|
86
|
+
background: rgba(59, 130, 246, 0.1);
|
|
87
|
+
color: var(--primary);
|
|
88
|
+
}
|
|
89
|
+
input {
|
|
90
|
+
background: var(--bg);
|
|
91
|
+
border: 1px solid var(--border);
|
|
92
|
+
color: var(--text);
|
|
93
|
+
padding: 8px;
|
|
94
|
+
border-radius: 4px;
|
|
95
|
+
width: 100%;
|
|
96
|
+
box-sizing: border-box;
|
|
97
|
+
}
|
|
98
|
+
button {
|
|
99
|
+
background: var(--primary);
|
|
100
|
+
color: white;
|
|
101
|
+
border: none;
|
|
102
|
+
padding: 8px 16px;
|
|
103
|
+
border-radius: 4px;
|
|
104
|
+
cursor: pointer;
|
|
105
|
+
font-weight: 500;
|
|
106
|
+
}
|
|
107
|
+
button:hover { opacity: 0.9; }
|
|
108
|
+
</style>
|
|
109
|
+
</head>
|
|
110
|
+
<body>
|
|
111
|
+
<div class="sidebar">
|
|
112
|
+
<div>
|
|
113
|
+
<h1>Federation</h1>
|
|
114
|
+
<p style="color: var(--text-dim); font-size: 0.875rem;">Visual Editor</p>
|
|
115
|
+
</div>
|
|
116
|
+
|
|
117
|
+
<div>
|
|
118
|
+
<div class="section-title">Configured Remotes</div>
|
|
119
|
+
<div id="remotes-list">
|
|
120
|
+
${Object.entries(remotes).map(([name, url]) => `
|
|
121
|
+
<div class="item" draggable="true" data-type="remote" data-name="${name}" data-url="${url}">
|
|
122
|
+
<span>${name}</span>
|
|
123
|
+
<span class="badge">Remote</span>
|
|
124
|
+
</div>
|
|
125
|
+
`).join('')}
|
|
126
|
+
</div>
|
|
127
|
+
</div>
|
|
128
|
+
|
|
129
|
+
<div>
|
|
130
|
+
<div class="section-title">Exposed Modules</div>
|
|
131
|
+
<div id="exposes-list">
|
|
132
|
+
${Object.entries(exposes).map(([key, path]) => `
|
|
133
|
+
<div class="item">
|
|
134
|
+
<span>${key}</span>
|
|
135
|
+
<span style="color: var(--text-dim); font-size: 0.75rem;">${path}</span>
|
|
136
|
+
</div>
|
|
137
|
+
`).join('')}
|
|
138
|
+
</div>
|
|
139
|
+
</div>
|
|
140
|
+
</div>
|
|
141
|
+
|
|
142
|
+
<div class="main">
|
|
143
|
+
<div style="display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px;">
|
|
144
|
+
<h2>Dependency Graph</h2>
|
|
145
|
+
<button onclick="saveConfig()">Save Changes</button>
|
|
146
|
+
</div>
|
|
147
|
+
|
|
148
|
+
<div class="drop-zone" id="canvas">
|
|
149
|
+
<h3>Drag Remotes Here to Link</h3>
|
|
150
|
+
<p>Visualize relationships between Host and Remotes</p>
|
|
151
|
+
<div id="graph-container" style="margin-top: 20px; display: flex; gap: 20px; flex-wrap: wrap; justify-content: center;">
|
|
152
|
+
<!-- Graph Nodes will appear here -->
|
|
153
|
+
</div>
|
|
154
|
+
</div>
|
|
155
|
+
|
|
156
|
+
<div style="margin-top: 40px;">
|
|
157
|
+
<h3>Shared Dependencies</h3>
|
|
158
|
+
<div style="display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; margin-top: 16px;">
|
|
159
|
+
${Object.entries(shared).map(([pkg, opts]) => `
|
|
160
|
+
<div class="card">
|
|
161
|
+
<strong>${pkg}</strong>
|
|
162
|
+
<div style="margin-top: 8px; font-size: 0.875rem; color: var(--text-dim);">
|
|
163
|
+
<div>Singleton: ${opts.singleton ? 'Yes' : 'No'}</div>
|
|
164
|
+
<div>Version: ${opts.requiredVersion || '*'}</div>
|
|
165
|
+
</div>
|
|
166
|
+
</div>
|
|
167
|
+
`).join('')}
|
|
168
|
+
</div>
|
|
169
|
+
</div>
|
|
170
|
+
</div>
|
|
171
|
+
|
|
172
|
+
<script>
|
|
173
|
+
// Simple Drag and Drop Logic
|
|
174
|
+
const draggables = document.querySelectorAll('[draggable="true"]');
|
|
175
|
+
const canvas = document.getElementById('canvas');
|
|
176
|
+
const graphContainer = document.getElementById('graph-container');
|
|
177
|
+
|
|
178
|
+
draggables.forEach(draggable => {
|
|
179
|
+
draggable.addEventListener('dragstart', () => {
|
|
180
|
+
draggable.classList.add('dragging');
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
draggable.addEventListener('dragend', () => {
|
|
184
|
+
draggable.classList.remove('dragging');
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
canvas.addEventListener('dragover', e => {
|
|
189
|
+
e.preventDefault();
|
|
190
|
+
canvas.classList.add('drag-over');
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
canvas.addEventListener('dragleave', () => {
|
|
194
|
+
canvas.classList.remove('drag-over');
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
canvas.addEventListener('drop', e => {
|
|
198
|
+
e.preventDefault();
|
|
199
|
+
canvas.classList.remove('drag-over');
|
|
200
|
+
const dragging = document.querySelector('.dragging');
|
|
201
|
+
if (dragging) {
|
|
202
|
+
const name = dragging.dataset.name;
|
|
203
|
+
const url = dragging.dataset.url;
|
|
204
|
+
addNodeToGraph(name, url);
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
function addNodeToGraph(name, url) {
|
|
209
|
+
const node = document.createElement('div');
|
|
210
|
+
node.className = 'card';
|
|
211
|
+
node.style.minWidth = '200px';
|
|
212
|
+
node.innerHTML = \`
|
|
213
|
+
<div style="display:flex; justify-content:space-between; align-items:center;">
|
|
214
|
+
<strong>\${name}</strong>
|
|
215
|
+
<button style="padding: 2px 6px; font-size: 12px; background: #ef4444;" onclick="this.parentElement.parentElement.remove()">×</button>
|
|
216
|
+
</div>
|
|
217
|
+
<div style="font-size: 12px; color: #94a3b8; margin-top: 4px;">\${url}</div>
|
|
218
|
+
<div style="margin-top: 10px; font-size: 12px; color: #22c55e;">● Linked</div>
|
|
219
|
+
\`;
|
|
220
|
+
graphContainer.appendChild(node);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
function saveConfig() {
|
|
224
|
+
alert('Config saved! (Simulation)');
|
|
225
|
+
// In real app, POST to /__nuclie/api/federation/save
|
|
226
|
+
}
|
|
227
|
+
</script>
|
|
228
|
+
</body>
|
|
229
|
+
</html>
|
|
230
|
+
`;
|
|
231
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Nuclie Dependency Graph Visualizer Engine
|
|
3
|
+
* Logic Layer for WebGPU Visualizer
|
|
4
|
+
* Day 16: WebGPU Visualizer v2 Lock
|
|
5
|
+
*/
|
|
6
|
+
export interface HelperNode {
|
|
7
|
+
id: string;
|
|
8
|
+
size: number;
|
|
9
|
+
importers: string[];
|
|
10
|
+
imported: string[];
|
|
11
|
+
centrality?: number;
|
|
12
|
+
shakeable?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export interface OptimizationHint {
|
|
15
|
+
type: 'split' | 'shake' | 'duplicate';
|
|
16
|
+
nodeId: string;
|
|
17
|
+
message: string;
|
|
18
|
+
impact: 'high' | 'medium' | 'low';
|
|
19
|
+
}
|
|
20
|
+
export declare class VisualizerEngine {
|
|
21
|
+
nodes: Map<string, HelperNode>;
|
|
22
|
+
constructor(nodes: HelperNode[]);
|
|
23
|
+
/**
|
|
24
|
+
* Calculate Graph Metrics (Centrality, Depth)
|
|
25
|
+
* O(N) pass
|
|
26
|
+
*/
|
|
27
|
+
analyze(): OptimizationHint[];
|
|
28
|
+
/**
|
|
29
|
+
* Generate WebGPU-ready buffer data (Mock)
|
|
30
|
+
* Flattens graph into Float32Arrays for position/color
|
|
31
|
+
*/
|
|
32
|
+
generateLayoutData(): {
|
|
33
|
+
nodeCount: number;
|
|
34
|
+
edgeCount: number;
|
|
35
|
+
positionBuffer: Float32Array<ArrayBuffer>;
|
|
36
|
+
colorBuffer: Float32Array<ArrayBuffer>;
|
|
37
|
+
};
|
|
38
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Nuclie Dependency Graph Visualizer Engine
|
|
3
|
+
* Logic Layer for WebGPU Visualizer
|
|
4
|
+
* Day 16: WebGPU Visualizer v2 Lock
|
|
5
|
+
*/
|
|
6
|
+
export class VisualizerEngine {
|
|
7
|
+
constructor(nodes) {
|
|
8
|
+
this.nodes = new Map(nodes.map(n => [n.id, n]));
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Calculate Graph Metrics (Centrality, Depth)
|
|
12
|
+
* O(N) pass
|
|
13
|
+
*/
|
|
14
|
+
analyze() {
|
|
15
|
+
const hints = [];
|
|
16
|
+
for (const [id, node] of this.nodes) {
|
|
17
|
+
// 1. Centrality (In-degree)
|
|
18
|
+
const inDegree = node.importers.length;
|
|
19
|
+
node.centrality = inDegree;
|
|
20
|
+
// 2. Identify "Hubs" (High impact split candidates)
|
|
21
|
+
// If a node is imported by many (>50) and large (>50KB)
|
|
22
|
+
if (inDegree > 50 && node.size > 50000) {
|
|
23
|
+
hints.push({
|
|
24
|
+
type: 'split',
|
|
25
|
+
nodeId: id,
|
|
26
|
+
message: `Hub detected: Imported by ${inDegree} modules. Consider lazy loading.`,
|
|
27
|
+
impact: 'high'
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
// 3. Identify Shakeable (Leaf nodes with 0 importers - entry points excepted)
|
|
31
|
+
// If not entry point and 0 importers -> Dead code?
|
|
32
|
+
// (Assuming we provided full graph including entry points)
|
|
33
|
+
if (inDegree === 0 && !id.includes('index') && !id.includes('main')) {
|
|
34
|
+
hints.push({
|
|
35
|
+
type: 'shake',
|
|
36
|
+
nodeId: id,
|
|
37
|
+
message: 'Orphan module detected (0 importers). Verify if entry point.',
|
|
38
|
+
impact: 'medium'
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
// 4. Duplicate Packages (e.g. lodash vs lodash-es)
|
|
42
|
+
if (id.includes('node_modules')) {
|
|
43
|
+
// Implementation would be more complex regex
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return hints;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Generate WebGPU-ready buffer data (Mock)
|
|
50
|
+
* Flattens graph into Float32Arrays for position/color
|
|
51
|
+
*/
|
|
52
|
+
generateLayoutData() {
|
|
53
|
+
// In a real app, this runs Force-Directed Simulation (d3-force or similar)
|
|
54
|
+
// For 10k nodes, we'd do this in a Worker or Compute Shader.
|
|
55
|
+
// Here we just return the size to prove we processed it.
|
|
56
|
+
return {
|
|
57
|
+
nodeCount: this.nodes.size,
|
|
58
|
+
edgeCount: Array.from(this.nodes.values()).reduce((acc, n) => acc + n.imported.length, 0),
|
|
59
|
+
// Mock buffer sizes
|
|
60
|
+
positionBuffer: new Float32Array(this.nodes.size * 3), // x,y,z
|
|
61
|
+
colorBuffer: new Float32Array(this.nodes.size * 3) // r,g,b
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
export function getGraphUIHtml(graph) {
|
|
2
|
+
const nodes = Array.from(graph.nodes.values()).map(n => ({
|
|
3
|
+
id: n.id,
|
|
4
|
+
label: n.path.split('/').pop(),
|
|
5
|
+
type: n.type,
|
|
6
|
+
color: n.type === 'css' || n.type === 'css-module' ? '#264de4' : '#f7df1e'
|
|
7
|
+
}));
|
|
8
|
+
const links = [];
|
|
9
|
+
graph.nodes.forEach(node => {
|
|
10
|
+
node.edges.forEach(edge => {
|
|
11
|
+
links.push({
|
|
12
|
+
source: edge.from,
|
|
13
|
+
target: edge.to,
|
|
14
|
+
kind: edge.kind
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
const data = JSON.stringify({ nodes, links });
|
|
19
|
+
return `
|
|
20
|
+
<!DOCTYPE html>
|
|
21
|
+
<html>
|
|
22
|
+
<head>
|
|
23
|
+
<title>Nuclie Graph Visualizer</title>
|
|
24
|
+
<script src="https://d3js.org/d3.v7.min.js"></script>
|
|
25
|
+
<style>
|
|
26
|
+
body { margin: 0; background: #1a1a1a; color: white; font-family: sans-serif; overflow: hidden; }
|
|
27
|
+
#graph { width: 100vw; height: 100vh; }
|
|
28
|
+
.node { stroke: #fff; stroke-width: 1.5px; }
|
|
29
|
+
.link { stroke: #999; stroke-opacity: 0.6; }
|
|
30
|
+
.label { font-size: 10px; fill: #eee; pointer-events: none; }
|
|
31
|
+
#info { position: absolute; top: 10px; left: 10px; background: rgba(0,0,0,0.7); padding: 10px; border-radius: 4px; pointer-events: none; }
|
|
32
|
+
</style>
|
|
33
|
+
</head>
|
|
34
|
+
<body>
|
|
35
|
+
<div id="info">Nuclie Dependency Graph</div>
|
|
36
|
+
<div id="graph"></div>
|
|
37
|
+
<script>
|
|
38
|
+
const data = ${data};
|
|
39
|
+
const width = window.innerWidth;
|
|
40
|
+
const height = window.innerHeight;
|
|
41
|
+
|
|
42
|
+
const svg = d3.select("#graph").append("svg")
|
|
43
|
+
.attr("width", width)
|
|
44
|
+
.attr("height", height)
|
|
45
|
+
.call(d3.zoom().on("zoom", (event) => {
|
|
46
|
+
container.attr("transform", event.transform);
|
|
47
|
+
}));
|
|
48
|
+
|
|
49
|
+
const container = svg.append("g");
|
|
50
|
+
|
|
51
|
+
const simulation = d3.forceSimulation(data.nodes)
|
|
52
|
+
.force("link", d3.forceLink(data.links).id(d => d.id).distance(100))
|
|
53
|
+
.force("charge", d3.forceManyBody().strength(-300))
|
|
54
|
+
.force("center", d3.forceCenter(width / 2, height / 2));
|
|
55
|
+
|
|
56
|
+
const link = container.append("g")
|
|
57
|
+
.attr("class", "links")
|
|
58
|
+
.selectAll("line")
|
|
59
|
+
.data(data.links)
|
|
60
|
+
.enter().append("line")
|
|
61
|
+
.attr("class", "link");
|
|
62
|
+
|
|
63
|
+
const node = container.append("g")
|
|
64
|
+
.attr("class", "nodes")
|
|
65
|
+
.selectAll("circle")
|
|
66
|
+
.data(data.nodes)
|
|
67
|
+
.enter().append("circle")
|
|
68
|
+
.attr("class", "node")
|
|
69
|
+
.attr("r", 8)
|
|
70
|
+
.attr("fill", d => d.color)
|
|
71
|
+
.call(d3.drag()
|
|
72
|
+
.on("start", dragstarted)
|
|
73
|
+
.on("drag", dragged)
|
|
74
|
+
.on("end", dragended));
|
|
75
|
+
|
|
76
|
+
const label = container.append("g")
|
|
77
|
+
.selectAll("text")
|
|
78
|
+
.data(data.nodes)
|
|
79
|
+
.enter().append("text")
|
|
80
|
+
.attr("class", "label")
|
|
81
|
+
.text(d => d.label);
|
|
82
|
+
|
|
83
|
+
simulation.on("tick", () => {
|
|
84
|
+
link
|
|
85
|
+
.attr("x1", d => d.source.x)
|
|
86
|
+
.attr("y1", d => d.source.y)
|
|
87
|
+
.attr("x2", d => d.target.x)
|
|
88
|
+
.attr("y2", d => d.target.y);
|
|
89
|
+
|
|
90
|
+
node
|
|
91
|
+
.attr("cx", d => d.x)
|
|
92
|
+
.attr("cy", d => d.y);
|
|
93
|
+
|
|
94
|
+
label
|
|
95
|
+
.attr("x", d => d.x + 10)
|
|
96
|
+
.attr("y", d => d.y + 3);
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
function dragstarted(event, d) {
|
|
100
|
+
if (!event.active) simulation.alphaTarget(0.3).restart();
|
|
101
|
+
d.fx = d.x;
|
|
102
|
+
d.fy = d.y;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function dragged(event, d) {
|
|
106
|
+
d.fx = event.x;
|
|
107
|
+
d.fy = event.y;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
function dragended(event, d) {
|
|
111
|
+
if (!event.active) simulation.alphaTarget(0);
|
|
112
|
+
d.fx = null;
|
|
113
|
+
d.fy = null;
|
|
114
|
+
}
|
|
115
|
+
</script>
|
|
116
|
+
</body>
|
|
117
|
+
</html>
|
|
118
|
+
`;
|
|
119
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WebGPU Graph Visualizer
|
|
3
|
+
* Interactive dependency graph visualization with drill-down
|
|
4
|
+
*/
|
|
5
|
+
import type { RootCauseNode, RootCauseIssue } from './root-cause.js';
|
|
6
|
+
export interface VisualizationConfig {
|
|
7
|
+
width: number;
|
|
8
|
+
height: number;
|
|
9
|
+
nodeRadius: number;
|
|
10
|
+
maxNodes: number;
|
|
11
|
+
}
|
|
12
|
+
export interface GraphLayout {
|
|
13
|
+
nodes: Array<{
|
|
14
|
+
id: string;
|
|
15
|
+
x: number;
|
|
16
|
+
y: number;
|
|
17
|
+
radius: number;
|
|
18
|
+
}>;
|
|
19
|
+
edges: Array<{
|
|
20
|
+
from: string;
|
|
21
|
+
to: string;
|
|
22
|
+
points: Array<{
|
|
23
|
+
x: number;
|
|
24
|
+
y: number;
|
|
25
|
+
}>;
|
|
26
|
+
}>;
|
|
27
|
+
}
|
|
28
|
+
export declare class GraphVisualizer {
|
|
29
|
+
private config;
|
|
30
|
+
private canvas;
|
|
31
|
+
private ctx;
|
|
32
|
+
private selectedNode;
|
|
33
|
+
private hoveredNode;
|
|
34
|
+
constructor(config?: Partial<VisualizationConfig>);
|
|
35
|
+
/**
|
|
36
|
+
* Initialize canvas for rendering
|
|
37
|
+
*/
|
|
38
|
+
initialize(canvasId: string): void;
|
|
39
|
+
/**
|
|
40
|
+
* Calculate force-directed layout for nodes
|
|
41
|
+
*/
|
|
42
|
+
calculateLayout(nodes: RootCauseNode[], edges: Array<{
|
|
43
|
+
from: string;
|
|
44
|
+
to: string;
|
|
45
|
+
}>): GraphLayout;
|
|
46
|
+
/**
|
|
47
|
+
* Render the graph
|
|
48
|
+
*/
|
|
49
|
+
render(nodes: RootCauseNode[], edges: Array<{
|
|
50
|
+
from: string;
|
|
51
|
+
to: string;
|
|
52
|
+
}>, issues: RootCauseIssue[]): void;
|
|
53
|
+
/**
|
|
54
|
+
* Draw tooltip for a node
|
|
55
|
+
*/
|
|
56
|
+
private drawTooltip;
|
|
57
|
+
/**
|
|
58
|
+
* Handle click events
|
|
59
|
+
*/
|
|
60
|
+
private handleClick;
|
|
61
|
+
/**
|
|
62
|
+
* Handle mouse move events
|
|
63
|
+
*/
|
|
64
|
+
private handleMouseMove;
|
|
65
|
+
/**
|
|
66
|
+
* Export graph as image
|
|
67
|
+
*/
|
|
68
|
+
exportAsImage(): string | null;
|
|
69
|
+
}
|