@ecopages/core 0.2.0-alpha.5 → 0.2.0-alpha.50
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/README.md +268 -14
- package/package.json +92 -110
- package/src/adapters/README.md +39 -0
- package/src/adapters/abstract/application-adapter.d.ts +28 -2
- package/src/adapters/abstract/application-adapter.js +14 -2
- package/src/adapters/abstract/router-adapter.d.ts +1 -1
- package/src/adapters/abstract/server-adapter.d.ts +2 -2
- package/src/adapters/bun/client-bridge.d.ts +1 -1
- package/src/adapters/bun/create-app.d.ts +12 -12
- package/src/adapters/bun/create-app.js +64 -41
- package/src/adapters/bun/hmr-manager.d.ts +30 -62
- package/src/adapters/bun/hmr-manager.js +30 -194
- package/src/adapters/bun/index.d.ts +2 -3
- package/src/adapters/bun/index.js +3 -3
- package/src/adapters/bun/runtime-host.d.ts +52 -0
- package/src/adapters/bun/runtime-host.js +56 -0
- package/src/adapters/bun/server-adapter.d.ts +93 -32
- package/src/adapters/bun/server-adapter.js +166 -89
- package/src/adapters/bun/static-preview-host.d.ts +28 -0
- package/src/adapters/bun/static-preview-host.js +45 -0
- package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
- package/src/{create-app.js → adapters/create-app.js} +4 -4
- package/src/adapters/index.d.ts +2 -6
- package/src/adapters/index.js +2 -8
- package/src/adapters/node/create-app.d.ts +15 -12
- package/src/adapters/node/create-app.js +34 -85
- package/src/adapters/node/http-request-bridge.d.ts +57 -0
- package/src/adapters/node/http-request-bridge.js +118 -0
- package/src/adapters/node/node-client-bridge.d.ts +1 -1
- package/src/adapters/node/node-hmr-manager.d.ts +38 -48
- package/src/adapters/node/node-hmr-manager.js +31 -203
- package/src/adapters/node/runtime-host.d.ts +57 -0
- package/src/adapters/node/runtime-host.js +92 -0
- package/src/adapters/node/server-adapter-dependencies.d.ts +19 -0
- package/src/adapters/node/server-adapter-dependencies.js +18 -0
- package/src/adapters/node/server-adapter.d.ts +20 -72
- package/src/adapters/node/server-adapter.js +99 -203
- package/src/adapters/node/static-content-server.d.ts +37 -1
- package/src/adapters/node/static-content-server.js +29 -1
- package/src/adapters/node/static-preview-host.d.ts +55 -0
- package/src/adapters/node/static-preview-host.js +68 -0
- package/src/adapters/shared/application-adapter.d.ts +1 -1
- package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
- package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
- package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
- package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
- package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
- package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
- package/src/adapters/shared/fs-server-response-factory.js +11 -27
- package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
- package/src/adapters/shared/fs-server-response-matcher.js +76 -45
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
- package/src/adapters/shared/hmr-html-response.d.ts +22 -0
- package/src/adapters/shared/hmr-html-response.js +33 -0
- package/src/adapters/shared/render-context.d.ts +5 -3
- package/src/adapters/shared/render-context.js +27 -3
- package/src/adapters/shared/runtime-app-bootstrap.d.ts +26 -0
- package/src/adapters/shared/runtime-app-bootstrap.js +46 -0
- package/src/adapters/shared/runtime-host.d.ts +12 -0
- package/src/adapters/shared/server-adapter.d.ts +33 -12
- package/src/adapters/shared/server-adapter.js +215 -132
- package/src/adapters/shared/server-route-handler.d.ts +5 -5
- package/src/adapters/shared/server-route-handler.js +7 -16
- package/src/adapters/shared/server-static-builder.d.ts +41 -8
- package/src/adapters/shared/server-static-builder.js +65 -11
- package/src/adapters/shared/shared-hmr-manager.d.ts +59 -0
- package/src/adapters/shared/shared-hmr-manager.js +240 -0
- package/src/adapters/shared/static-preview-host.d.ts +10 -0
- package/src/build/README.md +107 -0
- package/src/build/build-adapter.d.ts +175 -3
- package/src/build/build-adapter.js +625 -16
- package/src/build/build-manifest.d.ts +27 -0
- package/src/build/build-manifest.js +30 -0
- package/src/build/dev-build-coordinator.d.ts +72 -0
- package/src/build/dev-build-coordinator.js +154 -0
- package/src/build/esbuild-build-adapter.d.ts +16 -6
- package/src/build/esbuild-build-adapter.js +202 -75
- package/src/build/runtime-build-executor.d.ts +14 -0
- package/src/build/runtime-build-executor.js +22 -0
- package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
- package/src/build/runtime-specifier-alias-plugin.js +35 -0
- package/src/build/runtime-specifier-aliases.d.ts +5 -0
- package/src/build/runtime-specifier-aliases.js +95 -0
- package/src/config/README.md +36 -0
- package/src/config/config-builder.d.ts +54 -29
- package/src/config/config-builder.js +256 -50
- package/src/{constants.d.ts → config/constants.d.ts} +13 -0
- package/src/{constants.js → config/constants.js} +4 -0
- package/src/declarations.d.ts +19 -14
- package/src/dev/host-runtime.d.ts +10 -0
- package/src/dev/host-runtime.js +24 -0
- package/src/dev/sc-server.d.ts +1 -1
- package/src/dev/sc-server.js +1 -1
- package/src/eco/README.md +70 -16
- package/src/eco/eco.browser.d.ts +2 -0
- package/src/eco/eco.browser.js +88 -0
- package/src/eco/eco.js +63 -54
- package/src/eco/eco.types.d.ts +69 -6
- package/src/eco/eco.utils.d.ts +1 -40
- package/src/eco/eco.utils.js +5 -35
- package/src/eco/global-injector-map.d.ts +3 -3
- package/src/eco/global-injector-map.js +2 -2
- package/src/eco/lazy-injector-map.d.ts +2 -2
- package/src/errors/index.d.ts +1 -0
- package/src/errors/index.js +3 -1
- package/src/hmr/README.md +26 -0
- package/src/hmr/client/hmr-runtime.d.ts +1 -6
- package/src/hmr/client/hmr-runtime.js +38 -7
- package/src/hmr/hmr-strategy.d.ts +16 -13
- package/src/hmr/hmr-strategy.js +22 -7
- package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.postcss.test.e2e.js +31 -0
- package/src/hmr/hmr.test.e2e.js +26 -33
- package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
- package/src/hmr/strategies/default-hmr-strategy.js +1 -1
- package/src/hmr/strategies/js-hmr-strategy.d.ts +40 -42
- package/src/hmr/strategies/js-hmr-strategy.js +24 -43
- package/src/index.browser.d.ts +2 -2
- package/src/index.browser.js +1 -1
- package/src/index.d.ts +4 -3
- package/src/index.js +16 -5
- package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
- package/src/integrations/ghtml/ghtml-renderer.js +27 -30
- package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
- package/src/integrations/ghtml/ghtml.constants.js +4 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
- package/src/integrations/ghtml/ghtml.plugin.js +3 -4
- package/src/plugins/README.md +35 -0
- package/src/plugins/alias-resolver-plugin.d.ts +1 -0
- package/src/plugins/alias-resolver-plugin.js +27 -5
- package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
- package/src/plugins/eco-component-meta-plugin.js +42 -24
- package/src/plugins/foreign-jsx-override-plugin.d.ts +33 -0
- package/src/plugins/foreign-jsx-override-plugin.js +41 -0
- package/src/plugins/integration-plugin.d.ts +147 -29
- package/src/plugins/integration-plugin.js +103 -14
- package/src/plugins/processor.d.ts +17 -2
- package/src/plugins/processor.js +22 -3
- package/src/plugins/runtime-capability.d.ts +9 -0
- package/src/plugins/source-transform.d.ts +46 -0
- package/src/plugins/source-transform.js +71 -0
- package/src/route-renderer/GRAPH.md +83 -325
- package/src/route-renderer/README.md +73 -90
- package/src/route-renderer/orchestration/component-render-context.d.ts +97 -0
- package/src/route-renderer/orchestration/component-render-context.js +147 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +110 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +233 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +534 -0
- package/src/route-renderer/orchestration/integration-renderer.js +991 -0
- package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
- package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
- package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
- package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +3 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.js +27 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +91 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +170 -0
- package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
- package/src/route-renderer/orchestration/render-output.utils.js +171 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +156 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.js +577 -0
- package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
- package/src/route-renderer/orchestration/template-serialization.js +45 -0
- package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
- package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
- package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
- package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
- package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
- package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
- package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
- package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
- package/src/route-renderer/route-renderer.d.ts +57 -14
- package/src/route-renderer/route-renderer.js +30 -18
- package/src/router/README.md +94 -0
- package/src/router/client/link-intent.d.ts +53 -0
- package/src/router/client/link-intent.js +34 -0
- package/src/router/client/link-intent.test.browser.d.ts +1 -0
- package/src/router/client/link-intent.test.browser.js +43 -0
- package/src/router/client/navigation-coordinator.d.ts +169 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/server/route-registry.d.ts +78 -0
- package/src/router/server/route-registry.js +262 -0
- package/src/services/README.md +28 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
- package/src/services/assets/asset-processing-service/assets.types.js +0 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
- package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
- package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
- package/src/services/assets/asset-processing-service/index.d.ts +6 -0
- package/src/services/assets/asset-processing-service/index.js +6 -0
- package/src/services/assets/asset-processing-service/page-package.d.ts +6 -0
- package/src/services/assets/asset-processing-service/page-package.js +80 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
- package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/index.js +5 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +120 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +42 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +126 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
- package/src/services/assets/browser-bundle.service.d.ts +73 -0
- package/src/services/assets/browser-bundle.service.js +41 -0
- package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
- package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
- package/src/services/html/html-rewriter-provider.service.d.ts +40 -0
- package/src/services/html/html-rewriter-provider.service.js +68 -0
- package/src/services/html/html-transformer.service.d.ts +96 -0
- package/src/services/html/html-transformer.service.js +287 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +190 -0
- package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
- package/src/services/module-loading/app-module-loader.service.js +0 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +151 -0
- package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
- package/src/services/module-loading/host-module-loader-registry.js +15 -0
- package/src/services/module-loading/module-loading-types.d.ts +2 -0
- package/src/services/module-loading/module-loading-types.js +0 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +38 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +215 -0
- package/src/services/module-loading/page-module-import.service.d.ts +95 -0
- package/src/services/module-loading/page-module-import.service.js +191 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
- package/src/services/module-loading/server-module-transpiler.service.js +64 -0
- package/src/services/module-loading/source-module-support.d.ts +5 -0
- package/src/services/module-loading/source-module-support.js +8 -0
- package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
- package/src/services/runtime-state/dev-graph.service.js +162 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
- package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
- package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
- package/src/static-site-generator/README.md +26 -0
- package/src/static-site-generator/static-site-generator.d.ts +67 -20
- package/src/static-site-generator/static-site-generator.js +182 -138
- package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
- package/src/types/internal-types.js +0 -0
- package/src/{public-types.d.ts → types/public-types.d.ts} +239 -31
- package/src/types/public-types.js +0 -0
- package/src/utils/html-escaping.d.ts +7 -0
- package/src/utils/html-escaping.js +6 -0
- package/src/utils/locals-utils.d.ts +1 -1
- package/src/utils/parse-cli-args.d.ts +4 -1
- package/src/utils/parse-cli-args.js +16 -1
- package/src/utils/resolve-work-dir.d.ts +11 -0
- package/src/utils/resolve-work-dir.js +31 -0
- package/src/watchers/project-watcher.d.ts +11 -7
- package/src/watchers/project-watcher.js +69 -75
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- package/src/watchers/project-watcher.test-helpers.js +6 -5
- package/CHANGELOG.md +0 -94
- package/src/adapters/abstract/application-adapter.ts +0 -337
- package/src/adapters/abstract/router-adapter.ts +0 -30
- package/src/adapters/abstract/server-adapter.ts +0 -79
- package/src/adapters/bun/client-bridge.ts +0 -62
- package/src/adapters/bun/create-app.ts +0 -189
- package/src/adapters/bun/define-api-handler.d.ts +0 -61
- package/src/adapters/bun/define-api-handler.ts +0 -114
- package/src/adapters/bun/hmr-manager.ts +0 -276
- package/src/adapters/bun/index.ts +0 -3
- package/src/adapters/bun/server-adapter.ts +0 -492
- package/src/adapters/bun/server-lifecycle.d.ts +0 -52
- package/src/adapters/bun/server-lifecycle.js +0 -120
- package/src/adapters/bun/server-lifecycle.ts +0 -154
- package/src/adapters/index.ts +0 -6
- package/src/adapters/node/create-app.ts +0 -179
- package/src/adapters/node/index.d.ts +0 -4
- package/src/adapters/node/index.js +0 -8
- package/src/adapters/node/index.ts +0 -9
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.ts +0 -271
- package/src/adapters/node/server-adapter.ts +0 -561
- package/src/adapters/node/static-content-server.ts +0 -203
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
- package/src/adapters/shared/fs-server-response-factory.ts +0 -118
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
- package/src/adapters/shared/render-context.ts +0 -105
- package/src/adapters/shared/server-adapter.ts +0 -442
- package/src/adapters/shared/server-route-handler.ts +0 -166
- package/src/adapters/shared/server-static-builder.ts +0 -82
- package/src/build/build-adapter.ts +0 -133
- package/src/build/build-types.ts +0 -83
- package/src/build/esbuild-build-adapter.ts +0 -511
- package/src/config/config-builder.ts +0 -474
- package/src/constants.ts +0 -39
- package/src/create-app.ts +0 -87
- package/src/define-api-handler.js +0 -15
- package/src/define-api-handler.ts +0 -66
- package/src/dev/sc-server.ts +0 -143
- package/src/eco/component-render-context.d.ts +0 -105
- package/src/eco/component-render-context.js +0 -77
- package/src/eco/component-render-context.ts +0 -202
- package/src/eco/eco.ts +0 -221
- package/src/eco/eco.types.ts +0 -202
- package/src/eco/eco.utils.ts +0 -89
- package/src/eco/global-injector-map.ts +0 -112
- package/src/eco/lazy-injector-map.ts +0 -120
- package/src/eco/module-dependencies.ts +0 -75
- package/src/errors/http-error.ts +0 -72
- package/src/errors/index.ts +0 -2
- package/src/errors/locals-access-error.ts +0 -7
- package/src/global/app-logger.ts +0 -4
- package/src/hmr/client/hmr-runtime.ts +0 -121
- package/src/hmr/hmr-strategy.ts +0 -172
- package/src/hmr/hmr.test.e2e.ts +0 -75
- package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
- package/src/hmr/strategies/js-hmr-strategy.ts +0 -327
- package/src/index.browser.ts +0 -3
- package/src/index.ts +0 -5
- package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
- package/src/internal-types.ts +0 -212
- package/src/plugins/alias-resolver-plugin.ts +0 -45
- package/src/plugins/eco-component-meta-plugin.ts +0 -474
- package/src/plugins/integration-plugin.ts +0 -184
- package/src/plugins/processor.ts +0 -220
- package/src/public-types.ts +0 -1255
- package/src/route-renderer/component-graph-executor.d.ts +0 -32
- package/src/route-renderer/component-graph-executor.js +0 -31
- package/src/route-renderer/component-graph-executor.ts +0 -84
- package/src/route-renderer/component-graph.d.ts +0 -42
- package/src/route-renderer/component-graph.js +0 -72
- package/src/route-renderer/component-graph.ts +0 -159
- package/src/route-renderer/component-marker.d.ts +0 -52
- package/src/route-renderer/component-marker.js +0 -46
- package/src/route-renderer/component-marker.ts +0 -117
- package/src/route-renderer/dependency-resolver.js +0 -428
- package/src/route-renderer/dependency-resolver.ts +0 -596
- package/src/route-renderer/html-post-processing.service.d.ts +0 -40
- package/src/route-renderer/html-post-processing.service.js +0 -86
- package/src/route-renderer/html-post-processing.service.ts +0 -103
- package/src/route-renderer/integration-renderer.d.ts +0 -339
- package/src/route-renderer/integration-renderer.js +0 -526
- package/src/route-renderer/integration-renderer.ts +0 -696
- package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
- package/src/route-renderer/marker-graph-resolver.js +0 -93
- package/src/route-renderer/marker-graph-resolver.ts +0 -153
- package/src/route-renderer/page-module-loader.d.ts +0 -61
- package/src/route-renderer/page-module-loader.ts +0 -153
- package/src/route-renderer/render-execution.service.d.ts +0 -69
- package/src/route-renderer/render-execution.service.js +0 -91
- package/src/route-renderer/render-execution.service.ts +0 -158
- package/src/route-renderer/render-preparation.service.d.ts +0 -112
- package/src/route-renderer/render-preparation.service.js +0 -243
- package/src/route-renderer/render-preparation.service.ts +0 -358
- package/src/route-renderer/route-renderer.ts +0 -80
- package/src/router/fs-router-scanner.d.ts +0 -41
- package/src/router/fs-router-scanner.js +0 -155
- package/src/router/fs-router-scanner.ts +0 -217
- package/src/router/fs-router.d.ts +0 -26
- package/src/router/fs-router.js +0 -100
- package/src/router/fs-router.ts +0 -122
- package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
- package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
- package/src/services/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/asset-processing-service/assets.types.ts +0 -112
- package/src/services/asset-processing-service/index.d.ts +0 -3
- package/src/services/asset-processing-service/index.js +0 -3
- package/src/services/asset-processing-service/index.ts +0 -3
- package/src/services/asset-processing-service/processor.interface.ts +0 -27
- package/src/services/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
- package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
- package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
- package/src/services/asset-processing-service/processors/index.d.ts +0 -5
- package/src/services/asset-processing-service/processors/index.js +0 -5
- package/src/services/asset-processing-service/processors/index.ts +0 -5
- package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +0 -74
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
- package/src/services/cache/cache.types.ts +0 -126
- package/src/services/cache/index.ts +0 -18
- package/src/services/cache/memory-cache-store.ts +0 -130
- package/src/services/cache/page-cache-service.ts +0 -202
- package/src/services/html-transformer.service.d.ts +0 -50
- package/src/services/html-transformer.service.js +0 -163
- package/src/services/html-transformer.service.ts +0 -217
- package/src/services/page-module-import.service.d.ts +0 -37
- package/src/services/page-module-import.service.js +0 -88
- package/src/services/page-module-import.service.ts +0 -129
- package/src/services/page-request-cache-coordinator.service.ts +0 -128
- package/src/services/schema-validation-service.ts +0 -204
- package/src/services/validation/standard-schema.types.ts +0 -68
- package/src/static-site-generator/static-site-generator.ts +0 -359
- package/src/utils/css.d.ts +0 -1
- package/src/utils/css.js +0 -7
- package/src/utils/css.ts +0 -5
- package/src/utils/deep-merge.ts +0 -47
- package/src/utils/hash.ts +0 -5
- package/src/utils/html.ts +0 -1
- package/src/utils/invariant.ts +0 -15
- package/src/utils/locals-utils.ts +0 -37
- package/src/utils/parse-cli-args.ts +0 -83
- package/src/utils/path-utils.module.ts +0 -14
- package/src/utils/runtime.ts +0 -44
- package/src/utils/server-utils.module.ts +0 -67
- package/src/watchers/project-watcher.test-helpers.ts +0 -40
- package/src/watchers/project-watcher.ts +0 -364
- /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
- /package/src/{internal-types.js → adapters/shared/runtime-host.js} +0 -0
- /package/src/{public-types.js → adapters/shared/static-preview-host.js} +0 -0
- /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.js} +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
- /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -0,0 +1,577 @@
|
|
|
1
|
+
import { createRequire } from "node:module";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { fileSystem } from "@ecopages/file-system";
|
|
4
|
+
import {
|
|
5
|
+
AssetFactory,
|
|
6
|
+
createPagePackage
|
|
7
|
+
} from "../../services/assets/asset-processing-service/index.js";
|
|
8
|
+
import { buildGlobalInjectorBootstrapContent, buildGlobalInjectorMapScript } from "../../eco/global-injector-map.js";
|
|
9
|
+
import { LocalsAccessError } from "../../errors/locals-access-error.js";
|
|
10
|
+
import { appLogger } from "../../global/app-logger.js";
|
|
11
|
+
import { inspectUnresolvedMarkerArtifactHtml } from "./render-output.utils.js";
|
|
12
|
+
import { OwnershipValidationService } from "./ownership-validation.service.js";
|
|
13
|
+
import { OwnershipPlanningService } from "./ownership-planning.service.js";
|
|
14
|
+
import { dedupeProcessedAssets } from "./processed-asset-dedupe.js";
|
|
15
|
+
function createPageLocalsProxy(filePath) {
|
|
16
|
+
const errorMessage = `[ecopages] Request locals are only available during request-time rendering with cache: 'dynamic'. Page: ${filePath}. If you meant to use locals here, set cache: 'dynamic' and provide locals from route middleware/handlers.`;
|
|
17
|
+
return new Proxy(
|
|
18
|
+
{},
|
|
19
|
+
{
|
|
20
|
+
get: () => {
|
|
21
|
+
throw new LocalsAccessError(errorMessage);
|
|
22
|
+
},
|
|
23
|
+
set: () => {
|
|
24
|
+
throw new LocalsAccessError(errorMessage);
|
|
25
|
+
},
|
|
26
|
+
has: () => {
|
|
27
|
+
throw new LocalsAccessError(errorMessage);
|
|
28
|
+
},
|
|
29
|
+
ownKeys: () => {
|
|
30
|
+
throw new LocalsAccessError(errorMessage);
|
|
31
|
+
},
|
|
32
|
+
deleteProperty: () => {
|
|
33
|
+
throw new LocalsAccessError(errorMessage);
|
|
34
|
+
},
|
|
35
|
+
defineProperty: () => {
|
|
36
|
+
throw new LocalsAccessError(errorMessage);
|
|
37
|
+
},
|
|
38
|
+
getOwnPropertyDescriptor: () => {
|
|
39
|
+
throw new LocalsAccessError(errorMessage);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
function isGroupedContentScriptAsset(asset) {
|
|
45
|
+
return asset.kind === "script" && asset.source === "content" && Boolean(asset.groupedBundle?.id);
|
|
46
|
+
}
|
|
47
|
+
function getGroupedBundleAssetKey(groupedBundle) {
|
|
48
|
+
return `${groupedBundle.id}:${groupedBundle.entryName}`;
|
|
49
|
+
}
|
|
50
|
+
class RouteRenderOrchestrator {
|
|
51
|
+
appConfig;
|
|
52
|
+
assetProcessingService;
|
|
53
|
+
ownershipPlanningService;
|
|
54
|
+
ownershipValidationService;
|
|
55
|
+
pageBrowserGraphCache = /* @__PURE__ */ new Map();
|
|
56
|
+
groupedPageBrowserGraphCache = /* @__PURE__ */ new Map();
|
|
57
|
+
constructor(appConfig, assetProcessingService, dependencies = {}) {
|
|
58
|
+
this.appConfig = appConfig;
|
|
59
|
+
this.assetProcessingService = assetProcessingService;
|
|
60
|
+
this.ownershipPlanningService = dependencies.ownershipPlanningService ?? new OwnershipPlanningService();
|
|
61
|
+
this.ownershipValidationService = dependencies.ownershipValidationService ?? new OwnershipValidationService(appConfig);
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Builds normalized route render options before the integration render runs.
|
|
65
|
+
*
|
|
66
|
+
* This preparation step validates route-root ownership, resolves page data,
|
|
67
|
+
* collects processed assets, captures optional page-root render metadata, and
|
|
68
|
+
* produces the page package consumed by downstream HTML transformation.
|
|
69
|
+
*/
|
|
70
|
+
async prepareRenderOptions(routeOptions, adapter) {
|
|
71
|
+
const resolvedInputs = await adapter.resolveRouteRenderInputs(routeOptions);
|
|
72
|
+
const { Page, HtmlTemplate, Layout, props, metadata, integrationSpecificProps } = resolvedInputs;
|
|
73
|
+
const validationErrors = this.ownershipValidationService.validate({
|
|
74
|
+
currentIntegrationName: adapter.name,
|
|
75
|
+
roots: [
|
|
76
|
+
{ component: HtmlTemplate, source: "html-template" },
|
|
77
|
+
...Layout ? [{ component: Layout, source: "layout" }] : [],
|
|
78
|
+
{ component: Page, source: "page" }
|
|
79
|
+
]
|
|
80
|
+
});
|
|
81
|
+
const ownershipPlan = this.ownershipPlanningService.buildPlan({
|
|
82
|
+
routeFile: routeOptions.file,
|
|
83
|
+
currentIntegrationName: adapter.name,
|
|
84
|
+
HtmlTemplate,
|
|
85
|
+
Layout,
|
|
86
|
+
Page,
|
|
87
|
+
validationErrors
|
|
88
|
+
});
|
|
89
|
+
const componentsToResolve = Layout ? [HtmlTemplate, Layout, Page] : [HtmlTemplate, Page];
|
|
90
|
+
const { resolvedDependencies } = await adapter.resolveRouteDependencies({
|
|
91
|
+
components: componentsToResolve
|
|
92
|
+
});
|
|
93
|
+
const pageBrowserGraph = await this.resolvePageBrowserGraph({
|
|
94
|
+
routeFile: routeOptions.file,
|
|
95
|
+
integrationName: adapter.name,
|
|
96
|
+
collectContribution: async (routeFile) => await adapter.collectPageBrowserGraphContribution(routeFile)
|
|
97
|
+
});
|
|
98
|
+
const usedIntegrationDependencies = this.collectUsedIntegrationDependencies(componentsToResolve, adapter.name);
|
|
99
|
+
const allDependencies = [...resolvedDependencies, ...usedIntegrationDependencies];
|
|
100
|
+
const componentRender = await adapter.resolveRoutePageComponentRender({
|
|
101
|
+
Page,
|
|
102
|
+
Layout,
|
|
103
|
+
props,
|
|
104
|
+
routeOptions
|
|
105
|
+
});
|
|
106
|
+
if (componentRender?.assets?.length) {
|
|
107
|
+
allDependencies.push(...componentRender.assets);
|
|
108
|
+
}
|
|
109
|
+
const triggers = this.collectResolvedTriggers(componentsToResolve);
|
|
110
|
+
if (triggers.length > 0) {
|
|
111
|
+
const globalAssets = await this.buildGlobalInjectorAssets(triggers, adapter.name);
|
|
112
|
+
allDependencies.push(...globalAssets);
|
|
113
|
+
}
|
|
114
|
+
const eagerSsrLazyAssets = await this.buildEagerSsrLazyAssets(componentsToResolve, adapter.name);
|
|
115
|
+
if (eagerSsrLazyAssets.length > 0) {
|
|
116
|
+
allDependencies.push(...eagerSsrLazyAssets);
|
|
117
|
+
}
|
|
118
|
+
const dedupedDependencies = dedupeProcessedAssets(allDependencies);
|
|
119
|
+
const pagePackage = createPagePackage(dedupedDependencies, { pageBrowserGraph });
|
|
120
|
+
const pageProps = {
|
|
121
|
+
...props,
|
|
122
|
+
params: routeOptions.params || {},
|
|
123
|
+
query: routeOptions.query || {}
|
|
124
|
+
};
|
|
125
|
+
const cacheStrategy = Page.cache;
|
|
126
|
+
const defaultCacheStrategy = this.appConfig.cache?.defaultStrategy ?? "static";
|
|
127
|
+
const effectiveCacheStrategy = cacheStrategy ?? defaultCacheStrategy;
|
|
128
|
+
const localsAvailable = effectiveCacheStrategy === "dynamic" && routeOptions.locals !== void 0;
|
|
129
|
+
const pageLocals = localsAvailable ? routeOptions.locals : createPageLocalsProxy(routeOptions.file);
|
|
130
|
+
const locals = localsAvailable ? routeOptions.locals : void 0;
|
|
131
|
+
const preparedOptions = {
|
|
132
|
+
...routeOptions,
|
|
133
|
+
resolvedDependencies,
|
|
134
|
+
pagePackage,
|
|
135
|
+
componentRender,
|
|
136
|
+
HtmlTemplate,
|
|
137
|
+
Layout,
|
|
138
|
+
props,
|
|
139
|
+
Page,
|
|
140
|
+
metadata,
|
|
141
|
+
params: routeOptions.params || {},
|
|
142
|
+
query: routeOptions.query || {},
|
|
143
|
+
pageProps,
|
|
144
|
+
locals,
|
|
145
|
+
pageLocals,
|
|
146
|
+
cacheStrategy,
|
|
147
|
+
ownershipPlan
|
|
148
|
+
};
|
|
149
|
+
return {
|
|
150
|
+
...integrationSpecificProps,
|
|
151
|
+
...preparedOptions
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
async resolveDeclaredPageBrowserGraph(input) {
|
|
155
|
+
return await this.resolvePageBrowserGraph(input);
|
|
156
|
+
}
|
|
157
|
+
async resolvePageBrowserGraph(input) {
|
|
158
|
+
if (this.isHmrEnabled()) {
|
|
159
|
+
return await this.buildPageBrowserGraph(input);
|
|
160
|
+
}
|
|
161
|
+
const cacheKey = `${input.integrationName}:${input.routeFile}`;
|
|
162
|
+
const cachedGraph = this.pageBrowserGraphCache.get(cacheKey);
|
|
163
|
+
if (cachedGraph) {
|
|
164
|
+
return await cachedGraph;
|
|
165
|
+
}
|
|
166
|
+
const pendingGraph = this.buildPageBrowserGraph(input).catch((error) => {
|
|
167
|
+
this.pageBrowserGraphCache.delete(cacheKey);
|
|
168
|
+
throw error;
|
|
169
|
+
});
|
|
170
|
+
this.pageBrowserGraphCache.set(cacheKey, pendingGraph);
|
|
171
|
+
return await pendingGraph;
|
|
172
|
+
}
|
|
173
|
+
isHmrEnabled() {
|
|
174
|
+
return typeof this.assetProcessingService.getHmrManager === "function" && this.assetProcessingService.getHmrManager()?.isEnabled() === true;
|
|
175
|
+
}
|
|
176
|
+
async buildPageBrowserGraph(input) {
|
|
177
|
+
const contribution = await input.collectContribution(input.routeFile);
|
|
178
|
+
if (!contribution) {
|
|
179
|
+
return void 0;
|
|
180
|
+
}
|
|
181
|
+
const groupedDependencies = (contribution.dependencies ?? []).filter((dep) => isGroupedContentScriptAsset(dep));
|
|
182
|
+
const ungroupedDependencies = (contribution.dependencies ?? []).filter(
|
|
183
|
+
(dep) => !isGroupedContentScriptAsset(dep)
|
|
184
|
+
);
|
|
185
|
+
const groupedAssets = groupedDependencies.length ? (await this.resolveGroupedPageBrowserAssets(input, contribution)).get(input.routeFile) ?? [] : [];
|
|
186
|
+
const processedDependencies = ungroupedDependencies.length ? await this.assetProcessingService.processDependencies(
|
|
187
|
+
ungroupedDependencies,
|
|
188
|
+
`${input.integrationName}:${input.routeFile}`
|
|
189
|
+
) : [];
|
|
190
|
+
const resolvedAssets = [...processedDependencies, ...groupedAssets, ...contribution.assets ?? []];
|
|
191
|
+
return this.partitionPageBrowserGraphAssets(resolvedAssets);
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Resolves grouped page-browser assets for all routes owned by one integration.
|
|
195
|
+
*
|
|
196
|
+
* @remarks
|
|
197
|
+
* This keeps one shared browser-build result available across sibling routes so
|
|
198
|
+
* navigation can reuse the same emitted client graph instead of rebuilding one
|
|
199
|
+
* page entry at a time. HMR bypasses this cache because the grouped build must
|
|
200
|
+
* reflect the latest source on every request.
|
|
201
|
+
*/
|
|
202
|
+
async resolveGroupedPageBrowserAssets(input, currentContribution) {
|
|
203
|
+
if (this.isHmrEnabled()) {
|
|
204
|
+
const result = await this.buildGroupedPageBrowserAssets(input, currentContribution);
|
|
205
|
+
return result.assetsByRoute;
|
|
206
|
+
}
|
|
207
|
+
const cacheKey = input.integrationName;
|
|
208
|
+
const cached = this.groupedPageBrowserGraphCache.get(cacheKey);
|
|
209
|
+
if (cached) {
|
|
210
|
+
return await cached;
|
|
211
|
+
}
|
|
212
|
+
const pendingGroupedAssets = this.buildGroupedPageBrowserAssets(input, currentContribution).then((result) => {
|
|
213
|
+
if (result.hasCollectionFailures) {
|
|
214
|
+
this.groupedPageBrowserGraphCache.delete(cacheKey);
|
|
215
|
+
}
|
|
216
|
+
return result.assetsByRoute;
|
|
217
|
+
}).catch((error) => {
|
|
218
|
+
this.groupedPageBrowserGraphCache.delete(cacheKey);
|
|
219
|
+
throw error;
|
|
220
|
+
});
|
|
221
|
+
this.groupedPageBrowserGraphCache.set(cacheKey, pendingGroupedAssets);
|
|
222
|
+
return await pendingGroupedAssets;
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Builds the shared grouped page-browser asset map for one integration.
|
|
226
|
+
*
|
|
227
|
+
* @remarks
|
|
228
|
+
* Each route can declare grouped content-script dependencies that should be
|
|
229
|
+
* emitted together. This method collects those declarations across the owning
|
|
230
|
+
* integration, runs the grouped processor once, and then maps the emitted
|
|
231
|
+
* assets back onto the routes that reference them.
|
|
232
|
+
*/
|
|
233
|
+
async buildGroupedPageBrowserAssets(input, currentContribution) {
|
|
234
|
+
const routeFiles = await this.listIntegrationRouteFiles(input.integrationName);
|
|
235
|
+
const currentRouteGroupedDependencies = (currentContribution.dependencies ?? []).filter(
|
|
236
|
+
(dep) => isGroupedContentScriptAsset(dep)
|
|
237
|
+
);
|
|
238
|
+
const groupedDependencies = [...currentRouteGroupedDependencies];
|
|
239
|
+
const groupedAssetKeysByRoute = /* @__PURE__ */ new Map();
|
|
240
|
+
let hasCollectionFailures = false;
|
|
241
|
+
if (currentRouteGroupedDependencies.length > 0) {
|
|
242
|
+
groupedAssetKeysByRoute.set(
|
|
243
|
+
input.routeFile,
|
|
244
|
+
new Set(currentRouteGroupedDependencies.map((dep) => getGroupedBundleAssetKey(dep.groupedBundle)))
|
|
245
|
+
);
|
|
246
|
+
}
|
|
247
|
+
for (const routeFile of routeFiles) {
|
|
248
|
+
if (routeFile === input.routeFile) {
|
|
249
|
+
continue;
|
|
250
|
+
}
|
|
251
|
+
let contribution;
|
|
252
|
+
try {
|
|
253
|
+
contribution = await input.collectContribution(routeFile);
|
|
254
|
+
} catch (error) {
|
|
255
|
+
hasCollectionFailures = true;
|
|
256
|
+
appLogger.warn(
|
|
257
|
+
`Skipping grouped page-browser contribution for ${routeFile}: ${error instanceof Error ? error.message : String(error)}`
|
|
258
|
+
);
|
|
259
|
+
continue;
|
|
260
|
+
}
|
|
261
|
+
if (!contribution?.dependencies?.length) {
|
|
262
|
+
continue;
|
|
263
|
+
}
|
|
264
|
+
const routeGroupedDependencies = contribution.dependencies.filter(
|
|
265
|
+
(dep) => isGroupedContentScriptAsset(dep)
|
|
266
|
+
);
|
|
267
|
+
if (routeGroupedDependencies.length === 0) {
|
|
268
|
+
continue;
|
|
269
|
+
}
|
|
270
|
+
groupedDependencies.push(...routeGroupedDependencies);
|
|
271
|
+
groupedAssetKeysByRoute.set(
|
|
272
|
+
routeFile,
|
|
273
|
+
new Set(routeGroupedDependencies.map((dep) => getGroupedBundleAssetKey(dep.groupedBundle)))
|
|
274
|
+
);
|
|
275
|
+
}
|
|
276
|
+
if (groupedDependencies.length === 0) {
|
|
277
|
+
return {
|
|
278
|
+
assetsByRoute: /* @__PURE__ */ new Map(),
|
|
279
|
+
hasCollectionFailures
|
|
280
|
+
};
|
|
281
|
+
}
|
|
282
|
+
const processedGroupedDependencies = await this.assetProcessingService.processDependencies(
|
|
283
|
+
groupedDependencies,
|
|
284
|
+
`${input.integrationName}:grouped-page-browser-graph`
|
|
285
|
+
);
|
|
286
|
+
const groupedAssetsByRoute = /* @__PURE__ */ new Map();
|
|
287
|
+
for (const [routeFile, groupedAssetKeys] of groupedAssetKeysByRoute) {
|
|
288
|
+
groupedAssetsByRoute.set(
|
|
289
|
+
routeFile,
|
|
290
|
+
processedGroupedDependencies.filter((asset) => {
|
|
291
|
+
if (!asset.groupedBundle) {
|
|
292
|
+
return false;
|
|
293
|
+
}
|
|
294
|
+
return groupedAssetKeys.has(getGroupedBundleAssetKey(asset.groupedBundle));
|
|
295
|
+
})
|
|
296
|
+
);
|
|
297
|
+
}
|
|
298
|
+
return {
|
|
299
|
+
assetsByRoute: groupedAssetsByRoute,
|
|
300
|
+
hasCollectionFailures
|
|
301
|
+
};
|
|
302
|
+
}
|
|
303
|
+
async listIntegrationRouteFiles(integrationName) {
|
|
304
|
+
const integration = this.appConfig.integrations.find((plugin) => plugin.name === integrationName);
|
|
305
|
+
if (!integration) {
|
|
306
|
+
return [];
|
|
307
|
+
}
|
|
308
|
+
const scannedFiles = await fileSystem.glob(
|
|
309
|
+
integration.extensions.map((extension) => `**/*${extension}`),
|
|
310
|
+
{ cwd: this.appConfig.absolutePaths.pagesDir }
|
|
311
|
+
);
|
|
312
|
+
return scannedFiles.filter((file) => !file.includes(".ecopages-node.")).map((file) => path.join(this.appConfig.absolutePaths.pagesDir, file)).sort((left, right) => left.localeCompare(right));
|
|
313
|
+
}
|
|
314
|
+
partitionPageBrowserGraphAssets(assets) {
|
|
315
|
+
const entryAssets = [];
|
|
316
|
+
const chunkAssets = [];
|
|
317
|
+
for (const asset of assets) {
|
|
318
|
+
if (asset.packageRole === "dynamic-chunk") {
|
|
319
|
+
chunkAssets.push(asset);
|
|
320
|
+
continue;
|
|
321
|
+
}
|
|
322
|
+
entryAssets.push(asset);
|
|
323
|
+
}
|
|
324
|
+
return { entryAssets, chunkAssets };
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Captures one route render body as HTML while preserving a replayable body value.
|
|
328
|
+
*/
|
|
329
|
+
async captureHtmlRender(render) {
|
|
330
|
+
const renderedBody = await render();
|
|
331
|
+
const capturedRender = await this.captureRenderedBody(renderedBody);
|
|
332
|
+
return {
|
|
333
|
+
body: capturedRender.body,
|
|
334
|
+
html: capturedRender.html
|
|
335
|
+
};
|
|
336
|
+
}
|
|
337
|
+
/**
|
|
338
|
+
* Executes the full route-render flow and returns the final body plus cache strategy.
|
|
339
|
+
*/
|
|
340
|
+
async execute(options, adapter) {
|
|
341
|
+
const renderOptions = await this.prepareRenderOptions(options, adapter);
|
|
342
|
+
return this.executePrepared(renderOptions, adapter);
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* Executes the route-render finalization path for already prepared render options.
|
|
346
|
+
*/
|
|
347
|
+
async executePrepared(renderOptions, adapter) {
|
|
348
|
+
const renderExecution = await this.captureHtmlRender(async () => adapter.renderRouteBody(renderOptions));
|
|
349
|
+
const unresolvedArtifactInspection = inspectUnresolvedMarkerArtifactHtml(renderExecution.html);
|
|
350
|
+
const htmlFinalization = adapter.getRouteHtmlFinalization(renderOptions);
|
|
351
|
+
const hasUnresolvedMarkerHtml = unresolvedArtifactInspection.hasUnresolvedMarkerArtifacts;
|
|
352
|
+
if (hasUnresolvedMarkerHtml) {
|
|
353
|
+
throw new Error(
|
|
354
|
+
"[ecopages] Route render returned unresolved eco-marker artifact HTML. Full-route unresolved-marker fallback has been removed; resolve mixed foreign children inside renderComponentWithForeignChildren()."
|
|
355
|
+
);
|
|
356
|
+
}
|
|
357
|
+
const canReuseCapturedBody = !hasUnresolvedMarkerHtml && htmlFinalization.finalizeHtml === void 0;
|
|
358
|
+
if (canReuseCapturedBody) {
|
|
359
|
+
const body2 = await adapter.transformRouteResponse(
|
|
360
|
+
new Response(renderExecution.body, {
|
|
361
|
+
headers: {
|
|
362
|
+
"Content-Type": "text/html"
|
|
363
|
+
}
|
|
364
|
+
}),
|
|
365
|
+
htmlFinalization.htmlContributions
|
|
366
|
+
);
|
|
367
|
+
return {
|
|
368
|
+
body: body2,
|
|
369
|
+
cacheStrategy: renderOptions.cacheStrategy
|
|
370
|
+
};
|
|
371
|
+
}
|
|
372
|
+
const finalization = htmlFinalization.finalizeHtml ? htmlFinalization.finalizeHtml(unresolvedArtifactInspection.normalizedHtml) : unresolvedArtifactInspection.normalizedHtml;
|
|
373
|
+
const body = await adapter.transformRouteResponse(
|
|
374
|
+
new Response(finalization, {
|
|
375
|
+
headers: {
|
|
376
|
+
"Content-Type": "text/html"
|
|
377
|
+
}
|
|
378
|
+
}),
|
|
379
|
+
htmlFinalization.htmlContributions
|
|
380
|
+
);
|
|
381
|
+
return {
|
|
382
|
+
body,
|
|
383
|
+
cacheStrategy: renderOptions.cacheStrategy
|
|
384
|
+
};
|
|
385
|
+
}
|
|
386
|
+
async captureRenderedBody(body) {
|
|
387
|
+
const response = new Response(body);
|
|
388
|
+
if (typeof body === "string") {
|
|
389
|
+
return {
|
|
390
|
+
body,
|
|
391
|
+
html: await response.text()
|
|
392
|
+
};
|
|
393
|
+
}
|
|
394
|
+
if (!response.body) {
|
|
395
|
+
return {
|
|
396
|
+
body,
|
|
397
|
+
html: await response.text()
|
|
398
|
+
};
|
|
399
|
+
}
|
|
400
|
+
const [capturedBody, replayBody] = response.body.tee();
|
|
401
|
+
return {
|
|
402
|
+
body: replayBody,
|
|
403
|
+
html: await new Response(capturedBody).text()
|
|
404
|
+
};
|
|
405
|
+
}
|
|
406
|
+
collectResolvedTriggers(components, seen = /* @__PURE__ */ new Set()) {
|
|
407
|
+
const triggers = [];
|
|
408
|
+
for (const comp of components) {
|
|
409
|
+
if (!comp) {
|
|
410
|
+
continue;
|
|
411
|
+
}
|
|
412
|
+
const ecoComp = comp;
|
|
413
|
+
if (seen.has(ecoComp)) {
|
|
414
|
+
continue;
|
|
415
|
+
}
|
|
416
|
+
seen.add(ecoComp);
|
|
417
|
+
const ownTriggers = ecoComp.config?._resolvedLazyTriggers;
|
|
418
|
+
if (ownTriggers?.length) {
|
|
419
|
+
triggers.push(...ownTriggers);
|
|
420
|
+
}
|
|
421
|
+
const nested = ecoComp.config?.dependencies?.components;
|
|
422
|
+
if (nested?.length) {
|
|
423
|
+
triggers.push(...this.collectResolvedTriggers(nested, seen));
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
return triggers;
|
|
427
|
+
}
|
|
428
|
+
collectUsedIntegrationDependencies(components, currentIntegrationName) {
|
|
429
|
+
const integrationNames = this.collectIntegrationNames(components);
|
|
430
|
+
const dependencies = [];
|
|
431
|
+
for (const integrationName of integrationNames) {
|
|
432
|
+
if (integrationName === currentIntegrationName) {
|
|
433
|
+
continue;
|
|
434
|
+
}
|
|
435
|
+
const integrationPlugin = this.appConfig.integrations.find(
|
|
436
|
+
(integration) => integration.name === integrationName
|
|
437
|
+
);
|
|
438
|
+
if (!integrationPlugin || typeof integrationPlugin.getResolvedIntegrationDependencies !== "function") {
|
|
439
|
+
continue;
|
|
440
|
+
}
|
|
441
|
+
dependencies.push(...integrationPlugin.getResolvedIntegrationDependencies());
|
|
442
|
+
}
|
|
443
|
+
return dependencies;
|
|
444
|
+
}
|
|
445
|
+
collectIntegrationNames(components, seen = /* @__PURE__ */ new Set()) {
|
|
446
|
+
const integrationNames = /* @__PURE__ */ new Set();
|
|
447
|
+
for (const comp of components) {
|
|
448
|
+
if (!comp) {
|
|
449
|
+
continue;
|
|
450
|
+
}
|
|
451
|
+
const ecoComp = comp;
|
|
452
|
+
if (seen.has(ecoComp)) {
|
|
453
|
+
continue;
|
|
454
|
+
}
|
|
455
|
+
seen.add(ecoComp);
|
|
456
|
+
const integrationName = ecoComp.config?.integration ?? ecoComp.config?.__eco?.integration;
|
|
457
|
+
if (integrationName) {
|
|
458
|
+
integrationNames.add(integrationName);
|
|
459
|
+
}
|
|
460
|
+
const nested = ecoComp.config?.dependencies?.components;
|
|
461
|
+
if (nested?.length) {
|
|
462
|
+
const nestedNames = this.collectIntegrationNames(nested, seen);
|
|
463
|
+
for (const nestedName of nestedNames) {
|
|
464
|
+
integrationNames.add(nestedName);
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
}
|
|
468
|
+
return integrationNames;
|
|
469
|
+
}
|
|
470
|
+
async buildGlobalInjectorAssets(triggers, currentIntegrationName) {
|
|
471
|
+
const appProjectDir = this.appConfig.rootDir ?? this.appConfig.absolutePaths?.projectDir ?? process.cwd();
|
|
472
|
+
const appPackageRequire = createRequire(path.join(appProjectDir, "package.json"));
|
|
473
|
+
const corePackageEntryPath = appPackageRequire.resolve("@ecopages/core");
|
|
474
|
+
const globalInjectorImportPath = createRequire(corePackageEntryPath).resolve(
|
|
475
|
+
"@ecopages/scripts-injector/global"
|
|
476
|
+
);
|
|
477
|
+
const mapScript = AssetFactory.createInlineContentScript({
|
|
478
|
+
position: "head",
|
|
479
|
+
name: "ecopages-global-injector-map",
|
|
480
|
+
content: buildGlobalInjectorMapScript(triggers),
|
|
481
|
+
attributes: { type: "ecopages/global-injector-map" },
|
|
482
|
+
packageRole: "keep-separate",
|
|
483
|
+
bundle: false
|
|
484
|
+
});
|
|
485
|
+
const bootstrapInlineScript = AssetFactory.createInlineContentScript({
|
|
486
|
+
position: "head",
|
|
487
|
+
name: "ecopages-global-injector-bootstrap",
|
|
488
|
+
content: buildGlobalInjectorBootstrapContent(globalInjectorImportPath),
|
|
489
|
+
attributes: { type: "module" },
|
|
490
|
+
packageRole: "keep-separate",
|
|
491
|
+
bundle: true
|
|
492
|
+
});
|
|
493
|
+
return this.assetProcessingService.processDependencies(
|
|
494
|
+
[mapScript, bootstrapInlineScript],
|
|
495
|
+
currentIntegrationName
|
|
496
|
+
);
|
|
497
|
+
}
|
|
498
|
+
async buildEagerSsrLazyAssets(components, currentIntegrationName) {
|
|
499
|
+
const dependencies = this.collectEagerSsrLazyDependencies(components);
|
|
500
|
+
if (dependencies.length === 0) {
|
|
501
|
+
return [];
|
|
502
|
+
}
|
|
503
|
+
return this.assetProcessingService.processDependencies(dependencies, `${currentIntegrationName}:ssr-lazy`);
|
|
504
|
+
}
|
|
505
|
+
collectEagerSsrLazyDependencies(components) {
|
|
506
|
+
const dependencies = [];
|
|
507
|
+
const visitedConfigs = /* @__PURE__ */ new Set();
|
|
508
|
+
const seenKeys = /* @__PURE__ */ new Set();
|
|
509
|
+
const normalizeAttributes = (attributes) => ({
|
|
510
|
+
type: "module",
|
|
511
|
+
defer: "",
|
|
512
|
+
...attributes ?? {}
|
|
513
|
+
});
|
|
514
|
+
const collect = (config) => {
|
|
515
|
+
if (!config || visitedConfigs.has(config)) {
|
|
516
|
+
return;
|
|
517
|
+
}
|
|
518
|
+
visitedConfigs.add(config);
|
|
519
|
+
const componentFile = config.__eco?.file;
|
|
520
|
+
if (componentFile) {
|
|
521
|
+
const componentDir = path.dirname(componentFile);
|
|
522
|
+
for (const script of config.dependencies?.scripts ?? []) {
|
|
523
|
+
if (typeof script === "string" || !script.lazy || script.ssr !== true) {
|
|
524
|
+
continue;
|
|
525
|
+
}
|
|
526
|
+
const attributes = normalizeAttributes(script.attributes);
|
|
527
|
+
if (script.content) {
|
|
528
|
+
const key2 = `content:${script.content}:${JSON.stringify(attributes)}`;
|
|
529
|
+
if (seenKeys.has(key2)) {
|
|
530
|
+
continue;
|
|
531
|
+
}
|
|
532
|
+
seenKeys.add(key2);
|
|
533
|
+
dependencies.push(
|
|
534
|
+
AssetFactory.createContentScript({
|
|
535
|
+
position: "head",
|
|
536
|
+
content: script.content,
|
|
537
|
+
attributes,
|
|
538
|
+
packageRole: "dynamic-chunk"
|
|
539
|
+
})
|
|
540
|
+
);
|
|
541
|
+
continue;
|
|
542
|
+
}
|
|
543
|
+
if (!script.src) {
|
|
544
|
+
continue;
|
|
545
|
+
}
|
|
546
|
+
const resolvedPath = path.resolve(componentDir, script.src);
|
|
547
|
+
const key = `file:${resolvedPath}:${JSON.stringify(attributes)}`;
|
|
548
|
+
if (seenKeys.has(key)) {
|
|
549
|
+
continue;
|
|
550
|
+
}
|
|
551
|
+
seenKeys.add(key);
|
|
552
|
+
dependencies.push(
|
|
553
|
+
AssetFactory.createFileScript({
|
|
554
|
+
filepath: resolvedPath,
|
|
555
|
+
position: "head",
|
|
556
|
+
attributes,
|
|
557
|
+
packageRole: "dynamic-chunk"
|
|
558
|
+
})
|
|
559
|
+
);
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
if (config.layout?.config) {
|
|
563
|
+
collect(config.layout.config);
|
|
564
|
+
}
|
|
565
|
+
for (const nestedComponent of config.dependencies?.components ?? []) {
|
|
566
|
+
collect(nestedComponent?.config);
|
|
567
|
+
}
|
|
568
|
+
};
|
|
569
|
+
for (const component of components) {
|
|
570
|
+
collect(component.config);
|
|
571
|
+
}
|
|
572
|
+
return dependencies;
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
export {
|
|
576
|
+
RouteRenderOrchestrator
|
|
577
|
+
};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Minimal template-result shape that core can serialize generically.
|
|
3
|
+
*
|
|
4
|
+
* @remarks
|
|
5
|
+
* Core intentionally models only the transport shape used during deferred
|
|
6
|
+
* cross-integration child passing: alternating static string segments plus
|
|
7
|
+
* interpolated runtime values. Concrete runtime markers that identify a given
|
|
8
|
+
* framework's template payload must stay outside core and be registered by the
|
|
9
|
+
* owning integration package.
|
|
10
|
+
*/
|
|
11
|
+
export type SerializableTemplateShape = {
|
|
12
|
+
strings: readonly string[];
|
|
13
|
+
values?: readonly unknown[];
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Integration-owned adapter that teaches core how to serialize one deferred
|
|
17
|
+
* template payload shape.
|
|
18
|
+
*
|
|
19
|
+
* @remarks
|
|
20
|
+
* The separation here is intentional: core owns the HTML serialization logic,
|
|
21
|
+
* but integrations own runtime-shape detection. That keeps package-specific
|
|
22
|
+
* markers such as framework template sentinels out of core while still letting
|
|
23
|
+
* deferred children round-trip through mixed renderer boundaries.
|
|
24
|
+
*/
|
|
25
|
+
export type DeferredTemplateSerializer<TTemplate extends SerializableTemplateShape = SerializableTemplateShape> = {
|
|
26
|
+
matches(value: unknown): value is TTemplate;
|
|
27
|
+
serialize(template: TTemplate, serializeValue: (value: unknown) => string | undefined): string;
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* Serializes a generic template shape into HTML.
|
|
31
|
+
*
|
|
32
|
+
* @remarks
|
|
33
|
+
* This handles only HTML reconstruction semantics: quoted attribute values,
|
|
34
|
+
* boolean attributes, and omission of client-only event or property bindings.
|
|
35
|
+
* It does not decide whether an arbitrary value belongs to a framework-specific
|
|
36
|
+
* template runtime; integrations must make that decision before delegating here.
|
|
37
|
+
*/
|
|
38
|
+
export declare function serializeTemplateShape(template: SerializableTemplateShape, serializeValue: (value: unknown) => string | undefined): string;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { escapeHtmlAttribute } from "../../utils/html-escaping.js";
|
|
2
|
+
const ATTRIBUTE_TAIL_PATTERN = /(\s+)([@.?!]?)([^\s"'<>/=`@.?!]+)=$/;
|
|
3
|
+
function getSerializableTemplateAttribute(stringPart) {
|
|
4
|
+
const match = ATTRIBUTE_TAIL_PATTERN.exec(stringPart);
|
|
5
|
+
if (!match) return void 0;
|
|
6
|
+
return {
|
|
7
|
+
leading: stringPart.slice(0, match.index),
|
|
8
|
+
whitespace: match[1],
|
|
9
|
+
prefix: match[2],
|
|
10
|
+
name: match[3]
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
function serializeTemplateShape(template, serializeValue) {
|
|
14
|
+
const values = template.values ?? [];
|
|
15
|
+
let html = "";
|
|
16
|
+
for (let index = 0; index < values.length; index += 1) {
|
|
17
|
+
const stringPart = template.strings[index] ?? "";
|
|
18
|
+
const serializedValue = serializeValue(values[index]);
|
|
19
|
+
const attribute = getSerializableTemplateAttribute(stringPart);
|
|
20
|
+
if (!attribute) {
|
|
21
|
+
html += stringPart;
|
|
22
|
+
html += serializedValue ?? "";
|
|
23
|
+
continue;
|
|
24
|
+
}
|
|
25
|
+
html += attribute.leading;
|
|
26
|
+
if (attribute.prefix === "@" || attribute.prefix === "!" || attribute.prefix === ".") {
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
if (attribute.prefix === "?") {
|
|
30
|
+
if (serializedValue) {
|
|
31
|
+
html += `${attribute.whitespace}${attribute.name}`;
|
|
32
|
+
}
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (serializedValue === void 0) {
|
|
36
|
+
continue;
|
|
37
|
+
}
|
|
38
|
+
html += `${attribute.whitespace}${attribute.name}="${escapeHtmlAttribute(serializedValue)}"`;
|
|
39
|
+
}
|
|
40
|
+
html += template.strings[values.length] ?? "";
|
|
41
|
+
return html;
|
|
42
|
+
}
|
|
43
|
+
export {
|
|
44
|
+
serializeTemplateShape
|
|
45
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { EcoComponent } from '../../types/public-types.js';
|
|
2
|
+
import type { AssetDefinition } from '../../services/assets/asset-processing-service/index.js';
|
|
3
|
+
import { type LazyGroup } from './lazy-entry-collection.js';
|
|
4
|
+
/**
|
|
5
|
+
* Aggregated dependency output for one dependency-collection pass.
|
|
6
|
+
*/
|
|
7
|
+
export type CollectedComponentDependencies = {
|
|
8
|
+
/**
|
|
9
|
+
* Flat asset declarations ready for downstream processing.
|
|
10
|
+
*/
|
|
11
|
+
dependencies: AssetDefinition[];
|
|
12
|
+
/**
|
|
13
|
+
* Lazy script groups keyed by component config and trigger key.
|
|
14
|
+
*/
|
|
15
|
+
lazyScriptsByConfig: Map<NonNullable<EcoComponent['config']>, Map<string, LazyGroup>>;
|
|
16
|
+
};
|
|
17
|
+
type CollectComponentDependenciesOptions = {
|
|
18
|
+
components: Array<EcoComponent | Partial<EcoComponent> | undefined | null>;
|
|
19
|
+
integrationName: string;
|
|
20
|
+
resolveLazyScripts: (componentDir: string, scripts: string[]) => string;
|
|
21
|
+
createEcopagesJsxLazyEntryName: (integrationName: string, key: string) => string;
|
|
22
|
+
isEcopagesJsxIntegration: (integrationName: string) => boolean;
|
|
23
|
+
errors: {
|
|
24
|
+
invalidStylesheetEntry: string;
|
|
25
|
+
invalidScriptEntry: string;
|
|
26
|
+
lazyScriptMissingSrc: string;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* Walks component dependency trees and collects declared assets, module declarations,
|
|
31
|
+
* and lazy-script group metadata in one pass.
|
|
32
|
+
*
|
|
33
|
+
* The returned structures intentionally preserve both the flat asset list used by
|
|
34
|
+
* asset processing and the grouped lazy-trigger data used later during render output.
|
|
35
|
+
*/
|
|
36
|
+
export declare function collectComponentDependencies(options: CollectComponentDependenciesOptions): CollectedComponentDependencies;
|
|
37
|
+
export {};
|