@ecopages/core 0.2.0-alpha.5 → 0.2.0-alpha.51

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 (456) hide show
  1. package/README.md +267 -14
  2. package/package.json +98 -108
  3. package/src/adapters/README.md +39 -0
  4. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  5. package/src/adapters/abstract/application-adapter.js +14 -2
  6. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  7. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  8. package/src/adapters/bun/client-bridge.d.ts +1 -1
  9. package/src/adapters/bun/create-app.d.ts +12 -12
  10. package/src/adapters/bun/create-app.js +64 -41
  11. package/src/adapters/bun/hmr-manager.d.ts +30 -62
  12. package/src/adapters/bun/hmr-manager.js +30 -194
  13. package/src/adapters/bun/index.d.ts +2 -3
  14. package/src/adapters/bun/index.js +3 -3
  15. package/src/adapters/bun/runtime-host.d.ts +52 -0
  16. package/src/adapters/bun/runtime-host.js +56 -0
  17. package/src/adapters/bun/server-adapter.d.ts +93 -32
  18. package/src/adapters/bun/server-adapter.js +166 -89
  19. package/src/adapters/bun/static-preview-host.d.ts +28 -0
  20. package/src/adapters/bun/static-preview-host.js +45 -0
  21. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  22. package/src/{create-app.js → adapters/create-app.js} +4 -4
  23. package/src/adapters/index.d.ts +2 -6
  24. package/src/adapters/index.js +2 -8
  25. package/src/adapters/node/create-app.d.ts +15 -12
  26. package/src/adapters/node/create-app.js +34 -85
  27. package/src/adapters/node/http-request-bridge.d.ts +57 -0
  28. package/src/adapters/node/http-request-bridge.js +118 -0
  29. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  30. package/src/adapters/node/node-hmr-manager.d.ts +38 -48
  31. package/src/adapters/node/node-hmr-manager.js +31 -203
  32. package/src/adapters/node/runtime-host.d.ts +57 -0
  33. package/src/adapters/node/runtime-host.js +92 -0
  34. package/src/adapters/node/server-adapter-dependencies.d.ts +19 -0
  35. package/src/adapters/node/server-adapter-dependencies.js +18 -0
  36. package/src/adapters/node/server-adapter.d.ts +20 -72
  37. package/src/adapters/node/server-adapter.js +98 -203
  38. package/src/adapters/node/static-content-server.d.ts +37 -1
  39. package/src/adapters/node/static-content-server.js +29 -1
  40. package/src/adapters/node/static-preview-host.d.ts +55 -0
  41. package/src/adapters/node/static-preview-host.js +68 -0
  42. package/src/adapters/shared/application-adapter.d.ts +1 -1
  43. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  44. package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
  45. package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
  46. package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
  47. package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
  48. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
  49. package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
  50. package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
  51. package/src/adapters/shared/fs-server-response-factory.js +11 -27
  52. package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
  53. package/src/adapters/shared/fs-server-response-matcher.js +76 -45
  54. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  55. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  56. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  57. package/src/adapters/shared/hmr-html-response.js +33 -0
  58. package/src/adapters/shared/render-context.d.ts +5 -3
  59. package/src/adapters/shared/render-context.js +27 -3
  60. package/src/adapters/shared/runtime-app-bootstrap.d.ts +26 -0
  61. package/src/adapters/shared/runtime-app-bootstrap.js +46 -0
  62. package/src/adapters/shared/runtime-host.d.ts +12 -0
  63. package/src/adapters/shared/server-adapter.d.ts +33 -12
  64. package/src/adapters/shared/server-adapter.js +215 -132
  65. package/src/adapters/shared/server-route-handler.d.ts +5 -5
  66. package/src/adapters/shared/server-route-handler.js +7 -16
  67. package/src/adapters/shared/server-static-builder.d.ts +41 -8
  68. package/src/adapters/shared/server-static-builder.js +65 -11
  69. package/src/adapters/shared/shared-hmr-manager.d.ts +59 -0
  70. package/src/adapters/shared/shared-hmr-manager.js +240 -0
  71. package/src/adapters/shared/static-preview-host.d.ts +10 -0
  72. package/src/build/README.md +107 -0
  73. package/src/build/browser-runtime-import-rewrite-plugin.d.ts +26 -0
  74. package/src/build/browser-runtime-import-rewrite-plugin.js +162 -0
  75. package/src/build/browser-runtime-manifest.d.ts +31 -0
  76. package/src/build/browser-runtime-manifest.js +61 -0
  77. package/src/build/build-adapter.d.ts +175 -3
  78. package/src/build/build-adapter.js +633 -16
  79. package/src/build/build-manifest.d.ts +33 -0
  80. package/src/build/build-manifest.js +52 -0
  81. package/src/build/dev-build-coordinator.d.ts +72 -0
  82. package/src/build/dev-build-coordinator.js +154 -0
  83. package/src/build/esbuild-build-adapter.d.ts +16 -6
  84. package/src/build/esbuild-build-adapter.js +205 -75
  85. package/src/build/runtime-build-executor.d.ts +14 -0
  86. package/src/build/runtime-build-executor.js +22 -0
  87. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  88. package/src/build/runtime-specifier-alias-plugin.js +31 -0
  89. package/src/config/README.md +36 -0
  90. package/src/config/config-builder.d.ts +54 -29
  91. package/src/config/config-builder.js +256 -50
  92. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  93. package/src/{constants.js → config/constants.js} +4 -0
  94. package/src/declarations.d.ts +19 -14
  95. package/src/dev/host-runtime.d.ts +10 -0
  96. package/src/dev/host-runtime.js +24 -0
  97. package/src/dev/sc-server.d.ts +1 -1
  98. package/src/dev/sc-server.js +1 -1
  99. package/src/eco/README.md +70 -16
  100. package/src/eco/eco.browser.d.ts +2 -0
  101. package/src/eco/eco.browser.js +88 -0
  102. package/src/eco/eco.js +63 -54
  103. package/src/eco/eco.types.d.ts +69 -6
  104. package/src/eco/eco.utils.d.ts +1 -40
  105. package/src/eco/eco.utils.js +5 -35
  106. package/src/eco/global-injector-map.d.ts +3 -3
  107. package/src/eco/global-injector-map.js +2 -2
  108. package/src/eco/lazy-injector-map.d.ts +2 -2
  109. package/src/errors/index.d.ts +1 -0
  110. package/src/errors/index.js +3 -1
  111. package/src/hmr/README.md +26 -0
  112. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  113. package/src/hmr/client/hmr-runtime.js +38 -7
  114. package/src/hmr/hmr-strategy.d.ts +16 -13
  115. package/src/hmr/hmr-strategy.js +22 -7
  116. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  117. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  118. package/src/hmr/hmr.test.e2e.js +26 -33
  119. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  120. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  121. package/src/hmr/strategies/js-hmr-strategy.d.ts +40 -42
  122. package/src/hmr/strategies/js-hmr-strategy.js +24 -43
  123. package/src/index.browser.d.ts +2 -2
  124. package/src/index.browser.js +1 -1
  125. package/src/index.d.ts +4 -3
  126. package/src/index.js +16 -5
  127. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  128. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  129. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  130. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  131. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  132. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  133. package/src/plugins/README.md +35 -0
  134. package/src/plugins/alias-resolver-plugin.d.ts +1 -0
  135. package/src/plugins/alias-resolver-plugin.js +27 -5
  136. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  137. package/src/plugins/eco-component-meta-plugin.js +42 -24
  138. package/src/plugins/foreign-jsx-override-plugin.d.ts +33 -0
  139. package/src/plugins/foreign-jsx-override-plugin.js +41 -0
  140. package/src/plugins/integration-plugin.d.ts +157 -29
  141. package/src/plugins/integration-plugin.js +115 -14
  142. package/src/plugins/processor.d.ts +17 -2
  143. package/src/plugins/processor.js +22 -3
  144. package/src/plugins/runtime-capability.d.ts +9 -0
  145. package/src/plugins/source-transform.d.ts +46 -0
  146. package/src/plugins/source-transform.js +71 -0
  147. package/src/route-renderer/GRAPH.md +83 -325
  148. package/src/route-renderer/README.md +73 -90
  149. package/src/route-renderer/orchestration/component-render-context.d.ts +97 -0
  150. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  151. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  152. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  153. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +110 -0
  154. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +233 -0
  155. package/src/route-renderer/orchestration/integration-renderer.d.ts +534 -0
  156. package/src/route-renderer/orchestration/integration-renderer.js +991 -0
  157. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  158. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  159. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  160. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  161. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +3 -0
  162. package/src/route-renderer/orchestration/processed-asset-dedupe.js +27 -0
  163. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +91 -0
  164. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +170 -0
  165. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  166. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  167. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +156 -0
  168. package/src/route-renderer/orchestration/route-render-orchestrator.js +577 -0
  169. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  170. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  171. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  172. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  173. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  174. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  175. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  176. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  177. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  178. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  179. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  180. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  181. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  182. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  183. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  184. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  185. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  186. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  187. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  188. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  189. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  190. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  191. package/src/route-renderer/route-renderer.d.ts +57 -14
  192. package/src/route-renderer/route-renderer.js +30 -18
  193. package/src/router/README.md +94 -0
  194. package/src/router/client/link-intent.d.ts +53 -0
  195. package/src/router/client/link-intent.js +34 -0
  196. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  197. package/src/router/client/link-intent.test.browser.js +43 -0
  198. package/src/router/client/navigation-coordinator.d.ts +169 -0
  199. package/src/router/client/navigation-coordinator.js +215 -0
  200. package/src/router/server/route-registry.d.ts +78 -0
  201. package/src/router/server/route-registry.js +262 -0
  202. package/src/services/README.md +28 -0
  203. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  204. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  205. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  208. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  209. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  210. package/src/services/assets/asset-processing-service/assets.types.js +0 -0
  211. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +57 -0
  212. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  213. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  214. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  215. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  216. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  217. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  218. package/src/services/assets/asset-processing-service/index.js +6 -0
  219. package/src/services/assets/asset-processing-service/page-package.d.ts +6 -0
  220. package/src/services/assets/asset-processing-service/page-package.js +80 -0
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  222. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  223. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  224. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  225. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  226. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  227. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  228. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  229. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  230. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +120 -0
  231. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  232. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  233. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +42 -0
  234. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +126 -0
  235. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  236. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  237. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  238. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  239. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  240. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  241. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  242. package/src/services/assets/browser-bundle.service.js +41 -0
  243. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  244. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  245. package/src/services/html/html-rewriter-provider.service.d.ts +40 -0
  246. package/src/services/html/html-rewriter-provider.service.js +68 -0
  247. package/src/services/html/html-transformer.service.d.ts +96 -0
  248. package/src/services/html/html-transformer.service.js +287 -0
  249. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  250. package/src/services/invalidation/development-invalidation.service.js +190 -0
  251. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  252. package/src/services/module-loading/app-module-loader.service.js +0 -0
  253. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  254. package/src/services/module-loading/app-server-module-transpiler.service.js +151 -0
  255. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  256. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  257. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  258. package/src/services/module-loading/module-loading-types.js +0 -0
  259. package/src/services/module-loading/node-bootstrap-plugin.d.ts +38 -0
  260. package/src/services/module-loading/node-bootstrap-plugin.js +215 -0
  261. package/src/services/module-loading/page-module-import.service.d.ts +95 -0
  262. package/src/services/module-loading/page-module-import.service.js +191 -0
  263. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  264. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  265. package/src/services/module-loading/source-module-support.d.ts +5 -0
  266. package/src/services/module-loading/source-module-support.js +8 -0
  267. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  268. package/src/services/runtime-state/dev-graph.service.js +162 -0
  269. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  270. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  271. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  272. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  273. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  274. package/src/static-site-generator/README.md +26 -0
  275. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  276. package/src/static-site-generator/static-site-generator.js +182 -138
  277. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  278. package/src/types/internal-types.js +0 -0
  279. package/src/{public-types.d.ts → types/public-types.d.ts} +239 -31
  280. package/src/types/public-types.js +0 -0
  281. package/src/utils/html-escaping.d.ts +7 -0
  282. package/src/utils/html-escaping.js +6 -0
  283. package/src/utils/locals-utils.d.ts +1 -1
  284. package/src/utils/parse-cli-args.d.ts +4 -1
  285. package/src/utils/parse-cli-args.js +16 -1
  286. package/src/utils/resolve-work-dir.d.ts +11 -0
  287. package/src/utils/resolve-work-dir.js +31 -0
  288. package/src/watchers/project-watcher.d.ts +11 -7
  289. package/src/watchers/project-watcher.js +69 -75
  290. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  291. package/src/watchers/project-watcher.test-helpers.js +6 -5
  292. package/CHANGELOG.md +0 -94
  293. package/src/adapters/abstract/application-adapter.ts +0 -337
  294. package/src/adapters/abstract/router-adapter.ts +0 -30
  295. package/src/adapters/abstract/server-adapter.ts +0 -79
  296. package/src/adapters/bun/client-bridge.ts +0 -62
  297. package/src/adapters/bun/create-app.ts +0 -189
  298. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  299. package/src/adapters/bun/define-api-handler.ts +0 -114
  300. package/src/adapters/bun/hmr-manager.ts +0 -276
  301. package/src/adapters/bun/index.ts +0 -3
  302. package/src/adapters/bun/server-adapter.ts +0 -492
  303. package/src/adapters/bun/server-lifecycle.d.ts +0 -52
  304. package/src/adapters/bun/server-lifecycle.js +0 -120
  305. package/src/adapters/bun/server-lifecycle.ts +0 -154
  306. package/src/adapters/index.ts +0 -6
  307. package/src/adapters/node/create-app.ts +0 -179
  308. package/src/adapters/node/index.d.ts +0 -4
  309. package/src/adapters/node/index.js +0 -8
  310. package/src/adapters/node/index.ts +0 -9
  311. package/src/adapters/node/node-client-bridge.ts +0 -79
  312. package/src/adapters/node/node-hmr-manager.ts +0 -271
  313. package/src/adapters/node/server-adapter.ts +0 -561
  314. package/src/adapters/node/static-content-server.ts +0 -203
  315. package/src/adapters/shared/api-response.ts +0 -104
  316. package/src/adapters/shared/application-adapter.ts +0 -199
  317. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  318. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  319. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  320. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  321. package/src/adapters/shared/render-context.ts +0 -105
  322. package/src/adapters/shared/server-adapter.ts +0 -442
  323. package/src/adapters/shared/server-route-handler.ts +0 -166
  324. package/src/adapters/shared/server-static-builder.ts +0 -82
  325. package/src/build/build-adapter.ts +0 -133
  326. package/src/build/build-types.ts +0 -83
  327. package/src/build/esbuild-build-adapter.ts +0 -511
  328. package/src/config/config-builder.ts +0 -474
  329. package/src/constants.ts +0 -39
  330. package/src/create-app.ts +0 -87
  331. package/src/define-api-handler.js +0 -15
  332. package/src/define-api-handler.ts +0 -66
  333. package/src/dev/sc-server.ts +0 -143
  334. package/src/eco/component-render-context.d.ts +0 -105
  335. package/src/eco/component-render-context.js +0 -77
  336. package/src/eco/component-render-context.ts +0 -202
  337. package/src/eco/eco.ts +0 -221
  338. package/src/eco/eco.types.ts +0 -202
  339. package/src/eco/eco.utils.ts +0 -89
  340. package/src/eco/global-injector-map.ts +0 -112
  341. package/src/eco/lazy-injector-map.ts +0 -120
  342. package/src/eco/module-dependencies.ts +0 -75
  343. package/src/errors/http-error.ts +0 -72
  344. package/src/errors/index.ts +0 -2
  345. package/src/errors/locals-access-error.ts +0 -7
  346. package/src/global/app-logger.ts +0 -4
  347. package/src/hmr/client/hmr-runtime.ts +0 -121
  348. package/src/hmr/hmr-strategy.ts +0 -172
  349. package/src/hmr/hmr.test.e2e.ts +0 -75
  350. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  351. package/src/hmr/strategies/js-hmr-strategy.ts +0 -327
  352. package/src/index.browser.ts +0 -3
  353. package/src/index.ts +0 -5
  354. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  355. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  356. package/src/internal-types.ts +0 -212
  357. package/src/plugins/alias-resolver-plugin.ts +0 -45
  358. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  359. package/src/plugins/integration-plugin.ts +0 -184
  360. package/src/plugins/processor.ts +0 -220
  361. package/src/public-types.ts +0 -1255
  362. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  363. package/src/route-renderer/component-graph-executor.js +0 -31
  364. package/src/route-renderer/component-graph-executor.ts +0 -84
  365. package/src/route-renderer/component-graph.d.ts +0 -42
  366. package/src/route-renderer/component-graph.js +0 -72
  367. package/src/route-renderer/component-graph.ts +0 -159
  368. package/src/route-renderer/component-marker.d.ts +0 -52
  369. package/src/route-renderer/component-marker.js +0 -46
  370. package/src/route-renderer/component-marker.ts +0 -117
  371. package/src/route-renderer/dependency-resolver.js +0 -428
  372. package/src/route-renderer/dependency-resolver.ts +0 -596
  373. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  374. package/src/route-renderer/html-post-processing.service.js +0 -86
  375. package/src/route-renderer/html-post-processing.service.ts +0 -103
  376. package/src/route-renderer/integration-renderer.d.ts +0 -339
  377. package/src/route-renderer/integration-renderer.js +0 -526
  378. package/src/route-renderer/integration-renderer.ts +0 -696
  379. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  380. package/src/route-renderer/marker-graph-resolver.js +0 -93
  381. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  382. package/src/route-renderer/page-module-loader.d.ts +0 -61
  383. package/src/route-renderer/page-module-loader.ts +0 -153
  384. package/src/route-renderer/render-execution.service.d.ts +0 -69
  385. package/src/route-renderer/render-execution.service.js +0 -91
  386. package/src/route-renderer/render-execution.service.ts +0 -158
  387. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  388. package/src/route-renderer/render-preparation.service.js +0 -243
  389. package/src/route-renderer/render-preparation.service.ts +0 -358
  390. package/src/route-renderer/route-renderer.ts +0 -80
  391. package/src/router/fs-router-scanner.d.ts +0 -41
  392. package/src/router/fs-router-scanner.js +0 -155
  393. package/src/router/fs-router-scanner.ts +0 -217
  394. package/src/router/fs-router.d.ts +0 -26
  395. package/src/router/fs-router.js +0 -100
  396. package/src/router/fs-router.ts +0 -122
  397. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  398. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  399. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  400. package/src/services/asset-processing-service/assets.types.ts +0 -112
  401. package/src/services/asset-processing-service/index.d.ts +0 -3
  402. package/src/services/asset-processing-service/index.js +0 -3
  403. package/src/services/asset-processing-service/index.ts +0 -3
  404. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  405. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  406. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  407. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  408. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  409. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  410. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  411. package/src/services/asset-processing-service/processors/index.js +0 -5
  412. package/src/services/asset-processing-service/processors/index.ts +0 -5
  413. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  414. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  415. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  416. package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
  417. package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +0 -74
  418. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  419. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  420. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  421. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  422. package/src/services/cache/cache.types.ts +0 -126
  423. package/src/services/cache/index.ts +0 -18
  424. package/src/services/cache/memory-cache-store.ts +0 -130
  425. package/src/services/cache/page-cache-service.ts +0 -202
  426. package/src/services/html-transformer.service.d.ts +0 -50
  427. package/src/services/html-transformer.service.js +0 -163
  428. package/src/services/html-transformer.service.ts +0 -217
  429. package/src/services/page-module-import.service.d.ts +0 -37
  430. package/src/services/page-module-import.service.js +0 -88
  431. package/src/services/page-module-import.service.ts +0 -129
  432. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  433. package/src/services/schema-validation-service.ts +0 -204
  434. package/src/services/validation/standard-schema.types.ts +0 -68
  435. package/src/static-site-generator/static-site-generator.ts +0 -359
  436. package/src/utils/css.d.ts +0 -1
  437. package/src/utils/css.js +0 -7
  438. package/src/utils/css.ts +0 -5
  439. package/src/utils/deep-merge.ts +0 -47
  440. package/src/utils/hash.ts +0 -5
  441. package/src/utils/html.ts +0 -1
  442. package/src/utils/invariant.ts +0 -15
  443. package/src/utils/locals-utils.ts +0 -37
  444. package/src/utils/parse-cli-args.ts +0 -83
  445. package/src/utils/path-utils.module.ts +0 -14
  446. package/src/utils/runtime.ts +0 -44
  447. package/src/utils/server-utils.module.ts +0 -67
  448. package/src/watchers/project-watcher.test-helpers.ts +0 -40
  449. package/src/watchers/project-watcher.ts +0 -364
  450. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  451. /package/src/{internal-types.js → adapters/shared/runtime-host.js} +0 -0
  452. /package/src/{public-types.js → adapters/shared/static-preview-host.js} +0 -0
  453. /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.js} +0 -0
  454. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  455. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  456. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,14 +1,37 @@
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 BrowserRuntimeManifest } from '../build/browser-runtime-manifest.js';
3
+ import type { EcoPagesAppConfig, IHmrManager } from '../types/internal-types.js';
4
+ import type { HmrStrategy } from '../hmr/hmr-strategy.js';
5
+ import type { EcoPagesElement } from '../types/public-types.js';
6
+ import type { IntegrationRenderer } from '../route-renderer/orchestration/integration-renderer.js';
7
+ import { AssetProcessingService } from '../services/assets/asset-processing-service/asset-processing.service.js';
8
+ import type { AssetDefinition, ProcessedAsset } from '../services/assets/asset-processing-service/assets.types.js';
9
+ import type { RuntimeCapabilityDeclaration } from './runtime-capability.js';
10
+ export type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from './runtime-capability.js';
11
+ export type { EcoBuildLoader, EcoBuildOnLoadArgs, EcoBuildOnLoadResult, EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin, EcoBuildPluginBuilder, } from '../build/build-types.js';
12
+ export type { PageBrowserGraphContribution, PageBrowserGraphContributionContext } from '../types/public-types.js';
13
+ export type { HtmlDocumentContribution, HtmlDocumentContributionContext, } from '../route-renderer/orchestration/integration-renderer.js';
14
+ /**
15
+ * Type-erased integration plugin stored in app-level registries.
16
+ *
17
+ * Ecopages keeps one heterogeneous integration list, while each plugin and
18
+ * renderer still owns its framework-specific render payload type internally.
19
+ */
20
+ export type AnyIntegrationPlugin = IntegrationPlugin<unknown>;
8
21
  export declare const INTEGRATION_PLUGIN_ERRORS: {
9
22
  readonly NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config";
10
23
  readonly NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service";
11
24
  };
