@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
|
@@ -0,0 +1,433 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared browser-side navigation coordinator.
|
|
3
|
+
*
|
|
4
|
+
* This module is the client runtime contract used by browser-router,
|
|
5
|
+
* react-router, and HMR code to coordinate ownership, cross-runtime handoff,
|
|
6
|
+
* current-page reloads, and stale-navigation cancellation.
|
|
7
|
+
*
|
|
8
|
+
* The coordinator stays framework-agnostic: browser runtimes register their
|
|
9
|
+
* capabilities here, and the coordinator arbitrates which runtime currently
|
|
10
|
+
* owns the document and which navigation transaction is still current.
|
|
11
|
+
*
|
|
12
|
+
* @module
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
/** Logical owner name for a browser navigation runtime. */
|
|
16
|
+
export type EcoNavigationOwner = 'none' | 'browser-router' | 'react-router' | (string & {});
|
|
17
|
+
|
|
18
|
+
/** HTML attribute used to persist the rendered document owner across navigations. */
|
|
19
|
+
export const ECO_DOCUMENT_OWNER_ATTRIBUTE = 'data-eco-document-owner';
|
|
20
|
+
|
|
21
|
+
/** High-level navigation direction understood by browser runtimes. */
|
|
22
|
+
export type EcoNavigationDirection = 'forward' | 'back' | 'replace';
|
|
23
|
+
|
|
24
|
+
/** Navigation request sent between browser runtimes. */
|
|
25
|
+
export type EcoNavigationRequest = {
|
|
26
|
+
href: string;
|
|
27
|
+
direction?: EcoNavigationDirection;
|
|
28
|
+
source?: EcoNavigationOwner;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/** Navigation handoff request that includes a pre-fetched document. */
|
|
32
|
+
export type EcoNavigationHandoffRequest = EcoNavigationRequest & {
|
|
33
|
+
finalHref?: string;
|
|
34
|
+
targetOwner: EcoNavigationOwner;
|
|
35
|
+
document: Document;
|
|
36
|
+
html?: string;
|
|
37
|
+
/**
|
|
38
|
+
* Reports whether the source runtime's original navigation has already been
|
|
39
|
+
* superseded.
|
|
40
|
+
*
|
|
41
|
+
* Target runtimes use this to ignore handoff work that arrives after a newer
|
|
42
|
+
* navigation has already claimed ownership.
|
|
43
|
+
*/
|
|
44
|
+
isStaleSourceNavigation?: () => boolean;
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
/** Request to reload the current page through the active runtime. */
|
|
48
|
+
export type EcoReloadRequest = {
|
|
49
|
+
clearCache?: boolean;
|
|
50
|
+
source?: EcoNavigationOwner;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
/** Snapshot of the coordinator's current runtime ownership state. */
|
|
54
|
+
export type EcoNavigationOwnerState = {
|
|
55
|
+
owner: EcoNavigationOwner;
|
|
56
|
+
canHandleSpaNavigation: boolean;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Coordinator-managed navigation transaction.
|
|
61
|
+
*
|
|
62
|
+
* Runtimes use this to determine whether async work has become stale and to
|
|
63
|
+
* cancel or complete the active navigation sequence.
|
|
64
|
+
*/
|
|
65
|
+
export type EcoNavigationTransaction = {
|
|
66
|
+
id: number;
|
|
67
|
+
signal: AbortSignal;
|
|
68
|
+
isCurrent: () => boolean;
|
|
69
|
+
cancel: () => void;
|
|
70
|
+
complete: () => void;
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export type EcoNavigationRuntimeEvent =
|
|
74
|
+
| {
|
|
75
|
+
type: 'owner-change';
|
|
76
|
+
owner: EcoNavigationOwner;
|
|
77
|
+
previousOwner: EcoNavigationOwner;
|
|
78
|
+
reason: 'set' | 'claim' | 'release' | 'document' | 'unregister';
|
|
79
|
+
}
|
|
80
|
+
| {
|
|
81
|
+
type: 'registration-change';
|
|
82
|
+
owner: EcoNavigationOwner;
|
|
83
|
+
status: 'registered' | 'unregistered';
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
export type EcoNavigationRuntimeListener = (event: EcoNavigationRuntimeEvent) => void;
|
|
87
|
+
|
|
88
|
+
export type EcoNavigationRuntimeRegistration = {
|
|
89
|
+
owner: EcoNavigationOwner;
|
|
90
|
+
navigate?: (request: EcoNavigationRequest) => Promise<boolean | void>;
|
|
91
|
+
handoffNavigation?: (request: EcoNavigationHandoffRequest) => Promise<boolean | void>;
|
|
92
|
+
reloadCurrentPage?: (request?: EcoReloadRequest) => Promise<void>;
|
|
93
|
+
/**
|
|
94
|
+
* Releases runtime-owned client state before another runtime commits a new
|
|
95
|
+
* document.
|
|
96
|
+
*
|
|
97
|
+
* This hook intentionally does not run as part of `requestHandoff()`. The
|
|
98
|
+
* accepting runtime decides when cleanup is safe so cross-runtime handoffs do
|
|
99
|
+
* not blank the current page before the incoming document is ready.
|
|
100
|
+
*/
|
|
101
|
+
cleanupBeforeHandoff?: () => void | Promise<void>;
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
/** Public browser-side navigation coordinator interface. */
|
|
105
|
+
export interface EcoNavigationRuntime {
|
|
106
|
+
/** Returns the currently active runtime owner and whether it can handle SPA navigation. */
|
|
107
|
+
getOwnerState(): EcoNavigationOwnerState;
|
|
108
|
+
/** Starts a new navigation transaction, invalidating the previously active one. */
|
|
109
|
+
beginNavigationTransaction(): EcoNavigationTransaction;
|
|
110
|
+
/** Reports whether a navigation transaction is still in flight. */
|
|
111
|
+
hasPendingNavigationTransaction(): boolean;
|
|
112
|
+
/** Cancels the active navigation transaction, if one exists. */
|
|
113
|
+
cancelCurrentNavigationTransaction(): void;
|
|
114
|
+
/** Forces the current owner value without checking registrations. */
|
|
115
|
+
setOwner(owner: EcoNavigationOwner): void;
|
|
116
|
+
/** Claims ownership for a runtime that is ready to drive SPA navigation. */
|
|
117
|
+
claimOwnership(owner: EcoNavigationOwner): void;
|
|
118
|
+
/** Releases ownership when the given runtime no longer controls the document. */
|
|
119
|
+
releaseOwnership(owner: EcoNavigationOwner): void;
|
|
120
|
+
/** Resolves document ownership from the rendered owner marker or fallback. */
|
|
121
|
+
resolveDocumentOwner(doc: Document, fallbackOwner?: EcoNavigationOwner): EcoNavigationOwner;
|
|
122
|
+
/** Reads and adopts the rendered document owner as the active runtime owner. */
|
|
123
|
+
adoptDocumentOwner(doc: Document, fallbackOwner?: EcoNavigationOwner): EcoNavigationOwner;
|
|
124
|
+
/** Returns whether the active owner is some runtime other than the given owner. */
|
|
125
|
+
isOwnedByAnotherRuntime(owner: EcoNavigationOwner): boolean;
|
|
126
|
+
/** Subscribes to ownership and registration change events. */
|
|
127
|
+
subscribe(listener: EcoNavigationRuntimeListener): () => void;
|
|
128
|
+
/** Registers a runtime implementation with the coordinator. */
|
|
129
|
+
register(runtime: EcoNavigationRuntimeRegistration): () => void;
|
|
130
|
+
/** Requests navigation through another eligible registered runtime. */
|
|
131
|
+
requestNavigation(request: EcoNavigationRequest): Promise<boolean>;
|
|
132
|
+
/**
|
|
133
|
+
* Hands a pre-fetched document to the target runtime.
|
|
134
|
+
*
|
|
135
|
+
* The coordinator delegates the document but does not clean up the current
|
|
136
|
+
* owner first. Cleanup timing belongs to the accepting runtime so a stale or
|
|
137
|
+
* superseded handoff cannot tear down the current page prematurely.
|
|
138
|
+
*/
|
|
139
|
+
requestHandoff(request: EcoNavigationHandoffRequest): Promise<boolean>;
|
|
140
|
+
/** Requests the active runtime to reload the current page. */
|
|
141
|
+
reloadCurrentPage(request?: EcoReloadRequest): Promise<boolean>;
|
|
142
|
+
/** Runs a target runtime's cleanup hook before handoff. */
|
|
143
|
+
cleanupOwner(owner: EcoNavigationOwner): Promise<void>;
|
|
144
|
+
/** Runs cleanup for whichever runtime currently owns the document. */
|
|
145
|
+
cleanupCurrentOwner(): Promise<void>;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* Reads the explicit browser document owner marker from a rendered HTML document.
|
|
150
|
+
*
|
|
151
|
+
* Documents without a marker return `null`, allowing runtimes to fall back to
|
|
152
|
+
* their local default behavior without scanning hydration scripts.
|
|
153
|
+
*/
|
|
154
|
+
export function getEcoDocumentOwner(doc: Document): EcoNavigationOwner | null {
|
|
155
|
+
const owner = doc.documentElement.getAttribute(ECO_DOCUMENT_OWNER_ATTRIBUTE);
|
|
156
|
+
return owner && owner.length > 0 ? (owner as EcoNavigationOwner) : null;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
type EcoNavigationWindow = Window &
|
|
160
|
+
typeof globalThis & {
|
|
161
|
+
__ECO_PAGES__?: {
|
|
162
|
+
navigation?: EcoNavigationRuntime;
|
|
163
|
+
};
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
function getCandidateOwners(
|
|
167
|
+
currentOwner: EcoNavigationOwner,
|
|
168
|
+
registrations: Map<EcoNavigationOwner, EcoNavigationRuntimeRegistration>,
|
|
169
|
+
excludedOwner?: EcoNavigationOwner,
|
|
170
|
+
): EcoNavigationOwner[] {
|
|
171
|
+
const owners: EcoNavigationOwner[] = [];
|
|
172
|
+
|
|
173
|
+
if (currentOwner !== 'none' && currentOwner !== excludedOwner) {
|
|
174
|
+
owners.push(currentOwner);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
for (const owner of registrations.keys()) {
|
|
178
|
+
if (owner === currentOwner || owner === excludedOwner) {
|
|
179
|
+
continue;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
owners.push(owner);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
return owners;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
function createEcoNavigationRuntime(_windowObject: EcoNavigationWindow): EcoNavigationRuntime {
|
|
189
|
+
const registrations = new Map<EcoNavigationOwner, EcoNavigationRuntimeRegistration>();
|
|
190
|
+
const listeners = new Set<EcoNavigationRuntimeListener>();
|
|
191
|
+
let owner: EcoNavigationOwner = 'none';
|
|
192
|
+
let navigationSequence = 0;
|
|
193
|
+
let navigationAbortController: AbortController | null = null;
|
|
194
|
+
|
|
195
|
+
const emit = (event: EcoNavigationRuntimeEvent) => {
|
|
196
|
+
for (const listener of listeners) {
|
|
197
|
+
listener(event);
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
|
|
201
|
+
const updateOwner = (
|
|
202
|
+
nextOwner: EcoNavigationOwner,
|
|
203
|
+
reason: Extract<EcoNavigationRuntimeEvent, { type: 'owner-change' }>['reason'],
|
|
204
|
+
) => {
|
|
205
|
+
if (owner === nextOwner) {
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
const previousOwner = owner;
|
|
210
|
+
owner = nextOwner;
|
|
211
|
+
emit({
|
|
212
|
+
type: 'owner-change',
|
|
213
|
+
owner: nextOwner,
|
|
214
|
+
previousOwner,
|
|
215
|
+
reason,
|
|
216
|
+
});
|
|
217
|
+
};
|
|
218
|
+
|
|
219
|
+
const cancelNavigationTransaction = (navigationId: number, abortController: AbortController): void => {
|
|
220
|
+
if (navigationSequence !== navigationId || navigationAbortController !== abortController) {
|
|
221
|
+
return;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
navigationSequence += 1;
|
|
225
|
+
navigationAbortController = null;
|
|
226
|
+
abortController.abort();
|
|
227
|
+
};
|
|
228
|
+
|
|
229
|
+
const completeNavigationTransaction = (navigationId: number, abortController: AbortController): void => {
|
|
230
|
+
if (navigationSequence !== navigationId || navigationAbortController !== abortController) {
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
navigationAbortController = null;
|
|
235
|
+
};
|
|
236
|
+
|
|
237
|
+
const runtime: EcoNavigationRuntime = {
|
|
238
|
+
getOwnerState(): EcoNavigationOwnerState {
|
|
239
|
+
const activeRuntime = registrations.get(owner);
|
|
240
|
+
return {
|
|
241
|
+
owner,
|
|
242
|
+
canHandleSpaNavigation: typeof activeRuntime?.navigate === 'function',
|
|
243
|
+
};
|
|
244
|
+
},
|
|
245
|
+
|
|
246
|
+
hasPendingNavigationTransaction(): boolean {
|
|
247
|
+
return navigationAbortController !== null;
|
|
248
|
+
},
|
|
249
|
+
|
|
250
|
+
beginNavigationTransaction(): EcoNavigationTransaction {
|
|
251
|
+
navigationAbortController?.abort();
|
|
252
|
+
const abortController = new AbortController();
|
|
253
|
+
const navigationId = ++navigationSequence;
|
|
254
|
+
navigationAbortController = abortController;
|
|
255
|
+
|
|
256
|
+
return {
|
|
257
|
+
id: navigationId,
|
|
258
|
+
signal: abortController.signal,
|
|
259
|
+
isCurrent: () => navigationSequence === navigationId && navigationAbortController === abortController,
|
|
260
|
+
cancel: () => {
|
|
261
|
+
cancelNavigationTransaction(navigationId, abortController);
|
|
262
|
+
},
|
|
263
|
+
complete: () => {
|
|
264
|
+
completeNavigationTransaction(navigationId, abortController);
|
|
265
|
+
},
|
|
266
|
+
};
|
|
267
|
+
},
|
|
268
|
+
|
|
269
|
+
cancelCurrentNavigationTransaction(): void {
|
|
270
|
+
if (!navigationAbortController) {
|
|
271
|
+
return;
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
cancelNavigationTransaction(navigationSequence, navigationAbortController);
|
|
275
|
+
},
|
|
276
|
+
|
|
277
|
+
setOwner(nextOwner: EcoNavigationOwner): void {
|
|
278
|
+
updateOwner(nextOwner, 'set');
|
|
279
|
+
},
|
|
280
|
+
|
|
281
|
+
claimOwnership(nextOwner: EcoNavigationOwner): void {
|
|
282
|
+
updateOwner(nextOwner, 'claim');
|
|
283
|
+
},
|
|
284
|
+
|
|
285
|
+
releaseOwnership(currentOwner: EcoNavigationOwner): void {
|
|
286
|
+
if (owner !== currentOwner) {
|
|
287
|
+
return;
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
updateOwner('none', 'release');
|
|
291
|
+
},
|
|
292
|
+
|
|
293
|
+
resolveDocumentOwner(doc: Document, fallbackOwner: EcoNavigationOwner = 'none'): EcoNavigationOwner {
|
|
294
|
+
return getEcoDocumentOwner(doc) ?? fallbackOwner;
|
|
295
|
+
},
|
|
296
|
+
|
|
297
|
+
adoptDocumentOwner(doc: Document, fallbackOwner: EcoNavigationOwner = 'none'): EcoNavigationOwner {
|
|
298
|
+
const nextOwner = runtime.resolveDocumentOwner(doc, fallbackOwner);
|
|
299
|
+
updateOwner(nextOwner, 'document');
|
|
300
|
+
return nextOwner;
|
|
301
|
+
},
|
|
302
|
+
|
|
303
|
+
isOwnedByAnotherRuntime(candidateOwner: EcoNavigationOwner): boolean {
|
|
304
|
+
return owner !== 'none' && owner !== candidateOwner;
|
|
305
|
+
},
|
|
306
|
+
|
|
307
|
+
subscribe(listener: EcoNavigationRuntimeListener): () => void {
|
|
308
|
+
listeners.add(listener);
|
|
309
|
+
return () => {
|
|
310
|
+
listeners.delete(listener);
|
|
311
|
+
};
|
|
312
|
+
},
|
|
313
|
+
|
|
314
|
+
register(registration: EcoNavigationRuntimeRegistration): () => void {
|
|
315
|
+
registrations.set(registration.owner, registration);
|
|
316
|
+
emit({
|
|
317
|
+
type: 'registration-change',
|
|
318
|
+
owner: registration.owner,
|
|
319
|
+
status: 'registered',
|
|
320
|
+
});
|
|
321
|
+
|
|
322
|
+
return () => {
|
|
323
|
+
const currentRegistration = registrations.get(registration.owner);
|
|
324
|
+
if (currentRegistration !== registration) {
|
|
325
|
+
return;
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
registrations.delete(registration.owner);
|
|
329
|
+
emit({
|
|
330
|
+
type: 'registration-change',
|
|
331
|
+
owner: registration.owner,
|
|
332
|
+
status: 'unregistered',
|
|
333
|
+
});
|
|
334
|
+
if (owner === registration.owner) {
|
|
335
|
+
updateOwner('none', 'unregister');
|
|
336
|
+
}
|
|
337
|
+
};
|
|
338
|
+
},
|
|
339
|
+
|
|
340
|
+
async requestNavigation(request: EcoNavigationRequest): Promise<boolean> {
|
|
341
|
+
for (const candidateOwner of getCandidateOwners(owner, registrations, request.source)) {
|
|
342
|
+
const registration = registrations.get(candidateOwner);
|
|
343
|
+
if (!registration?.navigate) {
|
|
344
|
+
continue;
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
const handled = await registration.navigate(request);
|
|
348
|
+
if (handled !== false) {
|
|
349
|
+
return true;
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
|
|
353
|
+
return false;
|
|
354
|
+
},
|
|
355
|
+
|
|
356
|
+
async requestHandoff(request: EcoNavigationHandoffRequest): Promise<boolean> {
|
|
357
|
+
if (request.targetOwner === 'none') {
|
|
358
|
+
return false;
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
if (request.isStaleSourceNavigation?.()) {
|
|
362
|
+
return true;
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
const registration = registrations.get(request.targetOwner);
|
|
366
|
+
if (!registration?.handoffNavigation) {
|
|
367
|
+
return false;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
if (request.isStaleSourceNavigation?.()) {
|
|
371
|
+
return true;
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
const handled = await registration.handoffNavigation(request);
|
|
375
|
+
return handled !== false;
|
|
376
|
+
},
|
|
377
|
+
|
|
378
|
+
async reloadCurrentPage(request?: EcoReloadRequest): Promise<boolean> {
|
|
379
|
+
for (const candidateOwner of getCandidateOwners(owner, registrations)) {
|
|
380
|
+
const registration = registrations.get(candidateOwner);
|
|
381
|
+
if (!registration?.reloadCurrentPage) {
|
|
382
|
+
continue;
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
await registration.reloadCurrentPage(request);
|
|
386
|
+
return true;
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
return false;
|
|
390
|
+
},
|
|
391
|
+
|
|
392
|
+
async cleanupOwner(targetOwner: EcoNavigationOwner): Promise<void> {
|
|
393
|
+
if (targetOwner === 'none') {
|
|
394
|
+
return;
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
const registration = registrations.get(targetOwner);
|
|
398
|
+
if (!registration?.cleanupBeforeHandoff) {
|
|
399
|
+
return;
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
await registration.cleanupBeforeHandoff();
|
|
403
|
+
if (owner === targetOwner) {
|
|
404
|
+
updateOwner('none', 'release');
|
|
405
|
+
}
|
|
406
|
+
},
|
|
407
|
+
|
|
408
|
+
async cleanupCurrentOwner(): Promise<void> {
|
|
409
|
+
await runtime.cleanupOwner(owner);
|
|
410
|
+
},
|
|
411
|
+
};
|
|
412
|
+
|
|
413
|
+
return runtime;
|
|
414
|
+
}
|
|
415
|
+
|
|
416
|
+
/**
|
|
417
|
+
* Returns the singleton browser-side navigation coordinator.
|
|
418
|
+
*
|
|
419
|
+
* The coordinator centralizes ownership, handoff, and current-page reload
|
|
420
|
+
* requests across browser runtimes through one internal protocol.
|
|
421
|
+
*
|
|
422
|
+
* @param windowObject - Window-like object that stores the singleton runtime.
|
|
423
|
+
* @returns The shared browser navigation coordinator.
|
|
424
|
+
*/
|
|
425
|
+
export function getEcoNavigationRuntime(windowObject: Window & typeof globalThis = window): EcoNavigationRuntime {
|
|
426
|
+
const runtimeWindow = windowObject as EcoNavigationWindow;
|
|
427
|
+
runtimeWindow.__ECO_PAGES__ = runtimeWindow.__ECO_PAGES__ || {};
|
|
428
|
+
if (!runtimeWindow.__ECO_PAGES__.navigation) {
|
|
429
|
+
runtimeWindow.__ECO_PAGES__.navigation = createEcoNavigationRuntime(runtimeWindow);
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
return runtimeWindow.__ECO_PAGES__.navigation;
|
|
433
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import assert from 'node:assert/strict';
|
|
2
|
+
import fs from 'node:fs';
|
|
3
|
+
import os from 'node:os';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
import { test } from 'vitest';
|
|
6
|
+
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
7
|
+
import { FSRouterScanner } from './fs-router-scanner.ts';
|
|
8
|
+
|
|
9
|
+
test('FSRouterScanner scans dynamic routes in Node when module graph needs transpilation', async () => {
|
|
10
|
+
if (typeof Bun !== 'undefined') {
|
|
11
|
+
// This test expects Node's missing Bun global to trigger Esbuild transpilation. Skip in Bun runner.
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const rootDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ecopages-fs-router-scanner-node-'));
|
|
16
|
+
const pagesDir = path.join(rootDir, 'src', 'pages');
|
|
17
|
+
const dynamicDir = path.join(pagesDir, 'dynamic');
|
|
18
|
+
const distDir = path.join(rootDir, 'dist');
|
|
19
|
+
const workDir = path.join(rootDir, '.eco');
|
|
20
|
+
|
|
21
|
+
try {
|
|
22
|
+
fs.mkdirSync(dynamicDir, { recursive: true });
|
|
23
|
+
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
24
|
+
|
|
25
|
+
fs.writeFileSync(
|
|
26
|
+
path.join(rootDir, 'src', 'decorated.ts'),
|
|
27
|
+
[
|
|
28
|
+
'function sealed<T extends new (...args: never[]) => object>(target: T) {',
|
|
29
|
+
'\treturn target;',
|
|
30
|
+
'}',
|
|
31
|
+
'@sealed',
|
|
32
|
+
'export class DecoratedModule {}',
|
|
33
|
+
].join('\n'),
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
fs.writeFileSync(
|
|
37
|
+
path.join(dynamicDir, '[slug].kita.tsx'),
|
|
38
|
+
[
|
|
39
|
+
"import '../../decorated.ts';",
|
|
40
|
+
'',
|
|
41
|
+
'export const getStaticPaths = async () => ({',
|
|
42
|
+
"\tpaths: [{ params: { slug: 'hello-world' } }],",
|
|
43
|
+
'});',
|
|
44
|
+
'',
|
|
45
|
+
'export const getStaticProps = async () => ({ props: {} });',
|
|
46
|
+
'',
|
|
47
|
+
'export default async function Page() {',
|
|
48
|
+
"\treturn '<div>Hello</div>';",
|
|
49
|
+
'}',
|
|
50
|
+
].join('\n'),
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
const scanner = new FSRouterScanner({
|
|
54
|
+
dir: pagesDir,
|
|
55
|
+
origin: 'http://localhost:3000',
|
|
56
|
+
templatesExt: ['.kita.tsx'],
|
|
57
|
+
options: {
|
|
58
|
+
buildMode: false,
|
|
59
|
+
},
|
|
60
|
+
appConfig: {
|
|
61
|
+
rootDir,
|
|
62
|
+
workDir: '.eco',
|
|
63
|
+
absolutePaths: {
|
|
64
|
+
distDir,
|
|
65
|
+
workDir,
|
|
66
|
+
},
|
|
67
|
+
} as unknown as EcoPagesAppConfig,
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
const routes = await scanner.scan();
|
|
71
|
+
|
|
72
|
+
assert.equal(routes['http://localhost:3000/dynamic/hello-world']?.kind, 'dynamic');
|
|
73
|
+
assert.equal(routes['http://localhost:3000/dynamic/hello-world']?.pathname, '/dynamic/[slug]');
|
|
74
|
+
|
|
75
|
+
const transpiledModulesDir = path.join(workDir, '.server-route-modules');
|
|
76
|
+
assert.equal(fs.existsSync(transpiledModulesDir), true);
|
|
77
|
+
|
|
78
|
+
const transpiledFiles = fs.readdirSync(transpiledModulesDir).filter((file) => file.endsWith('.js'));
|
|
79
|
+
assert.ok(transpiledFiles.length > 0);
|
|
80
|
+
} finally {
|
|
81
|
+
fs.rmSync(rootDir, { recursive: true, force: true });
|
|
82
|
+
}
|
|
83
|
+
});
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import path from 'node:path';
|
|
2
|
-
import { appLogger } from '
|
|
3
|
-
import type { EcoPagesAppConfig, RouteKind, Routes } from '
|
|
4
|
-
import type { EcoPageFile, GetStaticPaths } from '
|
|
2
|
+
import { appLogger } from '../../global/app-logger.js';
|
|
3
|
+
import type { EcoPagesAppConfig, RouteKind, Routes } from '../../internal-types.js';
|
|
4
|
+
import type { EcoPageFile, GetStaticPaths } from '../../public-types.js';
|
|
5
5
|
import { fileSystem } from '@ecopages/file-system';
|
|
6
|
-
import { invariant } from '
|
|
6
|
+
import { invariant } from '../../utils/invariant.js';
|
|
7
7
|
import { existsSync } from 'node:fs';
|
|
8
|
-
import {
|
|
8
|
+
import { getAppServerModuleTranspiler } from '../../services/module-loading/app-server-module-transpiler.service.ts';
|
|
9
|
+
import type { ServerModuleTranspiler } from '../../services/module-loading/server-module-transpiler.service.ts';
|
|
10
|
+
import { resolveInternalExecutionDir } from '../../utils/resolve-work-dir.js';
|
|
9
11
|
|
|
10
12
|
type CreateRouteArgs = {
|
|
11
13
|
routePath: string;
|
|
@@ -33,9 +35,9 @@ export class FSRouterScanner {
|
|
|
33
35
|
private origin = '';
|
|
34
36
|
private templatesExt: string[];
|
|
35
37
|
private options: FSRouterScannerOptions;
|
|
36
|
-
|
|
38
|
+
readonly appConfig: EcoPagesAppConfig;
|
|
37
39
|
routes: Routes = {};
|
|
38
|
-
private
|
|
40
|
+
private serverModuleTranspiler: ServerModuleTranspiler;
|
|
39
41
|
|
|
40
42
|
constructor({
|
|
41
43
|
dir,
|
|
@@ -55,6 +57,7 @@ export class FSRouterScanner {
|
|
|
55
57
|
this.templatesExt = templatesExt;
|
|
56
58
|
this.options = options;
|
|
57
59
|
this.appConfig = appConfig;
|
|
60
|
+
this.serverModuleTranspiler = getAppServerModuleTranspiler(appConfig);
|
|
58
61
|
}
|
|
59
62
|
|
|
60
63
|
private getRoutePath(path: string): string {
|
|
@@ -143,10 +146,9 @@ export class FSRouterScanner {
|
|
|
143
146
|
}
|
|
144
147
|
|
|
145
148
|
private async importPageModule(filePath: string): Promise<unknown> {
|
|
146
|
-
return this.
|
|
149
|
+
return this.serverModuleTranspiler.importModule({
|
|
147
150
|
filePath,
|
|
148
|
-
|
|
149
|
-
outdir: path.join(this.appConfig.absolutePaths.distDir, '.server-route-modules'),
|
|
151
|
+
outdir: path.join(resolveInternalExecutionDir(this.appConfig), '.server-route-modules'),
|
|
150
152
|
externalPackages: false,
|
|
151
153
|
transpileErrorMessage: (details) => `Error transpiling route module: ${details}`,
|
|
152
154
|
noOutputMessage: (targetFilePath) => `No transpiled output generated for route module: ${targetFilePath}`,
|