@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,14 +1,34 @@
1
- import type { EcoBuildPlugin } from '../build/build-types';
2
- import type { EcoPagesAppConfig, IHmrManager } from '../internal-types';
3
- import type { HmrStrategy } from '../hmr/hmr-strategy';
4
- import type { EcoComponent, EcoPagesElement } from '../public-types';
5
- import type { IntegrationRenderer } from '../route-renderer/integration-renderer';
6
- import { AssetProcessingService } from '../services/asset-processing-service/asset-processing.service';
7
- import type { AssetDefinition, ProcessedAsset } from '../services/asset-processing-service/assets.types';
1
+ import type { EcoBuildPlugin } from '../build/build-types.js';
2
+ import type { EcoPagesAppConfig, IHmrManager } from '../types/internal-types.js';
3
+ import type { HmrStrategy } from '../hmr/hmr-strategy.js';
4
+ import type { EcoPagesElement } from '../types/public-types.js';
5
+ import type { IntegrationRenderer } from '../route-renderer/orchestration/integration-renderer.js';
6
+ import { AssetProcessingService } from '../services/assets/asset-processing-service/asset-processing.service.js';
7
+ import type { AssetDefinition, ProcessedAsset } from '../services/assets/asset-processing-service/assets.types.js';
8
+ import type { RuntimeCapabilityDeclaration } from './runtime-capability.js';
9
+ export type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from './runtime-capability.js';
10
+ export type { EcoBuildLoader, EcoBuildOnLoadArgs, EcoBuildOnLoadResult, EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin, EcoBuildPluginBuilder, } from '../build/build-types.js';
11
+ /**
12
+ * Type-erased integration plugin stored in app-level registries.
13
+ *
14
+ * Ecopages keeps one heterogeneous integration list, while each plugin and
15
+ * renderer still owns its framework-specific render payload type internally.
16
+ */
17
+ export type AnyIntegrationPlugin = IntegrationPlugin<unknown>;
8
18
  export declare const INTEGRATION_PLUGIN_ERRORS: {
9
19
  readonly NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config";
10
20
  readonly NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service";
11
21
  };
22
+ export declare function mergeIntegrationOptions<TDefaults, TOverrides>(defaults: TDefaults, overrides: TOverrides): TDefaults & TOverrides;
23
+ export declare function assertIntegrationInvariant(condition: boolean, message?: string): asserts condition;
24
+ /**
25
+ * Base configuration shared by all integration plugins.
26
+ *
27
+ * @remarks
28
+ * Integrations declare their file ownership, optional runtime requirements, and
29
+ * any global assets or build-time contributions here. Runtime-only side effects
30
+ * belong in `setup()` rather than the constructor.
31
+ */
12
32
  export interface IntegrationPluginConfig {
13
33
  /**
14
34
  * The name of the integration plugin.
@@ -31,29 +51,48 @@ export interface IntegrationPluginConfig {
31
51
  * @default 'render'
32
52
  */
33
53
  staticBuildStep?: 'render' | 'fetch';
54
+ /**
55
+ * Declares runtime-specific requirements that must be satisfied before the
56
+ * app can start with this integration enabled.
57
+ */
58
+ runtimeCapability?: RuntimeCapabilityDeclaration;
59
+ /**
60
+ * JSX import source owned by this integration.
61
+ *
62
+ * @remarks
63
+ * This is primarily used by mixed-JSX flows where host-owned browser bundles
64
+ * need to preserve the correct JSX runtime for files claimed by the
65
+ * integration.
66
+ */
67
+ jsxImportSource?: string;
34
68
  }
35
- /**
36
- * Metadata used by integration-owned boundary policy.
37
- *
38
- * This payload describes the currently active integration pass together with the
39
- * target component boundary being entered.
40
- */
41
- export type ComponentBoundaryPolicyInput = {
42
- currentIntegration: string;
43
- targetIntegration?: string;
44
- component: EcoComponent;
45
- };
46
69
  type RendererClass<C> = new (options: {
47
70
  appConfig: EcoPagesAppConfig;
48
71
  assetProcessingService: AssetProcessingService;
49
72
  resolvedIntegrationDependencies: ProcessedAsset[];
73
+ rendererModules?: unknown;
50
74
  runtimeOrigin: string;
51
75
  }) => IntegrationRenderer<C>;