25
+ export declare function mergeIntegrationOptions<TDefaults, TOverrides>(defaults: TDefaults, overrides: TOverrides): TDefaults & TOverrides;
26
+ export declare function assertIntegrationInvariant(condition: boolean, message?: string): asserts condition;
27
+ /**
28
+ * Base configuration shared by all integration plugins.
29
+ *
30
+ * @remarks
31
+ * Integrations declare their file ownership, optional runtime requirements, and
32
+ * any global assets or build-time contributions here. Runtime-only side effects
33
+ * belong in `setup()` rather than the constructor.
34
+ */
12
35
  export interface IntegrationPluginConfig {
13
36
  /**
14
37
  * The name of the integration plugin.
@@ -31,29 +54,51 @@ export interface IntegrationPluginConfig {
31
54
  * @default 'render'
32
55
  */
33
56
  staticBuildStep?: 'render' | 'fetch';
57
+ /**
58
+ * Declares runtime-specific requirements that must be satisfied before the
59
+ * app can start with this integration enabled.
60
+ */
61
+ runtimeCapability?: RuntimeCapabilityDeclaration;
62
+ /**
63
+ * JSX import source owned by this integration.
64
+ *
65
+ * @remarks
66
+ * This is primarily used by mixed-JSX flows where host-owned browser bundles
67
+ * need to preserve the correct JSX runtime for files claimed by the
68
+ * integration.
69
+ */
70
+ jsxImportSource?: string;
34
71
  }
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
72
  type RendererClass<C> = new (options: {
47
73
  appConfig: EcoPagesAppConfig;
48
74
  assetProcessingService: AssetProcessingService;
49
75
  resolvedIntegrationDependencies: ProcessedAsset[];
76
+ rendererModules?: unknown;
50
77
  runtimeOrigin: string;
51
78
  }) => IntegrationRenderer<C>;
