@ecopages/core 0.2.0-alpha.4 → 0.2.0-alpha.41
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 -68
- package/src/adapters/bun/hmr-manager.js +30 -212
- 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 -49
- package/src/adapters/node/node-hmr-manager.js +31 -219
- 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 +176 -3
- package/src/build/build-adapter.js +619 -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 -74
- 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 +46 -48
- package/src/hmr/strategies/js-hmr-strategy.js +60 -75
- 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 +986 -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 +134 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.js +442 -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 +119 -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 +42 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +297 -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 -35
- 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 +40 -29
- package/src/watchers/project-watcher.js +126 -116
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- package/src/watchers/project-watcher.test-helpers.js +6 -6
- package/CHANGELOG.md +0 -91
- 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 -296
- 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 -289
- 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 -132
- package/src/build/build-types.ts +0 -83
- package/src/build/esbuild-build-adapter.ts +0 -510
- 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 -320
- 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 -1260
- 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 -41
- package/src/watchers/project-watcher.ts +0 -344
- /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
package/src/eco/README.md
CHANGED
|
@@ -7,10 +7,12 @@ A unified API for defining components, pages, and page data in EcoPages.
|
|
|
7
7
|
The `eco` namespace provides a consistent, type-safe interface for:
|
|
8
8
|
|
|
9
9
|
1. **`eco.component()`** - Factory for defining reusable components with dependencies and optional lazy-loading
|
|
10
|
-
2. **`eco.
|
|
11
|
-
3. **`eco.
|
|
12
|
-
4. **`eco.
|
|
13
|
-
5. **`eco.
|
|
10
|
+
2. **`eco.html()`** - Semantic alias for the document shell component (the outermost HTML wrapper)
|
|
11
|
+
3. **`eco.layout()`** - Semantic alias for route layout components (page-level wrappers)
|
|
12
|
+
4. **`eco.page()`** - Factory for defining page components with optional inline `staticPaths`, `staticProps`, and `metadata`
|
|
13
|
+
5. **`eco.metadata()`** - Type-safe wrapper for page metadata (legacy pattern)
|
|
14
|
+
6. **`eco.staticPaths()`** - Type-safe wrapper for dynamic route generation (legacy pattern)
|
|
15
|
+
7. **`eco.staticProps()`** - Type-safe wrapper for static data fetching (legacy pattern)
|
|
14
16
|
|
|
15
17
|
## Component Patterns
|
|
16
18
|
|
|
@@ -42,9 +44,9 @@ export function Card({ children, class: className }: CardProps) {
|
|
|
42
44
|
|
|
43
45
|
> **Note:** If your component requires a dedicated CSS file, use `eco.component()` instead to manage the stylesheet dependency.
|
|
44
46
|
|
|
45
|
-
### Plain React Components
|
|
47
|
+
### Plain React Components
|
|
46
48
|
|
|
47
|
-
|
|
49
|
+
React components with hooks and Tailwind CSS work out of the box without `eco.component()`. Standard React components can be used directly:
|
|
48
50
|
|
|
49
51
|
```tsx
|
|
50
52
|
import { useEffect, useState } from 'react';
|
|
@@ -99,7 +101,6 @@ export function ThemeToggle() {
|
|
|
99
101
|
- React components with hooks (`useState`, `useEffect`, etc.)
|
|
100
102
|
- Components styled with Tailwind CSS classes
|
|
101
103
|
- Interactive UI that doesn't require external scripts or dedicated stylesheets
|
|
102
|
-
- Bun handles all imports automatically
|
|
103
104
|
|
|
104
105
|
> **Note:** Use `eco.component()` only when you need to manage external stylesheets, scripts, or lazy loading. For React components relying solely on hooks and Tailwind, plain functions are simpler and sufficient.
|
|
105
106
|
|
|
@@ -128,14 +129,14 @@ export const Counter = eco.component({
|
|
|
128
129
|
|
|
129
130
|
### Comparison
|
|
130
131
|
|
|
131
|
-
| Aspect | Simple JSX | Plain React
|
|
132
|
-
| -------------------- | ---------- |
|
|
133
|
-
| React hooks | No | Yes
|
|
134
|
-
| Scripts/Stylesheets | No | No
|
|
135
|
-
| Lazy loading | No | No
|
|
136
|
-
| Hydration strategies | No | No
|
|
137
|
-
| Runtime cost | Zero | Minimal
|
|
138
|
-
| Use case | Static UI | Interactive UI
|
|
132
|
+
| Aspect | Simple JSX | Plain React | `eco.component()` |
|
|
133
|
+
| -------------------- | ---------- | -------------- | ----------------- |
|
|
134
|
+
| React hooks | No | Yes | Yes |
|
|
135
|
+
| Scripts/Stylesheets | No | No | Yes |
|
|
136
|
+
| Lazy loading | No | No | Yes |
|
|
137
|
+
| Hydration strategies | No | No | Yes |
|
|
138
|
+
| Runtime cost | Zero | Minimal | Minimal |
|
|
139
|
+
| Use case | Static UI | Interactive UI | Advanced UI |
|
|
139
140
|
|
|
140
141
|
All patterns can coexist in the same project. Use the right tool for the job.
|
|
141
142
|
|
|
@@ -231,6 +232,53 @@ Both patterns work and can be mixed - the renderer checks for attached propertie
|
|
|
231
232
|
|
|
232
233
|
## API Reference
|
|
233
234
|
|
|
235
|
+
### `eco.html()`
|
|
236
|
+
|
|
237
|
+
Creates the document shell component — the outermost HTML wrapper rendered once per page. Semantically equivalent to `eco.component()` but signals intent to tooling and readers that this component owns the full document structure (`<html>`, `<head>`, `<body>`).
|
|
238
|
+
|
|
239
|
+
```tsx
|
|
240
|
+
import { eco } from '@ecopages/core';
|
|
241
|
+
|
|
242
|
+
export const Document = eco.html({
|
|
243
|
+
dependencies: {
|
|
244
|
+
stylesheets: ['./document.css'],
|
|
245
|
+
},
|
|
246
|
+
render: ({ children, metadata }) => (
|
|
247
|
+
<html lang="en">
|
|
248
|
+
<head>
|
|
249
|
+
<title>{metadata?.title ?? 'EcoPages'}</title>
|
|
250
|
+
</head>
|
|
251
|
+
<body>{children}</body>
|
|
252
|
+
</html>
|
|
253
|
+
),
|
|
254
|
+
});
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
### `eco.layout()`
|
|
258
|
+
|
|
259
|
+
Creates a route layout component — a wrapper rendered around page content. Semantically equivalent to `eco.component()` but clearly communicates that the component is intended to be used as a `layout` in `eco.page()`.
|
|
260
|
+
|
|
261
|
+
```tsx
|
|
262
|
+
import { eco } from '@ecopages/core';
|
|
263
|
+
|
|
264
|
+
export const BaseLayout = eco.layout({
|
|
265
|
+
dependencies: {
|
|
266
|
+
stylesheets: ['./base-layout.css'],
|
|
267
|
+
scripts: ['./base-layout.script.ts'],
|
|
268
|
+
},
|
|
269
|
+
render: ({ children }) => <main>{children}</main>,
|
|
270
|
+
});
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
Use `eco.layout()` components as the `layout` option in `eco.page()`:
|
|
274
|
+
|
|
275
|
+
```tsx
|
|
276
|
+
export default eco.page({
|
|
277
|
+
layout: BaseLayout,
|
|
278
|
+
render: () => <h1>Hello</h1>,
|
|
279
|
+
});
|
|
280
|
+
```
|
|
281
|
+
|
|
234
282
|
### `eco.component()`
|
|
235
283
|
|
|
236
284
|
Define a reusable component with dependencies.
|
|
@@ -516,12 +564,18 @@ interface EcoComponentDependencies {
|
|
|
516
564
|
components?: EcoComponent[];
|
|
517
565
|
}
|
|
518
566
|
|
|
567
|
+
// Shared base option shape used by component(), html(), and layout()
|
|
519
568
|
interface ComponentOptions<P, E = EcoPagesElement> {
|
|
520
569
|
componentDir?: string;
|
|
521
570
|
dependencies?: EcoComponentDependencies;
|
|
522
571
|
render: (props: P) => E;
|
|
523
572
|
}
|
|
524
573
|
|
|
574
|
+
// html() and layout() accept the same options as component() but return
|
|
575
|
+
// narrower types to signal intent (EcoHtmlComponent / EcoLayoutComponent).
|
|
576
|
+
type HtmlOptions<E = EcoPagesElement> = ComponentOptions<Record<string, unknown>, E>;
|
|
577
|
+
type LayoutOptions<E = EcoPagesElement> = ComponentOptions<{ children: E }, E>;
|
|
578
|
+
|
|
525
579
|
interface PageOptions<T, E = EcoPagesElement> {
|
|
526
580
|
componentDir?: string;
|
|
527
581
|
dependencies?: EcoComponentDependencies;
|
|
@@ -551,7 +605,7 @@ type PagePropsFor<T> =
|
|
|
551
605
|
```tsx
|
|
552
606
|
import { eco } from '@ecopages/core';
|
|
553
607
|
|
|
554
|
-
eco. // IDE shows: component, page, metadata, staticPaths, staticProps
|
|
608
|
+
eco. // IDE shows: component, html, layout, page, metadata, staticPaths, staticProps
|
|
555
609
|
```
|
|
556
610
|
|
|
557
611
|
### 2. Type Safety
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
function createComponentFactory(options) {
|
|
2
|
+
const component2 = ((props) => options.render(props));
|
|
3
|
+
component2.config = {
|
|
4
|
+
__eco: options.__eco,
|
|
5
|
+
integration: options.integration,
|
|
6
|
+
dependencies: options.dependencies
|
|
7
|
+
};
|
|
8
|
+
return component2;
|
|
9
|
+
}
|
|
10
|
+
function component(options) {
|
|
11
|
+
return createComponentFactory(options);
|
|
12
|
+
}
|
|
13
|
+
function embed(component2, props, children) {
|
|
14
|
+
const nextProps = children === void 0 ? props : { ...props, children };
|
|
15
|
+
return component2(nextProps);
|
|
16
|
+
}
|
|
17
|
+
function html(options) {
|
|
18
|
+
return createComponentFactory(options);
|
|
19
|
+
}
|
|
20
|
+
function layout(options) {
|
|
21
|
+
return createComponentFactory(options);
|
|
22
|
+
}
|
|
23
|
+
function page(options) {
|
|
24
|
+
const {
|
|
25
|
+
layout: pageLayout,
|
|
26
|
+
dependencies,
|
|
27
|
+
render,
|
|
28
|
+
staticPaths: staticPaths2,
|
|
29
|
+
staticProps: staticProps2,
|
|
30
|
+
metadata: metadata2,
|
|
31
|
+
cache,
|
|
32
|
+
requires,
|
|
33
|
+
middleware
|
|
34
|
+
} = options;
|
|
35
|
+
const pageComponent = createComponentFactory({
|
|
36
|
+
__eco: options.__eco,
|
|
37
|
+
integration: options.integration,
|
|
38
|
+
dependencies: pageLayout ? {
|
|
39
|
+
...dependencies,
|
|
40
|
+
components: [...dependencies?.components ?? [], pageLayout]
|
|
41
|
+
} : dependencies,
|
|
42
|
+
render
|
|
43
|
+
});
|
|
44
|
+
if (pageLayout && pageComponent.config) {
|
|
45
|
+
pageComponent.config.layout = pageLayout;
|
|
46
|
+
}
|
|
47
|
+
if (staticPaths2) {
|
|
48
|
+
pageComponent.staticPaths = staticPaths2;
|
|
49
|
+
}
|
|
50
|
+
if (staticProps2) {
|
|
51
|
+
pageComponent.staticProps = staticProps2;
|
|
52
|
+
}
|
|
53
|
+
if (metadata2) {
|
|
54
|
+
pageComponent.metadata = metadata2;
|
|
55
|
+
}
|
|
56
|
+
if (cache) {
|
|
57
|
+
pageComponent.cache = cache;
|
|
58
|
+
}
|
|
59
|
+
if (requires) {
|
|
60
|
+
pageComponent.requires = requires;
|
|
61
|
+
}
|
|
62
|
+
if (middleware) {
|
|
63
|
+
pageComponent.middleware = middleware;
|
|
64
|
+
}
|
|
65
|
+
return pageComponent;
|
|
66
|
+
}
|
|
67
|
+
function metadata(fn) {
|
|
68
|
+
return fn;
|
|
69
|
+
}
|
|
70
|
+
function staticPaths(fn) {
|
|
71
|
+
return fn;
|
|
72
|
+
}
|
|
73
|
+
function staticProps(fn) {
|
|
74
|
+
return fn;
|
|
75
|
+
}
|
|
76
|
+
const eco = {
|
|
77
|
+
component,
|
|
78
|
+
embed,
|
|
79
|
+
html,
|
|
80
|
+
layout,
|
|
81
|
+
page,
|
|
82
|
+
metadata,
|
|
83
|
+
staticPaths,
|
|
84
|
+
staticProps
|
|
85
|
+
};
|
|
86
|
+
export {
|
|
87
|
+
eco
|
|
88
|
+
};
|
package/src/eco/eco.js
CHANGED
|
@@ -1,60 +1,40 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import {
|
|
2
|
+
finalizeComponentRender,
|
|
3
|
+
getComponentRenderContext,
|
|
4
|
+
interceptForeignChild
|
|
5
|
+
} from "../route-renderer/orchestration/component-render-context.js";
|
|
6
|
+
import { isThenable } from "../route-renderer/orchestration/render-output.utils.js";
|
|
4
7
|
function createComponentFactory(options) {
|
|
5
8
|
const integrationName = options.integration ?? options.__eco?.integration;
|
|
6
9
|
const comp = ((props) => {
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
component: comp
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
"[ecopages] Missing component reference metadata for cross-integration marker emission."
|
|
20
|
-
);
|
|
21
|
-
}
|
|
22
|
-
const componentProps = props ?? {};
|
|
23
|
-
renderContext.propsByRef[propsRef] = componentProps;
|
|
24
|
-
let slotRef;
|
|
25
|
-
const children = componentProps.children;
|
|
26
|
-
if (typeof children === "string" && children.includes("<eco-marker")) {
|
|
27
|
-
const childMarkers = parseComponentMarkers(children);
|
|
28
|
-
if (childMarkers.length > 0) {
|
|
29
|
-
slotRef = createSlotRef(renderContext);
|
|
30
|
-
renderContext.slotChildrenByRef[slotRef] = childMarkers.map((marker) => marker.nodeId);
|
|
10
|
+
const componentProps = props ?? {};
|
|
11
|
+
const renderInline = (nextProps = props) => finalizeComponentRender(comp, options.render(nextProps));
|
|
12
|
+
const activeRenderContext = getComponentRenderContext();
|
|
13
|
+
const foreignChildRender = interceptForeignChild({
|
|
14
|
+
component: comp,
|
|
15
|
+
props: componentProps,
|
|
16
|
+
targetIntegration: integrationName
|
|
17
|
+
});
|
|
18
|
+
if (isThenable(foreignChildRender)) {
|
|
19
|
+
return foreignChildRender.then((resolvedForeignChildRender) => {
|
|
20
|
+
if (resolvedForeignChildRender?.kind === "resolved") {
|
|
21
|
+
return resolvedForeignChildRender.value;
|
|
31
22
|
}
|
|
32
|
-
|
|
33
|
-
return createComponentMarker({
|
|
34
|
-
nodeId,
|
|
35
|
-
integration: integrationName,
|
|
36
|
-
componentRef,
|
|
37
|
-
propsRef,
|
|
38
|
-
slotRef
|
|
23
|
+
return renderInline(resolvedForeignChildRender?.props ?? props);
|
|
39
24
|
});
|
|
40
25
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
if (lazyTriggers && lazyTriggers.length > 0) {
|
|
44
|
-
const triggerId = lazyTriggers[0].triggerId;
|
|
45
|
-
if (isThenable(content)) {
|
|
46
|
-
return content.then((resolvedContent) => addTriggerAttribute(resolvedContent, triggerId));
|
|
47
|
-
}
|
|
48
|
-
return addTriggerAttribute(content, triggerId);
|
|
26
|
+
if (foreignChildRender?.kind === "resolved") {
|
|
27
|
+
return foreignChildRender.value;
|
|
49
28
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
if (isThenable(content)) {
|
|
53
|
-
return content.then((resolvedContent) => wrapWithScriptsInjector(resolvedContent, lazyGroups));
|
|
54
|
-
}
|
|
55
|
-
return wrapWithScriptsInjector(content, lazyGroups);
|
|
29
|
+
if (foreignChildRender?.kind === "inline") {
|
|
30
|
+
return renderInline(foreignChildRender.props ?? props);
|
|
56
31
|
}
|
|
57
|
-
|
|
32
|
+
if (activeRenderContext && activeRenderContext.foreignChildRuntime && integrationName && integrationName !== activeRenderContext.currentIntegration) {
|
|
33
|
+
throw new Error(
|
|
34
|
+
`[ecopages] Missing foreign-child interception from ${activeRenderContext.currentIntegration} to ${integrationName} for ${options.__eco?.file ?? "unknown component"}.`
|
|
35
|
+
);
|
|
36
|
+
}
|
|
37
|
+
return renderInline();
|
|
58
38
|
});
|
|
59
39
|
comp.config = {
|
|
60
40
|
__eco: options.__eco,
|
|
@@ -66,20 +46,46 @@ function createComponentFactory(options) {
|
|
|
66
46
|
function component(options) {
|
|
67
47
|
return createComponentFactory(options);
|
|
68
48
|
}
|
|
49
|
+
function isMissingForeignChildInterceptionError(error) {
|
|
50
|
+
return error instanceof Error && error.message.startsWith("[ecopages] Missing foreign-child interception from ");
|
|
51
|
+
}
|
|
52
|
+
function embed(component2, props, children) {
|
|
53
|
+
const activeRenderContext = getComponentRenderContext();
|
|
54
|
+
const ecoComponent = component2;
|
|
55
|
+
const targetIntegration = ecoComponent.config?.integration ?? ecoComponent.config?.__eco?.integration;
|
|
56
|
+
const componentFile = ecoComponent.config?.__eco?.file ?? "unknown component";
|
|
57
|
+
const nextProps = children === void 0 ? props : { ...props, children };
|
|
58
|
+
try {
|
|
59
|
+
return component2(nextProps);
|
|
60
|
+
} catch (error) {
|
|
61
|
+
if (!isMissingForeignChildInterceptionError(error)) {
|
|
62
|
+
throw error;
|
|
63
|
+
}
|
|
64
|
+
throw new Error(
|
|
65
|
+
`[ecopages] eco.embed() could not hand off the Foreign Child from ${activeRenderContext?.currentIntegration ?? "unknown integration"} to ${targetIntegration ?? "unknown integration"} for ${componentFile}. The active Integration renderer exposed a foreign-child runtime, but it did not intercept this cross-integration render. Ensure mixed-integration Page, Layout, Html, or Component renders install foreign-child handoff before calling eco.embed().`
|
|
66
|
+
);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
function html(options) {
|
|
70
|
+
return createComponentFactory(options);
|
|
71
|
+
}
|
|
72
|
+
function layout(options) {
|
|
73
|
+
return createComponentFactory(options);
|
|
74
|
+
}
|
|
69
75
|
function page(options) {
|
|
70
|
-
const { layout, dependencies, render, staticPaths: staticPaths2, staticProps: staticProps2, metadata: metadata2, cache, requires, middleware } = options;
|
|
76
|
+
const { layout: layout2, dependencies, render, staticPaths: staticPaths2, staticProps: staticProps2, metadata: metadata2, cache, requires, middleware } = options;
|
|
71
77
|
const componentOptions = {
|
|
72
78
|
__eco: options.__eco,
|
|
73
79
|
integration: options.integration,
|
|
74
|
-
dependencies:
|
|
80
|
+
dependencies: layout2 ? {
|
|
75
81
|
...dependencies,
|
|
76
|
-
components: [...dependencies?.components || [],
|
|
82
|
+
components: [...dependencies?.components || [], layout2]
|
|
77
83
|
} : dependencies,
|
|
78
84
|
render
|
|
79
85
|
};
|
|
80
86
|
const pageComponent = createComponentFactory(componentOptions);
|
|
81
|
-
if (
|
|
82
|
-
pageComponent.config.layout =
|
|
87
|
+
if (layout2 && pageComponent.config) {
|
|
88
|
+
pageComponent.config.layout = layout2;
|
|
83
89
|
}
|
|
84
90
|
if (staticPaths2) pageComponent.staticPaths = staticPaths2;
|
|
85
91
|
if (staticProps2) pageComponent.staticProps = staticProps2;
|
|
@@ -100,6 +106,9 @@ function staticProps(fn) {
|
|
|
100
106
|
}
|
|
101
107
|
const eco = {
|
|
102
108
|
component,
|
|
109
|
+
embed,
|
|
110
|
+
html,
|
|
111
|
+
layout,
|
|
103
112
|
page,
|
|
104
113
|
metadata,
|
|
105
114
|
staticPaths,
|
package/src/eco/eco.types.d.ts
CHANGED
|
@@ -2,8 +2,53 @@
|
|
|
2
2
|
* Type definitions for the eco namespace API
|
|
3
3
|
* @module
|
|
4
4
|
*/
|
|
5
|
-
import type { DependencyLazyTrigger, EcoComponent, EcoComponentDependencies, EcoInjectedMeta, EcoPagesElement, GetMetadata, GetStaticPaths, GetStaticProps,
|
|
5
|
+
import type { DependencyLazyTrigger, EcoComponent, EcoComponentDependencies, EcoHtmlComponent, EcoInjectedMeta, EcoLayoutComponent, EcoPageLayoutComponent, EcoPagesElement, FileRouteMiddleware, GetMetadata, GetStaticPaths, GetStaticProps, HtmlTemplateProps, LayoutProps, RequestLocals, RequestPageContext } from '../types/public-types.js';
|
|
6
6
|
import type { CacheStrategy } from '../services/cache/cache.types.js';
|
|
7
|
+
/**
|
|
8
|
+
* Extracts the props type from one eco component.
|
|
9
|
+
*/
|
|
10
|
+
export type PropsOf<TComponent extends EcoComponent> = TComponent extends EcoComponent<infer P, any> ? P : never;
|
|
11
|
+
/**
|
|
12
|
+
* Extracts the render result type from one eco component.
|
|
13
|
+
*/
|
|
14
|
+
export type ResultOf<TComponent extends EcoComponent> = TComponent extends EcoComponent<any, infer R> ? R : never;
|
|
15
|
+
/**
|
|
16
|
+
* Narrows an eco component to its callable function signature.
|
|
17
|
+
*
|
|
18
|
+
* This is useful for helper modules such as `EcoEmbed` that invoke a component
|
|
19
|
+
* directly and need to exclude the non-callable metadata shape from the public
|
|
20
|
+
* type surface.
|
|
21
|
+
*/
|
|
22
|
+
export type CallableComponentOf<TComponent extends EcoComponent> = Extract<TComponent, (props: any, ...args: any[]) => any>;
|
|
23
|
+
/**
|
|
24
|
+
* Extracts the declared `children` type from one eco component when present.
|
|
25
|
+
*/
|
|
26
|
+
export type ChildrenOf<TComponent extends EcoComponent> = PropsOf<TComponent> extends {
|
|
27
|
+
children?: infer T;
|
|
28
|
+
} ? T : PropsOf<TComponent> extends {
|
|
29
|
+
children: infer T;
|
|
30
|
+
} ? T : never;
|
|
31
|
+
/**
|
|
32
|
+
* Extracts the props accepted by `eco.embed()` before optional `children`
|
|
33
|
+
* injection.
|
|
34
|
+
*
|
|
35
|
+
* When the target component already declares `children`, callers pass the rest
|
|
36
|
+
* of the props bag here and provide `children` as the third `eco.embed()`
|
|
37
|
+
* argument or the `EcoEmbed` wrapper children slot.
|
|
38
|
+
*/
|
|
39
|
+
export type EmbedPropsOf<TComponent extends EcoComponent> = 'children' extends keyof PropsOf<TComponent> ? Omit<PropsOf<TComponent>, 'children'> : PropsOf<TComponent>;
|
|
40
|
+
/**
|
|
41
|
+
* Props accepted by integration-owned `EcoEmbed` adapters.
|
|
42
|
+
*
|
|
43
|
+
* The `component` field is narrowed to the callable portion of the target eco
|
|
44
|
+
* component so JSX wrappers can invoke `eco.embed()` without repeating local
|
|
45
|
+
* callable-component extraction logic.
|
|
46
|
+
*/
|
|
47
|
+
export type EcoEmbedProps<TComponent extends EcoComponent> = {
|
|
48
|
+
component: CallableComponentOf<TComponent>;
|
|
49
|
+
props: EmbedPropsOf<TComponent>;
|
|
50
|
+
children?: unknown;
|
|
51
|
+
};
|
|
7
52
|
type WithRequiredLocals<K extends keyof RequestLocals> = Omit<RequestLocals, K> & {
|
|
8
53
|
[P in K]-?: Exclude<RequestLocals[P], null | undefined>;
|
|
9
54
|
};
|
|
@@ -26,6 +71,8 @@ export interface ComponentOptions<P, E = EcoPagesElement> {
|
|
|
26
71
|
dependencies?: EcoComponentDependencies;
|
|
27
72
|
render: (props: P) => E | Promise<E>;
|
|
28
73
|
}
|
|
74
|
+
export type HtmlOptions<E = EcoPagesElement> = ComponentOptions<HtmlTemplateProps, E>;
|
|
75
|
+
export type LayoutOptions<E = EcoPagesElement> = ComponentOptions<LayoutProps<E>, E>;
|
|
29
76
|
/**
|
|
30
77
|
* Base options shared by all page variants
|
|
31
78
|
*/
|
|
@@ -34,9 +81,7 @@ export interface PageOptionsBase<T, E = EcoPagesElement> {
|
|
|
34
81
|
__eco?: EcoInjectedMeta;
|
|
35
82
|
integration?: string;
|
|
36
83
|
dependencies?: EcoComponentDependencies;
|
|
37
|
-
layout?:
|
|
38
|
-
children: E;
|
|
39
|
-
} & Partial<RequestPageContext>>;
|
|
84
|
+
layout?: EcoPageLayoutComponent<E>;
|
|
40
85
|
/**
|
|
41
86
|
* Define static paths for dynamic routes (e.g., [slug].tsx).
|
|
42
87
|
* Returns all possible paths that should be pre-rendered at build time.
|
|
@@ -86,7 +131,7 @@ interface PageOptionsWithMiddleware<T, E = EcoPagesElement> extends PageOptionsB
|
|
|
86
131
|
* Request-time middleware for file-based routes.
|
|
87
132
|
* Runs before rendering and can short-circuit by returning a Response.
|
|
88
133
|
*/
|
|
89
|
-
middleware:
|
|
134
|
+
middleware: FileRouteMiddleware[];
|
|
90
135
|
}
|
|
91
136
|
/**
|
|
92
137
|
* Options for creating a page with eco.page()
|
|
@@ -127,7 +172,7 @@ export type EcoPageComponent<T> = EcoComponent<PagePropsFor<T> & Partial<Request
|
|
|
127
172
|
metadata?: GetMetadata<T>;
|
|
128
173
|
cache?: CacheStrategy;
|
|
129
174
|
requires?: PageRequires;
|
|
130
|
-
middleware?:
|
|
175
|
+
middleware?: FileRouteMiddleware[];
|
|
131
176
|
};
|
|
132
177
|
/**
|
|
133
178
|
* The eco namespace interface
|
|
@@ -139,6 +184,24 @@ export interface Eco {
|
|
|
139
184
|
* @template E - Element/return type (EcoPagesElement for Kita, ReactNode for React)
|
|
140
185
|
*/
|
|
141
186
|
component: <P = {}, E = EcoPagesElement>(options: ComponentOptions<P, E>) => EcoComponent<P, E>;
|
|
187
|
+
/**
|
|
188
|
+
* Render a component explicitly, with an optional `children` argument.
|
|
189
|
+
*
|
|
190
|
+
* This is useful when authoring crosses integration boundaries and inline JSX
|
|
191
|
+
* would otherwise force one file to model multiple JSX namespaces.
|
|
192
|
+
*/
|
|
193
|
+
embed: {
|
|
194
|
+
<TComponent extends EcoComponent>(component: CallableComponentOf<TComponent>, props: PropsOf<TComponent>): ResultOf<TComponent>;
|
|
195
|
+
<TComponent extends EcoComponent>(component: CallableComponentOf<TComponent>, props: EmbedPropsOf<TComponent>, children: ChildrenOf<TComponent> | unknown): ResultOf<TComponent>;
|
|
196
|
+
};
|
|
197
|
+
/**
|
|
198
|
+
* Create a document shell component for the HTML wrapper.
|
|
199
|
+
*/
|
|
200
|
+
html: <E = EcoPagesElement>(options: HtmlOptions<E>) => EcoHtmlComponent<E>;
|
|
201
|
+
/**
|
|
202
|
+
* Create a route layout component.
|
|
203
|
+
*/
|
|
204
|
+
layout: <E = EcoPagesElement>(options: LayoutOptions<E>) => EcoLayoutComponent<E>;
|
|
142
205
|
/**
|
|
143
206
|
* Create a page component with type-safe props from getStaticProps.
|
|
144
207
|
* Returns an EcoPageComponent with attached staticPaths, staticProps, and metadata.
|
package/src/eco/eco.utils.d.ts
CHANGED
|
@@ -1,40 +1 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* Returns `true` when `value` is a thenable (Promise-like) object.
|
|
4
|
-
*
|
|
5
|
-
* Used to transparently handle both synchronous and asynchronous component
|
|
6
|
-
* render results without requiring every caller to branch on `instanceof Promise`.
|
|
7
|
-
*
|
|
8
|
-
* @typeParam T Expected resolved type of the thenable.
|
|
9
|
-
*/
|
|
10
|
-
export declare function isThenable<T>(value: unknown): value is PromiseLike<T>;
|
|
11
|
-
/**
|
|
12
|
-
* Injects `data-eco-trigger` into the first real HTML element opening tag of
|
|
13
|
-
* a component's rendered output string.
|
|
14
|
-
*
|
|
15
|
-
* The scan skips over leading whitespace, HTML comments (`<!-- -->`), CDATA
|
|
16
|
-
* sections, and doctype declarations so that the attribute is always placed on
|
|
17
|
-
* the first actual element — not spurious markup that can precede it.
|
|
18
|
-
*
|
|
19
|
-
* The insertion point is the end of the element's tag name, before any existing
|
|
20
|
-
* attributes or the closing `>`, which produces output like:
|
|
21
|
-
*
|
|
22
|
-
* ```html
|
|
23
|
-
* <my-element data-eco-trigger="eco-trigger-abc123" class="foo">…</my-element>
|
|
24
|
-
* ```
|
|
25
|
-
*
|
|
26
|
-
* When no eligible opening tag is found the original string is returned
|
|
27
|
-
* unchanged so callers never receive a broken fragment.
|
|
28
|
-
*
|
|
29
|
-
* @param content Rendered HTML string (or any value coercible to string).
|
|
30
|
-
* @param triggerId Stable trigger identifier produced by `buildResolvedLazyTriggers`.
|
|
31
|
-
*/
|
|
32
|
-
export declare function addTriggerAttribute(content: unknown, triggerId: string): string;
|
|
33
|
-
/**
|
|
34
|
-
* Wraps rendered component output in a `<scripts-injector>` element that
|
|
35
|
-
* carries an inline injector map for the legacy (non-global-injector) path.
|
|
36
|
-
*
|
|
37
|
-
* @param content Rendered component HTML.
|
|
38
|
-
* @param lazyGroups Resolved lazy script groups attached to the component config.
|
|
39
|
-
*/
|
|
40
|
-
export declare function wrapWithScriptsInjector(content: unknown, lazyGroups: NonNullable<EcoComponent['config']>['_resolvedLazyScripts']): string;
|
|
1
|
+
export { addTriggerAttribute, isThenable, wrapWithScriptsInjector, } from '../route-renderer/orchestration/render-output.utils.js';
|
package/src/eco/eco.utils.js
CHANGED
|
@@ -1,38 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const str = String(content);
|
|
7
|
-
let i = 0;
|
|
8
|
-
while (i < str.length) {
|
|
9
|
-
if (str[i] !== "<") {
|
|
10
|
-
i++;
|
|
11
|
-
continue;
|
|
12
|
-
}
|
|
13
|
-
const next = str[i + 1];
|
|
14
|
-
if (next === "!" || next === "?") {
|
|
15
|
-
const end = str.indexOf(">", i);
|
|
16
|
-
if (end === -1) break;
|
|
17
|
-
i = end + 1;
|
|
18
|
-
continue;
|
|
19
|
-
}
|
|
20
|
-
if (next && /[a-zA-Z]/.test(next)) {
|
|
21
|
-
const tagSlice = str.slice(i + 1);
|
|
22
|
-
const nameEnd = tagSlice.search(/[\s/>]/);
|
|
23
|
-
if (nameEnd === -1) break;
|
|
24
|
-
const insertAt = i + 1 + nameEnd;
|
|
25
|
-
return `${str.slice(0, insertAt)} data-eco-trigger="${triggerId}"${str.slice(insertAt)}`;
|
|
26
|
-
}
|
|
27
|
-
break;
|
|
28
|
-
}
|
|
29
|
-
return str;
|
|
30
|
-
}
|
|
31
|
-
function wrapWithScriptsInjector(content, lazyGroups) {
|
|
32
|
-
const wrappedContent = String(content);
|
|
33
|
-
const injectorMapScript = buildInjectorMapScript(lazyGroups ?? []);
|
|
34
|
-
return `<scripts-injector><script type="ecopages/injector-map">${injectorMapScript}<\/script>${wrappedContent}<\/scripts-injector>`;
|
|
35
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
addTriggerAttribute,
|
|
3
|
+
isThenable,
|
|
4
|
+
wrapWithScriptsInjector
|
|
5
|
+
} from "../route-renderer/orchestration/render-output.utils.js";
|
|
36
6
|
export {
|
|
37
7
|
addTriggerAttribute,
|
|
38
8
|
isThenable,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { ResolvedLazyTrigger } from '../public-types.js';
|
|
1
|
+
import type { ResolvedLazyTrigger } from '../types/public-types.js';
|
|
2
2
|
/**
|
|
3
3
|
* Serializes resolved lazy triggers into a JSON string safe for embedding
|
|
4
4
|
* inside an inline `<script type="ecopages/global-injector-map">` tag.
|
|
@@ -10,7 +10,7 @@ import type { ResolvedLazyTrigger } from '../public-types.js';
|
|
|
10
10
|
*/
|
|
11
11
|
export declare function buildGlobalInjectorMapScript(triggers: ResolvedLazyTrigger[]): string;
|
|
12
12
|
/**
|
|
13
|
-
* Builds the
|
|
13
|
+
* Builds the module source that boots the global lazy injector on the client.
|
|
14
14
|
* Emitted once per page alongside the `ecopages/global-injector-map` script block.
|
|
15
15
|
*/
|
|
16
|
-
export declare function buildGlobalInjectorBootstrapContent(
|
|
16
|
+
export declare function buildGlobalInjectorBootstrapContent(globalInjectorModuleSpecifier: string): string;
|
|
@@ -37,8 +37,8 @@ function buildGlobalInjectorMapScript(triggers) {
|
|
|
37
37
|
const map = buildGlobalInjectorMap(triggers);
|
|
38
38
|
return JSON.stringify(map).replace(/<\/script/gi, "<\\/script");
|
|
39
39
|
}
|
|
40
|
-
function buildGlobalInjectorBootstrapContent(
|
|
41
|
-
return `import { initGlobalInjector } from ${JSON.stringify(
|
|
40
|
+
function buildGlobalInjectorBootstrapContent(globalInjectorModuleSpecifier) {
|
|
41
|
+
return `import { initGlobalInjector } from ${JSON.stringify(globalInjectorModuleSpecifier)};
|
|
42
42
|
|
|
43
43
|
function pruneStaleTriggerMaps() {
|
|
44
44
|
const mapScripts = Array.from(document.querySelectorAll('script[type="ecopages/global-injector-map"]'));
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import type { ResolvedLazyScriptGroup } from '../public-types.js';
|
|
1
|
+
import type { ResolvedLazyScriptGroup } from '../types/public-types.js';
|
|
2
2
|
/**
|
|
3
3
|
* Creates a safe JSON payload string for `<script type="ecopages/injector-map">`.
|
|
4
4
|
*
|
|
5
5
|
* @param lazyGroups Lazy script groups resolved during dependency processing.
|
|
6
6
|
* @returns Escaped JSON string safe for inline script embedding.
|
|
7
7
|
*/
|
|
8
|
-
export declare function buildInjectorMapScript(lazyGroups: ResolvedLazyScriptGroup[]): string;
|
|
8
|
+
export declare function buildInjectorMapScript(lazyGroups: readonly ResolvedLazyScriptGroup[]): string;
|
package/src/errors/index.d.ts
CHANGED
package/src/errors/index.js
CHANGED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
# HMR Layer
|
|
2
|
+
|
|
3
|
+
This directory contains the framework-owned hot-update strategy contracts used by runtime adapters and integrations.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
The HMR layer separates change classification from update execution.
|
|
8
|
+
|
|
9
|
+
It is responsible for:
|
|
10
|
+
|
|
11
|
+
- defining the shared HMR manager and strategy contracts
|
|
12
|
+
- letting integrations contribute framework-specific update strategies
|
|
13
|
+
- keeping adapter transports independent from update policy
|
|
14
|
+
|
|
15
|
+
## How It Fits
|
|
16
|
+
|
|
17
|
+
1. `ProjectWatcher` observes file changes.
|
|
18
|
+
2. `DevelopmentInvalidationService` classifies the change.
|
|
19
|
+
3. The active HMR manager selects a strategy.
|
|
20
|
+
4. The strategy coordinates browser rebuilds, metadata reloads, and client broadcasts.
|
|
21
|
+
|
|
22
|
+
## Design Rule
|
|
23
|
+
|
|
24
|
+
Generic invalidation policy belongs in core services.
|
|
25
|
+
Framework-specific update behavior belongs in HMR strategies.
|
|
26
|
+
Runtime-specific WebSocket or event-stream transport belongs in adapters.
|