76
+ /**
77
+ * Base class for framework integrations.
78
+ *
79
+ * @remarks
80
+ * An integration owns three main concerns:
81
+ * - which file extensions it claims
82
+ * - which renderer class turns those files into HTML
83
+ * - which build-time or runtime contributions must be registered for that framework
84
+ *
85
+ * Core owns lifecycle ordering. Integrations declare contributions through the
86
+ * hooks on this class, while `ConfigBuilder.build()` and app startup decide when
87
+ * those hooks run.
88
+ */
52
89
  export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
53
90
  readonly name: string;
54
91
  readonly extensions: string[];
55
92
  abstract renderer: RendererClass<C>;
56
93
  readonly staticBuildStep: 'render' | 'fetch';
94
+ readonly runtimeCapability?: RuntimeCapabilityDeclaration;
95
+ readonly jsxImportSource?: string;
57
96
  protected integrationDependencies: AssetDefinition[];
58
97
  protected resolvedIntegrationDependencies: ProcessedAsset[];
59
98
  protected options?: Record<string, unknown>;
@@ -62,8 +101,33 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
62
101
  protected hmrManager?: IHmrManager;
63
102
  runtimeOrigin: string;
64
103
  get plugins(): EcoBuildPlugin[];
104
+ /**
105
+ * Returns build plugins that should only apply to browser-oriented bundles.
106
+ *
107
+ * @remarks
108
+ * Browser-only transforms such as runtime import aliasing belong here so they
109
+ * do not affect server bundles or static-page module generation.
110
+ */
111
+ get browserBuildPlugins(): EcoBuildPlugin[];
112
+ /**
113
+ * Creates the integration with static declaration-only configuration.
114
+ *
115
+ * @remarks
116
+ * Constructors are expected to stay side-effect free. Build-manifest
117
+ * contributions belong in `prepareBuildContributions()` and runtime-only setup
118
+ * belongs in `setup()`.
119
+ */
65
120
  constructor(config: IntegrationPluginConfig);
121
+ /**
122
+ * Attaches the finalized app config to the integration.
123
+ *
124
+ * Core calls this during config finalization before runtime setup so the
125
+ * integration can resolve asset paths and other app-owned services later.
126
+ */
66
127
  setConfig(appConfig: EcoPagesAppConfig): void;
128
+ /**
129
+ * Records the runtime origin used for page-module loading and renderer setup.
130
+ */
67
131
  setRuntimeOrigin(runtimeOrigin: string): void;
68
132
  /**
69
133
  * Returns an HMR strategy for this integration, if applicable.
@@ -75,28 +139,77 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
75
139
  * ```typescript
76
140
  * getHmrStrategy(): HmrStrategy {
77
141
  * const context = this.hmrManager!.getDefaultContext();
78
- * return new ReactHmrStrategy(context);
142
+ * return new ReactHmrStrategy({ context, pageMetadataCache, runtimeAliasMap });
79
143
  * }
80
144
  * ```
81
145
  */
82
146
  getHmrStrategy?(): HmrStrategy | undefined;
147
+ /**
148
+ * Attaches the shared HMR manager and registers integration-owned development hooks.
149
+ *
150
+ * @remarks
151
+ * The default implementation registers the optional integration HMR strategy.
152
+ * Integrations should override this only when they need to extend that shared
153
+ * behavior rather than replace it.
154
+ */
83
155
  setHmrManager(hmrManager: IHmrManager): void;
156
+ /**
157
+ * Creates the asset-processing service used for global integration dependencies.
158
+ */
84
159
  initializeAssetDefinitionService(): void;
160
+ /**
161
+ * Returns processed global assets resolved during `setup()`.
162
+ */
85
163
  getResolvedIntegrationDependencies(): ProcessedAsset[];
