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

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
@@ -6,130 +6,113 @@ This folder contains the core rendering orchestration for Ecopages.
6
6
 
7
7
  The route renderer layer is responsible for:
8
8
 
9
- - Selecting the correct integration renderer for a route.
10
- - Loading page modules and resolving static data/metadata.
11
- - Resolving and processing component dependencies.
12
- - Applying full orchestration.
13
- - Emitting final HTML body output plus metadata/cache strategy.
9
+ - selecting the correct integration renderer for a route
10
+ - loading page modules and resolving static data or metadata
11
+ - resolving component dependencies and page browser assets
12
+ - coordinating mixed-integration rendering
13
+ - emitting final HTML plus cache strategy
14
14
 
15
- ## Main Components
15
+ ## Core Concepts
16
16
 
17
- ### `route-renderer.ts`
18
-
19
- - `RouteRendererFactory` chooses integration renderers based on route file extension.
20
- - `RouteRenderer` delegates route execution to the selected integration renderer.
21
-
22
- ### `integration-renderer.ts`
23
-
24
- Abstract base class that coordinates end-to-end route rendering:
25
-
26
- 1. Resolve page module and page data.
27
- 2. Resolve and process component dependencies.
28
- 3. Add route-level assets and orchestration assets.
29
- 4. Render HTML via integration-specific `render()`.
30
- 5. Inject processed assets into final HTML through `HtmlTransformerService`.
31
-
32
- It also provides:
17
+ The architecture is organized around three distinct concepts:
33
18
 
34
- - `renderToResponse()` contract for explicit-route rendering.
35
- - `renderComponent()` contract for component-level orchestration and artifact reporting.
36
- - marker graph resolution for nested cross-integration component boundaries.
19
+ - `ownership`: preparation-time metadata that describes which integration owns each declared component edge
20
+ - `foreign child`: a component encountered during render whose owning integration differs from the current integration
21
+ - `foreign subtree`: the resolved HTML, assets, and root-attachment metadata returned by the owning renderer for that foreign child
37
22
 
38
- ### `component-marker.ts`
23
+ These concepts intentionally live in different places:
39
24
 
40
- Defines marker token contract for component-level orchestration:
25
+ - `ownership-planning.service.ts` builds `ownershipPlan`
26
+ - `ownership-validation.service.ts` validates declared foreign ownership up front
27
+ - `component-render-context.ts` intercepts foreign children during active component render
28
+ - `queued-foreign-subtree-resolution.service.ts` resolves queued foreign subtrees for renderers that cannot hand them off inline
29
+ - `integration-renderer.ts` owns renderer-to-renderer delegation and shared shell composition
30
+ - `route-render-flow.ts` owns route preparation, final response capture, and unresolved artifact enforcement
41
31
 
42
- - `createComponentMarker()` for canonical `<eco-marker ...></eco-marker>` generation.
43
- - `parseComponentMarkers()` for marker extraction from rendered HTML.
32
+ ## Main Files
44
33
 
45
- ### `component-graph.ts`
34
+ ### `route-renderer.ts`
46
35
 
47
- Builds a deterministic DAG from marker nodes:
36
+ - `RouteRendererFactory` chooses integration renderers from route files
37
+ - `RouteRenderer` delegates execution to the selected renderer
48
38
 
49
- - node collection by marker id.
50
- - parent/child edges from slot reference registry.
51
- - topological levels for bottom-up execution.
39
+ ### `orchestration/`
52
40
 
53
- ### `component-graph-executor.ts`
41
+ - `route-render-flow.ts`: one route render from page-module loading through final HTML output
42
+ - `integration-renderer.ts`: abstract base class for route rendering, explicit view rendering, and foreign-child delegation
43
+ - `ownership-planning.service.ts`: declared ownership graph construction
44
+ - `ownership-validation.service.ts`: up-front ownership validation for route roots and declared descendants
45
+ - `component-render-context.ts`: active render context used by `eco.component()` to intercept foreign children
46
+ - `queued-foreign-subtree-resolution.service.ts`: queue resolution for renderers that need token-based foreign-subtree handoff
47
+ - `render-output.utils.ts`: unresolved artifact normalization and marker inspection
54
48
 