79
+ /**
80
+ * Base class for framework integrations.
81
+ *
82
+ * @remarks
83
+ * An integration owns three main concerns:
84
+ * - which file extensions it claims
85
+ * - which renderer class turns those files into HTML
86
+ * - which build-time or runtime contributions must be registered for that framework
87
+ *
88
+ * Core owns lifecycle ordering. Integrations declare contributions through the
89
+ * hooks on this class, while `ConfigBuilder.build()` and app startup decide when
90
+ * those hooks run. For page-browser and document shaping, integrations should
91
+ * prefer the contribution contracts re-exported from this module:
92
+ * `PageBrowserGraphContribution` / `PageBrowserGraphContributionContext` and
93
+ * `HtmlDocumentContribution` / `HtmlDocumentContributionContext`.
94
+ */
52
95
  export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
53
96
  readonly name: string;
54
97
  readonly extensions: string[];
55
98
  abstract renderer: RendererClass<C>;
56
99
  readonly staticBuildStep: 'render' | 'fetch';
100
+ readonly runtimeCapability?: RuntimeCapabilityDeclaration;
101
+ readonly jsxImportSource?: string;
57
102
  protected integrationDependencies: AssetDefinition[];
58
103
  protected resolvedIntegrationDependencies: ProcessedAsset[];
