@ecopages/core 0.2.0-alpha.2 → 0.2.0-alpha.20

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 (391) hide show
  1. package/CHANGELOG.md +26 -64
  2. package/README.md +212 -14
  3. package/package.json +116 -66
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +4 -12
  11. package/src/adapters/bun/create-app.js +4 -5
  12. package/src/adapters/bun/hmr-manager.d.ts +80 -21
  13. package/src/adapters/bun/hmr-manager.js +168 -62
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +40 -34
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +89 -18
  28. package/src/adapters/node/node-hmr-manager.js +185 -95
  29. package/src/adapters/node/server-adapter.d.ts +6 -35
  30. package/src/adapters/node/server-adapter.js +44 -105
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
  36. package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
  37. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
  38. package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
  39. package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
  40. package/src/adapters/shared/fs-server-response-factory.js +1 -1
  41. package/src/adapters/shared/fs-server-response-matcher.d.ts +8 -12
  42. package/src/adapters/shared/fs-server-response-matcher.js +10 -18
  43. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  44. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  45. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  46. package/src/adapters/shared/hmr-html-response.js +32 -0
  47. package/src/adapters/shared/render-context.d.ts +2 -1
  48. package/src/adapters/shared/render-context.js +6 -3
  49. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  50. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  51. package/src/adapters/shared/server-adapter.d.ts +13 -3
  52. package/src/adapters/shared/server-adapter.js +42 -5
  53. package/src/adapters/shared/server-route-handler.d.ts +4 -4
  54. package/src/adapters/shared/server-route-handler.js +6 -15
  55. package/src/adapters/shared/server-static-builder.d.ts +38 -6
  56. package/src/adapters/shared/server-static-builder.js +64 -10
  57. package/src/build/README.md +107 -0
  58. package/src/build/build-adapter.d.ts +168 -3
  59. package/src/build/build-adapter.js +604 -16
  60. package/src/build/build-manifest.d.ts +27 -0
  61. package/src/build/build-manifest.js +30 -0
  62. package/src/build/dev-build-coordinator.d.ts +72 -0
  63. package/src/build/dev-build-coordinator.js +154 -0
  64. package/src/build/esbuild-build-adapter.d.ts +15 -6
  65. package/src/build/esbuild-build-adapter.js +189 -74
  66. package/src/build/runtime-build-executor.d.ts +14 -0
  67. package/src/build/runtime-build-executor.js +22 -0
  68. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  69. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  70. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  71. package/src/build/runtime-specifier-aliases.js +95 -0
  72. package/src/config/README.md +36 -0
  73. package/src/config/config-builder.d.ts +52 -27
  74. package/src/config/config-builder.js +260 -49
  75. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  76. package/src/{constants.js → config/constants.js} +4 -0
  77. package/src/declarations.d.ts +19 -14
  78. package/src/dev/sc-server.d.ts +1 -1
  79. package/src/dev/sc-server.js +1 -1
  80. package/src/eco/README.md +70 -16
  81. package/src/eco/eco.browser.d.ts +2 -0
  82. package/src/eco/eco.browser.js +83 -0
  83. package/src/eco/eco.js +32 -57
  84. package/src/eco/eco.types.d.ts +12 -4
  85. package/src/eco/eco.utils.d.ts +1 -40
  86. package/src/eco/eco.utils.js +5 -35
  87. package/src/eco/global-injector-map.d.ts +1 -1
  88. package/src/eco/lazy-injector-map.d.ts +1 -1
  89. package/src/hmr/README.md +26 -0
  90. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  91. package/src/hmr/client/hmr-runtime.js +30 -7
  92. package/src/hmr/hmr-strategy.d.ts +16 -13
  93. package/src/hmr/hmr-strategy.js +22 -7
  94. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  95. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  96. package/src/hmr/hmr.test.e2e.js +26 -33
  97. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  98. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  99. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -43
  100. package/src/hmr/strategies/js-hmr-strategy.js +72 -73
  101. package/src/index.browser.d.ts +2 -2
  102. package/src/index.browser.js +1 -1
  103. package/src/index.d.ts +4 -3
  104. package/src/index.js +16 -5
  105. package/src/integrations/ghtml/ghtml-renderer.d.ts +7 -2
  106. package/src/integrations/ghtml/ghtml-renderer.js +33 -30
  107. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  108. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  109. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  110. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  111. package/src/plugins/README.md +35 -0
  112. package/src/plugins/alias-resolver-plugin.js +17 -3
  113. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  114. package/src/plugins/eco-component-meta-plugin.js +27 -21
  115. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  116. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  117. package/src/plugins/integration-plugin.d.ts +145 -28
  118. package/src/plugins/integration-plugin.js +109 -13
  119. package/src/plugins/processor.d.ts +15 -2
  120. package/src/plugins/processor.js +16 -2
  121. package/src/plugins/runtime-capability.d.ts +9 -0
  122. package/src/plugins/source-transform.d.ts +46 -0
  123. package/src/plugins/source-transform.js +71 -0
  124. package/src/route-renderer/GRAPH.md +64 -98
  125. package/src/route-renderer/README.md +67 -46
  126. package/src/route-renderer/orchestration/boundary-planning.service.d.ts +25 -0
  127. package/src/route-renderer/orchestration/boundary-planning.service.js +97 -0
  128. package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
  129. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  130. package/src/route-renderer/orchestration/integration-renderer.d.ts +554 -0
  131. package/src/route-renderer/orchestration/integration-renderer.js +957 -0
  132. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +89 -0
  133. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
  134. package/src/route-renderer/orchestration/render-execution.service.d.ts +43 -0
  135. package/src/route-renderer/orchestration/render-execution.service.js +106 -0
  136. package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
  137. package/src/route-renderer/orchestration/render-output.utils.js +65 -0
  138. package/src/route-renderer/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +18 -10
  139. package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +115 -17
  140. package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +50 -0
  141. package/src/route-renderer/orchestration/route-shell-composer.service.js +81 -0
  142. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  143. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  144. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  145. package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +28 -12
  146. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  147. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  148. package/src/route-renderer/route-renderer.d.ts +45 -4
  149. package/src/route-renderer/route-renderer.js +38 -3
  150. package/src/router/README.md +97 -0
  151. package/src/router/client/link-intent.d.ts +53 -0
  152. package/src/router/client/link-intent.js +34 -0
  153. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  154. package/src/router/client/link-intent.test.browser.js +43 -0
  155. package/src/router/client/navigation-coordinator.d.ts +149 -0
  156. package/src/router/client/navigation-coordinator.js +215 -0
  157. package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
  158. package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +14 -8
  159. package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
  160. package/src/router/{fs-router.js → server/fs-router.js} +1 -1
  161. package/src/services/README.md +29 -0
  162. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
  163. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +91 -10
  164. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  165. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  166. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
  167. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  168. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
  169. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  170. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  171. package/src/services/assets/asset-processing-service/index.d.ts +5 -0
  172. package/src/services/assets/asset-processing-service/index.js +5 -0
  173. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  174. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  175. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  176. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
  177. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +5 -4
  178. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +15 -23
  179. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  180. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  181. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +2 -2
  182. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +1 -1
  183. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  184. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +16 -4
  185. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  186. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +6 -5
  187. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
  188. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +1 -1
  189. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +5 -2
  191. package/src/services/assets/browser-bundle.service.d.ts +32 -0
  192. package/src/services/assets/browser-bundle.service.js +33 -0
  193. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  194. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  195. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  196. package/src/services/html/html-rewriter-provider.service.js +68 -0
  197. package/src/services/html/html-transformer.service.d.ts +77 -0
  198. package/src/services/html/html-transformer.service.js +215 -0
  199. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  200. package/src/services/invalidation/development-invalidation.service.js +190 -0
  201. package/src/services/module-loading/app-module-loader.service.d.ts +28 -0
  202. package/src/services/module-loading/app-module-loader.service.js +35 -0
  203. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  204. package/src/services/module-loading/app-server-module-transpiler.service.js +109 -0
  205. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  206. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  207. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  208. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  209. package/src/services/module-loading/node-bootstrap-plugin.js +204 -0
  210. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  211. package/src/services/module-loading/page-module-import.service.js +173 -0
  212. package/src/services/module-loading/server-module-transpiler.service.d.ts +72 -0
  213. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  214. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  215. package/src/services/runtime-state/dev-graph.service.js +162 -0
  216. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  217. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  218. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
  219. package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
  220. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  221. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  222. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  223. package/src/static-site-generator/README.md +26 -0
  224. package/src/static-site-generator/static-site-generator.d.ts +50 -3
  225. package/src/static-site-generator/static-site-generator.js +71 -5
  226. package/src/{internal-types.d.ts → types/internal-types.d.ts} +53 -22
  227. package/src/types/internal-types.js +0 -0
  228. package/src/{public-types.d.ts → types/public-types.d.ts} +146 -21
  229. package/src/types/public-types.js +0 -0
  230. package/src/utils/html-escaping.d.ts +7 -0
  231. package/src/utils/html-escaping.js +6 -0
  232. package/src/utils/locals-utils.d.ts +1 -1
  233. package/src/utils/parse-cli-args.d.ts +4 -1
  234. package/src/utils/parse-cli-args.js +16 -1
  235. package/src/utils/resolve-work-dir.d.ts +11 -0
  236. package/src/utils/resolve-work-dir.js +31 -0
  237. package/src/watchers/project-watcher.d.ts +40 -24
  238. package/src/watchers/project-watcher.js +129 -92
  239. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  240. package/src/watchers/project-watcher.test-helpers.js +1 -0
  241. package/src/adapters/abstract/application-adapter.ts +0 -337
  242. package/src/adapters/abstract/router-adapter.ts +0 -30
  243. package/src/adapters/abstract/server-adapter.ts +0 -79
  244. package/src/adapters/bun/client-bridge.ts +0 -62
  245. package/src/adapters/bun/create-app.ts +0 -189
  246. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  247. package/src/adapters/bun/define-api-handler.ts +0 -114
  248. package/src/adapters/bun/hmr-manager.ts +0 -281
  249. package/src/adapters/bun/index.ts +0 -3
  250. package/src/adapters/bun/server-adapter.ts +0 -492
  251. package/src/adapters/bun/server-lifecycle.ts +0 -154
  252. package/src/adapters/index.ts +0 -6
  253. package/src/adapters/node/create-app.ts +0 -179
  254. package/src/adapters/node/index.d.ts +0 -4
  255. package/src/adapters/node/index.js +0 -8
  256. package/src/adapters/node/index.ts +0 -9
  257. package/src/adapters/node/node-client-bridge.ts +0 -79
  258. package/src/adapters/node/node-hmr-manager.ts +0 -271
  259. package/src/adapters/node/server-adapter.ts +0 -561
  260. package/src/adapters/node/static-content-server.ts +0 -203
  261. package/src/adapters/shared/api-response.ts +0 -104
  262. package/src/adapters/shared/application-adapter.ts +0 -199
  263. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  264. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  265. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  266. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  267. package/src/adapters/shared/render-context.ts +0 -105
  268. package/src/adapters/shared/server-adapter.ts +0 -442
  269. package/src/adapters/shared/server-route-handler.ts +0 -166
  270. package/src/adapters/shared/server-static-builder.ts +0 -82
  271. package/src/build/build-adapter.ts +0 -132
  272. package/src/build/build-types.ts +0 -83
  273. package/src/build/esbuild-build-adapter.ts +0 -510
  274. package/src/config/config-builder.ts +0 -474
  275. package/src/constants.ts +0 -39
  276. package/src/create-app.ts +0 -87
  277. package/src/define-api-handler.js +0 -15
  278. package/src/define-api-handler.ts +0 -66
  279. package/src/dev/sc-server.ts +0 -143
  280. package/src/eco/component-render-context.d.ts +0 -105
  281. package/src/eco/component-render-context.js +0 -77
  282. package/src/eco/component-render-context.ts +0 -202
  283. package/src/eco/eco.ts +0 -221
  284. package/src/eco/eco.types.ts +0 -202
  285. package/src/eco/global-injector-map.ts +0 -112
  286. package/src/eco/lazy-injector-map.ts +0 -120
  287. package/src/eco/module-dependencies.ts +0 -75
  288. package/src/errors/http-error.ts +0 -72
  289. package/src/errors/index.ts +0 -2
  290. package/src/errors/locals-access-error.ts +0 -7
  291. package/src/global/app-logger.ts +0 -4
  292. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
  293. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  294. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  295. package/src/hmr/client/hmr-runtime.ts +0 -121
  296. package/src/hmr/hmr-strategy.ts +0 -172
  297. package/src/hmr/hmr.test.e2e.ts +0 -75
  298. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  299. package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
  300. package/src/index.browser.ts +0 -3
  301. package/src/index.ts +0 -5
  302. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  303. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  304. package/src/internal-types.ts +0 -212
  305. package/src/plugins/alias-resolver-plugin.ts +0 -45
  306. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  307. package/src/plugins/integration-plugin.ts +0 -184
  308. package/src/plugins/processor.ts +0 -220
  309. package/src/public-types.ts +0 -1255
  310. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  311. package/src/route-renderer/component-graph-executor.js +0 -31
  312. package/src/route-renderer/component-graph-executor.ts +0 -84
  313. package/src/route-renderer/component-graph.d.ts +0 -42
  314. package/src/route-renderer/component-graph.js +0 -72
  315. package/src/route-renderer/component-graph.ts +0 -159
  316. package/src/route-renderer/component-marker.d.ts +0 -52
  317. package/src/route-renderer/component-marker.js +0 -46
  318. package/src/route-renderer/component-marker.ts +0 -117
  319. package/src/route-renderer/dependency-resolver.ts +0 -596
  320. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  321. package/src/route-renderer/html-post-processing.service.js +0 -86
  322. package/src/route-renderer/html-post-processing.service.ts +0 -103
  323. package/src/route-renderer/integration-renderer.d.ts +0 -339
  324. package/src/route-renderer/integration-renderer.js +0 -526
  325. package/src/route-renderer/integration-renderer.ts +0 -696
  326. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  327. package/src/route-renderer/marker-graph-resolver.js +0 -93
  328. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  329. package/src/route-renderer/page-module-loader.d.ts +0 -61
  330. package/src/route-renderer/page-module-loader.ts +0 -153
  331. package/src/route-renderer/render-execution.service.d.ts +0 -69
  332. package/src/route-renderer/render-execution.service.js +0 -91
  333. package/src/route-renderer/render-execution.service.ts +0 -158
  334. package/src/route-renderer/render-preparation.service.ts +0 -358
  335. package/src/route-renderer/route-renderer.ts +0 -80
  336. package/src/router/fs-router-scanner.ts +0 -217
  337. package/src/router/fs-router.ts +0 -122
  338. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  339. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  340. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  341. package/src/services/asset-processing-service/assets.types.ts +0 -112
  342. package/src/services/asset-processing-service/index.d.ts +0 -3
  343. package/src/services/asset-processing-service/index.js +0 -3
  344. package/src/services/asset-processing-service/index.ts +0 -3
  345. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  346. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  347. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  348. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  349. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  350. package/src/services/asset-processing-service/processors/index.js +0 -5
  351. package/src/services/asset-processing-service/processors/index.ts +0 -5
  352. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  353. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  354. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  355. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  356. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  357. package/src/services/cache/cache.types.ts +0 -126
  358. package/src/services/cache/index.ts +0 -18
  359. package/src/services/cache/memory-cache-store.ts +0 -130
  360. package/src/services/cache/page-cache-service.ts +0 -202
  361. package/src/services/html-transformer.service.d.ts +0 -50
  362. package/src/services/html-transformer.service.js +0 -163
  363. package/src/services/html-transformer.service.ts +0 -217
  364. package/src/services/page-module-import.service.d.ts +0 -37
  365. package/src/services/page-module-import.service.js +0 -88
  366. package/src/services/page-module-import.service.ts +0 -129
  367. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  368. package/src/services/schema-validation-service.ts +0 -204
  369. package/src/services/validation/standard-schema.types.ts +0 -68
  370. package/src/static-site-generator/static-site-generator.ts +0 -359
  371. package/src/utils/css.d.ts +0 -1
  372. package/src/utils/css.js +0 -7
  373. package/src/utils/css.ts +0 -5
  374. package/src/utils/deep-merge.ts +0 -47
  375. package/src/utils/hash.ts +0 -5
  376. package/src/utils/html.ts +0 -1
  377. package/src/utils/invariant.ts +0 -15
  378. package/src/utils/locals-utils.ts +0 -37
  379. package/src/utils/parse-cli-args.ts +0 -83
  380. package/src/utils/path-utils.module.ts +0 -14
  381. package/src/utils/runtime.ts +0 -44
  382. package/src/utils/server-utils.module.ts +0 -67
  383. package/src/watchers/project-watcher.test-helpers.ts +0 -40
  384. package/src/watchers/project-watcher.ts +0 -306
  385. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  386. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  387. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  388. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  389. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  390. /package/src/{public-types.js → services/module-loading/module-loading-types.js} +0 -0
  391. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,9 +1,5 @@