55
- Resolves graph levels in reverse order (leaf to root) and replaces markers with rendered HTML via integration `renderComponent()`.
49
+ ### `page-loading/`
56
50
 
57
- ### `page-module-loader.ts`
51
+ - `page-module-loader.ts`: imports page modules and normalizes page exports
52
+ - `dependency-resolver.ts`: resolves component dependencies and browser-facing assets
58
53
 
59
- Service for loading page modules and deriving page data:
54
+ ## Render Flow
60
55
 
61
- - `importPageFile()` runtime-aware loading.
62
- - `resolvePageModule()` normalizes exports and statics.
63
- - `resolvePageData()` resolves static props then metadata.
56
+ The route-render contract is:
64
57
 
65
- ### `dependency-resolver.ts`
58
+ 1. `RouteRendererFactory` selects the owning integration renderer.
59
+ 2. `IntegrationRenderer.execute()` delegates preparation and finalization to `RouteRenderFlow`.
60
+ 3. `RouteRenderFlow.prepareRenderOptions()` loads the page module, validates ownership, builds `ownershipPlan`, resolves page data, resolves dependencies, and builds the page browser graph.
61
+ 4. The integration renderer performs page, layout, and document-shell rendering. When it encounters a foreign child, it delegates that child back to the owning renderer.
62
+ 5. If a renderer needs queued handoff, it emits internal foreign-subtree tokens and resolves them before returning final HTML.
63
+ 6. `RouteRenderFlow.execute()` captures the final body, rejects unresolved `<eco-marker>` artifacts, stamps root or document attributes when needed, and runs the HTML transformer.
66
64
 
67
- Builds processed assets from component dependency declarations:
65
+ Important:
68
66
 
69
- - Scripts/styles/components/modules.
70
- - Lazy dependency grouping and trigger derivation.
71
- - Default global injector behavior with optional legacy scripts-injector compatibility.
67
+ - route-level fallback resolution is gone; unresolved artifacts are now a hard failure
68
+ - ownership is declared from component metadata, not inferred from final HTML
69
+ - same-integration children stay renderer-local and do not need to pass through a universal transport
72
70
 
73
- ## Rendering Behavior
71
+ ## Declared Foreign Child Contract
74
72
 
75
- Default behavior:
73
+ Mixed-integration component configs must declare every possible foreign child in `config.dependencies.components`.
76
74
 
77
- - marker-graph component orchestration + component render artifacts.
78
- - global lazy trigger map + global injector bootstrap.
75
+ That declaration is used for two things:
79
76
 
80
- Global injector lifecycle notes:
77
+ - `OwnershipValidationService` surfaces missing metadata or unknown integrations before render execution
78
+ - `OwnershipPlanningService` records the expected ownership shape in `ownershipPlan`
81
79
 
82
- - The bootstrap remains active across client-side navigations.
83
- - On `eco:after-swap`, it prunes stale `ecopages/global-injector-map` scripts and calls `refresh()` so newly swapped `data-eco-trigger` elements can bind their lazy rules.
84
- - It must not call injector `cleanup()` on every swap, because that permanently disables future refresh work for the current runtime instance.
80
+ At runtime, renderers still discover actual foreign children through the active component render context.
85
81
 
86
- ## Current Component Artifact Contract
82
+ ## Foreign Subtree Contract
87
83
 
88
- Integration `renderComponent()` returns `ComponentRenderResult` with:
84
+ `renderForeignSubtree()` is the compatibility contract for renderer-to-renderer handoff. It returns:
89
85
 
90
86
  - `html`
91
- - `canAttachAttributes`
87
+ - `assets`
92
88
  - `rootTag`
93
- - `integrationName`
94
89
  - optional `rootAttributes`