59
104
  protected options?: Record<string, unknown>;
@@ -62,8 +107,42 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
62
107
  protected hmrManager?: IHmrManager;
63
108
  runtimeOrigin: string;
64
109
  get plugins(): EcoBuildPlugin[];
110
+ /**
111
+ * Returns build plugins that should only apply to browser-oriented bundles.
112
+ *
113
+ * @remarks
114
+ * Browser-only transforms such as runtime import aliasing belong here so they
115
+ * do not affect server bundles or static-page module generation.
116
+ */
117
+ get browserBuildPlugins(): EcoBuildPlugin[];
118
+ /**
119
+ * Returns shared browser runtime asset declarations owned by this integration.
120
+ *
121
+ * @remarks
122
+ * Core seals these declarations into the app build manifest so app-owned browser
123
+ * bundle paths can rewrite manifest-owned imports even when a specific build
124
+ * request does not install an integration-local runtime rewrite plugin.
125
+ */
126
+ get browserRuntimeManifest(): BrowserRuntimeManifest;
127
+ /**
128
+ * Creates the integration with static declaration-only configuration.
129
+ *
130
+ * @remarks
131
+ * Constructors are expected to stay side-effect free. Build-manifest
132
+ * contributions belong in `prepareBuildContributions()` and runtime-only setup
133
+ * belongs in `setup()`.
134
+ */
65
135
  constructor(config: IntegrationPluginConfig);
