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

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 +92 -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 -62
  12. package/src/adapters/bun/hmr-manager.js +30 -194
  13. package/src/adapters/bun/index.d.ts +2 -3
  14. package/src/adapters/bun/index.js +3 -3
  15. package/src/adapters/bun/runtime-host.d.ts +52 -0
  16. package/src/adapters/bun/runtime-host.js +56 -0
  17. package/src/adapters/bun/server-adapter.d.ts +93 -32
  18. package/src/adapters/bun/server-adapter.js +166 -89
  19. package/src/adapters/bun/static-preview-host.d.ts +28 -0
  20. package/src/adapters/bun/static-preview-host.js +45 -0
  21. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  22. package/src/{create-app.js → adapters/create-app.js} +4 -4
  23. package/src/adapters/index.d.ts +2 -6
  24. package/src/adapters/index.js +2 -8
  25. package/src/adapters/node/create-app.d.ts +15 -12
  26. package/src/adapters/node/create-app.js +34 -85
  27. package/src/adapters/node/http-request-bridge.d.ts +57 -0
  28. package/src/adapters/node/http-request-bridge.js +118 -0
  29. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  30. package/src/adapters/node/node-hmr-manager.d.ts +38 -48
  31. package/src/adapters/node/node-hmr-manager.js +31 -203
  32. package/src/adapters/node/runtime-host.d.ts +57 -0
  33. package/src/adapters/node/runtime-host.js +92 -0
  34. package/src/adapters/node/server-adapter-dependencies.d.ts +19 -0
  35. package/src/adapters/node/server-adapter-dependencies.js +18 -0
  36. package/src/adapters/node/server-adapter.d.ts +20 -72
  37. package/src/adapters/node/server-adapter.js +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 +240 -0
  71. package/src/adapters/shared/static-preview-host.d.ts +10 -0
  72. package/src/build/README.md +107 -0
  73. package/src/build/build-adapter.d.ts +175 -3
  74. package/src/build/build-adapter.js +625 -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 -75
  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 +40 -42
  120. package/src/hmr/strategies/js-hmr-strategy.js +24 -43
  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 +991 -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 +156 -0
  166. package/src/route-renderer/orchestration/route-render-orchestrator.js +577 -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 +120 -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 +38 -0
  258. package/src/services/module-loading/node-bootstrap-plugin.js +215 -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 -31
  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 +11 -7
  287. package/src/watchers/project-watcher.js +69 -75
  288. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  289. package/src/watchers/project-watcher.test-helpers.js +6 -5
  290. package/CHANGELOG.md +0 -94
  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 -276
  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 -271
  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 -133
  324. package/src/build/build-types.ts +0 -83
  325. package/src/build/esbuild-build-adapter.ts +0 -511
  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 -327
  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 -1255
  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 -40
  447. package/src/watchers/project-watcher.ts +0 -364
  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
