@ecopages/core 0.2.0-alpha.3 → 0.2.0-alpha.30

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.
Files changed (436) hide show
  1. package/CHANGELOG.md +66 -66
  2. package/README.md +268 -14
  3. package/package.json +72 -108
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +5 -12
  11. package/src/adapters/bun/create-app.js +43 -7
  12. package/src/adapters/bun/hmr-manager.d.ts +72 -26
  13. package/src/adapters/bun/hmr-manager.js +153 -81
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +63 -38
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +79 -21
  28. package/src/adapters/node/node-hmr-manager.js +167 -114
  29. package/src/adapters/node/server-adapter.d.ts +7 -35
  30. package/src/adapters/node/server-adapter.js +55 -107
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
  36. package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
  37. package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
  38. package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
  39. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
  40. package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
  41. package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
  42. package/src/adapters/shared/fs-server-response-factory.js +11 -27
  43. package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
  44. package/src/adapters/shared/fs-server-response-matcher.js +76 -45
  45. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  46. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  47. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  48. package/src/adapters/shared/hmr-html-response.js +32 -0
  49. package/src/adapters/shared/render-context.d.ts +4 -3
  50. package/src/adapters/shared/render-context.js +6 -3
  51. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  52. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  53. package/src/adapters/shared/server-adapter.d.ts +33 -12
  54. package/src/adapters/shared/server-adapter.js +208 -132
  55. package/src/adapters/shared/server-route-handler.d.ts +5 -5
  56. package/src/adapters/shared/server-route-handler.js +7 -16
  57. package/src/adapters/shared/server-static-builder.d.ts +41 -8
  58. package/src/adapters/shared/server-static-builder.js +65 -11
  59. package/src/build/README.md +107 -0
  60. package/src/build/build-adapter.d.ts +168 -3
  61. package/src/build/build-adapter.js +604 -16
  62. package/src/build/build-manifest.d.ts +27 -0
  63. package/src/build/build-manifest.js +30 -0
  64. package/src/build/dev-build-coordinator.d.ts +72 -0
  65. package/src/build/dev-build-coordinator.js +154 -0
  66. package/src/build/esbuild-build-adapter.d.ts +15 -6
  67. package/src/build/esbuild-build-adapter.js +189 -74
  68. package/src/build/runtime-build-executor.d.ts +14 -0
  69. package/src/build/runtime-build-executor.js +22 -0
  70. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  71. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  72. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  73. package/src/build/runtime-specifier-aliases.js +95 -0
  74. package/src/config/README.md +36 -0
  75. package/src/config/config-builder.d.ts +54 -29
  76. package/src/config/config-builder.js +255 -49
  77. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  78. package/src/{constants.js → config/constants.js} +4 -0
  79. package/src/declarations.d.ts +19 -14
  80. package/src/dev/host-runtime.d.ts +10 -0
  81. package/src/dev/host-runtime.js +24 -0
  82. package/src/dev/sc-server.d.ts +1 -1
  83. package/src/dev/sc-server.js +1 -1
  84. package/src/eco/README.md +70 -16
  85. package/src/eco/eco.browser.d.ts +2 -0
  86. package/src/eco/eco.browser.js +83 -0
  87. package/src/eco/eco.js +32 -57
  88. package/src/eco/eco.types.d.ts +14 -6
  89. package/src/eco/eco.utils.d.ts +1 -40
  90. package/src/eco/eco.utils.js +5 -35
  91. package/src/eco/global-injector-map.d.ts +3 -3
  92. package/src/eco/global-injector-map.js +2 -2
  93. package/src/eco/lazy-injector-map.d.ts +2 -2
  94. package/src/errors/index.d.ts +1 -0
  95. package/src/errors/index.js +3 -1
  96. package/src/hmr/README.md +26 -0
  97. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  98. package/src/hmr/client/hmr-runtime.js +38 -7
  99. package/src/hmr/hmr-strategy.d.ts +16 -13
  100. package/src/hmr/hmr-strategy.js +22 -7
  101. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  102. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  103. package/src/hmr/hmr.test.e2e.js +26 -33
  104. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  105. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  106. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -48
  107. package/src/hmr/strategies/js-hmr-strategy.js +64 -74
  108. package/src/index.browser.d.ts +2 -2
  109. package/src/index.browser.js +1 -1
  110. package/src/index.d.ts +4 -3
  111. package/src/index.js +16 -5
  112. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  113. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  114. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  115. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  116. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  117. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  118. package/src/plugins/README.md +35 -0
  119. package/src/plugins/alias-resolver-plugin.js +17 -3
  120. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  121. package/src/plugins/eco-component-meta-plugin.js +27 -22
  122. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  123. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  124. package/src/plugins/integration-plugin.d.ts +142 -29
  125. package/src/plugins/integration-plugin.js +103 -14
  126. package/src/plugins/processor.d.ts +17 -2
  127. package/src/plugins/processor.js +22 -3
  128. package/src/plugins/runtime-capability.d.ts +9 -0
  129. package/src/plugins/source-transform.d.ts +46 -0
  130. package/src/plugins/source-transform.js +71 -0
  131. package/src/route-renderer/GRAPH.md +83 -325
  132. package/src/route-renderer/README.md +73 -90
  133. package/src/route-renderer/orchestration/component-render-context.d.ts +89 -0
  134. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  135. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  136. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  137. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +108 -0
  138. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +206 -0
  139. package/src/route-renderer/orchestration/integration-renderer.d.ts +516 -0
  140. package/src/route-renderer/orchestration/integration-renderer.js +909 -0
  141. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  142. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  143. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  144. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  145. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +2 -0
  146. package/src/route-renderer/orchestration/processed-asset-dedupe.js +23 -0
  147. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +90 -0
  148. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +158 -0
  149. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  150. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  151. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +120 -0
  152. package/src/route-renderer/orchestration/route-render-orchestrator.js +388 -0
  153. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  154. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  155. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  156. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  157. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  158. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  159. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  160. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  161. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  162. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  163. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  164. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  165. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  166. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  167. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  168. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  169. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  170. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  171. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  172. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  173. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  174. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  175. package/src/route-renderer/route-renderer.d.ts +57 -14
  176. package/src/route-renderer/route-renderer.js +30 -18
  177. package/src/router/README.md +94 -0
  178. package/src/router/client/link-intent.d.ts +53 -0
  179. package/src/router/client/link-intent.js +34 -0
  180. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  181. package/src/router/client/link-intent.test.browser.js +43 -0
  182. package/src/router/client/navigation-coordinator.d.ts +169 -0
  183. package/src/router/client/navigation-coordinator.js +215 -0
  184. package/src/router/server/route-registry.d.ts +78 -0
  185. package/src/router/server/route-registry.js +262 -0
  186. package/src/services/README.md +28 -0
  187. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  188. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  189. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  191. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  192. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  193. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  194. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  195. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  196. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  197. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  198. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  199. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  200. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  201. package/src/services/assets/asset-processing-service/index.js +6 -0
  202. package/src/services/assets/asset-processing-service/page-package.d.ts +3 -0
  203. package/src/services/assets/asset-processing-service/page-package.js +74 -0
  204. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  205. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  208. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  209. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  210. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  211. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  212. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  213. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
  214. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  215. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  216. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  217. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +12 -7
  218. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  219. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  220. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  222. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  223. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  224. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  225. package/src/services/assets/browser-bundle.service.js +41 -0
  226. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  227. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  228. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  229. package/src/services/html/html-rewriter-provider.service.js +68 -0
  230. package/src/services/html/html-transformer.service.d.ts +87 -0
  231. package/src/services/html/html-transformer.service.js +216 -0
  232. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  233. package/src/services/invalidation/development-invalidation.service.js +190 -0
  234. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  235. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  236. package/src/services/module-loading/app-server-module-transpiler.service.js +115 -0
  237. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  238. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  239. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  240. package/src/services/module-loading/module-loading-types.js +0 -0
  241. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  242. package/src/services/module-loading/node-bootstrap-plugin.js +216 -0
  243. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  244. package/src/services/module-loading/page-module-import.service.js +170 -0
  245. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  246. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  247. package/src/services/module-loading/source-module-support.d.ts +5 -0
  248. package/src/services/module-loading/source-module-support.js +8 -0
  249. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  250. package/src/services/runtime-state/dev-graph.service.js +162 -0
  251. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  252. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  253. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  254. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  255. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  256. package/src/static-site-generator/README.md +26 -0
  257. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  258. package/src/static-site-generator/static-site-generator.js +182 -138
  259. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  260. package/src/types/internal-types.js +0 -0
  261. package/src/{public-types.d.ts → types/public-types.d.ts} +201 -32
  262. package/src/types/public-types.js +0 -0
  263. package/src/utils/html-escaping.d.ts +7 -0
  264. package/src/utils/html-escaping.js +6 -0
  265. package/src/utils/locals-utils.d.ts +1 -1
  266. package/src/utils/parse-cli-args.d.ts +4 -1
  267. package/src/utils/parse-cli-args.js +16 -1
  268. package/src/utils/resolve-work-dir.d.ts +11 -0
  269. package/src/utils/resolve-work-dir.js +31 -0
  270. package/src/watchers/project-watcher.d.ts +40 -29
  271. package/src/watchers/project-watcher.js +126 -116
  272. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  273. package/src/watchers/project-watcher.test-helpers.js +6 -6
  274. package/src/adapters/abstract/application-adapter.ts +0 -337
  275. package/src/adapters/abstract/router-adapter.ts +0 -30
  276. package/src/adapters/abstract/server-adapter.ts +0 -79
  277. package/src/adapters/bun/client-bridge.ts +0 -62
  278. package/src/adapters/bun/create-app.ts +0 -189
  279. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  280. package/src/adapters/bun/define-api-handler.ts +0 -114
  281. package/src/adapters/bun/hmr-manager.ts +0 -296
  282. package/src/adapters/bun/index.ts +0 -3
  283. package/src/adapters/bun/server-adapter.ts +0 -492
  284. package/src/adapters/bun/server-lifecycle.ts +0 -154
  285. package/src/adapters/index.ts +0 -6
  286. package/src/adapters/node/create-app.ts +0 -179
  287. package/src/adapters/node/index.d.ts +0 -4
  288. package/src/adapters/node/index.js +0 -8
  289. package/src/adapters/node/index.ts +0 -9
  290. package/src/adapters/node/node-client-bridge.ts +0 -79
  291. package/src/adapters/node/node-hmr-manager.ts +0 -289
  292. package/src/adapters/node/server-adapter.ts +0 -561
  293. package/src/adapters/node/static-content-server.ts +0 -203
  294. package/src/adapters/shared/api-response.ts +0 -104
  295. package/src/adapters/shared/application-adapter.ts +0 -199
  296. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  297. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  298. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  299. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  300. package/src/adapters/shared/render-context.ts +0 -105
  301. package/src/adapters/shared/server-adapter.ts +0 -442
  302. package/src/adapters/shared/server-route-handler.ts +0 -166
  303. package/src/adapters/shared/server-static-builder.ts +0 -82
  304. package/src/build/build-adapter.ts +0 -132
  305. package/src/build/build-types.ts +0 -83
  306. package/src/build/esbuild-build-adapter.ts +0 -510
  307. package/src/config/config-builder.ts +0 -474
  308. package/src/constants.ts +0 -39
  309. package/src/create-app.ts +0 -87
  310. package/src/define-api-handler.js +0 -15
  311. package/src/define-api-handler.ts +0 -66
  312. package/src/dev/sc-server.ts +0 -143
  313. package/src/eco/component-render-context.d.ts +0 -105
  314. package/src/eco/component-render-context.js +0 -77
  315. package/src/eco/component-render-context.ts +0 -202
  316. package/src/eco/eco.ts +0 -221
  317. package/src/eco/eco.types.ts +0 -202
  318. package/src/eco/eco.utils.ts +0 -89
  319. package/src/eco/global-injector-map.ts +0 -112
  320. package/src/eco/lazy-injector-map.ts +0 -120
  321. package/src/eco/module-dependencies.ts +0 -75
  322. package/src/errors/http-error.ts +0 -72
  323. package/src/errors/index.ts +0 -2
  324. package/src/errors/locals-access-error.ts +0 -7
  325. package/src/global/app-logger.ts +0 -4
  326. 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
  327. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  328. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  329. package/src/hmr/client/hmr-runtime.ts +0 -121
  330. package/src/hmr/hmr-strategy.ts +0 -172
  331. package/src/hmr/hmr.test.e2e.ts +0 -75
  332. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  333. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  334. package/src/index.browser.ts +0 -3
  335. package/src/index.ts +0 -5
  336. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  337. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  338. package/src/internal-types.ts +0 -212
  339. package/src/plugins/alias-resolver-plugin.ts +0 -45
  340. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  341. package/src/plugins/integration-plugin.ts +0 -184
  342. package/src/plugins/processor.ts +0 -220
  343. package/src/public-types.ts +0 -1260
  344. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  345. package/src/route-renderer/component-graph-executor.js +0 -31
  346. package/src/route-renderer/component-graph-executor.ts +0 -84
  347. package/src/route-renderer/component-graph.d.ts +0 -42
  348. package/src/route-renderer/component-graph.js +0 -72
  349. package/src/route-renderer/component-graph.ts +0 -159
  350. package/src/route-renderer/component-marker.d.ts +0 -52
  351. package/src/route-renderer/component-marker.js +0 -46
  352. package/src/route-renderer/component-marker.ts +0 -117
  353. package/src/route-renderer/dependency-resolver.js +0 -428
  354. package/src/route-renderer/dependency-resolver.ts +0 -596
  355. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  356. package/src/route-renderer/html-post-processing.service.js +0 -86
  357. package/src/route-renderer/html-post-processing.service.ts +0 -103
  358. package/src/route-renderer/integration-renderer.d.ts +0 -339
  359. package/src/route-renderer/integration-renderer.js +0 -526
  360. package/src/route-renderer/integration-renderer.ts +0 -696
  361. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  362. package/src/route-renderer/marker-graph-resolver.js +0 -93
  363. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  364. package/src/route-renderer/page-module-loader.d.ts +0 -61
  365. package/src/route-renderer/page-module-loader.ts +0 -153
  366. package/src/route-renderer/render-execution.service.d.ts +0 -69
  367. package/src/route-renderer/render-execution.service.js +0 -91
  368. package/src/route-renderer/render-execution.service.ts +0 -158
  369. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  370. package/src/route-renderer/render-preparation.service.js +0 -243
  371. package/src/route-renderer/render-preparation.service.ts +0 -358
  372. package/src/route-renderer/route-renderer.ts +0 -80
  373. package/src/router/fs-router-scanner.d.ts +0 -41
  374. package/src/router/fs-router-scanner.js +0 -155
  375. package/src/router/fs-router-scanner.ts +0 -217
  376. package/src/router/fs-router.d.ts +0 -26
  377. package/src/router/fs-router.js +0 -100
  378. package/src/router/fs-router.ts +0 -122
  379. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  380. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  381. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  382. package/src/services/asset-processing-service/assets.types.ts +0 -112
  383. package/src/services/asset-processing-service/index.d.ts +0 -3
  384. package/src/services/asset-processing-service/index.js +0 -3
  385. package/src/services/asset-processing-service/index.ts +0 -3
  386. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  387. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  388. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  389. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  390. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  391. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  392. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  393. package/src/services/asset-processing-service/processors/index.js +0 -5
  394. package/src/services/asset-processing-service/processors/index.ts +0 -5
  395. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  396. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  397. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  398. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  399. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  400. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  401. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  402. package/src/services/cache/cache.types.ts +0 -126
  403. package/src/services/cache/index.ts +0 -18
  404. package/src/services/cache/memory-cache-store.ts +0 -130
  405. package/src/services/cache/page-cache-service.ts +0 -202
  406. package/src/services/html-transformer.service.d.ts +0 -50
  407. package/src/services/html-transformer.service.js +0 -163
  408. package/src/services/html-transformer.service.ts +0 -217
  409. package/src/services/page-module-import.service.d.ts +0 -37
  410. package/src/services/page-module-import.service.js +0 -88
  411. package/src/services/page-module-import.service.ts +0 -129
  412. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  413. package/src/services/schema-validation-service.ts +0 -204
  414. package/src/services/validation/standard-schema.types.ts +0 -68
  415. package/src/static-site-generator/static-site-generator.ts +0 -359
  416. package/src/utils/css.d.ts +0 -1
  417. package/src/utils/css.js +0 -7
  418. package/src/utils/css.ts +0 -5
  419. package/src/utils/deep-merge.ts +0 -47
  420. package/src/utils/hash.ts +0 -5
  421. package/src/utils/html.ts +0 -1
  422. package/src/utils/invariant.ts +0 -15
  423. package/src/utils/locals-utils.ts +0 -37
  424. package/src/utils/parse-cli-args.ts +0 -83
  425. package/src/utils/path-utils.module.ts +0 -14
  426. package/src/utils/runtime.ts +0 -44
  427. package/src/utils/server-utils.module.ts +0 -67
  428. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  429. package/src/watchers/project-watcher.ts +0 -344
  430. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  431. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  432. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  433. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  434. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  435. /package/src/{public-types.js → services/module-loading/app-module-loader.service.js} +0 -0
  436. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,19 +1,23 @@