136
+ /**
137
+ * Attaches the finalized app config to the integration.
138
+ *
139
+ * Core calls this during config finalization before runtime setup so the
140
+ * integration can resolve asset paths and other app-owned services later.
141
+ */
66
142
  setConfig(appConfig: EcoPagesAppConfig): void;
143
+ /**
144
+ * Records the runtime origin used for page-module loading and renderer setup.
145
+ */
67
146
  setRuntimeOrigin(runtimeOrigin: string): void;
68
147
  /**
69
148
  * Returns an HMR strategy for this integration, if applicable.
@@ -75,28 +154,77 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
75
154
  * ```typescript
76
155
  * getHmrStrategy(): HmrStrategy {
77
156
  * const context = this.hmrManager!.getDefaultContext();
78
- * return new ReactHmrStrategy(context);
157
+ * return new ReactHmrStrategy({ context, pageMetadataCache, runtimeManifest });
79
158
  * }
80
159
  * ```
81
160
  */
82
161
  getHmrStrategy?(): HmrStrategy | undefined;
162
+ /**
163
+ * Attaches the shared HMR manager and registers integration-owned development hooks.
164
+ *
165
+ * @remarks
166
+ * The default implementation registers the optional integration HMR strategy.
167
+ * Integrations should override this only when they need to extend that shared
168
+ * behavior rather than replace it.
169
+ */
83
170
  setHmrManager(hmrManager: IHmrManager): void;