95
- - optional `assets`
96
-
97
- Current base orchestration behavior:
98
-
99
- - Calls `renderComponent()` for the page root component.
100
- - Merges returned `assets` into processed dependencies.
101
- - Applies returned `rootAttributes` to the first element under `<body>`.
90
+ - `attachmentPolicy`
91
+ - `integrationName`
102
92
 
103
- When rendered output contains `eco-marker` nodes:
93
+ `renderComponentWithForeignChildren()` is the higher-level renderer entrypoint. It is responsible for:
104
94
 
105
- - builds marker graph using `componentGraphContext` (`propsByRef`, `slotChildrenByRef`) from integration-specific page module exports.
106
- - resolves markers bottom-up through integration-specific `renderComponent()` calls.
107
- - fails fast when marker component refs or props refs are missing.
108
- - merges marker-rendered assets back into the dependency pipeline with deduplication.
95
+ - reusing the execution-scoped owning-renderer cache
96
+ - deciding whether the current component can stay local
97
+ - creating a foreign-child runtime when nested foreign ownership must be resolved
98
+ - normalizing unresolved artifact HTML before the render leaves the renderer
109
99
 
110
- This enables island-style hydration assets (for example React/Lit/Kita integration outputs) to be emitted through the normal dependency injection pipeline.
100
+ ## Queue Model
111
101
 
112
- ## React Island Boundary Notes
102
+ Not every integration needs queue-based handoff.
113
103
 
114
- - React component-level islands are emitted without synthetic wrapper elements.
115
- - The React integration attaches `data-eco-component-id` on the component's own SSR root element when a single root is available.
116
- - Island client bootstrap mounts with `createRoot()` into that root boundary.
117
- - The emitted hydration bootstrap also listens for `eco:after-swap` so islands hydrate correctly when their SSR markup appears after client-side navigation.
118
- - React hydration bootstraps are emitted with `data-eco-rerun` and stable `data-eco-script-id` metadata so head-script reconciliation can safely re-execute them when needed.
119
- - This keeps authored DOM shape stable for global layout/style selectors while preserving per-island runtime isolation.
104
+ - If a renderer can resolve a foreign child inline, it returns resolved output immediately.
105
+ - If it cannot, it may emit internal foreign-subtree tokens and resolve them before returning final HTML.
106
+ - The queue service is only for renderer-owned transport inside one render pass. It is not a general route-level fallback mechanism.
120
107
 
121
- ## Output Pipeline (High-Level)
108
+ ## React Island Notes
122
109
 
123
- 1. Factory selects integration renderer.
124
- 2. Integration renderer prepares render options.
125
- 3. Dependencies are resolved and processed.
126
- 4. Orchestration assets/artifacts are merged.
127
- 5. Integration renderer generates HTML body.
128
- 6. HTML transformer injects head/body dependencies.
129
- 7. Route result returns body + metadata + cache strategy.
110
+ - React islands are emitted without synthetic wrapper elements.
111
+ - The React integration attaches `data-eco-component-id` to the SSR root when a single root exists.
112
+ - The island bootstrap mounts with `createRoot()` into that SSR root.
113
+ - Hydration bootstraps listen for `eco:after-swap` so islands hydrate after client-side navigation.
130
114
 
131
- ## Notes for Future Work
115
+ ## Current Limits
132
116
 