1
- import type { EcoPagesAppConfig, FileSystemServerOptions } from '../../internal-types.js';
2
- import type { RouteRendererBody } from '../../public-types.js';
3
- import type { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
1
+ import type { FileSystemServerOptions } from '../../types/internal-types.js';
2
+ import type { RouteRendererBody } from '../../types/public-types.js';
3
+ /**
4
+ * Builds HTTP responses for static files and shared file-system fallbacks.
5
+ */
4
6
  export declare class FileSystemServerResponseFactory {
5
- private appConfig;
6
- private routeRendererFactory;
7
7
  private options;
8
- constructor({ appConfig, routeRendererFactory, options, }: {
9
- appConfig: EcoPagesAppConfig;
10
- routeRendererFactory: RouteRendererFactory;
8
+ constructor({ options }: {
11
9
  options: FileSystemServerOptions;
12
10
  });
13
11
  isHtml(contentType: string): contentType is "text/html";
14
12
  shouldEnableGzip(contentType: string): boolean;
15
13
  createResponseWithBody(body: RouteRendererBody, init?: ResponseInit): Promise<Response>;
16
14
  createDefaultNotFoundResponse(): Promise<Response>;
17
- createCustomNotFoundResponse(): Promise<Response>;
18
- createFileResponse(filePath: string, contentType: string): Promise<Response>;
15
+ /**
16
+ * Wraps already-rendered HTML in a 404 response envelope.
17
+ */
18
+ createHtmlNotFoundResponse(body: RouteRendererBody): Promise<Response>;
19
+ /**
20
+ * Reads a static file response, returning `null` when the file is missing.
21
+ */
22
+ createFileResponse(filePath: string, contentType: string): Promise<Response | null>;
19
23
  }
@@ -1,17 +1,9 @@
1
- import { STATUS_MESSAGE } from "../../constants.js";
1
+ import { STATUS_MESSAGE } from "../../config/constants.js";
2
2
  import { appLogger } from "../../global/app-logger.js";
3
3
  import { fileSystem } from "@ecopages/file-system";
4
4
  class FileSystemServerResponseFactory {
5
- appConfig;
6
- routeRendererFactory;
7
5
  options;
8
- constructor({
9
- appConfig,
10
- routeRendererFactory,
11
- options
12
- }) {
13
- this.appConfig = appConfig;
14
- this.routeRendererFactory = routeRendererFactory;
6
+ constructor({ options }) {
15
7
  this.options = options;
16
8
  }
17
9
  isHtml(contentType) {
@@ -34,22 +26,11 @@ class FileSystemServerResponseFactory {
34
26
  status: 404
35
27
  });
36
28
  }
37
- async createCustomNotFoundResponse() {
38
- const error404TemplatePath = this.appConfig.absolutePaths.error404TemplatePath;
39
- try {
40
- fileSystem.verifyFileExists(error404TemplatePath);
41
- } catch {
42
- appLogger.debug(
43
- "Custom 404 template not found, falling back to default 404 response",
44
- error404TemplatePath
45
- );
46
- return this.createDefaultNotFoundResponse();
47
- }
48
- const routeRenderer = this.routeRendererFactory.createRenderer(error404TemplatePath);
49
- const result = await routeRenderer.createRoute({
50
- file: error404TemplatePath
51
- });
52
- return await this.createResponseWithBody(result.body, {
29
+ /**
30
+ * Wraps already-rendered HTML in a 404 response envelope.
31
+ */
32
+ async createHtmlNotFoundResponse(body) {
33
+ return await this.createResponseWithBody(body, {
53
34
  status: 404,
54
35
  statusText: STATUS_MESSAGE[404],
55
36
  headers: {
@@ -57,6 +38,9 @@ class FileSystemServerResponseFactory {
57
38
  }
58
39
  });
59
40
  }
41
+ /**
42
+ * Reads a static file response, returning `null` when the file is missing.
43
+ */
60
44
  async createFileResponse(filePath, contentType) {
61
45
  try {
62
46
  let file;
@@ -88,7 +72,7 @@ class FileSystemServerResponseFactory {
88
72
  } else {
89
73
  appLogger.error("Error reading file", filePath, err);
90
74
  }
91
- return this.createCustomNotFoundResponse();
75
+ return null;
92
76
  }
93
77
  }
94
78
  }
@@ -1,16 +1,14 @@
1
- import type { MatchResult } from '../../internal-types.js';
2
- import type { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
3
- import type { FSRouter } from '../../router/fs-router.js';
1
+ import type { EcoPagesAppConfig, MatchResult } from '../../types/internal-types.js';
2
+ import type { PageRendererResolver } from '../../route-renderer/route-renderer.js';
3
+ import type { RouteRegistry } from '../../router/server/route-registry.js';
4
4
  import type { PageCacheService } from '../../services/cache/page-cache-service.js';
5
5
  import type { CacheStrategy } from '../../services/cache/cache.types.js';
6
6
  import type { FileSystemServerResponseFactory } from './fs-server-response-factory.js';
7
- export declare const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS: {
8
- readonly transpilePageModuleFailed: (details: string) => string;
9
- readonly noTranspiledOutputForPageModule: (filePath: string) => string;
10
- };
11
7
  export interface FileSystemResponseMatcherOptions {
12
- router: FSRouter;
13
- routeRendererFactory: RouteRendererFactory;
8
+ appConfig: EcoPagesAppConfig;
9
+ assetPrefix: string;
10
+ router: RouteRegistry;
11
+ routeRendererFactory: PageRendererResolver;
14
12
  fileSystemResponseFactory: FileSystemServerResponseFactory;
15
13
  /** Optional cache service. When null, caching is disabled. */
16
14
  cacheService?: PageCacheService | null;
@@ -20,23 +18,22 @@ export interface FileSystemResponseMatcherOptions {
20
18
  /**
21
19
  * Matches file-system routes to rendered HTML responses.
22
20
  *
23
- * This class sits at the request-time boundary between router matches and the
24
- * render pipeline. It coordinates page module inspection, request-local policy,
21
+ * This render pipeline coordinates page module inspection, request-local policy,
25
22
  * renderer invocation, middleware execution, cache integration, and fallback
26
23
  * error translation.
27
24
  */
28
25
  export declare class FileSystemResponseMatcher {
26
+ private appConfig;
27
+ private assetPrefix;
29
28
  private router;
30
29
  private routeRendererFactory;
31
30
  private fileSystemResponseFactory;
32
- private pageModuleImportService;
33
31
  private pageRequestCacheCoordinator;
34
32
  private fileRouteMiddlewarePipeline;
35
- constructor({ router, routeRendererFactory, fileSystemResponseFactory, cacheService, defaultCacheStrategy, }: FileSystemResponseMatcherOptions);
33
+ constructor({ appConfig, assetPrefix, router, routeRendererFactory, fileSystemResponseFactory, cacheService, defaultCacheStrategy, }: FileSystemResponseMatcherOptions);
36
34
  /**
37
35
  * Resolves unmatched paths either as static asset requests or as the custom
38
36
  * not-found page.
39
- *
40
37
  * @param requestUrl Incoming pathname.
41
38
  * @returns Static file response or rendered 404 response.
42
39
  */
@@ -53,12 +50,19 @@ export declare class FileSystemResponseMatcher {
53
50
  * @returns Final response for the matched route.
54
51
  */
55
52
  handleMatch(match: MatchResult, request?: Request): Promise<Response>;
53
+ /**
54
+ * Renders the app-owned custom 404 page, falling back to the default text 404
55
+ * when the page template cannot be resolved.
56
+ */
57
+ private renderCustomNotFoundResponse;
58
+ private createExecutionPlan;
56
59
  /**
57
60
  * Loads the matched page module for request-time inspection.
58
61
  *
59
62
  * The matcher needs access to page-level metadata such as `cache` and
60
- * `middleware` before full rendering starts, so it uses the shared module
61
- * import service directly rather than going through route rendering.
63
+ * `middleware` before full rendering starts, so it asks the owning route
64
+ * renderer to load the page module. That preserves integration-specific page
65
+ * import setup for request-time inspection as well as for full rendering.
62
66
  *
63
67
  * @param filePath Absolute page module path.
64
68
  * @returns Imported page module.
@@ -1,52 +1,51 @@
1
1
  import path from "node:path";
2
2
  import { appLogger } from "../../global/app-logger.js";
3
- import { PageModuleImportService } from "../../services/page-module-import.service.js";
4
- import { PageRequestCacheCoordinator } from "../../services/page-request-cache-coordinator.service.js";
3
+ import { PageRequestCacheCoordinator } from "../../services/cache/page-request-cache-coordinator.service.js";
5
4
  import { ServerUtils } from "../../utils/server-utils.module.js";
6
5
  import { FileRouteMiddlewarePipeline } from "./file-route-middleware-pipeline.js";
7
6
  import { LocalsAccessError } from "../../errors/locals-access-error.js";
8
7
  import { isDevelopmentRuntime } from "../../utils/runtime.js";
9
- const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS = {
10
- transpilePageModuleFailed: (details) => `Error transpiling page module: ${details}`,
11
- noTranspiledOutputForPageModule: (filePath) => `No transpiled output generated for page module: ${filePath}`
12
- };
13
8
  class FileSystemResponseMatcher {
9
+ appConfig;
10
+ assetPrefix;
14
11
  router;
15
12
  routeRendererFactory;
16
13
  fileSystemResponseFactory;
17
- pageModuleImportService;
18
14
  pageRequestCacheCoordinator;
19
15
  fileRouteMiddlewarePipeline;
20
16
  constructor({
17
+ appConfig,
18
+ assetPrefix,
21
19
  router,
22
20
  routeRendererFactory,
23
21
  fileSystemResponseFactory,
24
22
  cacheService = null,
25
23
  defaultCacheStrategy = "static"
26
24
  }) {
25
+ this.appConfig = appConfig;
26
+ this.assetPrefix = assetPrefix;
27
27
  this.router = router;
28
28
  this.routeRendererFactory = routeRendererFactory;
29
29
  this.fileSystemResponseFactory = fileSystemResponseFactory;
30
- this.pageModuleImportService = new PageModuleImportService();
31
30
  this.pageRequestCacheCoordinator = new PageRequestCacheCoordinator(cacheService, defaultCacheStrategy);
32
31
  this.fileRouteMiddlewarePipeline = new FileRouteMiddlewarePipeline(cacheService);
33
32
  }
34
33
  /**
35
34
  * Resolves unmatched paths either as static asset requests or as the custom
36
35
  * not-found page.
37
- *
38
36
  * @param requestUrl Incoming pathname.
39
37
  * @returns Static file response or rendered 404 response.
40
38
  */
41
39
  async handleNoMatch(requestUrl) {
42
40
  const isStaticFileRequest = ServerUtils.hasKnownExtension(requestUrl);
43
41
  if (!isStaticFileRequest) {
44
- return this.fileSystemResponseFactory.createCustomNotFoundResponse();
42
+ return this.renderCustomNotFoundResponse();
45
43
  }
46
44
  const relativeUrl = requestUrl.startsWith("/") ? requestUrl.slice(1) : requestUrl;
47
- const filePath = path.join(this.router.assetPrefix, relativeUrl);
45
+ const filePath = path.join(this.assetPrefix, relativeUrl);
48
46
  const contentType = ServerUtils.getContentType(filePath);
49
- return this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
47
+ const response = await this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
48
+ return response ?? this.renderCustomNotFoundResponse();
50
49
  }
51
50
  /**
52
51
  * Handles a matched file-system page route.
@@ -60,34 +59,25 @@ class FileSystemResponseMatcher {
60
59
  * @returns Final response for the matched route.
61
60
  */
62
61
  async handleMatch(match, request) {
63
- const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey(match);
64
62
  try {
65
- const resolvedRequest = request ?? new Request(new URL(cacheKey, this.router.origin).toString(), {
66
- method: "GET"
67
- });
68
- const localsStore = {};
69
- const pageModule = await this.importPageModule(match.filePath);
70
- const Page = pageModule?.default;
71
- const pageMiddleware = Page?.middleware ?? [];
72
- const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
73
- const localsForRender = pageCacheStrategy === "dynamic" ? localsStore : void 0;
63
+ const executionPlan = await this.createExecutionPlan(match, request);
74
64
  this.fileRouteMiddlewarePipeline.assertValidConfiguration({
75
- middleware: pageMiddleware,
76
- pageCacheStrategy,
77
- filePath: match.filePath
65
+ middleware: executionPlan.pageMiddleware,
66
+ pageCacheStrategy: executionPlan.pageCacheStrategy,
67
+ filePath: executionPlan.pageFilePath
78
68
  });
79
- const routeRenderer = this.routeRendererFactory.createRenderer(match.filePath);
69
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(executionPlan.pageFilePath);
80
70
  const middlewareContext = this.fileRouteMiddlewarePipeline.createContext({
81
- request: resolvedRequest,
71
+ request: executionPlan.request,
82
72
  params: match.params,
83
- locals: localsStore
73
+ locals: executionPlan.localsStore
84
74
  });
85
75
  const renderFn = async () => {
86
- const result = await routeRenderer.createRoute({
87
- file: match.filePath,
76
+ const result = await routeRenderer.execute({
77
+ file: executionPlan.pageFilePath,
88
78
  params: match.params,
89
79
  query: match.query,
90
- locals: localsForRender
80
+ locals: executionPlan.localsForRender
91
81
  });
92
82
  const html = await this.pageRequestCacheCoordinator.bodyToString(result.body);
93
83
  const strategy = result.cacheStrategy ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
@@ -95,13 +85,13 @@ class FileSystemResponseMatcher {
95
85
  };
96
86
  const renderResponse = async () => {
97
87
  return this.pageRequestCacheCoordinator.render({
98
- cacheKey,
99
- pageCacheStrategy,
88
+ cacheKey: executionPlan.cacheKey,
89
+ pageCacheStrategy: executionPlan.pageCacheStrategy,
100
90
  renderFn
101
91
  });
102
92
  };
103
93
  return await this.fileRouteMiddlewarePipeline.run({
104
- middleware: pageMiddleware,
94
+ middleware: executionPlan.pageMiddleware,
105
95
  context: middlewareContext,
106
96
  renderResponse
107
97
  });
@@ -117,29 +107,71 @@ class FileSystemResponseMatcher {
117
107
  }
118
108
  if (error instanceof Error) {
119
109
  if (isDevelopmentRuntime() || appLogger.isDebugEnabled()) {
120
- appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.pathname}`);
110
+ appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.requestedPathname}`);
121
111
  }
122
112
  }
123
- return this.fileSystemResponseFactory.createCustomNotFoundResponse();
113
+ return this.renderCustomNotFoundResponse();
114
+ }
115
+ }
116
+ /**
117
+ * Renders the app-owned custom 404 page, falling back to the default text 404
118
+ * when the page template cannot be resolved.
119
+ */
120
+ async renderCustomNotFoundResponse() {
121
+ const error404TemplatePath = this.appConfig.absolutePaths.error404TemplatePath;
122
+ try {
123
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(error404TemplatePath);
124
+ const result = await routeRenderer.execute({
125
+ file: error404TemplatePath
126
+ });
127
+ return this.fileSystemResponseFactory.createHtmlNotFoundResponse(result.body);
128
+ } catch {
129
+ appLogger.debug(
130
+ "Custom 404 template not found, falling back to default 404 response",
131
+ error404TemplatePath
132
+ );
133
+ return this.fileSystemResponseFactory.createDefaultNotFoundResponse();
124
134
  }
125
135
  }
136
+ async createExecutionPlan(match, request) {
137
+ const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey({
138
+ pathname: match.requestedPathname,
139
+ query: match.query
140
+ });
141
+ const resolvedRequest = request ?? new Request(new URL(cacheKey, this.router.origin).toString(), {
142
+ method: "GET"
143
+ });
144
+ const localsStore = {};
145
+ const pageFilePath = match.templateRoute.filePath;
146
+ const pageModule = await this.importPageModule(pageFilePath);
147
+ const Page = pageModule?.default;
148
+ const pageMiddleware = Page?.middleware ?? [];
149
+ const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
150
+ return {
151
+ cacheKey,
152
+ request: resolvedRequest,
153
+ pageFilePath,
154
+ pageMiddleware,
155
+ pageCacheStrategy,
156
+ localsStore,
157
+ localsForRender: pageCacheStrategy === "dynamic" ? localsStore : void 0
158
+ };
159
+ }
126
160
  /**
127
161
  * Loads the matched page module for request-time inspection.
128
162
  *
129
163
  * The matcher needs access to page-level metadata such as `cache` and
130
- * `middleware` before full rendering starts, so it uses the shared module
131
- * import service directly rather than going through route rendering.
164
+ * `middleware` before full rendering starts, so it asks the owning route
165
+ * renderer to load the page module. That preserves integration-specific page
166
+ * import setup for request-time inspection as well as for full rendering.
132
167
  *
133
168
  * @param filePath Absolute page module path.
134
169
  * @returns Imported page module.
135
170
  */
136
171
  async importPageModule(filePath) {
137
- return this.pageModuleImportService.importModule({
138
- filePath,
139
- rootDir: path.dirname(this.router.assetPrefix),
140
- outdir: path.join(this.router.assetPrefix, ".server-modules-meta"),
141
- transpileErrorMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.transpilePageModuleFailed,
142
- noOutputMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.noTranspiledOutputForPageModule
172
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(filePath);
173
+ return routeRenderer.loadPageModule(filePath, {
174
+ cacheScope: "request-metadata"
143
175
  });
144
176
  }
145
177
  /**
@@ -150,6 +182,5 @@ class FileSystemResponseMatcher {
150
182
  }
151
183
  }
152
184
  export {
153
- FILE_SYSTEM_RESPONSE_MATCHER_ERRORS,
154
185
  FileSystemResponseMatcher
155
186
  };
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Shared runtime state used while registering HMR-owned entrypoints.
3
+ */
4
+ export interface HmrEntrypointRegistrarOptions {
5
+ /** Absolute source directory used to derive the emitted HMR path. */
6
+ srcDir: string;
7
+ /** Absolute distribution directory where HMR outputs are written. */
8
+ distDir: string;
9
+ /** In-flight registrations keyed by normalized absolute entrypoint path. */
10
+ entrypointRegistrations: Map<string, Promise<string>>;
11
+ /** Stable entrypoint-to-output mapping retained once an entrypoint is registered. */
12
+ watchedFiles: Map<string, string>;
13
+ /** Runtime-specific cleanup invoked when an entrypoint registration fails. */
14
+ clearFailedRegistration?: (entrypointPath: string) => void;
15
+ /** Development-only guardrail for integrations that never finish producing output. */
16
+ registrationTimeoutMs: number;
17
+ }
18
+ /**
19
+ * Runtime-specific hooks required to materialize a single HMR entrypoint.
20
+ */
21
+ export interface HmrEntrypointRegistrationOptions {
22
+ /**
23
+ * Emits the browser-consumable HMR artifact for an entrypoint.
24
+ */
25
+ emit(entrypointPath: string, outputPath: string): Promise<void>;
26
+ /**
27
+ * Creates the runtime-specific error raised when the emit hook completes without producing output.
28
+ */
29
+ getMissingOutputError(entrypointPath: string, outputPath: string): Error;
30
+ }
31
+ /**
32
+ * Coordinates the shared HMR entrypoint registration lifecycle for both Node and Bun managers.
33
+ *
34
+ * The registrar owns the cross-runtime policy: normalize entrypoint identities, dedupe concurrent
35
+ * registrations, derive the emitted `_hmr` output path, clear stale output before rebuilding, and
36
+ * apply the development timeout that prevents unresolved registrations from hanging navigation.
37
+ * Runtime-specific managers remain responsible for the actual emit step and any cleanup outside
38
+ * this shared registration flow.
39
+ */
40
+ export declare class HmrEntrypointRegistrar {
41
+ private readonly options;
42
+ constructor(options: HmrEntrypointRegistrarOptions);
43
+ /**
44
+ * Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
45
+ *
46
+ * Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
47
+ * integration only builds once per registration cycle.
48
+ */
49
+ registerEntrypoint(entrypointPath: string, registrationOptions: HmrEntrypointRegistrationOptions): Promise<string>;
50
+ private registerEntrypointInternal;
51
+ private awaitEntrypointRegistration;
52
+ private getEntrypointOutput;
53
+ private removeStaleEntrypointOutput;
54
+ private encodeDynamicSegments;
55
+ }
@@ -0,0 +1,87 @@
1
+ import path from "node:path";
2
+ import { fileSystem } from "@ecopages/file-system";
3
+ import { appLogger } from "../../global/app-logger.js";
4
+ import { RESOLVED_ASSETS_DIR } from "../../config/constants.js";
5
+ class HmrEntrypointRegistrar {
6
+ options;
7
+ constructor(options) {
8
+ this.options = options;
9
+ }
10
+ /**
11
+ * Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
12
+ *
13
+ * Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
14
+ * integration only builds once per registration cycle.
15
+ */
16
+ async registerEntrypoint(entrypointPath, registrationOptions) {
17
+ const normalizedEntrypoint = path.resolve(entrypointPath);
18
+ const existingRegistration = this.options.entrypointRegistrations.get(normalizedEntrypoint);
19
+ if (existingRegistration) {
20
+ return await this.awaitEntrypointRegistration(existingRegistration, normalizedEntrypoint);
21
+ }
22
+ const registration = this.registerEntrypointInternal(normalizedEntrypoint, registrationOptions);
23
+ this.options.entrypointRegistrations.set(normalizedEntrypoint, registration);
24
+ try {
25
+ return await this.awaitEntrypointRegistration(registration, normalizedEntrypoint);
26
+ } catch (error) {
27
+ this.options.clearFailedRegistration?.(normalizedEntrypoint);
28
+ throw error;
29
+ } finally {
30
+ this.options.entrypointRegistrations.delete(normalizedEntrypoint);
31
+ }
32
+ }
33
+ async registerEntrypointInternal(entrypointPath, registrationOptions) {
34
+ if (this.options.watchedFiles.has(entrypointPath)) {
35
+ return this.options.watchedFiles.get(entrypointPath);
36
+ }
37
+ const { outputPath, outputUrl } = this.getEntrypointOutput(entrypointPath);
38
+ this.options.watchedFiles.set(entrypointPath, outputUrl);
39
+ this.removeStaleEntrypointOutput(outputPath);
40
+ await registrationOptions.emit(entrypointPath, outputPath);
41
+ if (!fileSystem.exists(outputPath)) {
42
+ throw registrationOptions.getMissingOutputError(entrypointPath, outputPath);
43
+ }
44
+ return outputUrl;
45
+ }
46
+ async awaitEntrypointRegistration(registration, entrypointPath) {
47
+ if (process.env.NODE_ENV !== "development") {
48
+ return await registration;
49
+ }
50
+ return await Promise.race([
51
+ registration,
52
+ new Promise((_, reject) => {
53
+ setTimeout(() => {
54
+ reject(new Error(`[HMR] Timed out registering entrypoint: ${entrypointPath}`));
55
+ }, this.options.registrationTimeoutMs);
56
+ })
57
+ ]);
58
+ }
59
+ getEntrypointOutput(entrypointPath) {
60
+ const relativePath = path.relative(this.options.srcDir, entrypointPath);
61
+ const relativePathJs = relativePath.replace(/\.(tsx?|jsx?|mdx?)$/, ".js");
62
+ const encodedPathJs = this.encodeDynamicSegments(relativePathJs);
63
+ const urlPath = encodedPathJs.split(path.sep).join("/");
64
+ return {
65
+ outputUrl: `/${path.join(RESOLVED_ASSETS_DIR, "_hmr", urlPath)}`,
66
+ outputPath: path.join(this.options.distDir, urlPath)
67
+ };
68
+ }
69
+ removeStaleEntrypointOutput(outputPath) {
70
+ if (!fileSystem.exists(outputPath)) {
71
+ return;
72
+ }
73
+ try {
74
+ fileSystem.remove(outputPath);
75
+ } catch (error) {
76
+ appLogger.warn(
77
+ `[HMR] Failed to remove stale entrypoint output ${outputPath}: ${error instanceof Error ? error.message : String(error)}`
78
+ );
79
+ }
80
+ }
81
+ encodeDynamicSegments(filepath) {
82
+ return filepath.replace(/\[([^\]]+)\]/g, "_$1_");
83
+ }
84
+ }
85
+ export {
86
+ HmrEntrypointRegistrar
87
+ };
@@ -0,0 +1,22 @@
1
+ import type { IHmrManager } from '../../types/public-types.js';
2
+ /**
3
+ * Returns whether a response is HTML and therefore eligible for development HMR
4
+ * runtime injection.
5
+ */
6
+ export declare function isHtmlResponse(response: Response): boolean;
7
+ /**
8
+ * Returns whether HTML responses should receive the HMR runtime bootstrap.
9
+ *
10
+ * This is shared because filesystem page responses and adapter-level HTML
11
+ * responses flow through different layers, but both need identical injection
12
+ * behavior in watch mode.
13
+ */
14
+ export declare function shouldInjectHmrHtmlResponse(watch: boolean, hmrManager?: Pick<IHmrManager, 'isEnabled'>): boolean;
15
+ /**
16
+ * Injects the development HMR runtime script into an HTML response if it is not
17
+ * already present.
18
+ *
19
+ * The check is intentionally idempotent because an HTML response can pass
20
+ * through more than one development-layer wrapper before reaching the client.
21
+ */
22
+ export declare function injectHmrRuntimeIntoHtmlResponse(response: Response): Promise<Response>;
@@ -0,0 +1,32 @@
1
+ const HMR_RUNTIME_IMPORT = "import '/_hmr_runtime.js'";
2
+ const HMR_RUNTIME_SCRIPT = `<script type="module">${HMR_RUNTIME_IMPORT};<\/script>`;
3
+ function isHtmlResponse(response) {
4
+ const contentType = response.headers.get("Content-Type");
5
+ return contentType !== null && contentType.startsWith("text/html");
6
+ }
7
+ function shouldInjectHmrHtmlResponse(watch, hmrManager) {
8
+ return watch && hmrManager?.isEnabled() === true;
9
+ }
10
+ async function injectHmrRuntimeIntoHtmlResponse(response) {
11
+ const html = await response.text();
12
+ if (html.includes(HMR_RUNTIME_IMPORT)) {
13
+ return new Response(html, {
14
+ status: response.status,
15
+ statusText: response.statusText,
16
+ headers: response.headers
17
+ });
18
+ }
19
+ const updatedHtml = html.replace(/<\/html>/i, `${HMR_RUNTIME_SCRIPT}</html>`);
20
+ const headers = new Headers(response.headers);
21
+ headers.delete("Content-Length");
22
+ return new Response(updatedHtml, {
23
+ status: response.status,
24
+ statusText: response.statusText,
25
+ headers
26
+ });
27
+ }
28
+ export {
29
+ injectHmrRuntimeIntoHtmlResponse,
30
+ isHtmlResponse,
31
+ shouldInjectHmrHtmlResponse
32
+ };
@@ -1,7 +1,8 @@
1
- import type { RenderContext } from '../../public-types.js';
2
- import type { IntegrationPlugin } from '../../plugins/integration-plugin.js';
1
+ import type { RenderContext } from '../../types/public-types.js';
2
+ import type { AnyIntegrationPlugin } from '../../plugins/integration-plugin.js';
3
3
  export interface CreateRenderContextOptions {
4
- integrations: IntegrationPlugin[];
4
+ integrations: AnyIntegrationPlugin[];
5
+ rendererModules?: unknown;
5
6
  }
6
7
  /**
7
8
  * Creates a render context for route handlers.
@@ -15,12 +15,14 @@ function createRenderContext(options) {
15
15
  );
16
16
  const integration = integrations.find((i) => i.name === integrationName);
17
17
  invariant(!!integration, `No integration found for: ${integrationName}`);
18
- return integration.initializeRenderer();
18
+ return integration.initializeRenderer({
19
+ rendererModules: options.rendererModules
20
+ });
19
21
  };
20
- return {
22
+ const renderContext = {
21
23
  async render(view, props, renderOptions) {
22
24
  const locals = this?.locals;
23
- const mergedProps = mergePropsWithLocals(props, locals);
25
+ const mergedProps = mergePropsWithLocals(props ?? {}, locals);
24
26
  const renderer = getRendererForView(view);
25
27
  const ctx = {
26
28
  partial: false,
@@ -63,6 +65,7 @@ function createRenderContext(options) {
63
65
  });
64
66
  }
65
67
  };
68
+ return renderContext;
66
69
  }
67
70
  export {
68
71
  createRenderContext
@@ -0,0 +1,38 @@
1
+ import { type BuildExecutor } from '../../build/build-adapter.js';
2
+ import type { EcoBuildPlugin } from '../../build/build-types.js';
3
+ import type { EcoPagesAppConfig, IClientBridge, IHmrManager } from '../../types/internal-types.js';
4
+ /**
5
+ * Installs and returns the app-owned runtime build executor used by adapter
6
+ * startup and follow-up runtime work.
7
+ */
8
+ export declare function installSharedRuntimeBuildExecutor(appConfig: EcoPagesAppConfig, options: {
9
+ development: boolean;
10
+ }): BuildExecutor;
11
+ /**
12
+ * Copies app public assets into dist and ensures the resolved assets directory
13
+ * exists before request handling begins.
14
+ */
15
+ export declare function prepareSharedRuntimePublicDir(appConfig: EcoPagesAppConfig): void;
16
+ /**
17
+ * Runs runtime plugin setup against app-owned config/runtime state and optional
18
+ * host plugin registration hooks.
19
+ */
20
+ export declare function initializeSharedRuntimePlugins(options: {
21
+ appConfig: EcoPagesAppConfig;
22
+ runtimeOrigin: string;
23
+ hmrManager?: IHmrManager;
24
+ onRuntimePlugin?: (plugin: unknown) => void;
25
+ }): Promise<void>;
26
+ /**
27
+ * Starts shared project watching for runtime adapters.
28
+ */
29
+ export declare function startSharedProjectWatching(options: {
30
+ appConfig: EcoPagesAppConfig;
31
+ refreshRouterRoutesCallback: () => Promise<void>;
32
+ hmrManager: IHmrManager;
33
+ bridge: IClientBridge;
34
+ }): Promise<void>;
35
+ /**
36
+ * Binds a runtime HMR manager to app-owned plugin and integration state.
37
+ */
38
+ export declare function bindSharedRuntimeHmrManager(appConfig: EcoPagesAppConfig, hmrManager: IHmrManager): EcoBuildPlugin[];