86
- initializeRenderer(): IntegrationRenderer<C>;
87
164
  /**
88
- * Declares whether a component boundary targeting this integration should be
89
- * deferred through the marker pipeline.
165
+ * Creates the shared renderer options owned by core lifecycle setup.
166
+ */
167
+ protected createRendererOptions(options?: {
168
+ rendererModules?: unknown;
169
+ }): {
170
+ appConfig: EcoPagesAppConfig;
171
+ assetProcessingService: AssetProcessingService;
172
+ resolvedIntegrationDependencies: ProcessedAsset[];
173
+ rendererModules: unknown;
174
+ runtimeOrigin: string;
175
+ };
176
+ /**
177
+ * Attaches runtime-only services after a renderer instance has been created.
178
+ */
179
+ protected attachRendererRuntimeServices<T extends IntegrationRenderer<C>>(renderer: T): T;
180
+ /**
181
+ * Instantiates the integration renderer with app-owned services.
90
182
  *
91
- * The default implementation never defers. Integrations that require deferred
92
- * subtree rendering should override this method and return `true` when their
93
- * boundary must be resolved during the marker graph stage.
183
+ * @remarks
184
+ * Renderers are cheap runtime objects. They receive the finalized app config,
185
+ * a fresh asset-processing service, integration-global processed assets, and
186
+ * any renderer module context supplied by the active runtime.
187
+ renderer.name ||= this.name;
188
+ */
189
+ initializeRenderer(options?: {
190
+ rendererModules?: unknown;
191
+ }): IntegrationRenderer<C>;
192
+ /**
193
+ * Prepares build-facing contributions before the app build manifest is sealed.
94
194
  *
95
- * @param input Boundary metadata for the current render pass.
96
- * @returns `true` when the boundary should be deferred; otherwise `false`.
195
+ * @remarks
196
+ * Integrations can override this when runtime or build plugin declarations must
197
+ * be materialized ahead of runtime startup. Runtime-only side effects stay in
198
+ * `setup()`.
199
+ */
200
+ prepareBuildContributions(): Promise<void>;
201
+ /**
202
+ * Performs runtime-only integration setup after config build has already
203
+ * sealed manifest contributions.
97
204
  */
98
- shouldDeferComponentBoundary(_input: ComponentBoundaryPolicyInput): boolean;
99
205
  setup(): Promise<void>;
206
+ /**
207
+ * Releases runtime resources owned by the integration.
208
+ *
209
+ * @remarks
210
+ * Most integrations do not need custom teardown. Override this only for
211
+ * explicit cleanup such as watchers, compiler handles, or runtime registries
212
+ * that outlive individual requests.
213
+ */
100
214
  teardown(): Promise<void>;
101
215
  }
102
- export {};
@@ -1,12 +1,22 @@
1
- import { AssetProcessingService } from "../services/asset-processing-service/asset-processing.service";
1
+ import { AssetProcessingService } from "../services/assets/asset-processing-service/asset-processing.service.js";
2
+ import { deepMerge } from "../utils/deep-merge.js";
3
+ import { invariant } from "../utils/invariant.js";
2
4
  const INTEGRATION_PLUGIN_ERRORS = {
3
5
  NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config",
4
6
  NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service"
5
7
  };