1
- import { IntegrationPlugin, type IntegrationPluginConfig } from '../../plugins/integration-plugin';
2
- import { GhtmlRenderer } from './ghtml-renderer';
3
- /**
4
- * The name of the ghtml plugin
5
- */
6
- export declare const GHTML_PLUGIN_NAME = "ghtml";
1
+ import { IntegrationPlugin, type IntegrationPluginConfig } from '../../plugins/integration-plugin.js';
2
+ import { GhtmlRenderer } from './ghtml-renderer.js';
7
3
  /**
8
4
  * The Ghtml plugin class
9
5
  * This plugin provides support for ghtml components in Ecopages
@@ -1,6 +1,6 @@
1
- import { IntegrationPlugin } from "../../plugins/integration-plugin";
2
- import { GhtmlRenderer } from "./ghtml-renderer";
3
- const GHTML_PLUGIN_NAME = "ghtml";
1
+ import { IntegrationPlugin } from "../../plugins/integration-plugin.js";
2
+ import { GhtmlRenderer } from "./ghtml-renderer.js";
3
+ import { GHTML_PLUGIN_NAME } from "./ghtml.constants.js";
4
4
  class GhtmlPlugin extends IntegrationPlugin {
5
5
  renderer = GhtmlRenderer;
6
6
  constructor(options) {
@@ -15,7 +15,6 @@ function ghtmlPlugin(options) {
15
15
  return new GhtmlPlugin(options);
16
16
  }
17
17
  export {
18
- GHTML_PLUGIN_NAME,
19
18
  GhtmlPlugin,
20
19
  ghtmlPlugin
21
20
  };
@@ -0,0 +1,35 @@
1
+ # Plugin Contracts
2
+
3
+ This directory contains the authoring contracts for Ecopages integrations, processors, and related plugin-facing runtime declarations.
4
+
5
+ ## Purpose
6
+
7
+ The plugin layer defines what packages are allowed to declare about themselves, while core retains orchestration ownership.
8
+
9
+ These contracts are responsible for:
10
+
11
+ - integration registration and lifecycle hooks
12
+ - processor registration and asset capability declaration
13
+ - runtime capability declaration and validation input
14
+ - shared build-plugin bridge types used by integrations and processors
15
+
16
+ ## Main Files
17
+
18
+ - `integration-plugin.ts`: framework-semantics contract for render integrations
19
+ - `processor.ts`: asset-transformation contract for processors
20
+ - `runtime-capability.ts`: runtime compatibility declaration types
21
+ - `source-transform.ts`: bundler-neutral source-transform primitive with Ecopages adapters plus app-level Vite plugin composition helpers
22
+ - `eco-component-meta-plugin.ts`: shared metadata transform used by core loading/build paths
23
+
24
+ ## Ownership Rules
25
+
26
+ - Integrations own rendering semantics, hydration behavior, and integration-specific HMR strategy.
27
+ - Processors own asset semantics, cache ownership, and processor-specific watch behavior.
28
+ - Core owns lifecycle ordering, startup orchestration, and manifest assembly.
29
+
30
+ ## Lifecycle Summary
31
+
32
+ 1. Config build validates and prepares plugin contributions.
33
+ 2. Core seals the app-owned build manifest.
34
+ 3. Runtime startup calls runtime-only setup hooks.
35
+ 4. Request-time rendering and development invalidation reuse those finalized contracts.
@@ -1,9 +1,11 @@
1
- import { existsSync } from "node:fs";
1
+ import { existsSync, readFileSync } from "node:fs";
2
2
  import path from "node:path";
3
3
  const RESOLVABLE_EXTENSIONS = [".ts", ".tsx", ".js", ".jsx", ".mjs", ".cjs", ".mdx", ".css", ".scss", ".sass", ".less"];
4
4
  function findResolvablePath(candidate) {
5
5
  if (path.extname(candidate)) {
6
- return existsSync(candidate) ? candidate : void 0;
6
+ if (existsSync(candidate)) {
7
+ return candidate;
8
+ }
7
9
  }
8
10
  for (const extension of RESOLVABLE_EXTENSIONS) {
9
11
  const fileCandidate = `${candidate}${extension}`;
@@ -19,6 +21,18 @@ function findResolvablePath(candidate) {
19
21
  }
20
22
  return void 0;
21
23
  }
24
+ function resolveAliasedBarrelTarget(resolvedPath) {
25
+ if (!path.basename(resolvedPath).startsWith("index.")) {
26
+ return resolvedPath;
27
+ }
28
+ const source = readFileSync(resolvedPath, "utf8").trim();
29
+ const match = source.match(/^export\s+\*\s+from\s+['"]([^'"]+)['"]\s*;?$/);
30
+ if (!match?.[1]?.startsWith(".")) {
31
+ return resolvedPath;
32
+ }
33
+ const target = findResolvablePath(path.resolve(path.dirname(resolvedPath), match[1]));
34
+ return target ?? resolvedPath;
35
+ }
22
36
  function createAliasResolverPlugin(srcDir) {
23
37
  return {
24
38
  name: "ecopages-alias-resolver",
@@ -27,7 +41,7 @@ function createAliasResolverPlugin(srcDir) {
27
41
  const candidate = path.join(srcDir, args.path.slice(2));
28
42
  const resolved = findResolvablePath(candidate);
29
43
  if (resolved) {
30
- return { path: resolved };
44
+ return { path: resolveAliasedBarrelTarget(resolved) };
31
45
  }
32
46
  return {};
33
47
  });
@@ -26,7 +26,8 @@
26
26
  * @module eco-component-meta-plugin
27
27
  */