171
+ /**
172
+ * Creates the asset-processing service used for global integration dependencies.
173
+ */
84
174
  initializeAssetDefinitionService(): void;
175
+ /**
176
+ * Returns processed global assets resolved during `setup()`.
177
+ */
85
178
  getResolvedIntegrationDependencies(): ProcessedAsset[];
86
- initializeRenderer(): IntegrationRenderer<C>;
87
179
  /**
88
- * Declares whether a component boundary targeting this integration should be
89
- * deferred through the marker pipeline.
180
+ * Creates the shared renderer options owned by core lifecycle setup.
181
+ */
182
+ protected createRendererOptions(options?: {
183
+ rendererModules?: unknown;
184
+ }): {
185
+ appConfig: EcoPagesAppConfig;
186
+ assetProcessingService: AssetProcessingService;
187
+ resolvedIntegrationDependencies: ProcessedAsset[];
188
+ rendererModules: unknown;
189
+ runtimeOrigin: string;
190
+ };
191
+ /**
192
+ * Attaches runtime-only services after a renderer instance has been created.
193
+ */
194
+ protected attachRendererRuntimeServices<T extends IntegrationRenderer<C>>(renderer: T): T;
195
+ /**
196
+ * Instantiates the integration renderer with app-owned services.
90
197
  *
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.
198
+ * @remarks
199
+ * Renderers are cheap runtime objects. They receive the finalized app config,
200
+ * a fresh asset-processing service, integration-global processed assets, and
201
+ * any renderer module context supplied by the active runtime.
202
+ renderer.name ||= this.name;
203
+ */
204
+ initializeRenderer(options?: {
205
+ rendererModules?: unknown;
206
+ }): IntegrationRenderer<C>;
207
+ /**
208
+ * Prepares build-facing contributions before the app build manifest is sealed.
94
209
  *
95
- * @param input Boundary metadata for the current render pass.
96
- * @returns `true` when the boundary should be deferred; otherwise `false`.
210
+ * @remarks
211
+ * Integrations can override this when runtime or build plugin declarations must
212
+ * be materialized ahead of runtime startup. Runtime-only side effects stay in
213
+ * `setup()`.
214
+ */
215
+ prepareBuildContributions(): Promise<void>;
216
+ /**
217
+ * Performs runtime-only integration setup after config build has already
218
+ * sealed manifest contributions.
97
219
  */
