@ecopages/core 0.2.0-alpha.4 → 0.2.0-alpha.40

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