28
28
  import type { EcoBuildPlugin } from '../build/build-types.js';
29
- import type { EcoPagesAppConfig } from '../internal-types.js';
29
+ import type { EcoPagesAppConfig } from '../types/internal-types.js';
30
+ import { type EcoSourceTransform, type EcoViteCompatiblePlugin } from './source-transform.js';
30
31
  /**
31
32
  * Options for creating the eco-component-meta-plugin.
32
33
  */
@@ -34,6 +35,11 @@ export interface EcoComponentDirPluginOptions {
34
35
  /** The EcoPages application configuration containing integration settings */
35
36
  config: EcoPagesAppConfig;
36
37
  }
38
+ /**
39
+ * Creates the bundler-neutral metadata transform used by Ecopages loaders and
40
+ * Vite-compatible adapters.
41
+ */
42
+ export declare function createEcoComponentMetaTransform(options: EcoComponentDirPluginOptions): EcoSourceTransform;
37
43
  /**
38
44
  * Creates a build plugin that auto-injects `__eco` metadata into EcoComponent config objects.
39
45
  *
@@ -47,6 +53,8 @@ export interface EcoComponentDirPluginOptions {
47
53
  * Supported patterns:
48
54
  * - `eco.page({ ... })` - Page component declarations
49
55
  * - `eco.component({ ... })` - Reusable component declarations
56
+ * - `eco.html({ ... })` - HTML shell declarations
57
+ * - `eco.layout({ ... })` - Layout declarations
50
58
  * - `Component.config = { ... }` - Config assignment pattern
51
59
  * - `config: { ... }` - Config property in object literals
52
60
  * - `export const config = { ... }` - Exported config declarations
@@ -63,6 +71,11 @@ export interface EcoComponentDirPluginOptions {
63
71
  * ```
64
72
  */