98
- shouldDeferComponentBoundary(_input: ComponentBoundaryPolicyInput): boolean;
99
220
  setup(): Promise<void>;
221
+ /**
222
+ * Releases runtime resources owned by the integration.
223
+ *
224
+ * @remarks
225
+ * Most integrations do not need custom teardown. Override this only for
226
+ * explicit cleanup such as watchers, compiler handles, or runtime registries
227
+ * that outlive individual requests.
228
+ */
100
229
  teardown(): Promise<void>;
101
230
  }
102
- export {};
@@ -1,12 +1,23 @@
1
- import { AssetProcessingService } from "../services/asset-processing-service/asset-processing.service";
1
+ import { createBrowserRuntimeManifest } from "../build/browser-runtime-manifest.js";
2
+ import { AssetProcessingService } from "../services/assets/asset-processing-service/asset-processing.service.js";
3
+ import { deepMerge } from "../utils/deep-merge.js";
4
+ import { invariant } from "../utils/invariant.js";
2
5
  const INTEGRATION_PLUGIN_ERRORS = {
3
6
  NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config",
4
7
  NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service"
5
8
  };
9
+ function mergeIntegrationOptions(defaults, overrides) {
10
+ return deepMerge(defaults, overrides);
11
+ }
12
+ function assertIntegrationInvariant(condition, message) {
13
+ invariant(condition, message);
14
+ }
6
15
  class IntegrationPlugin {
7
16
  name;
8
17
  extensions;
9
18
  staticBuildStep;
19
+ runtimeCapability;
20
+ jsxImportSource;
10
21
  integrationDependencies;
11
22
  resolvedIntegrationDependencies = [];
12
23
  options;
@@ -16,19 +27,67 @@ class IntegrationPlugin {
16
27
  get plugins() {
17
28
  return [];
18
29
  }
30
+ /**
31
+ * Returns build plugins that should only apply to browser-oriented bundles.
32
+ *
33
+ * @remarks
34
+ * Browser-only transforms such as runtime import aliasing belong here so they
35
+ * do not affect server bundles or static-page module generation.
36
+ */
37
+ get browserBuildPlugins() {
38
+ return [];
39
+ }
40
+ /**
41
+ * Returns shared browser runtime asset declarations owned by this integration.
42
+ *
43
+ * @remarks
44
+ * Core seals these declarations into the app build manifest so app-owned browser
45
+ * bundle paths can rewrite manifest-owned imports even when a specific build
46
+ * request does not install an integration-local runtime rewrite plugin.
47
+ */
48
+ get browserRuntimeManifest() {
49
+ return createBrowserRuntimeManifest();
50
+ }
51
+ /**
52
+ * Creates the integration with static declaration-only configuration.
53
+ *
54
+ * @remarks
55
+ * Constructors are expected to stay side-effect free. Build-manifest
56
+ * contributions belong in `prepareBuildContributions()` and runtime-only setup
57
+ * belongs in `setup()`.
58
+ */
19
59
  constructor(config) {
20
60
  this.name = config.name;
21
61
  this.extensions = config.extensions;
22
62
  this.integrationDependencies = config.integrationDependencies || [];
23
63
  this.staticBuildStep = config.staticBuildStep || "render";
64
+ this.runtimeCapability = config.runtimeCapability;
65
+ this.jsxImportSource = config.jsxImportSource;
24
66
  }
67
+ /**
68
+ * Attaches the finalized app config to the integration.
69
+ *
70
+ * Core calls this during config finalization before runtime setup so the
71
+ * integration can resolve asset paths and other app-owned services later.
72
+ */
25
73
  setConfig(appConfig) {
26
74
  this.appConfig = appConfig;
27
75
  this.initializeAssetDefinitionService();
28
76
  }
77
+ /**
78
+ * Records the runtime origin used for page-module loading and renderer setup.
79
+ */
29
80
  setRuntimeOrigin(runtimeOrigin) {
30
81
  this.runtimeOrigin = runtimeOrigin;
31
82
  }
83
+ /**
84
+ * Attaches the shared HMR manager and registers integration-owned development hooks.
85
+ *
86
+ * @remarks
87
+ * The default implementation registers the optional integration HMR strategy.
88
+ * Integrations should override this only when they need to extend that shared
89
+ * behavior rather than replace it.
90
+ */
32
91
  setHmrManager(hmrManager) {
33
92
  this.hmrManager = hmrManager;
34
93
  const strategy = this.getHmrStrategy?.();
@@ -39,6 +98,9 @@ class IntegrationPlugin {
39
98
  this.assetProcessingService.setHmrManager(hmrManager);
40
99
  }
41
100
  }
101
+ /**
102
+ * Creates the asset-processing service used for global integration dependencies.
103
+ */
42
104
  initializeAssetDefinitionService() {
43
105
  if (!this.appConfig) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
44
106
  this.assetProcessingService = AssetProcessingService.createWithDefaultProcessors(this.appConfig);
@@ -46,10 +108,16 @@ class IntegrationPlugin {
46
108
  this.assetProcessingService.setHmrManager(this.hmrManager);
47
109
  }
48
110
  }
111
+ /**
112
+ * Returns processed global assets resolved during `setup()`.
113
+ */
49
114
  getResolvedIntegrationDependencies() {
50
115
  return this.resolvedIntegrationDependencies;
51
116
  }
52
- initializeRenderer() {
117
+ /**
118
+ * Creates the shared renderer options owned by core lifecycle setup.
119
+ */
120
+ createRendererOptions(options) {
53
121
  if (!this.appConfig) {
54
122
  throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_APP_CONFIG);
55
123
  }
@@ -57,31 +125,54 @@ class IntegrationPlugin {
57
125
  if (this.hmrManager) {
58
126
  assetProcessingService.setHmrManager(this.hmrManager);
59
127
  }
60
- const renderer = new this.renderer({
128
+ return {
61
129
  appConfig: this.appConfig,
62
130
  assetProcessingService,
63
131
  resolvedIntegrationDependencies: this.resolvedIntegrationDependencies,
132
+ rendererModules: options?.rendererModules,
64
133
  runtimeOrigin: this.runtimeOrigin
65
- });
134
+ };
135
+ }
136
+ /**
137
+ * Attaches runtime-only services after a renderer instance has been created.
138
+ */
139
+ attachRendererRuntimeServices(renderer) {
140
+ if (typeof renderer.name !== "string" || renderer.name.length === 0) {
141
+ renderer.name = this.name;
142
+ }
66
143
  if (this.hmrManager) {
67
144
  renderer.setHmrManager(this.hmrManager);
68
145
  }
69
146
  return renderer;
70
147
  }
71
148
  /**
72
- * Declares whether a component boundary targeting this integration should be
73
- * deferred through the marker pipeline.
149
+ * Instantiates the integration renderer with app-owned services.
74
150
  *
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.
151
+ * @remarks
152
+ * Renderers are cheap runtime objects. They receive the finalized app config,
153
+ * a fresh asset-processing service, integration-global processed assets, and
154
+ * any renderer module context supplied by the active runtime.
155
+ renderer.name ||= this.name;
156
+ */
157
+ initializeRenderer(options) {
158
+ const renderer = new this.renderer(this.createRendererOptions(options));
159
+ renderer.name ||= this.name;
160
+ return this.attachRendererRuntimeServices(renderer);
161
+ }
162
+ /**
163
+ * Prepares build-facing contributions before the app build manifest is sealed.
78
164
  *
79
- * @param input Boundary metadata for the current render pass.
80
- * @returns `true` when the boundary should be deferred; otherwise `false`.
165
+ * @remarks
166
+ * Integrations can override this when runtime or build plugin declarations must
167
+ * be materialized ahead of runtime startup. Runtime-only side effects stay in
168
+ * `setup()`.
81
169
  */
82
- shouldDeferComponentBoundary(_input) {
83
- return false;
170
+ async prepareBuildContributions() {
84
171
  }
172
+ /**
173
+ * Performs runtime-only integration setup after config build has already
174
+ * sealed manifest contributions.
175
+ */
85
176
  async setup() {
86
177
  if (this.integrationDependencies.length === 0) return;
87
178
  if (!this.assetProcessingService) throw new Error(INTEGRATION_PLUGIN_ERRORS.NOT_INITIALIZED_WITH_ASSET_SERVICE);
@@ -91,10 +182,20 @@ class IntegrationPlugin {
91
182
  );
92
183
  this.initializeRenderer();
93
184
  }
185
+ /**
186
+ * Releases runtime resources owned by the integration.
187
+ *
188
+ * @remarks
189
+ * Most integrations do not need custom teardown. Override this only for
190
+ * explicit cleanup such as watchers, compiler handles, or runtime registries
191
+ * that outlive individual requests.
192
+ */
94
193
  async teardown() {
95
194
  }
96
195
  }
97
196
  export {
98
197
  INTEGRATION_PLUGIN_ERRORS,
99
- IntegrationPlugin
198
+ IntegrationPlugin,
199
+ assertIntegrationInvariant,
200
+ mergeIntegrationOptions
100
201
  };
@@ -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[];