@@ -0,0 +1,534 @@
1
+ /**
2
+ * This module contains the abstract class for the Integration Renderer
3
+ * Every integration renderer should extend this class
4
+ * @module
5
+ */
6
+ import type { EcoPagesAppConfig, IHmrManager } from '../../types/internal-types.js';
7
+ import type { ComponentRenderInput, ComponentRenderResult, ForeignSubtreeRenderPayload, EcoComponent, EcoComponentDependencies, EcoPageFile, EcoPagesElement, BaseIntegrationContext, HtmlTemplateProps, IntegrationRendererRenderOptions, PageBrowserGraphContribution, PageBrowserGraphContributionContext, PageBrowserGraphResult, PageMetadataProps, RouteRendererBody, RouteRendererOptions, RouteRenderResult } from '../../types/public-types.js';
8
+ import { type AssetProcessingService, type ProcessedAsset } from '../../services/assets/asset-processing-service/index.js';
9
+ import { HtmlTransformerService } from '../../services/html/html-transformer.service.js';
10
+ import type { HtmlDocumentContribution } from '../../services/html/html-transformer.service.js';
11
+ import { HttpError } from '../../errors/http-error.js';
12
+ import { DependencyResolverService } from '../page-loading/dependency-resolver.js';
13
+ import { PageModuleLoaderService } from '../page-loading/page-module-loader.js';
14
+ import { type RouteHtmlFinalization, RouteRenderOrchestrator, type RouteRenderOrchestratorAdapter, type RouteRenderOrchestratorResolvedInputs } from './route-render-orchestrator.js';
15
+ import type { ForeignChildRuntime } from './component-render-context.js';
16
+ import { ForeignSubtreeExecutionService, type ForeignSubtreeExecutionOwningRenderer } from './foreign-subtree-execution.service.js';
17
+ import { type QueuedForeignSubtreeResolutionContext } from './queued-foreign-subtree-resolution.service.js';
18
+ /**
19
+ * Controls how one route module is loaded outside the normal render path.
20
+ *
21
+ * Request-time metadata inspection and static-generation probes use these
22
+ * options to isolate their module identity from the main render cache while
23
+ * still going through the owning integration's import setup.
24
+ */
25
+ export type RouteModuleLoadOptions = {
26
+ bypassCache?: boolean;
27
+ cacheScope?: string;
28
+ };
29
+ /**
30
+ * Context for renderToResponse method.
31
+ */
32
+ export interface RenderToResponseContext {
33
+ partial?: boolean;
34
+ status?: number;
35
+ headers?: HeadersInit;
36
+ }
37
+ export type HtmlDocumentContributionContext<C = EcoPagesElement> = {
38
+ renderOptions?: IntegrationRendererRenderOptions<C>;
39
+ partial?: boolean;
40
+ };
41
+ export type { PageBrowserGraphContribution, PageBrowserGraphContributionContext } from '../../types/public-types.js';
42
+ export type { HtmlDocumentContribution } from '../../services/html/html-transformer.service.js';
43
+ /**
44
+ * The IntegrationRenderer class is an abstract class that provides a base for rendering integration-specific components in the EcoPages framework.
45
+ * It handles the import of page files, collection of dependencies, and preparation of render options.
46
+ * The class is designed to be extended by specific integration renderers.
47
+ */
48
+ export declare abstract class IntegrationRenderer<C = EcoPagesElement> {
49
+ abstract name: string;
50
+ protected appConfig: EcoPagesAppConfig;
51
+ protected assetProcessingService: AssetProcessingService;
52
+ protected htmlTransformer: HtmlTransformerService;
53
+ protected hmrManager?: IHmrManager;
54
+ protected resolvedIntegrationDependencies: ProcessedAsset[];
55
+ protected rendererModules?: unknown;
56
+ protected options: Required<IntegrationRendererRenderOptions>;
57
+ protected runtimeOrigin: string;
58
+ protected dependencyResolverService: DependencyResolverService;
59
+ protected pageModuleLoaderService: PageModuleLoaderService;
60
+ protected routeRenderOrchestrator: RouteRenderOrchestrator;
61
+ protected readonly foreignSubtreeExecutionService: ForeignSubtreeExecutionService;
62
+ protected DOC_TYPE: string;
63
+ /**
64
+ * Loads one route module through the owning renderer's import path.
65
+ *
66
+ * Request-time infrastructure may need page metadata such as cache strategy or
67
+ * middleware before full rendering starts. Exposing this narrow entrypoint lets
68
+ * those callers reuse integration-specific import setup instead of bypassing it
69
+ * with raw transpiler access.
70
+ */
71
+ loadPageModule(file: string, options?: RouteModuleLoadOptions): Promise<EcoPageFile>;
72
+ /**
73
+ * Reads the execution-scoped owning-renderer cache from one render input.
74
+ *
75
+ * Shared page/layout/document shell helpers pass one cache through
76
+ * `integrationContext` so repeated delegation to the same foreign integration
77
+ * can reuse a single initialized renderer instance during one render flow.
78
+ * The cache is deliberately scoped to the current render execution rather than
79
+ * stored on the renderer, which avoids leaking mutable integration state across
80
+ * requests while still preventing redundant renderer initialization.
81
+ *
82
+ * @param integrationContext - Optional render context carried with one render input.
83
+ * @returns The current execution cache when present.
84
+ */
85
+ private getOwningRendererCache;
86
+ private getForeignOwnerIntegrationName;
87
+ /**
88
+ * Attaches an execution-scoped owning-renderer cache to one render input.
89
+ *
90
+ * Foreign-owned page, layout, or document shells may delegate several times in
91
+ * the same render flow. Threading the cache through `integrationContext`
92
+ * preserves renderer reuse without changing the public render input contract.
93
+ * Existing integration-specific context is preserved and augmented.
94
+ *
95
+ * @param input - Original render input.
96
+ * @param rendererCache - Execution-scoped renderer cache to propagate.
97
+ * @returns Render input augmented with the shared renderer cache.
98
+ */
99
+ private withOwningRendererCache;
100
+ protected getRendererModuleValue(key: string): unknown;
101
+ protected getRendererModuleString(key: string): string | undefined;
102
+ protected getRendererBootstrapDependencies(partial?: boolean): ProcessedAsset[];
103
+ setHmrManager(hmrManager: IHmrManager): void;
104
+ /**
105
+ * Build response headers with optional custom headers.
106
+ * @param contentType - The Content-Type header value
107
+ * @param customHeaders - Optional custom headers to merge
108
+ * @returns Headers object
109
+ */
110
+ protected buildHeaders(contentType: string, customHeaders?: HeadersInit): Headers;
111
+ /**
112
+ * Create an HTML Response.
113
+ * @param body - Response body (string or ReadableStream)
114
+ * @param ctx - Render context with status and headers
115
+ * @returns Response object
116
+ */
117
+ protected createHtmlResponse(body: BodyInit, ctx: RenderToResponseContext): Response;
118
+ /**
119
+ * Create an HttpError for render failures.
120
+ * @param message - Error message
121
+ * @param cause - Original error if available
122
+ * @returns HttpError with 500 status
123
+ */
124
+ protected createRenderError(message: string, cause?: unknown): HttpError;
125
+ /**
126
+ * Prepares dependencies for renderToResponse by resolving component dependencies
127
+ * and configuring the HTML transformer.
128
+ * @param view - The view component being rendered
129
+ * @param layout - Optional layout component
130
+ * @returns Resolved processed assets
131
+ */
132
+ protected prepareViewDependencies(view: EcoComponent, layout?: EcoComponent): Promise<ProcessedAsset[]>;
133
+ protected resolvePageBrowserGraphForFile(filePath: string): Promise<PageBrowserGraphResult | undefined>;
134
+ protected mergePageBrowserGraphIntoPagePackage(pageBrowserGraph?: PageBrowserGraphResult): PageBrowserGraphResult | undefined;
135
+ /**
136
+ * Merges component-scoped assets into the active HTML transformer state.
137
+ *
138
+ * Explicit page, layout, and document shell composition can produce assets at
139
+ * each foreign subtree. This helper deduplicates those groups and folds them back into
140
+ * the transformer so downstream HTML finalization sees one canonical asset set.
141
+ *
142
+ * @param assetGroups - Optional groups of processed assets to merge.
143
+ * @returns The deduplicated asset subset contributed by this merge operation.
144
+ */
145
+ protected appendProcessedDependencies(...assetGroups: Array<readonly ProcessedAsset[] | undefined>): ProcessedAsset[];
146
+ /**
147
+ * Resolves metadata for explicit view rendering.
148
+ *
149
+ * When a view declares a `metadata()` function, that contract owns the final
150
+ * metadata for the explicit render. Otherwise the app-level default metadata is
151
+ * reused so explicit routes and page-module routes share the same fallback.
152
+ *
153
+ * @param view - View component being rendered.
154
+ * @param props - Props passed to the view.
155
+ * @returns Resolved metadata for the final document shell.
156
+ */
157
+ protected resolveViewMetadata<P>(view: EcoComponent<P>, props: P): Promise<PageMetadataProps>;
158
+ /**
159
+ * Renders one explicit view response in partial mode.
160
+ *
161
+ * Same-integration views can optionally stream or render inline via the caller's
162
+ * `renderInline()` hook. Once a view may cross integration boundaries, this
163
+ * helper routes the render through `renderComponentWithForeignChildren()` instead so mixed
164
+ * shells can reuse the execution-scoped renderer cache and resolve nested
165
+ * foreign ownership before the partial response is returned.
166
+ *
167
+ * @param input - View render options for the partial response.
168
+ * @returns HTML response for the partial render.
169
+ */
170
+ protected renderPartialViewResponse<P>(input: {
171
+ view: EcoComponent<P>;
172
+ props: P;
173
+ ctx: RenderToResponseContext;
174
+ renderInline?: () => Promise<BodyInit>;
175
+ transformHtml?: (html: string) => string;
176
+ }): Promise<Response>;
177
+ /**
178
+ * Renders an explicit view through optional layout and document shells.
179
+ *
180
+ * This helper is the shared explicit-route path for string-oriented and mixed
181
+ * integrations. It prepares view dependencies, resolves metadata, and composes
182
+ * view, layout, and html template boundaries with one execution-scoped renderer
183
+ * cache so repeated foreign shell delegation can reuse initialized renderers
184
+ * during the same render flow.
185
+ *
186
+ * @param input - View, props, and optional layout metadata for the render.
187
+ * @returns HTML response for the explicit view render.
188
+ */
189
+ protected renderViewWithDocumentShell<P>(input: {
190
+ view: EcoComponent<P>;
191
+ props: P;
192
+ ctx: RenderToResponseContext;
193
+ layout?: EcoComponent;
194
+ }): Promise<Response>;
195
+ /**
196
+ * Renders a route page through optional layout and document shells.
197
+ *
198
+ * Route rendering and explicit view rendering now share the same renderer-owned
199
+ * shell composition model. This helper composes page, layout, and html template
200
+ * renders while threading one execution-scoped renderer cache through every
201
+ * delegated foreign subtree so foreign shell ownership remains stable and renderer
202
+ * initialization is reused inside the current request.
203
+ *
204
+ * @param input - Page, layout, document, and metadata inputs for the route render.
205
+ * @returns Final serialized document HTML including the doctype prefix.
206
+ */
207
+ protected renderPageWithDocumentShell(input: {
208
+ page: {
209
+ component: EcoComponent;
210
+ props: Record<string, unknown>;
211
+ };
212
+ layout?: {
213
+ component: EcoComponent;
214
+ props?: Record<string, unknown>;
215
+ };
216
+ htmlTemplate: EcoComponent;
217
+ metadata: PageMetadataProps;
218
+ pageProps: Record<string, unknown>;
219
+ documentProps?: Record<string, unknown>;
220
+ transformDocumentHtml?: (html: string) => string;
221
+ }): Promise<string>;
222
+ private composeDocumentShell;
223
+ /**
224
+ * Renders one string-first component with serialized children and collects its assets.
225
+ *
226
+ * String-oriented integrations frequently share the same component contract:
227
+ * pass serialized children through props, coerce the render result to HTML, and
228
+ * attach any component-scoped dependencies. This helper centralizes that flow
229
+ * so integrations can opt into shared orchestration without repeating the same
230
+ * string-render boilerplate.
231
+ *
232
+ * @param input - Component render input.
233
+ * @param component - String-oriented component implementation to execute.
234
+ * @returns Structured component render result for orchestration paths.
235
+ */
236
+ protected renderStringComponentWithSerializedChildren(input: ComponentRenderInput, component: (props: Record<string, unknown>) => Promise<EcoPagesElement> | EcoPagesElement): Promise<ComponentRenderResult>;
237
+ protected getForeignSubtreeTokenPrefix(): string;
238
+ protected getForeignSubtreeResolutionContextKey(): string;
239
+ protected createQueuedForeignSubtreeExecutionRuntime<TContext extends QueuedForeignSubtreeResolutionContext>(options: {
240
+ renderInput: ComponentRenderInput;
241
+ rendererCache: Map<string, IntegrationRenderer<any>>;
242
+ runtimeContextKey?: string;
243
+ tokenPrefix?: string;
244
+ createRuntimeContext?: (integrationContext: BaseIntegrationContext & Record<string, unknown>, rendererCache: Map<string, unknown>) => TContext;
245
+ }): ForeignChildRuntime;
246
+ protected getQueuedForeignSubtreeResolutionContext<TContext extends QueuedForeignSubtreeResolutionContext>(input: ComponentRenderInput): TContext | undefined;
247
+ /**
248
+ * Renders a string-first component, then resolves any queued foreign
249
+ * boundaries before returning final component HTML.
250
+ */
251
+ protected renderStringComponentWithQueuedForeignSubtrees(input: ComponentRenderInput, component: (props: Record<string, unknown>) => Promise<EcoPagesElement> | EcoPagesElement): Promise<ComponentRenderResult>;
252
+ constructor({ appConfig, assetProcessingService, resolvedIntegrationDependencies, rendererModules, runtimeOrigin, }: {
253
+ appConfig: EcoPagesAppConfig;
254
+ assetProcessingService: AssetProcessingService;
255
+ resolvedIntegrationDependencies?: ProcessedAsset[];
256
+ rendererModules?: unknown;
257
+ runtimeOrigin: string;
258
+ });
259
+ /**
260
+ * Returns the HTML path from the provided file path.
261
+ * It extracts the path relative to the pages directory and removes the 'index' part if present.
262
+ *
263
+ * @param file - The file path to extract the HTML path from.
264
+ * @returns The extracted HTML path.
265
+ */
266
+ protected getHtmlPath({ file }: {
267
+ file: string;
268
+ }): string;
269
+ /**
270
+ * Returns the HTML template component.
271
+ * It imports the HTML template from the specified path in the app configuration.
272
+ *
273
+ * @returns The HTML template component.
274
+ */
275
+ protected getHtmlTemplate(): Promise<EcoComponent<HtmlTemplateProps>>;
276
+ protected usesIntegrationPageImporter(_file: string): boolean;
277
+ protected importIntegrationPageFile(_file: string, _options?: RouteModuleLoadOptions): Promise<EcoPageFile>;
278
+ protected normalizeImportedPageFile<TPageModule extends EcoPageFile>(_file: string, pageModule: TPageModule): TPageModule;
279
+ /**
280
+ * Imports the page file from the specified path.
281
+ * It uses dynamic import to load the file and returns the imported module.
282
+ *
283
+ * @param file - The file path to import.
284
+ * @returns The imported module.
285
+ */
286
+ protected importPageFile(file: string, options?: RouteModuleLoadOptions): Promise<EcoPageFile>;
287
+ /**
288
+ * Resolves the dependency path based on the component directory.
289
+ * It combines the component directory with the provided path URL.
290
+ *
291
+ * @param componentDir - The component directory path.
292
+ * @param pathUrl - The path URL to resolve.
293
+ * @returns The resolved dependency path.
294
+ */
295
+ protected resolveDependencyPath(componentDir: string, pathUrl: string): string;
296
+ /**
297
+ * Extracts the dependencies from the provided component configuration.
298
+ * It resolves the paths for scripts and stylesheets based on the component directory.
299
+ *
300
+ * @param componentDir - The component directory path.
301
+ * @param scripts - The scripts to extract.
302
+ * @param stylesheets - The stylesheets to extract.
303
+ * @returns The extracted dependencies.
304
+ */
305
+ protected extractDependencies({ componentDir, scripts, stylesheets, }: {
306
+ componentDir: string;
307
+ } & EcoComponentDependencies): EcoComponentDependencies;
308
+ /**
309
+ * Resolves lazy script paths to public asset URLs.
310
+ * Converts source paths to their final bundled output paths.
311
+ *
312
+ * @param componentDir - The component directory path.
313
+ * @param scripts - The lazy script paths to resolve.
314
+ * @returns Comma-separated string of resolved public script paths.
315
+ */
316
+ protected resolveLazyScripts(componentDir: string, scripts: string[]): string;
317
+ /**
318
+ * Collects the dependencies for the provided components.
319
+ * Combines component-specific dependencies with global integration dependencies.
320
+ *
321
+ * @param components - The components to collect dependencies from.
322
+ */
323
+ protected resolveDependencies(components: (EcoComponent | Partial<EcoComponent>)[]): Promise<ProcessedAsset[]>;
324
+ /**
325
+ * Processes component-specific dependencies WITHOUT prepending global integration dependencies.
326
+ * Use this method when you need only the component's own assets.
327
+ *
328
+ * @param components - The components to collect dependencies from.
329
+ */
330
+ protected processComponentDependencies(components: (EcoComponent | Partial<EcoComponent>)[]): Promise<ProcessedAsset[]>;
331
+ /**
332
+ * Builds the internal route-render adapter consumed by `RouteRenderOrchestrator`.
333
+ *
334
+ * The route orchestrator needs a narrow orchestration contract, but those hooks should
335
+ * not become public API on the renderer base class. Keeping the adapter object
336
+ * local to the execution path lets the orchestrator depend on one explicit seam while
337
+ * subclasses continue to override protected renderer behavior directly.
338
+ */
339
+ protected createRouteRenderOrchestratorAdapter(): RouteRenderOrchestratorAdapter<C>;
340
+ protected resolveRouteRenderInputs(routeOptions: RouteRendererOptions): Promise<RouteRenderOrchestratorResolvedInputs>;
341
+ protected resolveRouteDependencies(input: {
342
+ components: (EcoComponent | Partial<EcoComponent>)[];
343
+ }): Promise<{
344
+ resolvedDependencies: ProcessedAsset[];
345
+ }>;
346
+ protected resolveRoutePageComponentRender(input: {
347
+ Page: EcoComponent;
348
+ Layout?: EcoComponent;
349
+ props: Record<string, unknown>;
350
+ routeOptions: RouteRendererOptions;
351
+ }): Promise<ComponentRenderResult | undefined>;
352
+ protected renderRouteBody(renderOptions: IntegrationRendererRenderOptions<C>): Promise<RouteRendererBody>;
353
+ protected getRouteHtmlFinalization(renderOptions: IntegrationRendererRenderOptions<C>): RouteHtmlFinalization;
354
+ protected transformRouteResponse(response: Response, htmlContributions?: HtmlDocumentContribution[]): Promise<RouteRendererBody>;
355
+ /**
356
+ * Prepares the render options for the integration renderer.
357
+ * It imports the page file, collects dependencies, and prepares the render options.
358
+ *
359
+ * @param options - The route renderer options.
360
+ * @returns The prepared render options.
361
+ */
362
+ protected prepareRenderOptions(options: RouteRendererOptions, adapter?: RouteRenderOrchestratorAdapter<C>): Promise<IntegrationRendererRenderOptions<C>>;
363
+ /**
364
+ * Controls whether the page root should be rendered through `renderComponent()`
365
+ * during route option preparation in component-capable modes.
366
+ *
367
+ * Integrations that already own page-level hydration (for example router-driven
368
+ * React rendering) can override this and return `false` to avoid duplicate root
369
+ * mount assets and competing hydration entrypoints.
370
+ */
371
+ protected shouldRenderPageComponent(_input: {
372
+ Page: EcoComponent;
373
+ Layout?: EcoComponent;
374
+ options: RouteRendererOptions;
375
+ }): boolean;
376
+ /**
377
+ * Executes the integration renderer with the provided options.
378
+ *
379
+ * Execution flow:
380
+ * 1. Build normalized render options (`prepareRenderOptions`).
381
+ * 2. Render the route body once.
382
+ * 3. Reject unresolved route-level eco-marker artifacts.
383
+ * 4. Optionally apply root attributes for page/component root boundaries.
384
+ * 5. Run HTML transformer with final dependency set.
385
+ *
386
+ * Stream-safety note: the first render result is normalized to a string once,
387
+ * then the pipeline continues with that immutable HTML value to avoid disturbed
388
+ * response-body errors.
389
+ *
390
+ * @param options Route renderer options.
391
+ * @returns Rendered route body plus effective cache strategy.
392
+ */
393
+ execute(options: RouteRendererOptions): Promise<RouteRenderResult>;
394
+ /**
395
+ * Finalizes already-resolved HTML for explicit renderer-owned paths.
396
+ *
397
+ * This keeps document and root-attribute stamping plus HTML transformation
398
+ * available after a renderer has completed nested foreign-subtree resolution without
399
+ * routing back through shared route execution.
400
+ */
401
+ protected finalizeResolvedHtml(options: {
402
+ html: string;
403
+ partial?: boolean;
404
+ componentRootAttributes?: Record<string, string>;
405
+ documentAttributes?: Record<string, string>;
406
+ transformHtml?: boolean;
407
+ htmlContributions?: HtmlDocumentContribution[];
408
+ }): Promise<string>;
409
+ /**
410
+ * Returns document-level attributes to stamp onto the rendered `<html>` tag.
411
+ *
412
+ * Integrations can override this to expose explicit document ownership or
413
+ * other runtime coordination markers without relying on script sniffing.
414
+ */
415
+ protected getDocumentAttributes(_renderOptions: IntegrationRendererRenderOptions<C>): Record<string, string> | undefined;
416
+ /**
417
+ * Returns declarative HTML fragments that core should inject into the final document.
418
+ *
419
+ * @remarks
420
+ * Integrations may contribute document markup here, but core retains ownership
421
+ * of the final HTML rewrite pipeline and placement semantics. This is the
422
+ * supported document-markup extension point for integrations instead of custom
423
+ * response finalization logic.
424
+ */
425
+ protected getHtmlDocumentContributions(_options: HtmlDocumentContributionContext<C>): HtmlDocumentContribution[] | undefined;
426
+ /**
427
+ * Returns a renderer instance for a given integration name.
428
+ *
429
+ * Uses a per-execution cache to avoid repeated renderer initialization.
430
+ *
431
+ * @param integrationName Target integration name.
432
+ * @param cache Render-pass renderer cache.
433
+ * @returns Renderer for the requested integration.
434
+ * @throws Error when no integration plugin matches `integrationName`.
435
+ */
436
+ protected getIntegrationRendererForName(integrationName: string, cache: Map<string, ForeignSubtreeExecutionOwningRenderer>): ForeignSubtreeExecutionOwningRenderer;
437
+ /**
438
+ * Abstract method to render the integration-specific component.
439
+ * This method should be implemented by the specific integration renderer.
440
+ *
441
+ * @param options - The integration renderer render options.
442
+ * @returns The rendered body.
443
+ */
444
+ abstract render(options: IntegrationRendererRenderOptions<C>): Promise<RouteRendererBody>;
445
+ /**
446
+ * Renders one component under this integration's foreign-child runtime and resolves
447
+ * any nested foreign children captured during that render.
448
+ *
449
+ * Without this wrapper, a component tree with foreign-owned descendants would
450
+ * render them with no active foreign-child runtime, which bypasses the owning
451
+ * renderer's nested foreign-child handoff.
452
+ */
453
+ renderComponentWithForeignChildren(input: ComponentRenderInput): Promise<ComponentRenderResult>;
454
+ /**
455
+ * Compatibility foreign-subtree contract that exposes a narrower payload shape for
456
+ * future route-composition work while preserving the current
457
+ * `renderComponentWithForeignChildren()` runtime semantics.
458
+ */
459
+ renderForeignSubtree(input: ComponentRenderInput): Promise<ForeignSubtreeRenderPayload>;
460
+ private normalizeComponentRenderOutput;
461
+ protected normalizeUnresolvedMarkerArtifactHtml(html: string): string;
462
+ /**
463
+ * Returns whether the component dependency tree crosses into another
464
+ * integration.
465
+ *
466
+ * This keeps foreign-child runtime setup narrow: same-integration trees can render
467
+ * directly without paying the queue orchestration cost.
468
+ */
469
+ protected hasForeignChildDescendants(component: EcoComponent): boolean;
470
+ /**
471
+ * Render a view directly to a Response object.
472
+ * Used for explicit routing where views are rendered from route handlers.
473
+ *
474
+ * @param view - The eco.page component to render
475
+ * @param props - Props to pass to the view
476
+ * @param ctx - Render context with partial flag and response options
477
+ * @returns A Response object with the rendered content
478
+ */
479
+ abstract renderToResponse<P = Record<string, unknown>>(view: EcoComponent<P>, props: P, ctx: RenderToResponseContext): Promise<Response>;
480
+ /**
481
+ * Render a single component and return structured output for orchestration paths.
482
+ *
483
+ * Default behavior delegates to `renderToResponse` in partial mode and wraps
484
+ * the resulting HTML into the `ComponentRenderResult` contract.
485
+ *
486
+ * In foreign-subtree resolution, this method is the integration-owned step that turns an
487
+ * already-resolved deferred foreign subtree into concrete HTML, assets, and optional
488
+ * root attributes.
489
+ *
490
+ * Integrations can override this for richer behavior (asset emission,
491
+ * root attributes, integration-specific hydration metadata).
492
+ *
493
+ * @param input Component render request.
494
+ * @returns Structured render result used by component/page orchestration.
495
+ */
496
+ renderComponent(input: ComponentRenderInput): Promise<ComponentRenderResult>;
497
+ /**
498
+ * Extracts the first root element tag name from HTML output.
499
+ *
500
+ * @param html HTML fragment.
501
+ * @returns Root tag name when present; otherwise `undefined`.
502
+ */
503
+ protected getRootTagName(html: string): string | undefined;
504
+ /**
505
+ * Collects declarative Page Browser Graph contributions for one Page.
506
+ *
507
+ * @remarks
508
+ * Integrations may describe page-scoped browser requirements here, while core
509
+ * retains ownership of dependency processing and final graph assembly. This is
510
+ * the supported page-browser extension point for integrations.
511
+ *
512
+ * @param context - The route file path and already imported page module.
513
+ * @returns Declarative dependencies or pre-resolved assets for the Page.
514
+ */
515
+ protected collectPageBrowserGraphContribution(_context: PageBrowserGraphContributionContext): Promise<PageBrowserGraphContribution | undefined>;
516
+ /**
517
+ * Creates the per-render foreign-child runtime adopted by the shared component
518
+ * render context.
519
+ *
520
+ * The default runtime queues delegated foreign subtrees inside the owning
521
+ * renderer so string and markup renderers do not need to re-declare the same
522
+ * handoff boilerplate. Override only when a renderer needs custom runtime
523
+ * context or a different foreign-child execution strategy.
524
+ */
525
+ protected createForeignChildRuntime(options: {
526
+ renderInput: ComponentRenderInput;
527
+ rendererCache: Map<string, IntegrationRenderer<any>>;
528
+ }): ForeignChildRuntime;
529
+ /**
530
+ * Creates an explicit fail-fast runtime for tests or renderers that do not
531
+ * support cross-integration foreign-child execution.
532
+ */
533
+ protected createFailFastForeignChildRuntime(): ForeignChildRuntime;
534
+ }