65
73
  export declare function createEcoComponentMetaPlugin(options: EcoComponentDirPluginOptions): EcoBuildPlugin;
74
+ /**
75
+ * Creates a Vite-compatible metadata injection plugin from the shared
76
+ * Ecopages source-transform primitive.
77
+ */
78
+ export declare function createEcoComponentMetaVitePlugin(options: EcoComponentDirPluginOptions): EcoViteCompatiblePlugin;
66
79
  /**
67
80
  * Injects `__eco` metadata into EcoComponent config objects in file content.
68
81
  *
@@ -1,7 +1,10 @@
1
1
  import path from "node:path";
2
2
  import { parseSync } from "oxc-parser";
3
- import { fileSystem } from "@ecopages/file-system";
4
3
  import { rapidhash } from "../utils/hash.js";
4
+ import {
5
+ createEcoBuildPluginFromSourceTransform,
6
+ createVitePluginFromSourceTransform
7
+ } from "./source-transform.js";
5
8
  const REGEX_SPECIAL_CHARS = /[.*+?^${}()|[\]\\]/g;
6
9
  const VALID_LOADER_EXTENSIONS = /* @__PURE__ */ new Set([".ts", ".tsx", ".js", ".jsx"]);
7
10
  function hasValidLoaderExtension(ext) {
@@ -38,30 +41,31 @@ function createExtensionPattern(extensions) {
38
41
  const escaped = uniqueExtensions.map((ext) => ext.replace(REGEX_SPECIAL_CHARS, "\\$&"));
39
42
  return new RegExp(`(${escaped.join("|")})(\\?.*)?$`);
40
43
  }
41
- function createEcoComponentMetaPlugin(options) {
44
+ function createEcoComponentMetaTransform(options) {
45
+ const allExtensions = options.config.integrations.flatMap((integration) => integration.extensions).filter(hasValidLoaderExtension);
46
+ if (allExtensions.length === 0) {
47
+ throw new Error("[eco-component-meta-plugin] No extensions configured. At least one integration is required.");
48
+ }
49
+ const extensionPattern = createExtensionPattern(allExtensions);
50
+ const extensionToIntegration = buildExtensionToIntegrationMap(options.config.integrations);
42
51
  return {
43
52
  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
- });
53
+ enforce: "pre",
54
+ filter: extensionPattern,
55
+ transform(code, id) {
56
+ const integration = detectIntegration(id, extensionToIntegration);
57
+ return {
58
+ code: injectEcoMeta(code, id, integration)
59
+ };
62
60
  }
63
61
  };
64
62
  }
