@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
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import path from "node:path";
|
|
2
1
|
import { parseSync } from "oxc-parser";
|
|
3
|
-
import { fileSystem } from "@ecopages/file-system";
|
|
4
2
|
import { rapidhash } from "../utils/hash.js";
|
|
3
|
+
import {
|
|
4
|
+
createEcoBuildPluginFromSourceTransform,
|
|
5
|
+
createVitePluginFromSourceTransform
|
|
6
|
+
} from "./source-transform.js";
|
|
5
7
|
const REGEX_SPECIAL_CHARS = /[.*+?^${}()|[\]\\]/g;
|
|
6
8
|
const VALID_LOADER_EXTENSIONS = /* @__PURE__ */ new Set([".ts", ".tsx", ".js", ".jsx"]);
|
|
7
9
|
function hasValidLoaderExtension(ext) {
|
|
@@ -16,7 +18,13 @@ function buildExtensionToIntegrationMap(integrations) {
|
|
|
16
18
|
const mapping = [];
|
|
17
19
|
for (const integration of integrations) {
|
|
18
20
|
for (const ext of integration.extensions) {
|
|
19
|
-
mapping.push([
|
|
21
|
+
mapping.push([
|
|
22
|
+
ext,
|
|
23
|
+
{
|
|
24
|
+
name: integration.name,
|
|
25
|
+
jsxImportSource: integration.jsxImportSource
|
|
26
|
+
}
|
|
27
|
+
]);
|
|
20
28
|
}
|
|
21
29
|
}
|
|
22
30
|
mapping.sort((a, b) => b[0].length - a[0].length);
|
|
@@ -28,7 +36,14 @@ function detectIntegration(filePath, extensionToIntegration) {
|
|
|
28
36
|
return integration;
|
|
29
37
|
}
|
|
30
38
|
}
|
|
31
|
-
return "ghtml";
|
|
39
|
+
return { name: "ghtml" };
|
|
40
|
+
}
|
|
41
|
+
function prependJsxImportSource(code, jsxImportSource) {
|
|
42
|
+
if (!jsxImportSource || code.includes("@jsxImportSource")) {
|
|
43
|
+
return code;
|
|
44
|
+
}
|
|
45
|
+
return `/** @jsxImportSource ${jsxImportSource} */
|
|
46
|
+
${code}`;
|
|
32
47
|
}
|
|
33
48
|
function createExtensionPattern(extensions) {
|
|
34
49
|
if (extensions.length === 0) {
|
|
@@ -38,30 +53,31 @@ function createExtensionPattern(extensions) {
|
|
|
38
53
|
const escaped = uniqueExtensions.map((ext) => ext.replace(REGEX_SPECIAL_CHARS, "\\$&"));
|
|
39
54
|
return new RegExp(`(${escaped.join("|")})(\\?.*)?$`);
|
|
40
55
|
}
|
|
41
|
-
function
|
|
56
|
+
function createEcoComponentMetaTransform(options) {
|
|
57
|
+
const allExtensions = options.config.integrations.flatMap((integration) => integration.extensions).filter(hasValidLoaderExtension);
|
|
58
|
+
if (allExtensions.length === 0) {
|
|
59
|
+
throw new Error("[eco-component-meta-plugin] No extensions configured. At least one integration is required.");
|
|
60
|
+
}
|
|
61
|
+
const extensionPattern = createExtensionPattern(allExtensions);
|
|
62
|
+
const extensionToIntegration = buildExtensionToIntegrationMap(options.config.integrations);
|
|
42
63
|
return {
|
|
43
64
|
name: "eco-component-meta-plugin",
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
build.onLoad({ filter: extensionPattern }, (args) => {
|
|
52
|
-
const filePath = args.path.split("?")[0];
|
|
53
|
-
const contents = fileSystem.readFileSync(filePath);
|
|
54
|
-
const integration = detectIntegration(filePath, extensionToIntegration);
|
|
55
|
-
const transformedContents = injectEcoMeta(contents, filePath, integration);
|
|
56
|
-
const ext = path.extname(filePath).slice(1);
|
|
57
|
-
return {
|
|
58
|
-
contents: transformedContents,
|
|
59
|
-
loader: ext || "ts"
|
|
60
|
-
};
|
|
61
|
-
});
|
|
65
|
+
enforce: "pre",
|
|
66
|
+
filter: extensionPattern,
|
|
67
|
+
transform(code, id) {
|
|
68
|
+
const integration = detectIntegration(id, extensionToIntegration);
|
|
69
|
+
return {
|
|
70
|
+
code: prependJsxImportSource(injectEcoMeta(code, id, integration.name), integration.jsxImportSource)
|
|
71
|
+
};
|
|
62
72
|
}
|
|
63
73
|
};
|
|
64
74
|
}
|
|
75
|
+
function createEcoComponentMetaPlugin(options) {
|
|
76
|
+
return createEcoBuildPluginFromSourceTransform(createEcoComponentMetaTransform(options));
|
|
77
|
+
}
|
|
78
|
+
function createEcoComponentMetaVitePlugin(options) {
|
|
79
|
+
return createVitePluginFromSourceTransform(createEcoComponentMetaTransform(options));
|
|
80
|
+
}
|
|
65
81
|
function findInjectionPoints(node, insertions, injection, isInsideEcoComponent = false) {
|
|
66
82
|
if (!node || typeof node !== "object") return;
|
|
67
83
|
const n = node;
|
|
@@ -70,7 +86,7 @@ function findInjectionPoints(node, insertions, injection, isInsideEcoComponent =
|
|
|
70
86
|
if (callee?.type === "MemberExpression" || callee?.type === "StaticMemberExpression") {
|
|
71
87
|
const obj = callee.object;
|
|
72
88
|
const prop = callee.property;
|
|
73
|
-
if (obj?.type === "Identifier" && obj?.name === "eco" && (prop?.name === "page" || prop?.name === "component")) {
|
|
89
|
+
if (obj?.type === "Identifier" && obj?.name === "eco" && (prop?.name === "page" || prop?.name === "component" || prop?.name === "html" || prop?.name === "layout")) {
|
|
74
90
|
const args = n.arguments;
|
|
75
91
|
const firstArg = args?.[0];
|
|
76
92
|
if (firstArg?.type === "ObjectExpression") {
|
|
@@ -152,6 +168,8 @@ function injectEcoMeta(contents, filePath, integration) {
|
|
|
152
168
|
var eco_component_meta_plugin_default = createEcoComponentMetaPlugin;
|
|
153
169
|
export {
|
|
154
170
|
createEcoComponentMetaPlugin,
|
|
171
|
+
createEcoComponentMetaTransform,
|
|
172
|
+
createEcoComponentMetaVitePlugin,
|
|
155
173
|
eco_component_meta_plugin_default as default,
|
|
156
174
|
injectEcoMeta
|
|
157
175
|
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { EcoBuildPlugin } from '../build/build-types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Options for the shared foreign-JSX override build plugin.
|
|
4
|
+
*/
|
|
5
|
+
export interface ForeignJsxOverrideOptions {
|
|
6
|
+
/** JSX runtime that should own the transformed foreign files. */
|
|
7
|
+
hostJsxImportSource: string;
|
|
8
|
+
/** Extensions claimed by other JSX integrations that may appear in the host graph. */
|
|
9
|
+
foreignExtensions: string[];
|
|
10
|
+
/** More specific owned suffixes that must not be claimed by this override. */
|
|
11
|
+
excludeExtensions?: string[];
|
|
12
|
+
/** Optional plugin name override for debug output. */
|
|
13
|
+
name?: string;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Build plugin that prepends a `@jsxImportSource` pragma to foreign integration
|
|
17
|
+
* files bundled into a host integration's client graph.
|
|
18
|
+
*
|
|
19
|
+
* When a host integration (e.g. React) bundles a component file that belongs to
|
|
20
|
+
* another JSX integration (e.g. `.kita.tsx`), that file inherits the project
|
|
21
|
+
* `tsconfig` JSX runtime which produces the wrong output (HTML strings instead
|
|
22
|
+
* of framework elements). This plugin rewrites the source to explicitly target
|
|
23
|
+
* the host's JSX factory so esbuild compiles every JSX expression into the
|
|
24
|
+
* correct element creation calls.
|
|
25
|
+
*
|
|
26
|
+
* The plugin is intentionally framework-agnostic: any integration that does
|
|
27
|
+
* client-side bundling can use it by passing its own `jsxImportSource` and the
|
|
28
|
+
* set of foreign extensions collected from the app config.
|
|
29
|
+
*
|
|
30
|
+
* When no JSX-bearing foreign extensions are present, the returned plugin is a
|
|
31
|
+
* no-op so integrations can register it unconditionally.
|
|
32
|
+
*/
|
|
33
|
+
export declare function createForeignJsxOverridePlugin(options: ForeignJsxOverrideOptions): EcoBuildPlugin;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { readFileSync } from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
function createForeignJsxOverridePlugin(options) {
|
|
4
|
+
const extensions = options.foreignExtensions.filter((ext) => ext.endsWith(".tsx") || ext.endsWith(".jsx"));
|
|
5
|
+
const excludedExtensions = (options.excludeExtensions ?? []).filter(
|
|
6
|
+
(ext) => ext.endsWith(".tsx") || ext.endsWith(".jsx")
|
|
7
|
+
);
|
|
8
|
+
if (extensions.length === 0) {
|
|
9
|
+
return {
|
|
10
|
+
name: options.name ?? "foreign-jsx-override",
|
|
11
|
+
setup() {
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
const pragma = `/** @jsxImportSource ${options.hostJsxImportSource} */
|
|
16
|
+
`;
|
|
17
|
+
const filter = new RegExp(`(${extensions.map((e) => e.replace(".", "\\.")).join("|")})$`);
|
|
18
|
+
return {
|
|
19
|
+
name: options.name ?? "foreign-jsx-override",
|
|
20
|
+
setup(build) {
|
|
21
|
+
build.onLoad({ filter }, (args) => {
|
|
22
|
+
if (excludedExtensions.some((extension) => args.path.endsWith(extension))) {
|
|
23
|
+
return void 0;
|
|
24
|
+
}
|
|
25
|
+
const source = readFileSync(args.path, "utf-8");
|
|
26
|
+
const loader = args.path.endsWith(".jsx") ? "jsx" : "tsx";
|
|
27
|
+
if (source.includes("@jsxImportSource")) {
|
|
28
|
+
return void 0;
|
|
29
|
+
}
|
|
30
|
+
return {
|
|
31
|
+
contents: pragma + source,
|
|
32
|
+
loader,
|
|
33
|
+
resolveDir: path.dirname(args.path)
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
export {
|
|
40
|
+
createForeignJsxOverridePlugin
|
|
41
|
+
};
|
|
@@ -1,14 +1,36 @@
|
|
|
1
|
-
import type { EcoBuildPlugin } from '../build/build-types';
|
|
2
|
-
import type { EcoPagesAppConfig, IHmrManager } from '../internal-types';
|
|
3
|
-
import type { HmrStrategy } from '../hmr/hmr-strategy';
|
|
4
|
-
import type {
|
|
5
|
-
import type { IntegrationRenderer } from '../route-renderer/integration-renderer';
|
|
6
|
-
import { AssetProcessingService } from '../services/asset-processing-service/asset-processing.service';
|
|
7
|
-
import type { AssetDefinition, ProcessedAsset } from '../services/asset-processing-service/assets.types';
|
|
1
|
+
import type { EcoBuildPlugin } from '../build/build-types.js';
|
|
2
|
+
import type { EcoPagesAppConfig, IHmrManager } from '../types/internal-types.js';
|
|
3
|
+
import type { HmrStrategy } from '../hmr/hmr-strategy.js';
|
|
4
|
+
import type { EcoPagesElement } from '../types/public-types.js';
|
|
5
|
+
import type { IntegrationRenderer } from '../route-renderer/orchestration/integration-renderer.js';
|
|
6
|
+
import { AssetProcessingService } from '../services/assets/asset-processing-service/asset-processing.service.js';
|
|
7
|
+
import type { AssetDefinition, ProcessedAsset } from '../services/assets/asset-processing-service/assets.types.js';
|
|
8
|
+
import type { RuntimeCapabilityDeclaration } from './runtime-capability.js';
|
|
9
|
+
export type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from './runtime-capability.js';
|
|
10
|
+
export type { EcoBuildLoader, EcoBuildOnLoadArgs, EcoBuildOnLoadResult, EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin, EcoBuildPluginBuilder, } from '../build/build-types.js';
|
|
11
|
+
export type { PageBrowserGraphContribution, PageBrowserGraphContributionContext } from '../types/public-types.js';
|
|
12
|
+
export type { HtmlDocumentContribution, HtmlDocumentContributionContext, } from '../route-renderer/orchestration/integration-renderer.js';
|
|
13
|
+
/**
|
|
14
|
+
* Type-erased integration plugin stored in app-level registries.
|
|
15
|
+
*
|
|
16
|
+
* Ecopages keeps one heterogeneous integration list, while each plugin and
|
|
17
|
+
* renderer still owns its framework-specific render payload type internally.
|
|
18
|
+
*/
|
|
19
|
+
export type AnyIntegrationPlugin = IntegrationPlugin<unknown>;
|
|
8
20
|
export declare const INTEGRATION_PLUGIN_ERRORS: {
|
|
9
21
|
readonly NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config";
|
|
10
22
|
readonly NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service";
|
|
11
23
|
};
|
|
24
|
+
export declare function mergeIntegrationOptions<TDefaults, TOverrides>(defaults: TDefaults, overrides: TOverrides): TDefaults & TOverrides;
|
|
25
|
+
export declare function assertIntegrationInvariant(condition: boolean, message?: string): asserts condition;
|
|
26
|
+
/**
|
|
27
|
+
* Base configuration shared by all integration plugins.
|
|
28
|
+
*
|
|
29
|
+
* @remarks
|
|
30
|
+
* Integrations declare their file ownership, optional runtime requirements, and
|
|
31
|
+
* any global assets or build-time contributions here. Runtime-only side effects
|
|
32
|
+
* belong in `setup()` rather than the constructor.
|
|
33
|
+
*/
|
|
12
34
|
export interface IntegrationPluginConfig {
|
|
13
35
|
/**
|
|
14
36
|
* The name of the integration plugin.
|
|
@@ -31,29 +53,51 @@ export interface IntegrationPluginConfig {
|
|
|
31
53
|
* @default 'render'
|
|
32
54
|
*/
|
|
33
55
|
staticBuildStep?: 'render' | 'fetch';
|
|
56
|
+
/**
|
|
57
|
+
* Declares runtime-specific requirements that must be satisfied before the
|
|
58
|
+
* app can start with this integration enabled.
|
|
59
|
+
*/
|
|
60
|
+
runtimeCapability?: RuntimeCapabilityDeclaration;
|
|
61
|
+
/**
|
|
62
|
+
* JSX import source owned by this integration.
|
|
63
|
+
*
|
|
64
|
+
* @remarks
|
|
65
|
+
* This is primarily used by mixed-JSX flows where host-owned browser bundles
|
|
66
|
+
* need to preserve the correct JSX runtime for files claimed by the
|
|
67
|
+
* integration.
|
|
68
|
+
*/
|
|
69
|
+
jsxImportSource?: string;
|
|
34
70
|
}
|
|
35
|
-
/**
|
|
36
|
-
* Metadata used by integration-owned boundary policy.
|
|
37
|
-
*
|
|
38
|
-
* This payload describes the currently active integration pass together with the
|
|
39
|
-
* target component boundary being entered.
|
|
40
|
-
*/
|
|
41
|
-
export type ComponentBoundaryPolicyInput = {
|
|
42
|
-
currentIntegration: string;
|
|
43
|
-
targetIntegration?: string;
|
|
44
|
-
component: EcoComponent;
|
|
45
|
-
};
|
|
46
71
|
type RendererClass<C> = new (options: {
|
|
47
72
|
appConfig: EcoPagesAppConfig;
|
|
48
73
|
assetProcessingService: AssetProcessingService;
|
|
49
74
|
resolvedIntegrationDependencies: ProcessedAsset[];
|
|
75
|
+
rendererModules?: unknown;
|
|
50
76
|
runtimeOrigin: string;
|
|
51
77
|
}) => IntegrationRenderer<C>;
|
|
78
|
+
/**
|
|
79
|
+
* Base class for framework integrations.
|
|
80
|
+
*
|
|
81
|
+
* @remarks
|
|
82
|
+
* An integration owns three main concerns:
|
|
83
|
+
* - which file extensions it claims
|
|
84
|
+
* - which renderer class turns those files into HTML
|
|
85
|
+
* - which build-time or runtime contributions must be registered for that framework
|
|
86
|
+
*
|
|
87
|
+
* Core owns lifecycle ordering. Integrations declare contributions through the
|
|
88
|
+
* hooks on this class, while `ConfigBuilder.build()` and app startup decide when
|
|
89
|
+
* those hooks run. For page-browser and document shaping, integrations should
|
|
90
|
+
* prefer the contribution contracts re-exported from this module:
|
|
91
|
+
* `PageBrowserGraphContribution` / `PageBrowserGraphContributionContext` and
|
|
92
|
+
* `HtmlDocumentContribution` / `HtmlDocumentContributionContext`.
|
|
93
|
+
*/
|
|
52
94
|
export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
|
|
53
95
|
readonly name: string;
|
|
54
96
|
readonly extensions: string[];
|
|
55
97
|
abstract renderer: RendererClass<C>;
|
|
56
98
|
readonly staticBuildStep: 'render' | 'fetch';
|
|
99
|
+
readonly runtimeCapability?: RuntimeCapabilityDeclaration;
|
|
100
|
+
readonly jsxImportSource?: string;
|
|
57
101
|
protected integrationDependencies: AssetDefinition[];
|
|
58
102
|
protected resolvedIntegrationDependencies: ProcessedAsset[];
|
|
59
103
|
protected options?: Record<string, unknown>;
|
|
@@ -62,8 +106,33 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
|
|
|
62
106
|
protected hmrManager?: IHmrManager;
|
|
63
107
|
runtimeOrigin: string;
|
|
64
108
|
get plugins(): EcoBuildPlugin[];
|
|
109
|
+
/**
|
|
110
|
+
* Returns build plugins that should only apply to browser-oriented bundles.
|
|
111
|
+
*
|
|
112
|
+
* @remarks
|
|
113
|
+
* Browser-only transforms such as runtime import aliasing belong here so they
|
|
114
|
+
* do not affect server bundles or static-page module generation.
|
|
115
|
+
*/
|
|
116
|
+
get browserBuildPlugins(): EcoBuildPlugin[];
|
|
117
|
+
/**
|
|
118
|
+
* Creates the integration with static declaration-only configuration.
|
|
119
|
+
*
|
|
120
|
+
* @remarks
|
|
121
|
+
* Constructors are expected to stay side-effect free. Build-manifest
|
|
122
|
+
* contributions belong in `prepareBuildContributions()` and runtime-only setup
|
|
123
|
+
* belongs in `setup()`.
|
|
124
|
+
*/
|
|
65
125
|
constructor(config: IntegrationPluginConfig);
|
|
126
|
+
/**
|
|
127
|
+
* Attaches the finalized app config to the integration.
|
|
128
|
+
*
|
|
129
|
+
* Core calls this during config finalization before runtime setup so the
|
|
130
|
+
* integration can resolve asset paths and other app-owned services later.
|
|
131
|
+
*/
|
|
66
132
|
setConfig(appConfig: EcoPagesAppConfig): void;
|
|
133
|
+
/**
|
|
134
|
+
* Records the runtime origin used for page-module loading and renderer setup.
|
|
135
|
+
*/
|
|
67
136
|
setRuntimeOrigin(runtimeOrigin: string): void;
|
|
68
137
|
/**
|
|
69
138
|
* Returns an HMR strategy for this integration, if applicable.
|
|
@@ -75,28 +144,77 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
|
|
|
75
144
|
* ```typescript
|
|
76
145
|
* getHmrStrategy(): HmrStrategy {
|
|
77
146
|
* const context = this.hmrManager!.getDefaultContext();
|
|
78
|
-
* return new ReactHmrStrategy(context);
|
|
147
|
+
* return new ReactHmrStrategy({ context, pageMetadataCache, runtimeAliasMap });
|
|
79
148
|
* }
|
|
80
149
|
* ```
|
|
81
150
|
*/
|
|
82
151
|
getHmrStrategy?(): HmrStrategy | undefined;
|
|
152
|
+
/**
|
|
153
|
+
* Attaches the shared HMR manager and registers integration-owned development hooks.
|
|
154
|
+
*
|
|
155
|
+
* @remarks
|
|
156
|
+
* The default implementation registers the optional integration HMR strategy.
|
|
157
|
+
* Integrations should override this only when they need to extend that shared
|
|
158
|
+
* behavior rather than replace it.
|
|
159
|
+
*/
|
|
83
160
|
setHmrManager(hmrManager: IHmrManager): void;
|
|
161
|
+
/**
|
|
162
|
+
* Creates the asset-processing service used for global integration dependencies.
|
|
163
|
+
*/
|
|
84
164
|
initializeAssetDefinitionService(): void;
|
|
165
|
+
/**
|
|
166
|
+
* Returns processed global assets resolved during `setup()`.
|
|
167
|
+
*/
|
|
85
168
|
getResolvedIntegrationDependencies(): ProcessedAsset[];
|
|
86
|
-
initializeRenderer(): IntegrationRenderer<C>;
|
|
87
169
|
/**
|
|
88
|
-
*
|
|
89
|
-
|
|
170
|
+
* Creates the shared renderer options owned by core lifecycle setup.
|
|
171
|
+
*/
|
|
172
|
+
protected createRendererOptions(options?: {
|
|
173
|
+
rendererModules?: unknown;
|
|
174
|
+
}): {
|
|
175
|
+
appConfig: EcoPagesAppConfig;
|
|
176
|
+
assetProcessingService: AssetProcessingService;
|
|
177
|
+
resolvedIntegrationDependencies: ProcessedAsset[];
|
|
178
|
+
rendererModules: unknown;
|
|
179
|
+
runtimeOrigin: string;
|
|
180
|
+
};
|
|
181
|
+
/**
|
|
182
|
+
* Attaches runtime-only services after a renderer instance has been created.
|
|
183
|
+
*/
|
|
184
|
+
protected attachRendererRuntimeServices<T extends IntegrationRenderer<C>>(renderer: T): T;
|
|
185
|
+
/**
|
|
186
|
+
* Instantiates the integration renderer with app-owned services.
|
|
90
187
|
*
|
|
91
|
-
*
|
|
92
|
-
*
|
|
93
|
-
*
|
|
188
|
+
* @remarks
|
|
189
|
+
* Renderers are cheap runtime objects. They receive the finalized app config,
|
|
190
|
+
* a fresh asset-processing service, integration-global processed assets, and
|
|
191
|
+
* any renderer module context supplied by the active runtime.
|
|
192
|
+
renderer.name ||= this.name;
|
|
193
|
+
*/
|
|
194
|
+
initializeRenderer(options?: {
|
|
195
|
+
rendererModules?: unknown;
|
|
196
|
+
}): IntegrationRenderer<C>;
|
|
197
|
+
/**
|
|
198
|
+
* Prepares build-facing contributions before the app build manifest is sealed.
|
|
94
199
|
*
|
|
95
|
-
* @
|
|
96
|
-
*
|
|
200
|
+
* @remarks
|
|
201
|
+
* Integrations can override this when runtime or build plugin declarations must
|
|
202
|
+
* be materialized ahead of runtime startup. Runtime-only side effects stay in
|
|
203
|
+
* `setup()`.
|
|
204
|
+
*/
|
|
205
|
+
prepareBuildContributions(): Promise<void>;
|
|
206
|
+
/**
|
|
207
|
+
* Performs runtime-only integration setup after config build has already
|
|
208
|
+
* sealed manifest contributions.
|
|
97
209
|
*/
|
|
98
|
-
shouldDeferComponentBoundary(_input: ComponentBoundaryPolicyInput): boolean;
|
|
99
210
|
setup(): Promise<void>;
|
|
211
|
+
/**
|
|
212
|
+
* Releases runtime resources owned by the integration.
|
|
213
|
+
*
|
|
214
|
+
* @remarks
|
|
215
|
+
* Most integrations do not need custom teardown. Override this only for
|
|
216
|
+
* explicit cleanup such as watchers, compiler handles, or runtime registries
|
|
217
|
+
* that outlive individual requests.
|
|
218
|
+
*/
|
|
100
219
|
teardown(): Promise<void>;
|
|
101
220
|
}
|
|
102
|
-
export {};
|
|
@@ -1,12 +1,22 @@
|
|
|
1
|
-
import { AssetProcessingService } from "../services/asset-processing-service/asset-processing.service";
|
|
1
|
+
import { AssetProcessingService } from "../services/assets/asset-processing-service/asset-processing.service.js";
|
|
2
|
+
import { deepMerge } from "../utils/deep-merge.js";
|
|
3
|
+
import { invariant } from "../utils/invariant.js";
|
|
2
4
|
const INTEGRATION_PLUGIN_ERRORS = {
|
|
3
5
|
NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config",
|
|
4
6
|
NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service"
|
|
5
7
|
};
|
|
8
|
+
function mergeIntegrationOptions(defaults, overrides) {
|
|
9
|
+
return deepMerge(defaults, overrides);
|
|
10
|
+
}
|
|
11
|
+
function assertIntegrationInvariant(condition, message) {
|
|
12
|
+
invariant(condition, message);
|
|
13
|
+
}
|
|
6
14
|
class IntegrationPlugin {
|
|
7
15
|
name;
|
|
8
16
|
extensions;
|
|
9
17
|
staticBuildStep;
|
|
18
|
+
runtimeCapability;
|
|
19
|
+
jsxImportSource;
|
|
10
20
|
integrationDependencies;
|
|
11
21
|
resolvedIntegrationDependencies = [];
|
|
12
22
|
options;
|
|
@@ -16,19 +26,56 @@ class IntegrationPlugin {
|
|
|
16
26
|
get plugins() {
|
|
17
27
|
return [];
|
|
18
28
|
}
|
|
29
|
+
/**
|
|
30
|
+
* Returns build plugins that should only apply to browser-oriented bundles.
|
|
31
|
+
*
|
|
32
|
+
* @remarks
|
|
33
|
+
* Browser-only transforms such as runtime import aliasing belong here so they
|
|
34
|
+
* do not affect server bundles or static-page module generation.
|
|
35
|
+
*/
|
|
36
|
+
get browserBuildPlugins() {
|
|
37
|
+
return [];
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Creates the integration with static declaration-only configuration.
|
|
41
|
+
*
|
|
42
|
+
* @remarks
|
|
43
|
+
* Constructors are expected to stay side-effect free. Build-manifest
|
|
44
|
+
* contributions belong in `prepareBuildContributions()` and runtime-only setup
|
|
45
|
+
* belongs in `setup()`.
|
|
46
|
+
*/
|
|
19
47
|
constructor(config) {
|
|
20
48
|
this.name = config.name;
|
|
21
49
|
this.extensions = config.extensions;
|
|
22
50
|
this.integrationDependencies = config.integrationDependencies || [];
|
|
23
51
|
this.staticBuildStep = config.staticBuildStep || "render";
|
|
52
|
+
this.runtimeCapability = config.runtimeCapability;
|
|
53
|
+
this.jsxImportSource = config.jsxImportSource;
|
|
24
54
|
}
|
|
55
|
+
/**
|
|
56
|
+
* Attaches the finalized app config to the integration.
|
|
57
|
+
*
|
|
58
|
+
* Core calls this during config finalization before runtime setup so the
|
|
59
|
+
* integration can resolve asset paths and other app-owned services later.
|
|
60
|
+
*/
|
|
25
61
|
setConfig(appConfig) {
|
|
26
62
|
this.appConfig = appConfig;
|
|
27
63
|
this.initializeAssetDefinitionService();
|
|
28
64
|
}
|
|
65
|
+
/**
|
|
66
|
+
* Records the runtime origin used for page-module loading and renderer setup.
|
|
67
|
+
*/
|
|
29
68
|
setRuntimeOrigin(runtimeOrigin) {
|
|
30
69
|
this.runtimeOrigin = runtimeOrigin;
|
|
31
70
|
}
|
|
71
|
+
/**
|
|
72
|
+
* Attaches the shared HMR manager and registers integration-owned development hooks.
|
|
73
|
+
*
|
|
74
|
+
* @remarks
|
|
75
|
+
* The default implementation registers the optional integration HMR strategy.
|
|
76
|
+
* Integrations should override this only when they need to extend that shared
|
|
77
|
+
* behavior rather than replace it.
|
|
78
|
+
*/
|
|
32
79
|
setHmrManager(hmrManager) {
|
|
33
80
|
this.hmrManager = hmrManager;
|
|
34
81
|
const strategy = this.getHmrStrategy?.();
|
|
@@ -39,6 +86,9 @@ class IntegrationPlugin {
|
|
|
39
86
|
this.assetProcessingService.setHmrManager(hmrManager);
|
|
40
87
|
}
|
|
41
88
|
}
|
|
89
|
+
/**
|
|
90
|
+
* Creates the asset-processing service used for global integration dependencies.
|
|
91
|
+
*/
|
|
42
92
|
initializeAssetDefinitionService() {
|
|
43
93
|
if (!this.appConfig) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
|
|
44
94
|
this.assetProcessingService = AssetProcessingService.createWithDefaultProcessors(this.appConfig);
|
|
@@ -46,10 +96,16 @@ class IntegrationPlugin {
|
|
|
46
96
|
this.assetProcessingService.setHmrManager(this.hmrManager);
|
|
47
97
|
}
|
|
48
98
|
}
|
|
99
|
+
/**
|
|
100
|
+
* Returns processed global assets resolved during `setup()`.
|
|
101
|
+
*/
|
|
49
102
|
getResolvedIntegrationDependencies() {
|
|
50
103
|
return this.resolvedIntegrationDependencies;
|
|
51
104
|
}
|
|
52
|
-
|
|
105
|
+
/**
|
|
106
|
+
* Creates the shared renderer options owned by core lifecycle setup.
|
|
107
|
+
*/
|
|
108
|
+
createRendererOptions(options) {
|
|
53
109
|
if (!this.appConfig) {
|
|
54
110
|
throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
|
|
55
111
|
}
|
|
@@ -57,31 +113,54 @@ class IntegrationPlugin {
|
|
|
57
113
|
if (this.hmrManager) {
|
|
58
114
|
assetProcessingService.setHmrManager(this.hmrManager);
|
|
59
115
|
}
|
|
60
|
-
|
|
116
|
+
return {
|
|
61
117
|
appConfig: this.appConfig,
|
|
62
118
|
assetProcessingService,
|
|
63
119
|
resolvedIntegrationDependencies: this.resolvedIntegrationDependencies,
|
|
120
|
+
rendererModules: options?.rendererModules,
|
|
64
121
|
runtimeOrigin: this.runtimeOrigin
|
|
65
|
-
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Attaches runtime-only services after a renderer instance has been created.
|
|
126
|
+
*/
|
|
127
|
+
attachRendererRuntimeServices(renderer) {
|
|
128
|
+
if (typeof renderer.name !== "string" || renderer.name.length === 0) {
|
|
129
|
+
renderer.name = this.name;
|
|
130
|
+
}
|
|
66
131
|
if (this.hmrManager) {
|
|
67
132
|
renderer.setHmrManager(this.hmrManager);
|
|
68
133
|
}
|
|
69
134
|
return renderer;
|
|
70
135
|
}
|
|
71
136
|
/**
|
|
72
|
-
*
|
|
73
|
-
* deferred through the marker pipeline.
|
|
137
|
+
* Instantiates the integration renderer with app-owned services.
|
|
74
138
|
*
|
|
75
|
-
*
|
|
76
|
-
*
|
|
77
|
-
*
|
|
139
|
+
* @remarks
|
|
140
|
+
* Renderers are cheap runtime objects. They receive the finalized app config,
|
|
141
|
+
* a fresh asset-processing service, integration-global processed assets, and
|
|
142
|
+
* any renderer module context supplied by the active runtime.
|
|
143
|
+
renderer.name ||= this.name;
|
|
144
|
+
*/
|
|
145
|
+
initializeRenderer(options) {
|
|
146
|
+
const renderer = new this.renderer(this.createRendererOptions(options));
|
|
147
|
+
renderer.name ||= this.name;
|
|
148
|
+
return this.attachRendererRuntimeServices(renderer);
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Prepares build-facing contributions before the app build manifest is sealed.
|
|
78
152
|
*
|
|
79
|
-
* @
|
|
80
|
-
*
|
|
153
|
+
* @remarks
|
|
154
|
+
* Integrations can override this when runtime or build plugin declarations must
|
|
155
|
+
* be materialized ahead of runtime startup. Runtime-only side effects stay in
|
|
156
|
+
* `setup()`.
|
|
81
157
|
*/
|
|
82
|
-
|
|
83
|
-
return false;
|
|
158
|
+
async prepareBuildContributions() {
|
|
84
159
|
}
|
|
160
|
+
/**
|
|
161
|
+
* Performs runtime-only integration setup after config build has already
|
|
162
|
+
* sealed manifest contributions.
|
|
163
|
+
*/
|
|
85
164
|
async setup() {
|
|
86
165
|
if (this.integrationDependencies.length === 0) return;
|
|
87
166
|
if (!this.assetProcessingService) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_ASSET_SERVICE);
|
|
@@ -91,10 +170,20 @@ class IntegrationPlugin {
|
|
|
91
170
|
);
|
|
92
171
|
this.initializeRenderer();
|
|
93
172
|
}
|
|
173
|
+
/**
|
|
174
|
+
* Releases runtime resources owned by the integration.
|
|
175
|
+
*
|
|
176
|
+
* @remarks
|
|
177
|
+
* Most integrations do not need custom teardown. Override this only for
|
|
178
|
+
* explicit cleanup such as watchers, compiler handles, or runtime registries
|
|
179
|
+
* that outlive individual requests.
|
|
180
|
+
*/
|
|
94
181
|
async teardown() {
|
|
95
182
|
}
|
|
96
183
|
}
|
|
97
184
|
export {
|
|
98
185
|
INTEGRATION_PLUGIN_ERRORS,
|
|
99
|
-
IntegrationPlugin
|
|
186
|
+
IntegrationPlugin,
|
|
187
|
+
assertIntegrationInvariant,
|
|
188
|
+
mergeIntegrationOptions
|
|
100
189
|
};
|
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
import type { EcoBuildPlugin } from '../build/build-types.js';
|
|
2
|
-
import type { EcoPagesAppConfig, IClientBridge } from '../internal-types';
|
|
3
|
-
import type { AssetDefinition } from '../services/asset-processing-service';
|
|
2
|
+
import type { EcoPagesAppConfig, IClientBridge } from '../types/internal-types.js';
|
|
3
|
+
import type { AssetDefinition } from '../services/assets/asset-processing-service/assets.types.js';
|
|
4
|
+
import type { RuntimeCapabilityDeclaration } from './runtime-capability.js';
|
|
5
|
+
export type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from './runtime-capability.js';
|
|
6
|
+
export type { EcoBuildLoader, EcoBuildOnLoadArgs, EcoBuildOnLoadResult, EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin, EcoBuildPluginBuilder, } from '../build/build-types.js';
|
|
4
7
|
export declare const PROCESSOR_ERRORS: {
|
|
5
8
|
readonly CACHE_DIRECTORY_NOT_SET: "Cache directory not set in context";
|
|
6
9
|
};
|
|
10
|
+
export declare function mergeProcessorOptions<TDefaults, TOverrides>(defaults: TDefaults, overrides: TOverrides): TDefaults & TOverrides;
|
|
7
11
|
export interface ProcessorWatchContext {
|
|
8
12
|
path: string;
|
|
9
13
|
bridge: IClientBridge;
|
|
@@ -38,6 +42,7 @@ export interface ProcessorConfig<TOptions = Record<string, unknown>> {
|
|
|
38
42
|
options?: TOptions;
|
|
39
43
|
watch?: ProcessorWatchConfig;
|
|
40
44
|
capabilities?: ProcessorAssetCapability[];
|
|
45
|
+
runtimeCapability?: RuntimeCapabilityDeclaration;
|
|
41
46
|
}
|
|
42
47
|
export interface ProcessorContext {
|
|
43
48
|
config: EcoPagesAppConfig;
|
|
@@ -59,12 +64,22 @@ export declare abstract class Processor<TOptions = Record<string, unknown>> {
|
|
|
59
64
|
protected options?: TOptions;
|
|
60
65
|
protected watchConfig?: ProcessorWatchConfig;
|
|
61
66
|
protected capabilities: ProcessorAssetCapability[];
|
|
67
|
+
readonly runtimeCapability?: RuntimeCapabilityDeclaration;
|
|
62
68
|
/** Plugins that are only used during the build process */
|
|
63
69
|
abstract buildPlugins?: EcoBuildPlugin[];
|
|
64
70
|
/** Plugins that are used during runtime for file processing */
|
|
65
71
|
abstract plugins?: EcoBuildPlugin[];
|
|
66
72
|
constructor(config: ProcessorConfig<TOptions>);
|
|
67
73
|
setContext(appConfig: EcoPagesAppConfig): void;
|
|
74
|
+
/**
|
|
75
|
+
* Prepares build-facing processor contributions before config finalization.
|
|
76
|
+
*
|
|
77
|
+
* @remarks
|
|
78
|
+
* Override this when a processor must compute runtime/build plugins or other
|
|
79
|
+
* manifest-owned state before startup. Runtime-only work such as cache
|
|
80
|
+
* warming or watcher registration should stay in `setup()`.
|
|
81
|
+
*/
|
|
82
|
+
prepareBuildContributions(): Promise<void>;
|
|
68
83
|
abstract setup(): Promise<void>;
|
|
69
84
|
abstract teardown(): Promise<void>;
|
|
70
85
|
abstract process(input: unknown, filePath?: string): Promise<unknown>;
|