8
+ function mergeIntegrationOptions(defaults, overrides) {
9
+ return deepMerge(defaults, overrides);
10
+ }
11
+ function assertIntegrationInvariant(condition, message) {
12
+ invariant(condition, message);
13
+ }
6
14
  class IntegrationPlugin {
7
15
  name;
8
16
  extensions;
9
17
  staticBuildStep;
18
+ runtimeCapability;
19
+ jsxImportSource;
10
20
  integrationDependencies;
11
21
  resolvedIntegrationDependencies = [];
12
22
  options;
@@ -16,19 +26,56 @@ class IntegrationPlugin {
16
26
  get plugins() {
17
27
  return [];
18
28
  }
29
+ /**
30
+ * Returns build plugins that should only apply to browser-oriented bundles.
31
+ *
32
+ * @remarks
33
+ * Browser-only transforms such as runtime import aliasing belong here so they
34
+ * do not affect server bundles or static-page module generation.
35
+ */
36
+ get browserBuildPlugins() {
37
+ return [];
38
+ }
39
+ /**
40
+ * Creates the integration with static declaration-only configuration.
41
+ *
42
+ * @remarks
43
+ * Constructors are expected to stay side-effect free. Build-manifest
44
+ * contributions belong in `prepareBuildContributions()` and runtime-only setup
45
+ * belongs in `setup()`.
46
+ */
19
47
  constructor(config) {
20
48
  this.name = config.name;
21
49
  this.extensions = config.extensions;
22
50
  this.integrationDependencies = config.integrationDependencies || [];
23
51
  this.staticBuildStep = config.staticBuildStep || "render";
52
+ this.runtimeCapability = config.runtimeCapability;
53
+ this.jsxImportSource = config.jsxImportSource;
24
54
  }
55
+ /**
56
+ * Attaches the finalized app config to the integration.
57
+ *
58
+ * Core calls this during config finalization before runtime setup so the
59
+ * integration can resolve asset paths and other app-owned services later.
60
+ */
25
61
  setConfig(appConfig) {
26
62
  this.appConfig = appConfig;
27
63
  this.initializeAssetDefinitionService();
28
64
  }
65
+ /**
66
+ * Records the runtime origin used for page-module loading and renderer setup.
67
+ */
29
68
  setRuntimeOrigin(runtimeOrigin) {
30
69
  this.runtimeOrigin = runtimeOrigin;
31
70
  }
71
+ /**
72
+ * Attaches the shared HMR manager and registers integration-owned development hooks.
73
+ *
74
+ * @remarks
75
+ * The default implementation registers the optional integration HMR strategy.
76
+ * Integrations should override this only when they need to extend that shared
77
+ * behavior rather than replace it.
78
+ */
32
79
  setHmrManager(hmrManager) {
33
80
  this.hmrManager = hmrManager;
34
81
  const strategy = this.getHmrStrategy?.();
@@ -39,6 +86,9 @@ class IntegrationPlugin {
39
86
  this.assetProcessingService.setHmrManager(hmrManager);
40
87
  }
41
88
  }
89
+ /**
90
+ * Creates the asset-processing service used for global integration dependencies.
91
+ */
42
92
  initializeAssetDefinitionService() {
43
93
  if (!this.appConfig) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
44
94
  this.assetProcessingService = AssetProcessingService.createWithDefaultProcessors(this.appConfig);
@@ -46,10 +96,16 @@ class IntegrationPlugin {
46
96
  this.assetProcessingService.setHmrManager(this.hmrManager);
47
97
  }
48
98
  }
99
+ /**
100
+ * Returns processed global assets resolved during `setup()`.
101
+ */
49
102
  getResolvedIntegrationDependencies() {
50
103
  return this.resolvedIntegrationDependencies;
51
104
  }
52
- initializeRenderer() {
105
+ /**
106
+ * Creates the shared renderer options owned by core lifecycle setup.
107
+ */
108
+ createRendererOptions(options) {
53
109
  if (!this.appConfig) {
54
110
  throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
55
111
  }
@@ -57,31 +113,54 @@ class IntegrationPlugin {
57
113
  if (this.hmrManager) {
58
114
  assetProcessingService.setHmrManager(this.hmrManager);
59
115
  }
60
- const renderer = new this.renderer({
116
+ return {
61
117
  appConfig: this.appConfig,
62
118
  assetProcessingService,
63
119
  resolvedIntegrationDependencies: this.resolvedIntegrationDependencies,
120
+ rendererModules: options?.rendererModules,
64
121
  runtimeOrigin: this.runtimeOrigin
65
- });
122
+ };
123
+ }
124
+ /**
125
+ * Attaches runtime-only services after a renderer instance has been created.
126
+ */
127
+ attachRendererRuntimeServices(renderer) {
128
+ if (typeof renderer.name !== "string" || renderer.name.length === 0) {
129
+ renderer.name = this.name;
130
+ }
66
131
  if (this.hmrManager) {
67
132
  renderer.setHmrManager(this.hmrManager);
68
133
  }
69
134
  return renderer;
70
135
  }
71
136
  /**
72
- * Declares whether a component boundary targeting this integration should be
73
- * deferred through the marker pipeline.
137
+ * Instantiates the integration renderer with app-owned services.
74
138
  *
75
- * The default implementation never defers. Integrations that require deferred
76
- * subtree rendering should override this method and return `true` when their
77
- * boundary must be resolved during the marker graph stage.
139
+ * @remarks
140
+ * Renderers are cheap runtime objects. They receive the finalized app config,
141
+ * a fresh asset-processing service, integration-global processed assets, and
142
+ * any renderer module context supplied by the active runtime.
143
+ renderer.name ||= this.name;
144
+ */
145
+ initializeRenderer(options) {
146
+ const renderer = new this.renderer(this.createRendererOptions(options));
147
+ renderer.name ||= this.name;
148
+ return this.attachRendererRuntimeServices(renderer);
149
+ }
150
+ /**
151
+ * Prepares build-facing contributions before the app build manifest is sealed.
78
152
  *
79
- * @param input Boundary metadata for the current render pass.
80
- * @returns `true` when the boundary should be deferred; otherwise `false`.
153
+ * @remarks
154
+ * Integrations can override this when runtime or build plugin declarations must
155
+ * be materialized ahead of runtime startup. Runtime-only side effects stay in
156
+ * `setup()`.
81
157
  */
82
- shouldDeferComponentBoundary(_input) {
83
- return false;
158
+ async prepareBuildContributions() {
84
159
  }
160
+ /**
161
+ * Performs runtime-only integration setup after config build has already
162
+ * sealed manifest contributions.
163
+ */
85
164
  async setup() {
86
165
  if (this.integrationDependencies.length === 0) return;
87
166
  if (!this.assetProcessingService) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_ASSET_SERVICE);
@@ -91,10 +170,20 @@ class IntegrationPlugin {
91
170
  );
92
171
  this.initializeRenderer();
93
172
  }
173
+ /**
174
+ * Releases runtime resources owned by the integration.
175
+ *
176
+ * @remarks
177
+ * Most integrations do not need custom teardown. Override this only for
178
+ * explicit cleanup such as watchers, compiler handles, or runtime registries
179
+ * that outlive individual requests.
180
+ */
94
181
  async teardown() {
95
182
  }
96
183
  }
97
184
  export {
98
185
  INTEGRATION_PLUGIN_ERRORS,
99
- IntegrationPlugin
186
+ IntegrationPlugin,
187
+ assertIntegrationInvariant,
188
+ mergeIntegrationOptions
100
189
  };
@@ -1,9 +1,13 @@
1
1
  import type { EcoBuildPlugin } from '../build/build-types.js';
2
- import type { EcoPagesAppConfig, IClientBridge } from '../internal-types';
3
- import type { AssetDefinition } from '../services/asset-processing-service';
2
+ import type { EcoPagesAppConfig, IClientBridge } from '../types/internal-types.js';
3
+ import type { AssetDefinition } from '../services/assets/asset-processing-service/assets.types.js';
4
+ import type { RuntimeCapabilityDeclaration } from './runtime-capability.js';
5
+ export type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from './runtime-capability.js';
6
+ export type { EcoBuildLoader, EcoBuildOnLoadArgs, EcoBuildOnLoadResult, EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin, EcoBuildPluginBuilder, } from '../build/build-types.js';
4
7
  export declare const PROCESSOR_ERRORS: {
5
8
  readonly CACHE_DIRECTORY_NOT_SET: "Cache directory not set in context";
6
9
  };
10
+ export declare function mergeProcessorOptions<TDefaults, TOverrides>(defaults: TDefaults, overrides: TOverrides): TDefaults & TOverrides;
7
11
  export interface ProcessorWatchContext {
8
12
  path: string;
9
13
  bridge: IClientBridge;
@@ -38,6 +42,7 @@ export interface ProcessorConfig<TOptions = Record<string, unknown>> {
38
42
  options?: TOptions;
39
43
  watch?: ProcessorWatchConfig;
40
44
  capabilities?: ProcessorAssetCapability[];
45
+ runtimeCapability?: RuntimeCapabilityDeclaration;
41
46
  }
42
47
  export interface ProcessorContext {
43
48
  config: EcoPagesAppConfig;
@@ -59,12 +64,22 @@ export declare abstract class Processor<TOptions = Record<string, unknown>> {
59
64
  protected options?: TOptions;
60
65
  protected watchConfig?: ProcessorWatchConfig;
61
66
  protected capabilities: ProcessorAssetCapability[];
67
+ readonly runtimeCapability?: RuntimeCapabilityDeclaration;
62
68
  /** Plugins that are only used during the build process */
63
69
  abstract buildPlugins?: EcoBuildPlugin[];
64
70
  /** Plugins that are used during runtime for file processing */
65
71
  abstract plugins?: EcoBuildPlugin[];
66
72
  constructor(config: ProcessorConfig<TOptions>);
67
73
  setContext(appConfig: EcoPagesAppConfig): void;
74
+ /**
75
+ * Prepares build-facing processor contributions before config finalization.
76
+ *
77
+ * @remarks
78
+ * Override this when a processor must compute runtime/build plugins or other
79
+ * manifest-owned state before startup. Runtime-only work such as cache
80
+ * warming or watcher registration should stay in `setup()`.
81
+ */
82
+ prepareBuildContributions(): Promise<void>;
68
83
  abstract setup(): Promise<void>;
69
84
  abstract teardown(): Promise<void>;
70
85
  abstract process(input: unknown, filePath?: string): Promise<unknown>;
@@ -1,9 +1,14 @@
1
1
  import path from "node:path";
2
2
  import { fileSystem } from "@ecopages/file-system";
3
- import { GENERATED_BASE_PATHS } from "../constants";
3
+ import { DEFAULT_ECOPAGES_WORK_DIR } from "../config/constants.js";
4
+ import { GENERATED_BASE_PATHS } from "../config/constants.js";
5
+ import { deepMerge } from "../utils/deep-merge.js";
4
6
  const PROCESSOR_ERRORS = {
5
7
  CACHE_DIRECTORY_NOT_SET: "Cache directory not set in context"
6
8
  };
9
+ function mergeProcessorOptions(defaults, overrides) {
10
+ return deepMerge(defaults, overrides);
11
+ }
7
12
  function resolveGeneratedPath(type, options) {
8
13
  const { root, module, subPath } = options;
9
14
  const parts = [root, GENERATED_BASE_PATHS[type], module, subPath].filter(Boolean);
@@ -16,15 +21,18 @@ class Processor {
16
21
  options;
17
22
  watchConfig;
18
23
  capabilities = [];
24
+ runtimeCapability;
19
25
  constructor(config) {
20
26
  this.name = config.name;
21
27
  this.options = config.options;
22
28
  this.watchConfig = config.watch;
23
29
  this.capabilities = config.capabilities ?? [];
30
+ this.runtimeCapability = config.runtimeCapability;
24
31
  }
25
32
  setContext(appConfig) {
33
+ const workDir = appConfig.absolutePaths.workDir ?? path.join(appConfig.rootDir, appConfig.workDir ?? DEFAULT_ECOPAGES_WORK_DIR);
26
34
  const cachePath = resolveGeneratedPath("cache", {
27
- root: appConfig.absolutePaths.distDir,
35
+ root: workDir,
28
36
  module: this.name
29
37
  });
30
38
  fileSystem.ensureDir(cachePath);
@@ -36,6 +44,16 @@ class Processor {
36
44
  cache: cachePath
37
45
  };
38
46
  }
47
+ /**
48
+ * Prepares build-facing processor contributions before config finalization.
49
+ *
50
+ * @remarks
51
+ * Override this when a processor must compute runtime/build plugins or other
52
+ * manifest-owned state before startup. Runtime-only work such as cache
53
+ * warming or watcher registration should stay in `setup()`.
54
+ */
55
+ async prepareBuildContributions() {
56
+ }
39
57
  getCachePath(key) {
40
58
  return `${this.context?.cache}/${key}`;
41
59
  }
@@ -118,5 +136,6 @@ class Processor {
118
136
  }
119
137
  export {
120
138
  PROCESSOR_ERRORS,
121
- Processor
139
+ Processor,
140
+ mergeProcessorOptions
122
141
  };
@@ -0,0 +1,9 @@
1
+ export type RuntimeCapabilityTag = 'bun-only' | 'node-compatible' | 'requires-native-bun-api' | 'requires-node-builtins';
2
+ /**
3
+ * Declares the runtime assumptions a plugin makes so config finalization can
4
+ * reject incompatible startup environments before bootstrapping the app.
5
+ */
6
+ export interface RuntimeCapabilityDeclaration {
7
+ tags: RuntimeCapabilityTag[];
8
+ minRuntimeVersion?: string;
9
+ }
@@ -0,0 +1,46 @@
1
+ import type { EcoBuildPlugin } from '../build/build-types.js';
2
+ import type { EcoPagesAppConfig } from '../types/internal-types.js';
3
+ export interface EcoSourceTransformResult {
4
+ code: string;
5
+ map?: unknown;
6
+ }
7
+ export interface EcoSourceTransform {
8
+ name: string;
9
+ filter: RegExp;
10
+ enforce?: 'pre' | 'post';
11
+ transform(code: string, id: string): EcoSourceTransformResult | string | undefined;
12
+ }
13
+ export interface EcoViteCompatiblePlugin {
14
+ name: string;
15
+ enforce?: 'pre' | 'post';
16
+ transform(code: string, id: string): EcoSourceTransformResult | string | undefined;
17
+ }
18
+ /**
19
+ * Normalizes bundler module ids so one transform can serve Ecopages loaders,
20
+ * Vite, and future bundler adapters.
21
+ */
22
+ export declare function normalizeTransformId(id: string): string;
23
+ /**
24
+ * Applies one source transform if the normalized id matches its filter.
25
+ */
26
+ export declare function applySourceTransform(transform: EcoSourceTransform, code: string, id: string): EcoSourceTransformResult | string | undefined;
27
+ /**
28
+ * Adapts a source transform into the existing Ecopages build-plugin contract.
29
+ */
30
+ export declare function createEcoBuildPluginFromSourceTransform(transform: EcoSourceTransform): EcoBuildPlugin;
31
+ /**
32
+ * Adapts a source transform into a Vite-compatible plugin object.
33
+ *
34
+ * @remarks
35
+ * This intentionally returns a plain object shape so core does not need a hard
36
+ * dependency on `vite` just to author transform primitives.
37
+ */
38
+ export declare function createVitePluginFromSourceTransform(transform: EcoSourceTransform): EcoViteCompatiblePlugin;
39
+ /**
40
+ * Returns the app-owned source transforms in stable registration order.
41
+ */
42
+ export declare function getAppSourceTransforms(appConfig: EcoPagesAppConfig): EcoSourceTransform[];
43
+ /**
44
+ * Adapts the app-owned source transforms into Vite-compatible plugin objects.
45
+ */
46
+ export declare function createVitePluginsFromAppSourceTransforms(appConfig: EcoPagesAppConfig): EcoViteCompatiblePlugin[];
@@ -0,0 +1,71 @@
1
+ import path from "node:path";
2
+ import { fileSystem } from "@ecopages/file-system";
3
+ function normalizeTransformId(id) {
4
+ const queryIndex = id.indexOf("?");
5
+ const hashIndex = id.indexOf("#");
6
+ const endIndex = [queryIndex, hashIndex].filter((index) => index >= 0).sort((left, right) => left - right)[0];
7
+ return endIndex === void 0 ? id : id.slice(0, endIndex);
8
+ }
9
+ function applySourceTransform(transform, code, id) {
10
+ const normalizedId = normalizeTransformId(id);
11
+ if (!transform.filter.test(normalizedId)) {
12
+ return void 0;
13
+ }
14
+ return transform.transform(code, normalizedId);
15
+ }
16
+ function inferLoaderFromPath(filePath) {
17
+ const extension = path.extname(filePath).toLowerCase();
18
+ switch (extension) {
19
+ case ".ts":
20
+ return "ts";
21
+ case ".tsx":
22
+ return "tsx";
23
+ case ".jsx":
24
+ return "jsx";
25
+ default:
26
+ return "js";
27
+ }
28
+ }
29
+ function createEcoBuildPluginFromSourceTransform(transform) {
30
+ return {
31
+ name: transform.name,
32
+ setup(build) {
33
+ build.onLoad({ filter: transform.filter }, (args) => {
34
+ const filePath = normalizeTransformId(args.path);
35
+ const code = fileSystem.readFileSync(filePath);
36
+ const result = applySourceTransform(transform, code, filePath);
37
+ if (!result) {
38
+ return void 0;
39
+ }
40
+ return {
41
+ contents: typeof result === "string" ? result : result.code,
42
+ loader: inferLoaderFromPath(filePath),
43
+ resolveDir: path.dirname(filePath)
44
+ };
45
+ });
46
+ }
47
+ };
48
+ }
49
+ function createVitePluginFromSourceTransform(transform) {
50
+ return {
51
+ name: transform.name,
52
+ enforce: transform.enforce,
53
+ transform(code, id) {
54
+ return applySourceTransform(transform, code, id);
55
+ }
56
+ };
57
+ }
58
+ function getAppSourceTransforms(appConfig) {
59
+ return Array.from(appConfig.sourceTransforms.values());
60
+ }
61
+ function createVitePluginsFromAppSourceTransforms(appConfig) {
62
+ return getAppSourceTransforms(appConfig).map((transform) => createVitePluginFromSourceTransform(transform));
63
+ }
64
+ export {
65
+ applySourceTransform,
66
+ createEcoBuildPluginFromSourceTransform,
67
+ createVitePluginFromSourceTransform,
68
+ createVitePluginsFromAppSourceTransforms,
69
+ getAppSourceTransforms,
70
+ normalizeTransformId
71
+ };