63
+ function createEcoComponentMetaPlugin(options) {
64
+ return createEcoBuildPluginFromSourceTransform(createEcoComponentMetaTransform(options));
65
+ }
66
+ function createEcoComponentMetaVitePlugin(options) {
67
+ return createVitePluginFromSourceTransform(createEcoComponentMetaTransform(options));
68
+ }
65
69
  function findInjectionPoints(node, insertions, injection, isInsideEcoComponent = false) {
66
70
  if (!node || typeof node !== "object") return;
67
71
  const n = node;
@@ -70,7 +74,7 @@ function findInjectionPoints(node, insertions, injection, isInsideEcoComponent =
70
74
  if (callee?.type === "MemberExpression" || callee?.type === "StaticMemberExpression") {
71
75
  const obj = callee.object;
72
76
  const prop = callee.property;
73
- if (obj?.type === "Identifier" && obj?.name === "eco" && (prop?.name === "page" || prop?.name === "component")) {
77
+ if (obj?.type === "Identifier" && obj?.name === "eco" && (prop?.name === "page" || prop?.name === "component" || prop?.name === "html" || prop?.name === "layout")) {
74
78
  const args = n.arguments;
75
79
  const firstArg = args?.[0];
76
80
  if (firstArg?.type === "ObjectExpression") {
@@ -152,6 +156,8 @@ function injectEcoMeta(contents, filePath, integration) {
152
156
  var eco_component_meta_plugin_default = createEcoComponentMetaPlugin;
153
157
  export {
154
158
  createEcoComponentMetaPlugin,
159
+ createEcoComponentMetaTransform,
160
+ createEcoComponentMetaVitePlugin,
155
161
  eco_component_meta_plugin_default as default,
156
162
  injectEcoMeta
157
163
  };
@@ -0,0 +1,31 @@
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
+ /** Optional plugin name override for debug output. */
11
+ name?: string;
12
+ }
13
+ /**
14
+ * Build plugin that prepends a `@jsxImportSource` pragma to foreign integration
15
+ * files bundled into a host integration's client graph.
16
+ *
17
+ * When a host integration (e.g. React) bundles a component file that belongs to
18
+ * another JSX integration (e.g. `.kita.tsx`), that file inherits the project
19
+ * `tsconfig` JSX runtime which produces the wrong output (HTML strings instead
20
+ * of framework elements). This plugin rewrites the source to explicitly target
21
+ * the host's JSX factory so esbuild compiles every JSX expression into the
22
+ * correct element creation calls.
23
+ *
24
+ * The plugin is intentionally framework-agnostic: any integration that does
25
+ * client-side bundling can use it by passing its own `jsxImportSource` and the
26
+ * set of foreign extensions collected from the app config.
27
+ *
28
+ * When no JSX-bearing foreign extensions are present, the returned plugin is a
29
+ * no-op so integrations can register it unconditionally.
30
+ */
31
+ export declare function createForeignJsxOverridePlugin(options: ForeignJsxOverrideOptions): EcoBuildPlugin;
@@ -0,0 +1,35 @@
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
+ if (extensions.length === 0) {
6
+ return {
7
+ name: options.name ?? "foreign-jsx-override",
8
+ setup() {
9
+ }
10
+ };
11
+ }
12
+ const pragma = `/** @jsxImportSource ${options.hostJsxImportSource} */
13
+ `;
14
+ const filter = new RegExp(`(${extensions.map((e) => e.replace(".", "\\.")).join("|")})$`);
15
+ return {
16
+ name: options.name ?? "foreign-jsx-override",
17
+ setup(build) {
18
+ build.onLoad({ filter }, (args) => {
19
+ const source = readFileSync(args.path, "utf-8");
20
+ const loader = args.path.endsWith(".jsx") ? "jsx" : "tsx";
21
+ if (source.includes("@jsxImportSource")) {
22
+ return void 0;
23
+ }
24
+ return {
25
+ contents: pragma + source,
26
+ loader,
27
+ resolveDir: path.dirname(args.path)
28
+ };
29
+ });
30
+ }
31
+ };
32
+ }
33
+ export {
34
+ createForeignJsxOverridePlugin
35
+ };
@@ -1,14 +1,24 @@
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';
8
10
  export declare const INTEGRATION_PLUGIN_ERRORS: {
9
11
  readonly NOT_INITIALIZED_WITH_APP_CONFIG: "Plugin not initialized with app config";
10
12
  readonly NOT_INITIALIZED_WITH_ASSET_SERVICE: "Plugin not initialized with asset dependency service";
11
13
  };
14
+ /**
15
+ * Base configuration shared by all integration plugins.
16
+ *
17
+ * @remarks
18
+ * Integrations declare their file ownership, optional runtime requirements, and
19
+ * any global assets or build-time contributions here. Runtime-only side effects
20
+ * belong in `setup()` rather than the constructor.
21
+ */
12
22
  export interface IntegrationPluginConfig {
13
23
  /**
14
24
  * The name of the integration plugin.
@@ -31,29 +41,48 @@ export interface IntegrationPluginConfig {
31
41
  * @default 'render'
32
42
  */
33
43
  staticBuildStep?: 'render' | 'fetch';
44
+ /**
45
+ * Declares runtime-specific requirements that must be satisfied before the
46
+ * app can start with this integration enabled.
47
+ */
48
+ runtimeCapability?: RuntimeCapabilityDeclaration;
49
+ /**
50
+ * JSX import source owned by this integration.
51
+ *
52
+ * @remarks
53
+ * This is primarily used by mixed-JSX flows where host-owned browser bundles
54
+ * need to preserve the correct JSX runtime for files claimed by the
55
+ * integration.
56
+ */
57
+ jsxImportSource?: string;
34
58
  }
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
59
  type RendererClass<C> = new (options: {
47
60
  appConfig: EcoPagesAppConfig;
48
61
  assetProcessingService: AssetProcessingService;
49
62
  resolvedIntegrationDependencies: ProcessedAsset[];
63
+ rendererModules?: unknown;
50
64
  runtimeOrigin: string;
51
65
  }) => IntegrationRenderer<C>;
66
+ /**
67
+ * Base class for framework integrations.
68
+ *
69
+ * @remarks
70
+ * An integration owns three main concerns:
71
+ * - which file extensions it claims
72
+ * - which renderer class turns those files into HTML
73
+ * - which build-time or runtime contributions must be registered for that framework
74
+ *
75
+ * Core owns lifecycle ordering. Integrations declare contributions through the
76
+ * hooks on this class, while `ConfigBuilder.build()` and app startup decide when
77
+ * those hooks run.
78
+ */
52
79
  export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
53
80
  readonly name: string;
54
81
  readonly extensions: string[];
55
82
  abstract renderer: RendererClass<C>;
56
83
  readonly staticBuildStep: 'render' | 'fetch';
84
+ readonly runtimeCapability?: RuntimeCapabilityDeclaration;
85
+ readonly jsxImportSource?: string;
57
86
  protected integrationDependencies: AssetDefinition[];
58
87
  protected resolvedIntegrationDependencies: ProcessedAsset[];
59
88
  protected options?: Record<string, unknown>;
@@ -62,8 +91,33 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
62
91
  protected hmrManager?: IHmrManager;
63
92
  runtimeOrigin: string;
64
93
  get plugins(): EcoBuildPlugin[];
94
+ /**
95
+ * Returns build plugins that should only apply to browser-oriented bundles.
96
+ *
97
+ * @remarks
98
+ * Browser-only transforms such as runtime import aliasing belong here so they
99
+ * do not affect server bundles or static-page module generation.
100
+ */
101
+ get browserBuildPlugins(): EcoBuildPlugin[];
102
+ /**
103
+ * Creates the integration with static declaration-only configuration.
104
+ *
105
+ * @remarks
106
+ * Constructors are expected to stay side-effect free. Build-manifest
107
+ * contributions belong in `prepareBuildContributions()` and runtime-only setup
108
+ * belongs in `setup()`.
109
+ */
65
110
  constructor(config: IntegrationPluginConfig);
111
+ /**
112
+ * Attaches the finalized app config to the integration.
113
+ *
114
+ * Core calls this during config finalization before runtime setup so the
115
+ * integration can resolve asset paths and other app-owned services later.
116
+ */
66
117
  setConfig(appConfig: EcoPagesAppConfig): void;
118
+ /**
119
+ * Records the runtime origin used for page-module loading and renderer setup.
120
+ */
67
121
  setRuntimeOrigin(runtimeOrigin: string): void;
68
122
  /**
69
123
  * Returns an HMR strategy for this integration, if applicable.
@@ -80,23 +134,86 @@ export declare abstract class IntegrationPlugin<C = EcoPagesElement> {
80
134
  * ```
81
135
  */
82
136
  getHmrStrategy?(): HmrStrategy | undefined;
137
+ /**
138
+ * Returns bare-specifier mappings that should be registered in the active
139
+ * runtime specifier registry.
140
+ *
141
+ * @remarks
142
+ * Integrations that own browser runtime bundles can override this to expose
143
+ * stable bare specifiers for client-side imports.
144
+ *
145
+ * Today these mappings are consumed by the development runtime and browser
146
+ * bundle aliasing path. They are intentionally generic enough to grow into a
147
+ * broader import-map-style facility later without moving framework-specific
148
+ * map contents into core.
149
+ */
150
+ getRuntimeSpecifierMap(): Record<string, string>;
151
+ /**
152
+ * Attaches the shared HMR manager and registers integration-owned development hooks.
153
+ *
154
+ * @remarks
155
+ * The default implementation registers both runtime bare-specifier mappings and
156
+ * the optional integration HMR strategy. Integrations should override this only
157
+ * when they need to extend that shared behavior rather than replace it.
158
+ */
83
159
  setHmrManager(hmrManager: IHmrManager): void;
160
+ /**
161
+ * Creates the asset-processing service used for global integration dependencies.
162
+ */
84
163
  initializeAssetDefinitionService(): void;
164
+ /**
165
+ * Returns processed global assets resolved during `setup()`.
166
+ */
85
167
  getResolvedIntegrationDependencies(): ProcessedAsset[];
86
- initializeRenderer(): IntegrationRenderer<C>;
87
168
  /**
88
- * Declares whether a component boundary targeting this integration should be
89
- * deferred through the marker pipeline.
169
+ * Creates the shared renderer options owned by core lifecycle setup.
170
+ */
171
+ protected createRendererOptions(options?: {
172
+ rendererModules?: unknown;
173
+ }): {
174
+ appConfig: EcoPagesAppConfig;
175
+ assetProcessingService: AssetProcessingService;
176
+ resolvedIntegrationDependencies: ProcessedAsset[];
177
+ rendererModules: unknown;
178
+ runtimeOrigin: string;
179
+ };
180
+ /**
181
+ * Attaches runtime-only services after a renderer instance has been created.
182
+ */
183
+ protected attachRendererRuntimeServices<T extends IntegrationRenderer<C>>(renderer: T): T;
184
+ /**
185
+ * Instantiates the integration renderer with app-owned services.
90
186
  *
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.
187
+ * @remarks
188
+ * Renderers are cheap runtime objects. They receive the finalized app config,
189
+ * a fresh asset-processing service, integration-global processed assets, and
190
+ * any renderer module context supplied by the active runtime.
191
+ renderer.name ||= this.name;
192
+ */
193
+ initializeRenderer(options?: {
194
+ rendererModules?: unknown;
195
+ }): IntegrationRenderer<C>;
196
+ /**
197
+ * Prepares build-facing contributions before the app build manifest is sealed.
94
198
  *
95
- * @param input Boundary metadata for the current render pass.
96
- * @returns `true` when the boundary should be deferred; otherwise `false`.
199
+ * @remarks
200
+ * Integrations can override this when runtime or build plugin declarations must
201
+ * be materialized ahead of runtime startup. Runtime-only side effects stay in
202
+ * `setup()`.
203
+ */
204
+ prepareBuildContributions(): Promise<void>;
205
+ /**
206
+ * Performs runtime-only integration setup after config build has already
207
+ * sealed manifest contributions.
97
208
  */
98
- shouldDeferComponentBoundary(_input: ComponentBoundaryPolicyInput): boolean;
99
209
  setup(): Promise<void>;
210
+ /**
211
+ * Releases runtime resources owned by the integration.
212
+ *
213
+ * @remarks
214
+ * Most integrations do not need custom teardown. Override this only for
215
+ * explicit cleanup such as watchers, compiler handles, or runtime registries
216
+ * that outlive individual requests.
217
+ */
100
218
  teardown(): Promise<void>;
101
219
  }
102
- export {};