@ecopages/core 0.2.0-alpha.4 → 0.2.0-alpha.6
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 +213 -12
- package/package.json +100 -188
- package/src/adapters/README.md +39 -0
- package/src/adapters/bun/hmr-manager.test.ts +267 -0
- package/src/adapters/bun/hmr-manager.ts +181 -68
- package/src/adapters/bun/index.ts +1 -2
- package/src/adapters/bun/server-adapter.ts +41 -34
- package/src/adapters/bun/server-lifecycle.ts +40 -70
- package/src/adapters/index.ts +1 -1
- package/src/adapters/node/bootstrap-dependency-resolver.test.ts +282 -0
- package/src/adapters/node/bootstrap-dependency-resolver.ts +301 -0
- package/src/adapters/node/index.ts +7 -0
- package/src/adapters/node/node-client-bridge.test.ts +198 -0
- package/src/adapters/node/node-hmr-manager.test.ts +322 -0
- package/src/adapters/node/node-hmr-manager.ts +208 -116
- package/src/adapters/node/runtime-adapter.test.ts +868 -0
- package/src/adapters/node/runtime-adapter.ts +439 -0
- package/src/adapters/node/server-adapter.ts +31 -104
- package/src/adapters/node/static-content-server.test.ts +60 -0
- package/src/adapters/node/static-content-server.ts +36 -0
- package/src/adapters/node/write-runtime-manifest.ts +38 -0
- package/src/adapters/shared/api-response.test.ts +97 -0
- package/src/{define-api-handler.ts → adapters/shared/define-api-handler.ts} +1 -1
- package/src/adapters/shared/explicit-static-route-matcher.test.ts +381 -0
- package/src/adapters/shared/explicit-static-route-matcher.ts +7 -1
- package/src/adapters/shared/file-route-middleware-pipeline.test.ts +90 -0
- package/src/adapters/shared/file-route-middleware-pipeline.ts +6 -2
- package/src/adapters/shared/fs-server-response-factory.test.ts +187 -0
- package/src/adapters/shared/fs-server-response-matcher.test.ts +286 -0
- package/src/adapters/shared/fs-server-response-matcher.ts +17 -10
- package/src/adapters/shared/hmr-entrypoint-registrar.ts +149 -0
- package/src/adapters/shared/hmr-html-response.ts +52 -0
- package/src/adapters/shared/hmr-manager.contract.test.ts +196 -0
- package/src/adapters/shared/hmr-manager.dispatch.test.ts +220 -0
- package/src/adapters/shared/render-context.test.ts +146 -0
- package/src/adapters/shared/render-context.ts +21 -6
- package/src/adapters/shared/runtime-bootstrap.ts +79 -0
- package/src/adapters/shared/server-adapter.test.ts +77 -0
- package/src/adapters/shared/server-adapter.ts +51 -4
- package/src/adapters/shared/server-route-handler.test.ts +110 -0
- package/src/adapters/shared/server-route-handler.ts +5 -18
- package/src/adapters/shared/server-static-builder.test.ts +316 -0
- package/src/adapters/shared/server-static-builder.ts +92 -8
- package/src/build/README.md +101 -0
- package/src/build/build-adapter-serialization.test.ts +268 -0
- package/src/build/build-adapter.test.ts +815 -0
- package/src/build/build-adapter.ts +235 -6
- package/src/build/build-manifest.ts +54 -0
- package/src/build/dev-build-coordinator.ts +221 -0
- package/src/build/esbuild-build-adapter.ts +132 -83
- package/src/build/runtime-build-executor.ts +34 -0
- package/src/build/runtime-specifier-alias-plugin.test.ts +43 -0
- package/src/build/runtime-specifier-alias-plugin.ts +58 -0
- package/src/config/README.md +33 -0
- package/src/config/config-builder.test.ts +410 -0
- package/src/config/config-builder.ts +281 -49
- package/src/constants.ts +15 -0
- package/src/declarations.d.ts +18 -13
- package/src/eco/README.md +70 -16
- package/src/eco/component-render-context.ts +39 -17
- package/src/eco/eco.test.ts +678 -0
- package/src/eco/eco.ts +29 -8
- package/src/eco/eco.types.ts +20 -1
- package/src/eco/eco.utils.test.ts +124 -0
- package/src/eco/global-injector-map.test.ts +42 -0
- package/src/eco/lazy-injector-map.test.ts +66 -0
- package/src/eco/module-dependencies.test.ts +30 -0
- package/src/errors/http-error.test.ts +134 -0
- package/src/global/utils.test.ts +12 -0
- package/src/hmr/README.md +26 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/client/hmr-runtime.ts +38 -7
- package/src/hmr/hmr-strategy.test.ts +124 -0
- package/src/hmr/hmr.postcss.test.e2e.ts +41 -0
- package/src/hmr/hmr.test.e2e.ts +29 -38
- package/src/hmr/strategies/js-hmr-strategy.test.ts +335 -0
- package/src/hmr/strategies/js-hmr-strategy.ts +115 -115
- package/src/index.ts +1 -1
- package/src/integrations/ghtml/ghtml-renderer.test.ts +63 -0
- package/src/integrations/ghtml/ghtml-renderer.ts +4 -1
- package/src/internal-types.ts +39 -19
- package/src/plugins/README.md +34 -0
- package/src/plugins/alias-resolver-plugin.test.ts +41 -0
- package/src/plugins/alias-resolver-plugin.ts +21 -3
- package/src/plugins/eco-component-meta-plugin.test.ts +380 -0
- package/src/plugins/eco-component-meta-plugin.ts +10 -3
- package/src/plugins/integration-plugin.test.ts +111 -0
- package/src/plugins/integration-plugin.ts +45 -3
- package/src/plugins/processor.test.ts +148 -0
- package/src/plugins/processor.ts +22 -2
- package/src/plugins/runtime-capability.ts +14 -0
- package/src/public-types.ts +73 -16
- package/src/route-renderer/GRAPH.md +16 -20
- package/src/route-renderer/README.md +8 -21
- package/src/route-renderer/component-graph/component-graph-executor.test.ts +41 -0
- package/src/route-renderer/component-graph/component-graph.test.ts +63 -0
- package/src/route-renderer/component-graph/component-marker.test.ts +73 -0
- package/src/route-renderer/component-graph/component-reference.ts +29 -0
- package/src/route-renderer/component-graph/marker-graph-resolver.test.ts +135 -0
- package/src/route-renderer/{marker-graph-resolver.ts → component-graph/marker-graph-resolver.ts} +11 -9
- package/src/route-renderer/orchestration/integration-renderer.test.ts +936 -0
- package/src/route-renderer/{integration-renderer.ts → orchestration/integration-renderer.ts} +113 -19
- package/src/route-renderer/orchestration/render-execution.service.test.ts +97 -0
- package/src/route-renderer/{render-execution.service.ts → orchestration/render-execution.service.ts} +109 -37
- package/src/route-renderer/orchestration/render-preparation.service.test.ts +235 -0
- package/src/route-renderer/{render-preparation.service.ts → orchestration/render-preparation.service.ts} +127 -9
- package/src/route-renderer/page-loading/dependency-resolver.test.ts +345 -0
- package/src/route-renderer/{dependency-resolver.ts → page-loading/dependency-resolver.ts} +28 -12
- package/src/route-renderer/page-loading/page-module-loader.test.ts +96 -0
- package/src/route-renderer/{page-module-loader.ts → page-loading/page-module-loader.ts} +49 -21
- package/src/route-renderer/route-renderer.ts +36 -1
- package/src/router/README.md +26 -0
- package/src/router/client/link-intent.d.ts +53 -0
- package/src/router/client/link-intent.test.browser.ts +51 -0
- package/src/router/client/link-intent.ts +92 -0
- package/src/router/client/navigation-coordinator.test.ts +237 -0
- package/src/router/client/navigation-coordinator.ts +433 -0
- package/src/router/server/fs-router-scanner.test.ts +83 -0
- package/src/router/{fs-router-scanner.ts → server/fs-router-scanner.ts} +12 -10
- package/src/router/server/fs-router.test.ts +214 -0
- package/src/router/{fs-router.ts → server/fs-router.ts} +2 -2
- package/src/services/README.md +29 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +385 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.ts +101 -6
- package/src/services/assets/asset-processing-service/asset.factory.test.ts +63 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.ts +2 -1
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +72 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +95 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +67 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +78 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/index.ts +2 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.ts +1 -1
- package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +59 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.ts +11 -5
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.ts +17 -27
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +286 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.ts +3 -3
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.test.ts +227 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.ts +5 -4
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +199 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.ts +4 -1
- package/src/services/assets/browser-bundle.service.test.ts +36 -0
- package/src/services/assets/browser-bundle.service.ts +53 -0
- package/src/services/cache/index.ts +3 -3
- package/src/services/cache/memory-cache-store.test.ts +225 -0
- package/src/services/cache/memory-cache-store.ts +1 -1
- package/src/services/cache/page-cache-service.test.ts +175 -0
- package/src/services/cache/page-cache-service.ts +3 -3
- package/src/services/cache/page-request-cache-coordinator.service.test.ts +79 -0
- package/src/services/{page-request-cache-coordinator.service.ts → cache/page-request-cache-coordinator.service.ts} +9 -6
- package/src/services/html/html-rewriter-provider.service.test.ts +183 -0
- package/src/services/html/html-rewriter-provider.service.ts +103 -0
- package/src/services/html/html-transformer.service.test.ts +378 -0
- package/src/services/html/html-transformer.service.ts +279 -0
- package/src/services/invalidation/development-invalidation.service.test.ts +77 -0
- package/src/services/invalidation/development-invalidation.service.ts +261 -0
- package/src/services/module-loading/app-server-module-transpiler.service.ts +52 -0
- package/src/services/module-loading/page-module-import.service.test.ts +253 -0
- package/src/services/module-loading/page-module-import.service.ts +200 -0
- package/src/services/module-loading/server-loader.service.test.ts +161 -0
- package/src/services/module-loading/server-loader.service.ts +130 -0
- package/src/services/module-loading/server-module-transpiler.service.test.ts +115 -0
- package/src/services/module-loading/server-module-transpiler.service.ts +105 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.test.ts +95 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.ts +101 -0
- package/src/services/runtime-state/dev-graph.service.ts +217 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +136 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.ts +96 -0
- package/src/services/runtime-state/server-invalidation-state.service.ts +68 -0
- package/src/services/validation/schema-validation-service.test.ts +223 -0
- package/src/services/{schema-validation-service.ts → validation/schema-validation-service.ts} +1 -1
- package/src/static-site-generator/README.md +26 -0
- package/src/static-site-generator/static-site-generator.test.ts +307 -0
- package/src/static-site-generator/static-site-generator.ts +109 -6
- package/src/utils/deep-merge.test.ts +114 -0
- package/src/utils/invariant.test.ts +22 -0
- package/src/utils/path-utils.test.ts +15 -0
- package/src/utils/resolve-work-dir.ts +45 -0
- package/src/utils/server-utils.test.ts +38 -0
- package/src/watchers/project-watcher.integration.test.ts +337 -0
- package/src/watchers/project-watcher.test-helpers.ts +1 -1
- package/src/watchers/project-watcher.test.ts +678 -0
- package/src/watchers/project-watcher.ts +130 -111
- package/CHANGELOG.md +0 -91
- package/src/adapters/abstract/application-adapter.d.ts +0 -168
- package/src/adapters/abstract/application-adapter.js +0 -109
- package/src/adapters/abstract/router-adapter.d.ts +0 -26
- package/src/adapters/abstract/router-adapter.js +0 -5
- package/src/adapters/abstract/server-adapter.d.ts +0 -69
- package/src/adapters/abstract/server-adapter.js +0 -15
- package/src/adapters/bun/client-bridge.d.ts +0 -34
- package/src/adapters/bun/client-bridge.js +0 -48
- package/src/adapters/bun/create-app.d.ts +0 -60
- package/src/adapters/bun/create-app.js +0 -117
- package/src/adapters/bun/define-api-handler.d.ts +0 -61
- package/src/adapters/bun/define-api-handler.js +0 -15
- package/src/adapters/bun/define-api-handler.ts +0 -114
- package/src/adapters/bun/hmr-manager.d.ts +0 -85
- package/src/adapters/bun/hmr-manager.js +0 -240
- package/src/adapters/bun/index.d.ts +0 -3
- package/src/adapters/bun/index.js +0 -8
- package/src/adapters/bun/server-adapter.d.ts +0 -155
- package/src/adapters/bun/server-adapter.js +0 -368
- package/src/adapters/bun/server-lifecycle.d.ts +0 -52
- package/src/adapters/bun/server-lifecycle.js +0 -120
- package/src/adapters/index.d.ts +0 -6
- package/src/adapters/index.js +0 -14
- package/src/adapters/node/create-app.d.ts +0 -21
- package/src/adapters/node/create-app.js +0 -143
- package/src/adapters/node/index.d.ts +0 -4
- package/src/adapters/node/index.js +0 -8
- package/src/adapters/node/node-client-bridge.d.ts +0 -26
- package/src/adapters/node/node-client-bridge.js +0 -66
- package/src/adapters/node/node-hmr-manager.d.ts +0 -63
- package/src/adapters/node/node-hmr-manager.js +0 -237
- package/src/adapters/node/server-adapter.d.ts +0 -190
- package/src/adapters/node/server-adapter.js +0 -420
- package/src/adapters/node/static-content-server.d.ts +0 -24
- package/src/adapters/node/static-content-server.js +0 -166
- package/src/adapters/shared/api-response.d.ts +0 -52
- package/src/adapters/shared/api-response.js +0 -96
- package/src/adapters/shared/application-adapter.d.ts +0 -18
- package/src/adapters/shared/application-adapter.js +0 -90
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +0 -38
- package/src/adapters/shared/explicit-static-route-matcher.js +0 -100
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +0 -65
- package/src/adapters/shared/file-route-middleware-pipeline.js +0 -98
- package/src/adapters/shared/fs-server-response-factory.d.ts +0 -19
- package/src/adapters/shared/fs-server-response-factory.js +0 -97
- package/src/adapters/shared/fs-server-response-matcher.d.ts +0 -71
- package/src/adapters/shared/fs-server-response-matcher.js +0 -155
- package/src/adapters/shared/render-context.d.ts +0 -14
- package/src/adapters/shared/render-context.js +0 -69
- package/src/adapters/shared/server-adapter.d.ts +0 -87
- package/src/adapters/shared/server-adapter.js +0 -353
- package/src/adapters/shared/server-route-handler.d.ts +0 -89
- package/src/adapters/shared/server-route-handler.js +0 -120
- package/src/adapters/shared/server-static-builder.d.ts +0 -38
- package/src/adapters/shared/server-static-builder.js +0 -46
- package/src/build/build-adapter.d.ts +0 -74
- package/src/build/build-adapter.js +0 -54
- package/src/build/build-types.d.ts +0 -57
- package/src/build/build-types.js +0 -0
- package/src/build/esbuild-build-adapter.d.ts +0 -69
- package/src/build/esbuild-build-adapter.js +0 -390
- package/src/config/config-builder.d.ts +0 -227
- package/src/config/config-builder.js +0 -392
- package/src/constants.d.ts +0 -32
- package/src/constants.js +0 -21
- package/src/create-app.d.ts +0 -17
- package/src/create-app.js +0 -66
- package/src/define-api-handler.d.ts +0 -25
- package/src/define-api-handler.js +0 -15
- package/src/dev/sc-server.d.ts +0 -30
- package/src/dev/sc-server.js +0 -111
- package/src/eco/component-render-context.d.ts +0 -105
- package/src/eco/component-render-context.js +0 -77
- package/src/eco/eco.d.ts +0 -9
- package/src/eco/eco.js +0 -110
- package/src/eco/eco.types.d.ts +0 -170
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.utils.d.ts +0 -40
- package/src/eco/eco.utils.js +0 -40
- package/src/eco/global-injector-map.d.ts +0 -16
- package/src/eco/global-injector-map.js +0 -80
- package/src/eco/lazy-injector-map.d.ts +0 -8
- package/src/eco/lazy-injector-map.js +0 -70
- package/src/eco/module-dependencies.d.ts +0 -18
- package/src/eco/module-dependencies.js +0 -49
- package/src/errors/http-error.d.ts +0 -31
- package/src/errors/http-error.js +0 -50
- package/src/errors/index.d.ts +0 -2
- package/src/errors/index.js +0 -4
- package/src/errors/locals-access-error.d.ts +0 -4
- package/src/errors/locals-access-error.js +0 -9
- package/src/global/app-logger.d.ts +0 -2
- package/src/global/app-logger.js +0 -6
- package/src/hmr/client/hmr-runtime.d.ts +0 -10
- package/src/hmr/client/hmr-runtime.js +0 -86
- package/src/hmr/hmr-strategy.d.ts +0 -159
- package/src/hmr/hmr-strategy.js +0 -29
- package/src/hmr/hmr.test.e2e.d.ts +0 -1
- package/src/hmr/hmr.test.e2e.js +0 -50
- package/src/hmr/strategies/default-hmr-strategy.d.ts +0 -43
- package/src/hmr/strategies/default-hmr-strategy.js +0 -34
- package/src/hmr/strategies/js-hmr-strategy.d.ts +0 -136
- package/src/hmr/strategies/js-hmr-strategy.js +0 -188
- package/src/index.browser.d.ts +0 -3
- package/src/index.browser.js +0 -4
- package/src/index.d.ts +0 -5
- package/src/index.js +0 -10
- package/src/integrations/ghtml/ghtml-renderer.d.ts +0 -15
- package/src/integrations/ghtml/ghtml-renderer.js +0 -60
- package/src/integrations/ghtml/ghtml.plugin.d.ts +0 -20
- package/src/integrations/ghtml/ghtml.plugin.js +0 -21
- package/src/internal-types.d.ts +0 -200
- package/src/internal-types.js +0 -0
- package/src/plugins/alias-resolver-plugin.d.ts +0 -2
- package/src/plugins/alias-resolver-plugin.js +0 -39
- package/src/plugins/eco-component-meta-plugin.d.ts +0 -95
- package/src/plugins/eco-component-meta-plugin.js +0 -157
- package/src/plugins/integration-plugin.d.ts +0 -102
- package/src/plugins/integration-plugin.js +0 -100
- package/src/plugins/processor.d.ts +0 -82
- package/src/plugins/processor.js +0 -122
- package/src/public-types.d.ts +0 -1098
- package/src/public-types.js +0 -0
- 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.d.ts +0 -42
- package/src/route-renderer/component-graph.js +0 -72
- package/src/route-renderer/component-marker.d.ts +0 -52
- package/src/route-renderer/component-marker.js +0 -46
- package/src/route-renderer/dependency-resolver.d.ts +0 -24
- package/src/route-renderer/dependency-resolver.js +0 -428
- 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/marker-graph-resolver.d.ts +0 -76
- package/src/route-renderer/marker-graph-resolver.js +0 -93
- package/src/route-renderer/page-module-loader.d.ts +0 -61
- package/src/route-renderer/page-module-loader.js +0 -102
- 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-preparation.service.d.ts +0 -112
- package/src/route-renderer/render-preparation.service.js +0 -243
- package/src/route-renderer/route-renderer.d.ts +0 -26
- package/src/route-renderer/route-renderer.js +0 -68
- package/src/router/fs-router-scanner.d.ts +0 -41
- package/src/router/fs-router-scanner.js +0 -155
- package/src/router/fs-router.d.ts +0 -26
- package/src/router/fs-router.js +0 -100
- package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
- package/src/services/asset-processing-service/asset-processing.service.js +0 -250
- package/src/services/asset-processing-service/asset.factory.d.ts +0 -17
- package/src/services/asset-processing-service/asset.factory.js +0 -82
- package/src/services/asset-processing-service/assets.types.d.ts +0 -88
- package/src/services/asset-processing-service/assets.types.js +0 -0
- 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/processor.interface.d.ts +0 -22
- package/src/services/asset-processing-service/processor.interface.js +0 -6
- package/src/services/asset-processing-service/processor.registry.d.ts +0 -8
- package/src/services/asset-processing-service/processor.registry.js +0 -15
- package/src/services/asset-processing-service/processors/base/base-processor.d.ts +0 -24
- package/src/services/asset-processing-service/processors/base/base-processor.js +0 -59
- 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/index.d.ts +0 -5
- package/src/services/asset-processing-service/processors/index.js +0 -5
- package/src/services/asset-processing-service/processors/script/content-script.processor.d.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/file-script.processor.d.ts +0 -8
- package/src/services/asset-processing-service/processors/script/file-script.processor.js +0 -76
- 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/stylesheet/content-stylesheet.processor.d.ts +0 -5
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +0 -9
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +0 -63
- package/src/services/cache/cache.types.d.ts +0 -107
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/index.d.ts +0 -7
- package/src/services/cache/index.js +0 -7
- package/src/services/cache/memory-cache-store.d.ts +0 -42
- package/src/services/cache/memory-cache-store.js +0 -98
- package/src/services/cache/page-cache-service.d.ts +0 -70
- package/src/services/cache/page-cache-service.js +0 -152
- 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.d.ts +0 -75
- package/src/services/page-request-cache-coordinator.service.js +0 -107
- package/src/services/schema-validation-service.d.ts +0 -122
- package/src/services/schema-validation-service.js +0 -101
- package/src/services/validation/standard-schema.types.d.ts +0 -65
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/static-site-generator/static-site-generator.d.ts +0 -57
- package/src/static-site-generator/static-site-generator.js +0 -272
- package/src/utils/css.d.ts +0 -1
- package/src/utils/css.js +0 -7
- package/src/utils/deep-merge.d.ts +0 -14
- package/src/utils/deep-merge.js +0 -32
- package/src/utils/hash.d.ts +0 -1
- package/src/utils/hash.js +0 -7
- package/src/utils/html.d.ts +0 -1
- package/src/utils/html.js +0 -4
- package/src/utils/invariant.d.ts +0 -5
- package/src/utils/invariant.js +0 -11
- package/src/utils/locals-utils.d.ts +0 -15
- package/src/utils/locals-utils.js +0 -24
- package/src/utils/parse-cli-args.d.ts +0 -24
- package/src/utils/parse-cli-args.js +0 -47
- package/src/utils/path-utils.module.d.ts +0 -5
- package/src/utils/path-utils.module.js +0 -14
- package/src/utils/runtime.d.ts +0 -11
- package/src/utils/runtime.js +0 -40
- package/src/utils/server-utils.module.d.ts +0 -19
- package/src/utils/server-utils.module.js +0 -56
- package/src/watchers/project-watcher.d.ts +0 -125
- package/src/watchers/project-watcher.js +0 -265
- package/src/watchers/project-watcher.test-helpers.d.ts +0 -4
- package/src/watchers/project-watcher.test-helpers.js +0 -52
- /package/src/route-renderer/{component-graph-executor.ts → component-graph/component-graph-executor.ts} +0 -0
- /package/src/route-renderer/{component-graph.ts → component-graph/component-graph.ts} +0 -0
- /package/src/route-renderer/{component-marker.ts → component-graph/component-marker.ts} +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/index.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.ts +0 -0
package/src/create-app.js
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { AbstractApplicationAdapter } from "./adapters/abstract/application-adapter.js";
|
|
2
|
-
import { SharedApplicationAdapter } from "./adapters/shared/application-adapter.js";
|
|
3
|
-
async function createRuntimeApp(options) {
|
|
4
|
-
const bun = globalThis.Bun;
|
|
5
|
-
if (bun) {
|
|
6
|
-
const { createApp: createBunApp } = await import("./adapters/bun/create-app.js");
|
|
7
|
-
return await createBunApp(options);
|
|
8
|
-
}
|
|
9
|
-
const { createNodeApp } = await import("./adapters/node/create-app.js");
|
|
10
|
-
return await createNodeApp(options);
|
|
11
|
-
}
|
|
12
|
-
async function createApp(options) {
|
|
13
|
-
return createRuntimeApp(options);
|
|
14
|
-
}
|
|
15
|
-
class EcopagesApp extends SharedApplicationAdapter {
|
|
16
|
-
appOptions;
|
|
17
|
-
runtimeApp = null;
|
|
18
|
-
runtimeAppPromise = null;
|
|
19
|
-
constructor(options) {
|
|
20
|
-
super(options);
|
|
21
|
-
this.appOptions = options;
|
|
22
|
-
}
|
|
23
|
-
async getRuntimeApp() {
|
|
24
|
-
if (this.runtimeApp) {
|
|
25
|
-
return this.runtimeApp;
|
|
26
|
-
}
|
|
27
|
-
if (!this.runtimeAppPromise) {
|
|
28
|
-
this.runtimeAppPromise = createRuntimeApp({
|
|
29
|
-
...this.appOptions,
|
|
30
|
-
clearOutput: false
|
|
31
|
-
}).then((app) => {
|
|
32
|
-
for (const handler of this.apiHandlers) {
|
|
33
|
-
app.add(handler);
|
|
34
|
-
}
|
|
35
|
-
for (const route of this.staticRoutes) {
|
|
36
|
-
app.static(route.path, route.loader);
|
|
37
|
-
}
|
|
38
|
-
if (this.errorHandler) {
|
|
39
|
-
app.onError(this.errorHandler);
|
|
40
|
-
}
|
|
41
|
-
this.runtimeApp = app;
|
|
42
|
-
return app;
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
return this.runtimeAppPromise;
|
|
46
|
-
}
|
|
47
|
-
async initializeServerAdapter() {
|
|
48
|
-
return this.getRuntimeApp();
|
|
49
|
-
}
|
|
50
|
-
async start() {
|
|
51
|
-
const runtimeApp = await this.getRuntimeApp();
|
|
52
|
-
return runtimeApp.start();
|
|
53
|
-
}
|
|
54
|
-
async fetch(request) {
|
|
55
|
-
const runtimeApp = await this.getRuntimeApp();
|
|
56
|
-
const candidate = runtimeApp;
|
|
57
|
-
if (!candidate.fetch) {
|
|
58
|
-
throw new Error("The selected runtime adapter does not expose fetch()");
|
|
59
|
-
}
|
|
60
|
-
return candidate.fetch(request);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
export {
|
|
64
|
-
EcopagesApp,
|
|
65
|
-
createApp
|
|
66
|
-
};
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import type { ApiHandler, ApiHandlerContext, Middleware, RouteSchema, TypedGroupHandlerContext } from './public-types.js';
|
|
2
|
-
type UniversalContext = ApiHandlerContext<Request, unknown>;
|
|
3
|
-
type SchemaHandlerContext<TSchema extends RouteSchema | undefined, TContext extends UniversalContext> = TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext;
|
|
4
|
-
export declare function defineApiHandler<TPath extends string, TSchema extends RouteSchema | undefined = undefined, TContext extends UniversalContext = UniversalContext>(handler: Omit<ApiHandler<TPath, Request, unknown>, 'handler' | 'middleware' | 'schema'> & {
|
|
5
|
-
handler: (context: SchemaHandlerContext<TSchema, TContext>) => Promise<Response> | Response;
|
|
6
|
-
middleware?: Middleware<Request, unknown, TContext>[];
|
|
7
|
-
schema?: TSchema;
|
|
8
|
-
}): ApiHandler<TPath, Request, unknown>;
|
|
9
|
-
export interface GroupHandler<TPrefix extends string = string> {
|
|
10
|
-
prefix: TPrefix;
|
|
11
|
-
middleware?: readonly Middleware<Request, unknown, any>[];
|
|
12
|
-
routes: readonly ApiHandler<string, Request, unknown>[];
|
|
13
|
-
}
|
|
14
|
-
type GroupDefineHandler<TContext extends UniversalContext> = <const TPath extends string, TSchema extends RouteSchema | undefined = undefined>(handler: Omit<ApiHandler<TPath, Request, unknown>, 'handler' | 'middleware' | 'schema'> & {
|
|
15
|
-
path: TPath;
|
|
16
|
-
handler: (context: SchemaHandlerContext<TSchema, TContext>) => Promise<Response> | Response;
|
|
17
|
-
middleware?: Middleware<Request, unknown, TContext>[];
|
|
18
|
-
schema?: TSchema;
|
|
19
|
-
}) => ApiHandler<TPath, Request, unknown>;
|
|
20
|
-
export declare function defineGroupHandler<TPrefix extends string, TMiddleware extends readonly Middleware<Request, unknown, any>[] = [], TContext extends UniversalContext = TMiddleware extends readonly Middleware<Request, unknown, infer TGroupContext>[] ? TGroupContext : UniversalContext>(config: {
|
|
21
|
-
prefix: TPrefix;
|
|
22
|
-
middleware?: TMiddleware;
|
|
23
|
-
routes: (define: GroupDefineHandler<TContext>) => readonly ApiHandler<string, Request, unknown>[];
|
|
24
|
-
}): GroupHandler<TPrefix>;
|
|
25
|
-
export {};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
function defineApiHandler(handler) {
|
|
2
|
-
return handler;
|
|
3
|
-
}
|
|
4
|
-
function defineGroupHandler(config) {
|
|
5
|
-
const define = ((handler) => handler);
|
|
6
|
-
return {
|
|
7
|
-
prefix: config.prefix,
|
|
8
|
-
middleware: config.middleware,
|
|
9
|
-
routes: config.routes(define)
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
export {
|
|
13
|
-
defineApiHandler,
|
|
14
|
-
defineGroupHandler
|
|
15
|
-
};
|
package/src/dev/sc-server.d.ts
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import type { Server } from 'bun';
|
|
2
|
-
import type { EcoPagesAppConfig } from '../internal-types.js';
|
|
3
|
-
type StaticContentServerOptions = {
|
|
4
|
-
port?: number;
|
|
5
|
-
};
|
|
6
|
-
/**
|
|
7
|
-
* Static content server for production builds.
|
|
8
|
-
* Serves pre-built static files from the dist directory with gzip compression support.
|
|
9
|
-
*/
|
|
10
|
-
export declare class StaticContentServer {
|
|
11
|
-
server: Server<unknown> | null;
|
|
12
|
-
private appConfig;
|
|
13
|
-
private options;
|
|
14
|
-
constructor({ appConfig, options }: {
|
|
15
|
-
appConfig: EcoPagesAppConfig;
|
|
16
|
-
options?: StaticContentServerOptions;
|
|
17
|
-
});
|
|
18
|
-
private shouldServeGzip;
|
|
19
|
-
private isHtml;
|
|
20
|
-
private sendNotFoundPage;
|
|
21
|
-
private serveFromDir;
|
|
22
|
-
fetch(request: Request): Promise<Response>;
|
|
23
|
-
private startServer;
|
|
24
|
-
stop(): void;
|
|
25
|
-
static createServer({ appConfig, options, }: {
|
|
26
|
-
appConfig: EcoPagesAppConfig;
|
|
27
|
-
options?: StaticContentServerOptions;
|
|
28
|
-
}): StaticContentServer;
|
|
29
|
-
}
|
|
30
|
-
export {};
|
package/src/dev/sc-server.js
DELETED
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { extname, join } from "node:path";
|
|
2
|
-
import { STATUS_MESSAGE } from "../constants.js";
|
|
3
|
-
import { fileSystem } from "@ecopages/file-system";
|
|
4
|
-
import { ServerUtils } from "../utils/server-utils.module.js";
|
|
5
|
-
import { getRequiredBunRuntime } from "../utils/runtime.js";
|
|
6
|
-
class StaticContentServer {
|
|
7
|
-
server = null;
|
|
8
|
-
appConfig;
|
|
9
|
-
options = { port: 3e3 };
|
|
10
|
-
constructor({ appConfig, options }) {
|
|
11
|
-
this.appConfig = appConfig;
|
|
12
|
-
if (options) this.options = options;
|
|
13
|
-
this.startServer();
|
|
14
|
-
}
|
|
15
|
-
shouldServeGzip(contentType) {
|
|
16
|
-
return ["text/javascript", "text/css"].includes(contentType);
|
|
17
|
-
}
|
|
18
|
-
isHtml(contentType) {
|
|
19
|
-
return contentType === "text/html";
|
|
20
|
-
}
|
|
21
|
-
async sendNotFoundPage() {
|
|
22
|
-
const error404TemplatePath = `${this.appConfig.absolutePaths.distDir}/404.html`;
|
|
23
|
-
try {
|
|
24
|
-
fileSystem.exists(error404TemplatePath);
|
|
25
|
-
} catch {
|
|
26
|
-
return new Response(STATUS_MESSAGE[404], {
|
|
27
|
-
status: 404
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
const response = new Response(fileSystem.readFileAsBuffer(error404TemplatePath), {
|
|
31
|
-
headers: { "Content-Type": "text/html" }
|
|
32
|
-
});
|
|
33
|
-
return response;
|
|
34
|
-
}
|
|
35
|
-
async serveFromDir({ path, request }) {
|
|
36
|
-
const { absolutePaths } = this.appConfig;
|
|
37
|
-
const basePath = join(absolutePaths.distDir, path);
|
|
38
|
-
const contentType = ServerUtils.getContentType(extname(basePath));
|
|
39
|
-
const acceptsGzip = request.headers.get("Accept-Encoding")?.includes("gzip");
|
|
40
|
-
try {
|
|
41
|
-
if (acceptsGzip && this.shouldServeGzip(contentType)) {
|
|
42
|
-
const gzipPath = `${basePath}.gz`;
|
|
43
|
-
if (fileSystem.exists(gzipPath)) {
|
|
44
|
-
const file = fileSystem.readFileAsBuffer(gzipPath);
|
|
45
|
-
return new Response(file, {
|
|
46
|
-
headers: {
|
|
47
|
-
"Content-Type": contentType,
|
|
48
|
-
"Content-Encoding": "gzip",
|
|
49
|
-
Vary: "Accept-Encoding"
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
if (path.includes(".") && fileSystem.exists(basePath)) {
|
|
55
|
-
const file = fileSystem.readFileAsBuffer(basePath);
|
|
56
|
-
return new Response(file, {
|
|
57
|
-
headers: { "Content-Type": contentType }
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
const htmlCandidates = [`${basePath}.html`, `${basePath}/index.html`];
|
|
61
|
-
for (const candidate of htmlCandidates) {
|
|
62
|
-
if (fileSystem.exists(candidate)) {
|
|
63
|
-
const file = fileSystem.readFileAsBuffer(candidate);
|
|
64
|
-
return new Response(file, {
|
|
65
|
-
headers: {
|
|
66
|
-
"Content-Type": ServerUtils.getContentType(extname(candidate))
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return this.sendNotFoundPage();
|
|
72
|
-
} catch {
|
|
73
|
-
return this.sendNotFoundPage();
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
async fetch(request) {
|
|
77
|
-
let reqPath = new URL(request.url).pathname;
|
|
78
|
-
if (reqPath === "/") reqPath = "/index.html";
|
|
79
|
-
const response = this.serveFromDir({
|
|
80
|
-
path: reqPath,
|
|
81
|
-
request
|
|
82
|
-
});
|
|
83
|
-
if (response) return response;
|
|
84
|
-
return new Response(STATUS_MESSAGE[404], {
|
|
85
|
-
status: 404
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
startServer() {
|
|
89
|
-
this.server = getRequiredBunRuntime().serve({
|
|
90
|
-
fetch: this.fetch.bind(this),
|
|
91
|
-
port: this.options.port
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
stop() {
|
|
95
|
-
if (this.server) {
|
|
96
|
-
this.server.stop(true);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
static createServer({
|
|
100
|
-
appConfig,
|
|
101
|
-
options
|
|
102
|
-
}) {
|
|
103
|
-
return new StaticContentServer({
|
|
104
|
-
appConfig,
|
|
105
|
-
options
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
export {
|
|
110
|
-
StaticContentServer
|
|
111
|
-
};
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import type { EcoComponent } from '../public-types.js';
|
|
2
|
-
import type { MarkerNodeId } from '../route-renderer/component-marker.js';
|
|
3
|
-
/**
|
|
4
|
-
* Outcome returned by boundary policy during one component render pass.
|
|
5
|
-
*
|
|
6
|
-
* - `inline`: render the target component immediately in the current pass
|
|
7
|
-
* - `defer`: emit an `eco-marker` and resolve it during the marker graph phase
|
|
8
|
-
*/
|
|
9
|
-
export type BoundaryRenderMode = 'inline' | 'defer';
|
|
10
|
-
/**
|
|
11
|
-
* Input provided to boundary policy when a component boundary is reached.
|
|
12
|
-
*
|
|
13
|
-
* This keeps `eco.component()` decoupled from concrete integration/plugin
|
|
14
|
-
* objects while still giving policy enough information to decide whether the
|
|
15
|
-
* boundary should render immediately or be deferred.
|
|
16
|
-
*/
|
|
17
|
-
export type BoundaryRenderDecisionInput = {
|
|
18
|
-
currentIntegration: string;
|
|
19
|
-
targetIntegration?: string;
|
|
20
|
-
component: EcoComponent;
|
|
21
|
-
};
|
|
22
|
-
/**
|
|
23
|
-
* Narrow render-pass facade used by `eco.component()` for boundary decisions.
|
|
24
|
-
*
|
|
25
|
-
* The boundary context is intentionally small so component rendering can remain
|
|
26
|
-
* unaware of integration registries, plugin instances, or renderer lifecycles.
|
|
27
|
-
*/
|
|
28
|
-
export type ComponentRenderBoundaryContext = {
|
|
29
|
-
/**
|
|
30
|
-
* Decides whether the next component boundary should render inline or defer to
|
|
31
|
-
* the marker graph stage.
|
|
32
|
-
*
|
|
33
|
-
* @param input Boundary metadata for the current render pass.
|
|
34
|
-
* @returns Boundary rendering mode for the target component.
|
|
35
|
-
*/
|
|
36
|
-
decideBoundaryRender(input: BoundaryRenderDecisionInput): BoundaryRenderMode;
|
|
37
|
-
};
|
|
38
|
-
/**
|
|
39
|
-
* Per-render mutable state used while collecting marker graph references.
|
|
40
|
-
*
|
|
41
|
-
* Counters generate deterministic ids within one render execution.
|
|
42
|
-
*/
|
|
43
|
-
type ComponentRenderContext = {
|
|
44
|
-
currentIntegration: string;
|
|
45
|
-
boundaryContext: ComponentRenderBoundaryContext;
|
|
46
|
-
nextNodeId: number;
|
|
47
|
-
nextPropsRefId: number;
|
|
48
|
-
nextSlotRefId: number;
|
|
49
|
-
propsByRef: Record<string, Record<string, unknown>>;
|
|
50
|
-
slotChildrenByRef: Record<string, MarkerNodeId[]>;
|
|
51
|
-
};
|
|
52
|
-
/**
|
|
53
|
-
* Serializable graph context captured from one render execution.
|
|
54
|
-
*
|
|
55
|
-
* This payload is merged with explicit page-module graph context before marker
|
|
56
|
-
* resolution in the route renderer.
|
|
57
|
-
*/
|
|
58
|
-
export type ComponentGraphContext = {
|
|
59
|
-
propsByRef: Record<string, Record<string, unknown>>;
|
|
60
|
-
slotChildrenByRef: Record<string, MarkerNodeId[]>;
|
|
61
|
-
};
|
|
62
|
-
/**
|
|
63
|
-
* Returns the current component render context, if one is active.
|
|
64
|
-
*
|
|
65
|
-
* @returns Active render context or `undefined` outside render execution.
|
|
66
|
-
*/
|
|
67
|
-
export declare function getComponentRenderContext(): ComponentRenderContext | undefined;
|
|
68
|
-
/**
|
|
69
|
-
* Allocates the next marker node id in the active render context.
|
|
70
|
-
*
|
|
71
|
-
* @param context Active render context.
|
|
72
|
-
* @returns Stable marker node id for this render pass.
|
|
73
|
-
*/
|
|
74
|
-
export declare function createNodeId(context: ComponentRenderContext): MarkerNodeId;
|
|
75
|
-
/**
|
|
76
|
-
* Allocates the next props reference id in the active render context.
|
|
77
|
-
*
|
|
78
|
-
* @param context Active render context.
|
|
79
|
-
* @returns Props reference key.
|
|
80
|
-
*/
|
|
81
|
-
export declare function createPropsRef(context: ComponentRenderContext): string;
|
|
82
|
-
/**
|
|
83
|
-
* Allocates the next slot reference id in the active render context.
|
|
84
|
-
*
|
|
85
|
-
* @param context Active render context.
|
|
86
|
-
* @returns Slot reference key.
|
|
87
|
-
*/
|
|
88
|
-
export declare function createSlotRef(context: ComponentRenderContext): string;
|
|
89
|
-
/**
|
|
90
|
-
* Runs render work under a fresh component render context and returns both:
|
|
91
|
-
* - the render result value
|
|
92
|
-
* - captured graph reference maps for downstream marker resolution
|
|
93
|
-
*
|
|
94
|
-
* @param input Execution metadata for current integration and boundary policy.
|
|
95
|
-
* @param render Async render function to execute inside the context.
|
|
96
|
-
* @returns Render result and captured graph context maps.
|
|
97
|
-
*/
|
|
98
|
-
export declare function runWithComponentRenderContext<T>(input: {
|
|
99
|
-
currentIntegration: string;
|
|
100
|
-
boundaryContext: ComponentRenderBoundaryContext;
|
|
101
|
-
}, render: () => Promise<T>): Promise<{
|
|
102
|
-
value: T;
|
|
103
|
-
graphContext: ComponentGraphContext;
|
|
104
|
-
}>;
|
|
105
|
-
export {};
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
const contextStack = [];
|
|
2
|
-
let nodeContextStorage = null;
|
|
3
|
-
let nodeContextStorageLoader = null;
|
|
4
|
-
async function getContextStorage() {
|
|
5
|
-
if (nodeContextStorage) {
|
|
6
|
-
return nodeContextStorage;
|
|
7
|
-
}
|
|
8
|
-
if (nodeContextStorageLoader) {
|
|
9
|
-
return nodeContextStorageLoader;
|
|
10
|
-
}
|
|
11
|
-
nodeContextStorageLoader = import("node:async_hooks").then((module) => {
|
|
12
|
-
const storage = new module.AsyncLocalStorage();
|
|
13
|
-
nodeContextStorage = {
|
|
14
|
-
getStore: () => storage.getStore(),
|
|
15
|
-
run: (store, callback) => storage.run(store, callback)
|
|
16
|
-
};
|
|
17
|
-
return nodeContextStorage;
|
|
18
|
-
}).catch(() => {
|
|
19
|
-
nodeContextStorage = null;
|
|
20
|
-
return null;
|
|
21
|
-
}).finally(() => {
|
|
22
|
-
nodeContextStorageLoader = null;
|
|
23
|
-
});
|
|
24
|
-
return nodeContextStorageLoader;
|
|
25
|
-
}
|
|
26
|
-
function getComponentRenderContext() {
|
|
27
|
-
return nodeContextStorage?.getStore() ?? contextStack[contextStack.length - 1];
|
|
28
|
-
}
|
|
29
|
-
function createNodeId(context) {
|
|
30
|
-
context.nextNodeId += 1;
|
|
31
|
-
return `n_${context.nextNodeId}`;
|
|
32
|
-
}
|
|
33
|
-
function createPropsRef(context) {
|
|
34
|
-
context.nextPropsRefId += 1;
|
|
35
|
-
return `p_${context.nextPropsRefId}`;
|
|
36
|
-
}
|
|
37
|
-
function createSlotRef(context) {
|
|
38
|
-
context.nextSlotRefId += 1;
|
|
39
|
-
return `s_${context.nextSlotRefId}`;
|
|
40
|
-
}
|
|
41
|
-
async function runWithComponentRenderContext(input, render) {
|
|
42
|
-
const context = {
|
|
43
|
-
currentIntegration: input.currentIntegration,
|
|
44
|
-
boundaryContext: input.boundaryContext,
|
|
45
|
-
nextNodeId: 0,
|
|
46
|
-
nextPropsRefId: 0,
|
|
47
|
-
nextSlotRefId: 0,
|
|
48
|
-
propsByRef: {},
|
|
49
|
-
slotChildrenByRef: {}
|
|
50
|
-
};
|
|
51
|
-
const storage = await getContextStorage();
|
|
52
|
-
let value;
|
|
53
|
-
if (storage) {
|
|
54
|
-
value = await storage.run(context, render);
|
|
55
|
-
} else {
|
|
56
|
-
contextStack.push(context);
|
|
57
|
-
try {
|
|
58
|
-
value = await render();
|
|
59
|
-
} finally {
|
|
60
|
-
contextStack.pop();
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return {
|
|
64
|
-
value,
|
|
65
|
-
graphContext: {
|
|
66
|
-
propsByRef: context.propsByRef,
|
|
67
|
-
slotChildrenByRef: context.slotChildrenByRef
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
export {
|
|
72
|
-
createNodeId,
|
|
73
|
-
createPropsRef,
|
|
74
|
-
createSlotRef,
|
|
75
|
-
getComponentRenderContext,
|
|
76
|
-
runWithComponentRenderContext
|
|
77
|
-
};
|
package/src/eco/eco.d.ts
DELETED
package/src/eco/eco.js
DELETED
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { createNodeId, createPropsRef, createSlotRef, getComponentRenderContext } from "./component-render-context.js";
|
|
2
|
-
import { createComponentMarker, parseComponentMarkers } from "../route-renderer/component-marker.js";
|
|
3
|
-
import { addTriggerAttribute, isThenable, wrapWithScriptsInjector } from "./eco.utils.js";
|
|
4
|
-
function createComponentFactory(options) {
|
|
5
|
-
const integrationName = options.integration ?? options.__eco?.integration;
|
|
6
|
-
const comp = ((props) => {
|
|
7
|
-
const renderContext = getComponentRenderContext();
|
|
8
|
-
const shouldEmitMarker = renderContext !== void 0 && renderContext.boundaryContext.decideBoundaryRender({
|
|
9
|
-
currentIntegration: renderContext.currentIntegration,
|
|
10
|
-
targetIntegration: integrationName,
|
|
11
|
-
component: comp
|
|
12
|
-
}) === "defer";
|
|
13
|
-
if (shouldEmitMarker && renderContext) {
|
|
14
|
-
const nodeId = createNodeId(renderContext);
|
|
15
|
-
const propsRef = createPropsRef(renderContext);
|
|
16
|
-
const componentRef = comp.config?.__eco?.id ?? comp.config?.__eco?.file;
|
|
17
|
-
if (!componentRef) {
|
|
18
|
-
throw new Error(
|
|
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);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return createComponentMarker({
|
|
34
|
-
nodeId,
|
|
35
|
-
integration: integrationName,
|
|
36
|
-
componentRef,
|
|
37
|
-
propsRef,
|
|
38
|
-
slotRef
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
const content = options.render(props);
|
|
42
|
-
const lazyTriggers = comp.config?._resolvedLazyTriggers;
|
|
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);
|
|
49
|
-
}
|
|
50
|
-
const lazyGroups = comp.config?._resolvedLazyScripts;
|
|
51
|
-
if (lazyGroups && lazyGroups.length > 0) {
|
|
52
|
-
if (isThenable(content)) {
|
|
53
|
-
return content.then((resolvedContent) => wrapWithScriptsInjector(resolvedContent, lazyGroups));
|
|
54
|
-
}
|
|
55
|
-
return wrapWithScriptsInjector(content, lazyGroups);
|
|
56
|
-
}
|
|
57
|
-
return content;
|
|
58
|
-
});
|
|
59
|
-
comp.config = {
|
|
60
|
-
__eco: options.__eco,
|
|
61
|
-
integration: options.integration,
|
|
62
|
-
dependencies: options.dependencies
|
|
63
|
-
};
|
|
64
|
-
return comp;
|
|
65
|
-
}
|
|
66
|
-
function component(options) {
|
|
67
|
-
return createComponentFactory(options);
|
|
68
|
-
}
|
|
69
|
-
function page(options) {
|
|
70
|
-
const { layout, dependencies, render, staticPaths: staticPaths2, staticProps: staticProps2, metadata: metadata2, cache, requires, middleware } = options;
|
|
71
|
-
const componentOptions = {
|
|
72
|
-
__eco: options.__eco,
|
|
73
|
-
integration: options.integration,
|
|
74
|
-
dependencies: layout ? {
|
|
75
|
-
...dependencies,
|
|
76
|
-
components: [...dependencies?.components || [], layout]
|
|
77
|
-
} : dependencies,
|
|
78
|
-
render
|
|
79
|
-
};
|
|
80
|
-
const pageComponent = createComponentFactory(componentOptions);
|
|
81
|
-
if (layout && pageComponent.config) {
|
|
82
|
-
pageComponent.config.layout = layout;
|
|
83
|
-
}
|
|
84
|
-
if (staticPaths2) pageComponent.staticPaths = staticPaths2;
|
|
85
|
-
if (staticProps2) pageComponent.staticProps = staticProps2;
|
|
86
|
-
if (metadata2) pageComponent.metadata = metadata2;
|
|
87
|
-
if (cache) pageComponent.cache = cache;
|
|
88
|
-
if (requires) pageComponent.requires = requires;
|
|
89
|
-
if (middleware) pageComponent.middleware = middleware;
|
|
90
|
-
return pageComponent;
|
|
91
|
-
}
|
|
92
|
-
function metadata(fn) {
|
|
93
|
-
return fn;
|
|
94
|
-
}
|
|
95
|
-
function staticPaths(fn) {
|
|
96
|
-
return fn;
|
|
97
|
-
}
|
|
98
|
-
function staticProps(fn) {
|
|
99
|
-
return fn;
|
|
100
|
-
}
|
|
101
|
-
const eco = {
|
|
102
|
-
component,
|
|
103
|
-
page,
|
|
104
|
-
metadata,
|
|
105
|
-
staticPaths,
|
|
106
|
-
staticProps
|
|
107
|
-
};
|
|
108
|
-
export {
|
|
109
|
-
eco
|
|
110
|
-
};
|