133
- - Expand integration-side marker emission so more nested trees are resolved through graph mode by default.
134
- - Add broader fixtures/e2e for deep multi-level slot graphs.
135
- - Add optional batching by integration per graph level to reduce repeated renderer invocations.
117
+ - `ownershipPlan` is still diagnostic and preparatory metadata; it does not yet drive a full route-composer execution model.
118
+ - Different integrations still own different foreign-child runtime strategies, which is intentional where child transport or hydration behavior differs.
@@ -0,0 +1,89 @@
1
+ import type { EcoComponent } from '../../types/public-types.js';
2
+ /**
3
+ * Result returned by a renderer-owned foreign-child runtime.
4
+ *
5
+ * `inline` keeps rendering inside the current integration. `resolved` returns a
6
+ * renderer-owned value immediately, which can be final HTML or a renderer-local
7
+ * transport token for later queue resolution.
8
+ */
9
+ export type ForeignChildInterceptionResult = {
10
+ kind: 'inline';
11
+ } | {
12
+ kind: 'resolved';
13
+ value: unknown;
14
+ };
15
+ /**
16
+ * Foreign-child metadata passed into the active renderer-owned runtime.
17
+ */
18
+ export type ForeignChildInterceptionInput = {
19
+ currentIntegration: string;
20
+ targetIntegration?: string;
21
+ component: EcoComponent;
22
+ props: Record<string, unknown>;
23
+ };
24
+ /**
25
+ * Narrow renderer-owned foreign-child runtime injected into one active render
26
+ * context.
27
+ *
28
+ * Integrations implement this contract when foreign children must be handed
29
+ * off inside the renderer instead of being left for route-level reconciliation.
30
+ */
31
+ export interface ForeignChildRuntime {
32
+ /**
33
+ * Intercepts one foreign child during an active render.
34
+ *
35
+ * This runtime is typically installed by the Foreign Subtree execution module,
36
+ * which decides whether the child stays inline or leaves the current renderer.
37
+ */
38
+ interceptForeignChild?(input: ForeignChildInterceptionInput): ForeignChildInterceptionResult | Promise<ForeignChildInterceptionResult>;
39
+ interceptForeignChildSync?(input: ForeignChildInterceptionInput): ForeignChildInterceptionResult;
40
+ }
41
+ type ForeignChildRenderInput = {
42
+ component: EcoComponent;
43
+ props: Record<string, unknown>;
44
+ targetIntegration?: string;
45
+ };
46
+ /**
47
+ * Per-render mutable state used while applying foreign-child interception and lazy
48
+ * output wrapping.
49
+ */
50
+ export type ComponentRenderContext = {
51
+ currentIntegration: string;
52
+ foreignChildRuntime?: ForeignChildRuntime;
53
+ interceptForeignChild(input: ForeignChildRenderInput): Promise<unknown | undefined> | unknown | undefined;
54
+ finalizeComponentRender<T>(component: EcoComponent, content: T): T;
55
+ };
56
+ /**
57
+ * Returns the current component render context, if one is active.
58
+ *
59
+ * @returns Active render context or `undefined` outside render execution.
60
+ */
61
+ export declare function getComponentRenderContext(): ComponentRenderContext | undefined;
62
+ /**
63
+ * Runs foreign-child interception for one component render step.
64
+ *
65
+ * The active runtime may resolve the foreign child immediately or keep it inline.
66
+ */
67
+ export declare function interceptForeignChild(input: ForeignChildRenderInput): Promise<unknown | undefined> | unknown | undefined;
68
+ /**
69
+ * Applies lazy trigger or injector wrapping to completed component output.
70
+ *
71
+ * This helper works both inside render-context execution and in fallback flows
72
+ * where no active context exists.
73
+ */
74
+ export declare function finalizeComponentRender<T>(component: EcoComponent, content: T): T;
75
+ /**
76
+ * Runs render work under a fresh component render context and returns the
77
+ * resulting value.
78
+ *
79
+ * @param input Execution metadata for current integration and foreign-child policy.
80
+ * @param render Async render function to execute inside the context.
81
+ * @returns Render result value.
82
+ */
83
+ export declare function runWithComponentRenderContext<T>(input: {
84
+ currentIntegration: string;
85
+ foreignChildRuntime?: ForeignChildRuntime;
86
+ }, render: () => Promise<T>): Promise<{
87
+ value: T;
88
+ }>;
89
+ export {};
@@ -0,0 +1,147 @@
1
+ import { addTriggerAttribute, isThenable, wrapWithScriptsInjector } from "./render-output.utils.js";
2
+ class ComponentRenderOutputRuntime {
3
+ finalizeComponentRender(component, content) {
4
+ const lazyTriggers = component.config?._resolvedLazyTriggers;
5
+ if (lazyTriggers && lazyTriggers.length > 0) {
6
+ return this.addTriggerToContent(content, lazyTriggers[0].triggerId);
7
+ }
8
+ const lazyGroups = component.config?._resolvedLazyScripts;
9
+ if (lazyGroups && lazyGroups.length > 0) {
10
+ return this.wrapContentWithScriptsInjector(content, lazyGroups);
11
+ }
12
+ return content;
13
+ }
14
+ addTriggerToContent(content, triggerId) {
15
+ if (isThenable(content)) {
16
+ return content.then((resolvedContent) => addTriggerAttribute(resolvedContent, triggerId));
17
+ }
18
+ return addTriggerAttribute(content, triggerId);
19
+ }
20
+ wrapContentWithScriptsInjector(content, lazyGroups) {
21
+ if (isThenable(content)) {
22
+ return content.then((resolvedContent) => wrapWithScriptsInjector(resolvedContent, lazyGroups));
23
+ }
24
+ return wrapWithScriptsInjector(content, lazyGroups);
25
+ }
26
+ }
27
+ class ContextualComponentRenderRuntime extends ComponentRenderOutputRuntime {
28
+ context;
29
+ constructor(context) {
30
+ super();
31
+ this.context = context;
32
+ }
33
+ applyForeignChildInterceptionResult(result) {
34
+ if (result.kind === "resolved") {
35
+ return result.value;
36
+ }
37
+ return void 0;
38
+ }
39
+ /**
40
+ * Resolves one foreign-child interception through the active runtime.
41
+ *
42
+ * The runtime may choose inline rendering or immediate resolved output.
43
+ */
44
+ interceptForeignChild(input) {
45
+ const foreignChildRuntimeInput = {
46
+ currentIntegration: this.context.currentIntegration,
47
+ targetIntegration: input.targetIntegration,
48
+ component: input.component,
49
+ props: input.props
50
+ };
51
+ const asyncInterception = this.context.foreignChildRuntime?.interceptForeignChild?.(foreignChildRuntimeInput);
52
+ if (asyncInterception !== void 0) {
53
+ if (isThenable(asyncInterception)) {
54
+ return asyncInterception.then((result) => this.applyForeignChildInterceptionResult(result));
55
+ }
56
+ return this.applyForeignChildInterceptionResult(asyncInterception);
57
+ }
58
+ const syncInterception = this.context.foreignChildRuntime?.interceptForeignChildSync?.(foreignChildRuntimeInput);
59
+ if (syncInterception === void 0) {
60
+ return void 0;
61
+ }
62
+ return this.applyForeignChildInterceptionResult(syncInterception);
63
+ }
64
+ }
65
+ const GLOBAL_COMPONENT_RENDER_CONTEXT_STATE_KEY = "__ECOPAGES_COMPONENT_RENDER_CONTEXT_STATE__";
66
+ function getSharedContextScope() {
67
+ const globalProcess = globalThis.process;
68
+ if (globalProcess && typeof globalProcess === "object") {
69
+ return globalProcess;
70
+ }
71
+ return globalThis;
72
+ }
73
+ function getComponentRenderContextState() {
74
+ const sharedScope = getSharedContextScope();
75
+ sharedScope[GLOBAL_COMPONENT_RENDER_CONTEXT_STATE_KEY] ??= {
76
+ contextStack: [],
77
+ nodeContextStorage: null,
78
+ nodeContextStorageLoader: null
79
+ };
80
+ return sharedScope[GLOBAL_COMPONENT_RENDER_CONTEXT_STATE_KEY];
81
+ }
82
+ async function getContextStorage() {
83
+ const state = getComponentRenderContextState();
84
+ if (state.nodeContextStorage) {
85
+ return state.nodeContextStorage;
86
+ }
87
+ if (state.nodeContextStorageLoader) {
88
+ return state.nodeContextStorageLoader;
89
+ }
90
+ state.nodeContextStorageLoader = import("node:async_hooks").then((module) => {
91
+ const storage = new module.AsyncLocalStorage();
92
+ state.nodeContextStorage = {
93
+ getStore: () => storage.getStore(),
94
+ run: (store, callback) => storage.run(store, callback)
95
+ };
96
+ return state.nodeContextStorage;
97
+ }).catch(() => {
98
+ state.nodeContextStorage = null;
99
+ return null;
100
+ }).finally(() => {
101
+ state.nodeContextStorageLoader = null;
102
+ });
103
+ return state.nodeContextStorageLoader;
104
+ }
105
+ function getComponentRenderContext() {
106
+ const state = getComponentRenderContextState();
107
+ return state.nodeContextStorage?.getStore() ?? state.contextStack[state.contextStack.length - 1];
108
+ }
109
+ const componentRenderOutputRuntime = new ComponentRenderOutputRuntime();
110
+ function interceptForeignChild(input) {
111
+ return getComponentRenderContext()?.interceptForeignChild(input);
112
+ }
113
+ function finalizeComponentRender(component, content) {
114
+ const renderContext = getComponentRenderContext();
115
+ return renderContext?.finalizeComponentRender(component, content) ?? componentRenderOutputRuntime.finalizeComponentRender(component, content);
116
+ }
117
+ async function runWithComponentRenderContext(input, render) {
118
+ const context = {
119
+ currentIntegration: input.currentIntegration,
120
+ foreignChildRuntime: input.foreignChildRuntime
121
+ };
122
+ const runtime = new ContextualComponentRenderRuntime(context);
123
+ context.interceptForeignChild = (deferredInput) => runtime.interceptForeignChild(deferredInput);
124
+ context.finalizeComponentRender = (component, content) => runtime.finalizeComponentRender(component, content);
125
+ const storage = await getContextStorage();
126
+ let value;
127
+ if (storage) {
128
+ value = await storage.run(context, render);
129
+ } else {
130
+ const state = getComponentRenderContextState();
131
+ state.contextStack.push(context);
132
+ try {
133
+ value = await render();
134
+ } finally {
135
+ state.contextStack.pop();
136
+ }
137
+ }
138
+ return {
139
+ value
140
+ };
141
+ }
142
+ export {
143
+ finalizeComponentRender,
144
+ getComponentRenderContext,
145
+ interceptForeignChild,
146
+ runWithComponentRenderContext
147
+ };
@@ -0,0 +1,18 @@
1
+ import type { EcoComponent, OwnershipPlanNodeSource } from '../../types/public-types.js';
2
+ export type DeclaredOwnershipRoot = {
3
+ component: EcoComponent;
4
+ source: Extract<OwnershipPlanNodeSource, 'page' | 'layout' | 'html-template'>;
5
+ };
6
+ export type DeclaredOwnershipNodeInput = {
7
+ component: EcoComponent;
8
+ source: Exclude<OwnershipPlanNodeSource, 'route'>;
9
+ parentIntegrationName: string;
10
+ integrationName: string;
11
+ componentId: string;
12
+ isForeignToParent: boolean;
13
+ };
14
+ export declare function mapDeclaredOwnershipGraph<T>(input: {
15
+ roots: DeclaredOwnershipRoot[];
16
+ currentIntegrationName: string;
17
+ mapNode: (node: DeclaredOwnershipNodeInput, children: T[]) => T;
18
+ }): T[];
@@ -0,0 +1,34 @@
1
+ function mapDeclaredOwnershipGraph(input) {
2
+ let nextSyntheticId = 0;
3
+ const mapComponent = (component, source, parentIntegrationName, lineage) => {
4
+ const integrationName = component.config?.integration ?? component.config?.__eco?.integration ?? parentIntegrationName;
5
+ const componentMeta = component.config?.__eco;
6
+ const isForeignToParent = integrationName !== parentIntegrationName;
7
+ const componentId = componentMeta?.id ?? componentMeta?.file ?? `${source}:${nextSyntheticId += 1}`;
8
+ const nextLineage = new Set(lineage);
9
+ nextLineage.add(component);
10
+ const children = (component.config?.dependencies?.components ?? []).flatMap((child) => {
11
+ if (!child || nextLineage.has(child)) {
12
+ return [];
13
+ }
14
+ return [mapComponent(child, "dependency", integrationName, nextLineage)];
15
+ });
16
+ return input.mapNode(
17
+ {
18
+ component,
19
+ source,
20
+ parentIntegrationName,
21
+ integrationName,
22
+ componentId,
23
+ isForeignToParent
24
+ },
25
+ children
26
+ );
27
+ };
28
+ return input.roots.map(
29
+ ({ component, source }) => mapComponent(component, source, input.currentIntegrationName, /* @__PURE__ */ new Set())
30
+ );
31
+ }
32
+ export {
33
+ mapDeclaredOwnershipGraph
34
+ };
@@ -0,0 +1,108 @@
1
+ import type { ProcessedAsset } from '../../services/assets/asset-processing-service/index.js';
2
+ import type { BaseIntegrationContext, ComponentRenderInput, ComponentRenderResult, EcoComponent, ForeignSubtreeRenderPayload } from '../../types/public-types.js';
3
+ import { type ForeignChildRuntime } from './component-render-context.js';
4
+ import { QueuedForeignSubtreeResolutionService, type QueuedForeignSubtreeResolution, type QueuedForeignSubtreeResolutionContext } from './queued-foreign-subtree-resolution.service.js';
5
+ export interface ForeignSubtreeExecutionOwningRenderer {
6
+ readonly name: string;
7
+ renderComponentWithForeignChildren(input: ComponentRenderInput): Promise<ComponentRenderResult>;
8
+ renderForeignSubtree(input: ComponentRenderInput): Promise<ForeignSubtreeRenderPayload>;
9
+ }
10
+ export interface ForeignSubtreeExecutionDecisionInput {
11
+ currentIntegration: string;
12
+ targetIntegration?: string;
13
+ }
14
+ export interface ForeignSubtreeExecutionRenderOptions {
15
+ currentIntegrationName: string;
16
+ input: ComponentRenderInput;
17
+ renderComponent(input: ComponentRenderInput): Promise<ComponentRenderResult>;
18
+ normalizeComponentRenderOutput(result: ComponentRenderResult): ComponentRenderResult;
19
+ hasForeignChildDescendants(component: EcoComponent): boolean;
20
+ createForeignChildRuntime(options: {
21
+ renderInput: ComponentRenderInput;
22
+ rendererCache: Map<string, ForeignSubtreeExecutionOwningRenderer>;
23
+ }): ForeignChildRuntime;
24
+ getOwningRenderer(integrationName: string, rendererCache: Map<string, ForeignSubtreeExecutionOwningRenderer>): ForeignSubtreeExecutionOwningRenderer;
25
+ }
26
+ export interface ForeignSubtreeQueuedRuntimeOptions<TContext extends QueuedForeignSubtreeResolutionContext> {
27
+ renderInput: ComponentRenderInput;
28
+ rendererCache: Map<string, ForeignSubtreeExecutionOwningRenderer>;
29
+ runtimeContextKey: string;
30
+ tokenPrefix: string;
31
+ createRuntimeContext?: (integrationContext: BaseIntegrationContext & Record<string, unknown>, rendererCache: Map<string, unknown>) => TContext;
32
+ }
33
+ export interface ForeignSubtreeStringQueuedHtmlOptions {
34
+ currentIntegrationName: string;
35
+ renderInput: ComponentRenderInput;
36
+ html: string;
37
+ runtimeContextKey: string;
38
+ queueLabel: string;
39
+ getOwningRenderer(integrationName: string, rendererCache: Map<string, ForeignSubtreeExecutionOwningRenderer>): ForeignSubtreeExecutionOwningRenderer;
40
+ applyAttributesToFirstElement(html: string, attributes: Record<string, string>): string;
41
+ dedupeProcessedAssets(assets: ProcessedAsset[]): ProcessedAsset[];
42
+ }
43
+ export interface ForeignSubtreeQueuedHtmlOptions<TContext extends QueuedForeignSubtreeResolutionContext> {
44
+ currentIntegrationName: string;
45
+ html: string;
46
+ runtimeContext?: TContext;
47
+ queueLabel: string;
48
+ renderQueuedChildren(children: unknown, runtimeContext: TContext, queuedResolutionsByToken: Map<string, QueuedForeignSubtreeResolution>, resolveToken: (token: string) => Promise<string>): Promise<{
49
+ assets: ProcessedAsset[];
50
+ html?: string;
51
+ }>;
52
+ getOwningRenderer(integrationName: string, rendererCache: Map<string, ForeignSubtreeExecutionOwningRenderer>): ForeignSubtreeExecutionOwningRenderer;
53
+ applyAttributesToFirstElement(html: string, attributes: Record<string, string>): string;
54
+ dedupeProcessedAssets(assets: ProcessedAsset[]): ProcessedAsset[];
55
+ }
56
+ /**
57
+ * Executes one component render tree under Foreign Child support.
58
+ *
59
+ * This service owns the execution policy for mixed-integration component trees:
60
+ * it decides when a child stays inline, when it must delegate to an owning
61
+ * renderer, how one render-pass renderer cache is reused, and how queued
62
+ * Foreign Subtree tokens resolve back into final HTML.
63
+ */
64
+ export declare class ForeignSubtreeExecutionService {
65
+ private readonly queuedForeignSubtreeResolutionService;
66
+ constructor(queuedForeignSubtreeResolutionService?: QueuedForeignSubtreeResolutionService);
67
+ /**
68
+ * Returns whether the current render pass must hand the child off to a foreign owner.
69
+ */
70
+ shouldDelegateForeignChild(input: ForeignSubtreeExecutionDecisionInput): boolean;
71
+ /**
72
+ * Creates the base runtime used when a renderer has not supplied its own queueing runtime.
73
+ *
74
+ * The runtime allows same-integration children to continue inline and fails fast
75
+ * when execution crosses into a foreign owner without a renderer-owned handoff.
76
+ */
77
+ createFailFastRuntime(rendererName: string): ForeignChildRuntime;
78
+ getQueuedRuntimeContext<TContext extends QueuedForeignSubtreeResolutionContext>(input: ComponentRenderInput, runtimeContextKey: string): TContext | undefined;
79
+ createQueuedRuntime<TContext extends QueuedForeignSubtreeResolutionContext>(options: ForeignSubtreeQueuedRuntimeOptions<TContext>): ForeignChildRuntime;
80
+ /**
81
+ * Resolves a string-first renderer HTML fragment that may contain queued Foreign Subtree tokens.
82
+ */
83
+ resolveStringQueuedHtml<TContext extends QueuedForeignSubtreeResolutionContext>(options: ForeignSubtreeStringQueuedHtmlOptions): Promise<{
84
+ assets: ProcessedAsset[];
85
+ html: string;
86
+ }>;
87
+ resolveQueuedHtml<TContext extends QueuedForeignSubtreeResolutionContext>(options: ForeignSubtreeQueuedHtmlOptions<TContext>): Promise<{
88
+ assets: ProcessedAsset[];
89
+ html: string;
90
+ }>;
91
+ /**
92
+ * Executes one component render with Foreign Child support under the current integration.
93
+ */
94
+ executeComponentRender(options: ForeignSubtreeExecutionRenderOptions): Promise<ComponentRenderResult>;
95
+ private getRendererCache;
96
+ private withRendererCache;
97
+ /**
98
+ * Returns the delegatable owning renderer integration for one component.
99
+ *
100
+ * The pseudo `html` integration marks document-shell ownership only and does
101
+ * not participate in component-level foreign subtree execution.
102
+ */
103
+ private getForeignOwnerIntegrationName;
104
+ private resolveForeignChildInOwningRenderer;
105
+ private resolveForeignSubtreeInOwningRenderer;
106
+ private runInForeignOwningRenderer;
107
+ resolveQueuedTokens(html: string, queuedResolutionsByToken: Map<string, QueuedForeignSubtreeResolution>, resolveToken: (token: string) => Promise<string>): Promise<string>;
108
+ }