@ecopages/core 0.2.0-alpha.9 → 0.2.1

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 (357) hide show
  1. package/CHANGELOG.md +18 -11
  2. package/README.md +23 -26
  3. package/package.json +76 -58
  4. package/src/adapters/README.md +2 -2
  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 +4 -4
  13. package/src/adapters/bun/hmr-manager.js +8 -8
  14. package/src/adapters/bun/index.d.ts +1 -1
  15. package/src/adapters/bun/index.js +2 -2
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +6 -5
  18. package/src/adapters/bun/server-lifecycle.d.ts +4 -4
  19. package/src/adapters/bun/server-lifecycle.js +2 -2
  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 +1 -5
  23. package/src/adapters/index.js +1 -7
  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 +2 -2
  28. package/src/adapters/node/node-hmr-manager.js +3 -3
  29. package/src/adapters/node/server-adapter.d.ts +4 -4
  30. package/src/adapters/node/server-adapter.js +13 -12
  31. package/src/adapters/node/static-content-server.d.ts +1 -1
  32. package/src/adapters/node/static-content-server.js +1 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/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/file-route-middleware-pipeline.d.ts +1 -1
  37. package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
  38. package/src/adapters/shared/fs-server-response-factory.js +1 -1
  39. package/src/adapters/shared/fs-server-response-matcher.d.ts +1 -1
  40. package/src/adapters/shared/hmr-entrypoint-registrar.js +1 -1
  41. package/src/adapters/shared/hmr-html-response.d.ts +1 -1
  42. package/src/adapters/shared/render-context.d.ts +2 -1
  43. package/src/adapters/shared/render-context.js +3 -1
  44. package/src/adapters/shared/runtime-bootstrap.d.ts +1 -1
  45. package/src/adapters/shared/runtime-bootstrap.js +1 -1
  46. package/src/adapters/shared/server-adapter.d.ts +1 -1
  47. package/src/adapters/shared/server-adapter.js +5 -1
  48. package/src/adapters/shared/server-route-handler.d.ts +4 -4
  49. package/src/adapters/shared/server-route-handler.js +3 -3
  50. package/src/adapters/shared/server-static-builder.d.ts +5 -5
  51. package/src/adapters/shared/server-static-builder.js +5 -4
  52. package/src/build/README.md +19 -13
  53. package/src/build/build-adapter.d.ts +67 -20
  54. package/src/build/build-adapter.js +420 -19
  55. package/src/build/dev-build-coordinator.d.ts +10 -12
  56. package/src/build/dev-build-coordinator.js +8 -15
  57. package/src/build/esbuild-build-adapter.d.ts +6 -0
  58. package/src/build/esbuild-build-adapter.js +94 -11
  59. package/src/build/runtime-build-executor.d.ts +5 -4
  60. package/src/build/runtime-build-executor.js +5 -3
  61. package/src/build/runtime-specifier-alias-plugin.js +19 -15
  62. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  63. package/src/build/runtime-specifier-aliases.js +95 -0
  64. package/src/config/README.md +5 -2
  65. package/src/config/config-builder.d.ts +25 -2
  66. package/src/config/config-builder.js +44 -7
  67. package/src/declarations.d.ts +1 -1
  68. package/src/dev/sc-server.d.ts +1 -1
  69. package/src/dev/sc-server.js +1 -1
  70. package/src/eco/eco.browser.d.ts +2 -0
  71. package/src/eco/eco.browser.js +83 -0
  72. package/src/eco/eco.js +19 -48
  73. package/src/eco/eco.types.d.ts +1 -1
  74. package/src/eco/eco.utils.d.ts +1 -40
  75. package/src/eco/eco.utils.js +5 -35
  76. package/src/eco/global-injector-map.d.ts +1 -1
  77. package/src/eco/lazy-injector-map.d.ts +1 -1
  78. package/src/hmr/hmr-strategy.d.ts +16 -13
  79. package/src/hmr/hmr-strategy.js +22 -7
  80. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  81. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  82. package/src/hmr/strategies/js-hmr-strategy.d.ts +2 -2
  83. package/src/hmr/strategies/js-hmr-strategy.js +2 -2
  84. package/src/index.browser.d.ts +2 -2
  85. package/src/index.browser.js +1 -1
  86. package/src/index.d.ts +3 -2
  87. package/src/index.js +15 -4
  88. package/src/integrations/ghtml/ghtml-renderer.d.ts +6 -1
  89. package/src/integrations/ghtml/ghtml-renderer.js +29 -28
  90. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -2
  91. package/src/integrations/ghtml/ghtml.plugin.js +2 -2
  92. package/src/plugins/README.md +1 -0
  93. package/src/plugins/eco-component-meta-plugin.d.ts +12 -1
  94. package/src/plugins/eco-component-meta-plugin.js +26 -20
  95. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  96. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  97. package/src/plugins/integration-plugin.d.ts +99 -33
  98. package/src/plugins/integration-plugin.js +68 -21
  99. package/src/plugins/processor.d.ts +2 -2
  100. package/src/plugins/processor.js +2 -2
  101. package/src/plugins/source-transform.d.ts +46 -0
  102. package/src/plugins/source-transform.js +71 -0
  103. package/src/route-renderer/GRAPH.md +54 -84
  104. package/src/route-renderer/README.md +14 -20
  105. package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
  106. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  107. package/src/route-renderer/orchestration/integration-renderer.d.ts +233 -76
  108. package/src/route-renderer/orchestration/integration-renderer.js +500 -143
  109. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +93 -0
  110. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
  111. package/src/route-renderer/orchestration/render-execution.service.d.ts +11 -71
  112. package/src/route-renderer/orchestration/render-execution.service.js +65 -80
  113. package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
  114. package/src/route-renderer/orchestration/render-output.utils.js +65 -0
  115. package/src/route-renderer/orchestration/render-preparation.service.d.ts +2 -8
  116. package/src/route-renderer/orchestration/render-preparation.service.js +10 -17
  117. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  118. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  119. package/src/route-renderer/page-loading/dependency-resolver.d.ts +2 -2
  120. package/src/route-renderer/page-loading/dependency-resolver.js +10 -8
  121. package/src/route-renderer/page-loading/page-module-loader.d.ts +6 -4
  122. package/src/route-renderer/page-loading/page-module-loader.js +7 -5
  123. package/src/route-renderer/route-renderer.d.ts +5 -3
  124. package/src/route-renderer/route-renderer.js +13 -3
  125. package/src/router/README.md +79 -8
  126. package/src/router/client/navigation-coordinator.js +2 -2
  127. package/src/router/server/fs-router-scanner.d.ts +1 -1
  128. package/src/router/server/fs-router-scanner.js +6 -1
  129. package/src/router/server/fs-router.d.ts +1 -1
  130. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +3 -3
  131. package/src/services/assets/asset-processing-service/asset-processing.service.js +6 -6
  132. package/src/services/assets/asset-processing-service/asset.factory.d.ts +1 -1
  133. package/src/services/assets/asset-processing-service/asset.factory.js +2 -2
  134. package/src/services/assets/asset-processing-service/index.d.ts +5 -5
  135. package/src/services/assets/asset-processing-service/index.js +5 -5
  136. package/src/services/assets/asset-processing-service/processor.interface.d.ts +2 -2
  137. package/src/services/assets/asset-processing-service/processor.registry.d.ts +2 -2
  138. package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +1 -1
  139. package/src/services/assets/asset-processing-service/processors/base/base-processor.js +1 -1
  140. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +3 -3
  141. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +2 -2
  142. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -5
  143. package/src/services/assets/asset-processing-service/processors/index.js +5 -5
  144. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +2 -2
  145. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +1 -1
  146. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +4 -3
  147. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +15 -3
  148. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +3 -3
  149. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +1 -1
  150. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
  151. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +1 -1
  152. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  153. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +1 -1
  154. package/src/services/assets/browser-bundle.service.d.ts +1 -1
  155. package/src/services/assets/browser-bundle.service.js +2 -2
  156. package/src/services/html/html-rewriter-provider.service.js +4 -1
  157. package/src/services/html/html-transformer.service.d.ts +2 -2
  158. package/src/services/html/html-transformer.service.js +4 -10
  159. package/src/services/invalidation/development-invalidation.service.d.ts +1 -1
  160. package/src/services/invalidation/development-invalidation.service.js +1 -0
  161. package/src/services/module-loading/app-module-loader.service.d.ts +25 -0
  162. package/src/services/module-loading/app-module-loader.service.js +31 -0
  163. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +9 -1
  164. package/src/services/module-loading/app-server-module-transpiler.service.js +77 -2
  165. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  166. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  167. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  168. package/src/{adapters/node/bootstrap-dependency-resolver.d.ts → services/module-loading/node-bootstrap-plugin.d.ts} +2 -24
  169. package/src/{adapters/node/bootstrap-dependency-resolver.js → services/module-loading/node-bootstrap-plugin.js} +42 -22
  170. package/src/services/module-loading/page-module-import.service.d.ts +4 -0
  171. package/src/services/module-loading/page-module-import.service.js +38 -9
  172. package/src/services/module-loading/server-module-transpiler.service.d.ts +3 -0
  173. package/src/services/module-loading/server-module-transpiler.service.js +4 -1
  174. package/src/services/runtime-state/dev-graph.service.d.ts +6 -6
  175. package/src/services/runtime-state/dev-graph.service.js +10 -10
  176. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +1 -1
  177. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +1 -1
  178. package/src/services/runtime-state/server-invalidation-state.service.d.ts +1 -1
  179. package/src/static-site-generator/static-site-generator.d.ts +2 -2
  180. package/src/static-site-generator/static-site-generator.js +1 -1
  181. package/src/{internal-types.d.ts → types/internal-types.d.ts} +24 -14
  182. package/src/{public-types.d.ts → types/public-types.d.ts} +30 -14
  183. package/src/types/public-types.js +0 -0
  184. package/src/utils/html-escaping.d.ts +7 -0
  185. package/src/utils/html-escaping.js +6 -0
  186. package/src/utils/locals-utils.d.ts +1 -1
  187. package/src/utils/parse-cli-args.d.ts +4 -1
  188. package/src/utils/parse-cli-args.js +16 -1
  189. package/src/utils/resolve-work-dir.js +1 -1
  190. package/src/watchers/project-watcher.d.ts +4 -4
  191. package/src/watchers/project-watcher.js +4 -10
  192. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  193. package/src/adapters/abstract/application-adapter.ts +0 -337
  194. package/src/adapters/abstract/router-adapter.ts +0 -30
  195. package/src/adapters/abstract/server-adapter.ts +0 -79
  196. package/src/adapters/bun/client-bridge.ts +0 -62
  197. package/src/adapters/bun/create-app.ts +0 -189
  198. package/src/adapters/bun/hmr-manager.ts +0 -409
  199. package/src/adapters/bun/index.ts +0 -2
  200. package/src/adapters/bun/server-adapter.ts +0 -499
  201. package/src/adapters/bun/server-lifecycle.ts +0 -124
  202. package/src/adapters/index.ts +0 -6
  203. package/src/adapters/node/bootstrap-dependency-resolver.ts +0 -301
  204. package/src/adapters/node/create-app.ts +0 -179
  205. package/src/adapters/node/index.d.ts +0 -6
  206. package/src/adapters/node/index.js +0 -11
  207. package/src/adapters/node/index.ts +0 -16
  208. package/src/adapters/node/node-client-bridge.ts +0 -79
  209. package/src/adapters/node/node-hmr-manager.ts +0 -381
  210. package/src/adapters/node/runtime-adapter.d.ts +0 -46
  211. package/src/adapters/node/runtime-adapter.js +0 -306
  212. package/src/adapters/node/runtime-adapter.ts +0 -439
  213. package/src/adapters/node/server-adapter.ts +0 -488
  214. package/src/adapters/node/static-content-server.ts +0 -239
  215. package/src/adapters/node/write-runtime-manifest.d.ts +0 -26
  216. package/src/adapters/node/write-runtime-manifest.js +0 -12
  217. package/src/adapters/node/write-runtime-manifest.ts +0 -38
  218. package/src/adapters/shared/api-response.ts +0 -104
  219. package/src/adapters/shared/application-adapter.ts +0 -199
  220. package/src/adapters/shared/define-api-handler.ts +0 -66
  221. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -140
  222. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -127
  223. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  224. package/src/adapters/shared/fs-server-response-matcher.ts +0 -205
  225. package/src/adapters/shared/hmr-entrypoint-registrar.ts +0 -149
  226. package/src/adapters/shared/hmr-html-response.ts +0 -52
  227. package/src/adapters/shared/render-context.ts +0 -120
  228. package/src/adapters/shared/runtime-bootstrap.ts +0 -79
  229. package/src/adapters/shared/server-adapter.ts +0 -489
  230. package/src/adapters/shared/server-route-handler.ts +0 -153
  231. package/src/adapters/shared/server-static-builder.ts +0 -166
  232. package/src/build/build-adapter.ts +0 -361
  233. package/src/build/build-manifest.ts +0 -54
  234. package/src/build/build-types.ts +0 -83
  235. package/src/build/dev-build-coordinator.ts +0 -221
  236. package/src/build/esbuild-build-adapter.ts +0 -559
  237. package/src/build/runtime-build-executor.ts +0 -34
  238. package/src/build/runtime-specifier-alias-plugin.ts +0 -58
  239. package/src/config/config-builder.ts +0 -706
  240. package/src/constants.ts +0 -54
  241. package/src/create-app.ts +0 -87
  242. package/src/dev/sc-server.ts +0 -143
  243. package/src/eco/component-render-context.d.ts +0 -105
  244. package/src/eco/component-render-context.js +0 -87
  245. package/src/eco/component-render-context.ts +0 -224
  246. package/src/eco/eco.ts +0 -242
  247. package/src/eco/eco.types.ts +0 -221
  248. package/src/eco/global-injector-map.ts +0 -112
  249. package/src/eco/lazy-injector-map.ts +0 -120
  250. package/src/eco/module-dependencies.ts +0 -75
  251. package/src/errors/http-error.ts +0 -72
  252. package/src/errors/index.ts +0 -2
  253. package/src/errors/locals-access-error.ts +0 -7
  254. package/src/global/app-logger.ts +0 -4
  255. package/src/hmr/client/hmr-runtime.ts +0 -152
  256. package/src/hmr/hmr-strategy.ts +0 -172
  257. package/src/hmr/hmr.postcss.test.e2e.ts +0 -41
  258. package/src/hmr/hmr.test.e2e.ts +0 -66
  259. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  260. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  261. package/src/index.browser.ts +0 -3
  262. package/src/index.ts +0 -5
  263. package/src/integrations/ghtml/ghtml-renderer.ts +0 -96
  264. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  265. package/src/internal-types.ts +0 -232
  266. package/src/plugins/alias-resolver-plugin.ts +0 -63
  267. package/src/plugins/eco-component-meta-plugin.ts +0 -481
  268. package/src/plugins/integration-plugin.ts +0 -226
  269. package/src/plugins/processor.ts +0 -240
  270. package/src/plugins/runtime-capability.ts +0 -14
  271. package/src/public-types.ts +0 -1317
  272. package/src/route-renderer/component-graph/component-graph-executor.d.ts +0 -32
  273. package/src/route-renderer/component-graph/component-graph-executor.js +0 -31
  274. package/src/route-renderer/component-graph/component-graph-executor.ts +0 -84
  275. package/src/route-renderer/component-graph/component-graph.d.ts +0 -42
  276. package/src/route-renderer/component-graph/component-graph.js +0 -72
  277. package/src/route-renderer/component-graph/component-graph.ts +0 -159
  278. package/src/route-renderer/component-graph/component-marker.d.ts +0 -52
  279. package/src/route-renderer/component-graph/component-marker.js +0 -46
  280. package/src/route-renderer/component-graph/component-marker.ts +0 -117
  281. package/src/route-renderer/component-graph/component-reference.d.ts +0 -10
  282. package/src/route-renderer/component-graph/component-reference.js +0 -19
  283. package/src/route-renderer/component-graph/component-reference.ts +0 -29
  284. package/src/route-renderer/component-graph/marker-graph-resolver.d.ts +0 -77
  285. package/src/route-renderer/component-graph/marker-graph-resolver.js +0 -95
  286. package/src/route-renderer/component-graph/marker-graph-resolver.ts +0 -155
  287. package/src/route-renderer/orchestration/integration-renderer.ts +0 -790
  288. package/src/route-renderer/orchestration/render-execution.service.ts +0 -230
  289. package/src/route-renderer/orchestration/render-preparation.service.ts +0 -476
  290. package/src/route-renderer/page-loading/dependency-resolver.ts +0 -612
  291. package/src/route-renderer/page-loading/page-module-loader.ts +0 -181
  292. package/src/route-renderer/route-renderer.ts +0 -115
  293. package/src/router/client/link-intent.test.browser.ts +0 -51
  294. package/src/router/client/link-intent.ts +0 -92
  295. package/src/router/client/navigation-coordinator.ts +0 -433
  296. package/src/router/server/fs-router-scanner.ts +0 -219
  297. package/src/router/server/fs-router.ts +0 -122
  298. package/src/services/assets/asset-processing-service/asset-processing.service.ts +0 -401
  299. package/src/services/assets/asset-processing-service/asset.factory.ts +0 -105
  300. package/src/services/assets/asset-processing-service/assets.types.ts +0 -113
  301. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +0 -95
  302. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +0 -78
  303. package/src/services/assets/asset-processing-service/index.ts +0 -5
  304. package/src/services/assets/asset-processing-service/processor.interface.ts +0 -27
  305. package/src/services/assets/asset-processing-service/processor.registry.ts +0 -18
  306. package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +0 -82
  307. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +0 -95
  308. package/src/services/assets/asset-processing-service/processors/index.ts +0 -5
  309. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  310. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  311. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +0 -85
  312. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  313. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -80
  314. package/src/services/assets/browser-bundle.service.ts +0 -53
  315. package/src/services/cache/cache.types.ts +0 -126
  316. package/src/services/cache/index.ts +0 -18
  317. package/src/services/cache/memory-cache-store.ts +0 -130
  318. package/src/services/cache/page-cache-service.ts +0 -202
  319. package/src/services/cache/page-request-cache-coordinator.service.ts +0 -131
  320. package/src/services/html/html-rewriter-provider.service.ts +0 -103
  321. package/src/services/html/html-transformer.service.ts +0 -279
  322. package/src/services/invalidation/development-invalidation.service.ts +0 -261
  323. package/src/services/module-loading/app-server-module-transpiler.service.ts +0 -52
  324. package/src/services/module-loading/page-module-import.service.ts +0 -200
  325. package/src/services/module-loading/server-loader.service.d.ts +0 -96
  326. package/src/services/module-loading/server-loader.service.js +0 -32
  327. package/src/services/module-loading/server-loader.service.ts +0 -130
  328. package/src/services/module-loading/server-module-transpiler.service.ts +0 -105
  329. package/src/services/runtime-manifest/node-runtime-manifest.service.d.ts +0 -35
  330. package/src/services/runtime-manifest/node-runtime-manifest.service.js +0 -60
  331. package/src/services/runtime-manifest/node-runtime-manifest.service.ts +0 -101
  332. package/src/services/runtime-state/dev-graph.service.ts +0 -217
  333. package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +0 -136
  334. package/src/services/runtime-state/runtime-specifier-registry.service.ts +0 -96
  335. package/src/services/runtime-state/server-invalidation-state.service.ts +0 -68
  336. package/src/services/validation/schema-validation-service.ts +0 -204
  337. package/src/services/validation/standard-schema.types.ts +0 -68
  338. package/src/static-site-generator/static-site-generator.ts +0 -462
  339. package/src/utils/css.d.ts +0 -1
  340. package/src/utils/css.js +0 -7
  341. package/src/utils/css.ts +0 -5
  342. package/src/utils/deep-merge.ts +0 -47
  343. package/src/utils/hash.ts +0 -5
  344. package/src/utils/html.ts +0 -1
  345. package/src/utils/invariant.ts +0 -15
  346. package/src/utils/locals-utils.ts +0 -37
  347. package/src/utils/parse-cli-args.ts +0 -83
  348. package/src/utils/path-utils.module.ts +0 -14
  349. package/src/utils/resolve-work-dir.ts +0 -45
  350. package/src/utils/runtime.ts +0 -44
  351. package/src/utils/server-utils.module.ts +0 -67
  352. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  353. package/src/watchers/project-watcher.ts +0 -363
  354. /package/src/{constants.d.ts → config/constants.d.ts} +0 -0
  355. /package/src/{constants.js → config/constants.js} +0 -0
  356. /package/src/{internal-types.js → services/module-loading/module-loading-types.js} +0 -0
  357. /package/src/{public-types.js → types/internal-types.js} +0 -0
@@ -1,32 +0,0 @@
1
- import type { ComponentMarker } from './component-marker.js';
2
- import type { ComponentGraph } from './component-graph.js';
3
- /**
4
- * Render result returned by a graph node resolver.
5
- *
6
- * `html` is inserted in place of the corresponding marker token.
7
- */
8
- export type GraphNodeRenderResult = {
9
- html: string;
10
- };
11
- /**
12
- * Callback used to render one marker node during graph execution.
13
- *
14
- * Resolver implementations may call integration-specific `renderComponent`
15
- * and can use closure state to wire child output into parent render calls.
16
- */
17
- export type GraphNodeResolver = (marker: ComponentMarker) => Promise<GraphNodeRenderResult>;
18
- /**
19
- * Resolves all markers in bottom-up order based on computed graph levels.
20
- *
21
- * Child nodes are resolved first so parent slot content can consume already
22
- * resolved child HTML in subsequent resolver invocations.
23
- *
24
- * If a node id exists in `graph.levels` but no marker is present in `inputHtml`,
25
- * that node is skipped.
26
- *
27
- * @param inputHtml HTML containing marker tokens.
28
- * @param graph Precomputed marker graph with topological levels.
29
- * @param resolver Async callback that renders each marker node.
30
- * @returns HTML with resolved markers replaced.
31
- */
32
- export declare function resolveComponentGraph(inputHtml: string, graph: ComponentGraph, resolver: GraphNodeResolver): Promise<string>;
@@ -1,31 +0,0 @@
1
- import { parseComponentMarkers } from "./component-marker.js";
2
- function escapeRegex(value) {
3
- return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
4
- }
5
- function replaceMarkerByNodeId(html, nodeId, replacement) {
6
- const pattern = `<eco-marker[^>]*data-eco-node-id="${escapeRegex(nodeId)}"[^>]*><\\/eco-marker>`;
7
- const markerRegex = new RegExp(pattern);
8
- return html.replace(markerRegex, replacement);
9
- }
10
- async function resolveComponentGraph(inputHtml, graph, resolver) {
11
- let html = inputHtml;
12
- const markersById = /* @__PURE__ */ new Map();
13
- for (const marker of parseComponentMarkers(inputHtml)) {
14
- markersById.set(marker.nodeId, marker);
15
- }
16
- const levels = [...graph.levels].reverse();
17
- for (const level of levels) {
18
- for (const nodeId of level) {
19
- const marker = markersById.get(nodeId);
20
- if (!marker) {
21
- continue;
22
- }
23
- const result = await resolver(marker);
24
- html = replaceMarkerByNodeId(html, nodeId, result.html);
25
- }
26
- }
27
- return html;
28
- }
29
- export {
30
- resolveComponentGraph
31
- };
@@ -1,84 +0,0 @@
1
- import type { ComponentMarker, MarkerNodeId } from './component-marker.ts';
2
- import { parseComponentMarkers } from './component-marker.ts';
3
- import type { ComponentGraph } from './component-graph.ts';
4
-
5
- /**
6
- * Render result returned by a graph node resolver.
7
- *
8
- * `html` is inserted in place of the corresponding marker token.
9
- */
10
- export type GraphNodeRenderResult = {
11
- html: string;
12
- };
13
-
14
- /**
15
- * Callback used to render one marker node during graph execution.
16
- *
17
- * Resolver implementations may call integration-specific `renderComponent`
18
- * and can use closure state to wire child output into parent render calls.
19
- */
20
- export type GraphNodeResolver = (marker: ComponentMarker) => Promise<GraphNodeRenderResult>;
21
-
22
- /**
23
- * Escapes dynamic content before embedding it in a regular expression.
24
- *
25
- * @param value Raw regex input.
26
- * @returns Escaped regex-safe value.
27
- */
28
- function escapeRegex(value: string): string {
29
- return value.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
30
- }
31
-
32
- /**
33
- * Replaces exactly one marker token matching the provided node id.
34
- *
35
- * @param html Current HTML buffer.
36
- * @param nodeId Marker node id to replace.
37
- * @param replacement Rendered HTML replacement.
38
- * @returns Updated HTML buffer.
39
- */
40
- function replaceMarkerByNodeId(html: string, nodeId: MarkerNodeId, replacement: string): string {
41
- const pattern = `<eco-marker[^>]*data-eco-node-id="${escapeRegex(nodeId)}"[^>]*><\\/eco-marker>`;
42
- const markerRegex = new RegExp(pattern);
43
- return html.replace(markerRegex, replacement);
44
- }
45
-
46
- /**
47
- * Resolves all markers in bottom-up order based on computed graph levels.
48
- *
49
- * Child nodes are resolved first so parent slot content can consume already
50
- * resolved child HTML in subsequent resolver invocations.
51
- *
52
- * If a node id exists in `graph.levels` but no marker is present in `inputHtml`,
53
- * that node is skipped.
54
- *
55
- * @param inputHtml HTML containing marker tokens.
56
- * @param graph Precomputed marker graph with topological levels.
57
- * @param resolver Async callback that renders each marker node.
58
- * @returns HTML with resolved markers replaced.
59
- */
60
- export async function resolveComponentGraph(
61
- inputHtml: string,
62
- graph: ComponentGraph,
63
- resolver: GraphNodeResolver,
64
- ): Promise<string> {
65
- let html = inputHtml;
66
- const markersById = new Map<MarkerNodeId, ComponentMarker>();
67
- for (const marker of parseComponentMarkers(inputHtml)) {
68
- markersById.set(marker.nodeId, marker);
69
- }
70
-
71
- const levels = [...graph.levels].reverse();
72
- for (const level of levels) {
73
- for (const nodeId of level) {
74
- const marker = markersById.get(nodeId);
75
- if (!marker) {
76
- continue;
77
- }
78
- const result = await resolver(marker);
79
- html = replaceMarkerByNodeId(html, nodeId, result.html);
80
- }
81
- }
82
-
83
- return html;
84
- }
@@ -1,42 +0,0 @@
1
- import type { ComponentMarker, MarkerNodeId } from './component-marker.js';
2
- /**
3
- * Maps a parent slot reference to child marker node ids discovered in that slot.
4
- *
5
- * Keys are `slotRef` values emitted in marker payloads.
6
- */
7
- export type SlotChildrenRegistry = Record<string, MarkerNodeId[]>;
8
- /**
9
- * Graph node enriched with source-order information for deterministic traversal.
10
- */
11
- export type ComponentGraphNode = ComponentMarker & {
12
- order: number;
13
- };
14
- /**
15
- * Directed acyclic graph representation for component marker orchestration.
16
- *
17
- * `levels` are topological layers from roots to leaves.
18
- */
19
- export type ComponentGraph = {
20
- nodes: Map<MarkerNodeId, ComponentGraphNode>;
21
- edges: Map<MarkerNodeId, Set<MarkerNodeId>>;
22
- reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>;
23
- levels: MarkerNodeId[][];
24
- };
25
- /**
26
- * Extracts marker graph metadata from rendered HTML and slot linkage data.
27
- *
28
- * This is the canonical graph builder used by marker execution.
29
- *
30
- * Algorithm summary:
31
- * 1. Parse markers from HTML in source order.
32
- * 2. Create nodes and derive edges from `slotChildrenRegistry`.
33
- * 3. Compute deterministic topological levels.
34
- *
35
- * Unknown child node ids in `slotChildrenRegistry` are ignored to keep the
36
- * extractor tolerant to stale references.
37
- *
38
- * @param html Rendered HTML containing `eco-marker` tokens.
39
- * @param slotChildrenRegistry Optional slot -> child linkage map.
40
- * @returns Component graph structure with levels ready for execution.
41
- */
42
- export declare function extractComponentGraph(html: string, slotChildrenRegistry?: SlotChildrenRegistry): ComponentGraph;
@@ -1,72 +0,0 @@
1
- import { parseComponentMarkers } from "./component-marker.js";
2
- function ensureEdgeMaps(edges, reverseEdges, from, to) {
3
- if (!edges.has(from)) {
4
- edges.set(from, /* @__PURE__ */ new Set());
5
- }
6
- if (!reverseEdges.has(to)) {
7
- reverseEdges.set(to, /* @__PURE__ */ new Set());
8
- }
9
- edges.get(from)?.add(to);
10
- reverseEdges.get(to)?.add(from);
11
- }
12
- function computeLevels(nodes, edges, reverseEdges) {
13
- const indegree = /* @__PURE__ */ new Map();
14
- for (const nodeId of nodes.keys()) {
15
- indegree.set(nodeId, reverseEdges.get(nodeId)?.size ?? 0);
16
- }
17
- const levels = [];
18
- let frontier = [...nodes.values()].filter((node) => (indegree.get(node.nodeId) ?? 0) === 0).sort((a, b) => a.order - b.order).map((node) => node.nodeId);
19
- const visited = /* @__PURE__ */ new Set();
20
- while (frontier.length > 0) {
21
- levels.push(frontier);
22
- const next = [];
23
- for (const current of frontier) {
24
- visited.add(current);
25
- for (const child of edges.get(current) ?? []) {
26
- const nextInDegree = (indegree.get(child) ?? 0) - 1;
27
- indegree.set(child, nextInDegree);
28
- if (nextInDegree === 0) {
29
- next.push(child);
30
- }
31
- }
32
- }
33
- frontier = next.filter((nodeId, index) => next.indexOf(nodeId) === index).sort((a, b) => {
34
- const orderA = nodes.get(a)?.order ?? 0;
35
- const orderB = nodes.get(b)?.order ?? 0;
36
- return orderA - orderB;
37
- });
38
- }
39
- if (visited.size !== nodes.size) {
40
- throw new Error("[ecopages] Component marker graph contains a cycle or unresolved dependency links.");
41
- }
42
- return levels;
43
- }
44
- function extractComponentGraph(html, slotChildrenRegistry = {}) {
45
- const markers = parseComponentMarkers(html);
46
- const nodes = /* @__PURE__ */ new Map();
47
- const edges = /* @__PURE__ */ new Map();
48
- const reverseEdges = /* @__PURE__ */ new Map();
49
- markers.forEach((marker, index) => {
50
- nodes.set(marker.nodeId, {
51
- ...marker,
52
- order: index
53
- });
54
- });
55
- for (const marker of markers) {
56
- if (!marker.slotRef) {
57
- continue;
58
- }
59
- const linkedChildren = slotChildrenRegistry[marker.slotRef] ?? [];
60
- for (const childNodeId of linkedChildren) {
61
- if (!nodes.has(childNodeId)) {
62
- continue;
63
- }
64
- ensureEdgeMaps(edges, reverseEdges, marker.nodeId, childNodeId);
65
- }
66
- }
67
- const levels = computeLevels(nodes, edges, reverseEdges);
68
- return { nodes, edges, reverseEdges, levels };
69
- }
70
- export {
71
- extractComponentGraph
72
- };
@@ -1,159 +0,0 @@
1
- import type { ComponentMarker, MarkerNodeId } from './component-marker.ts';
2
- import { parseComponentMarkers } from './component-marker.ts';
3
-
4
- /**
5
- * Maps a parent slot reference to child marker node ids discovered in that slot.
6
- *
7
- * Keys are `slotRef` values emitted in marker payloads.
8
- */
9
- export type SlotChildrenRegistry = Record<string, MarkerNodeId[]>;
10
-
11
- /**
12
- * Graph node enriched with source-order information for deterministic traversal.
13
- */
14
- export type ComponentGraphNode = ComponentMarker & {
15
- order: number;
16
- };
17
-
18
- /**
19
- * Directed acyclic graph representation for component marker orchestration.
20
- *
21
- * `levels` are topological layers from roots to leaves.
22
- */
23
- export type ComponentGraph = {
24
- nodes: Map<MarkerNodeId, ComponentGraphNode>;
25
- edges: Map<MarkerNodeId, Set<MarkerNodeId>>;
26
- reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>;
27
- levels: MarkerNodeId[][];
28
- };
29
-
30
- /**
31
- * Ensures adjacency maps are initialized and registers one directed edge.
32
- *
33
- * @param edges Parent -> children adjacency map.
34
- * @param reverseEdges Child -> parents adjacency map.
35
- * @param from Parent node id.
36
- * @param to Child node id.
37
- */
38
- function ensureEdgeMaps(
39
- edges: Map<MarkerNodeId, Set<MarkerNodeId>>,
40
- reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>,
41
- from: MarkerNodeId,
42
- to: MarkerNodeId,
43
- ): void {
44
- if (!edges.has(from)) {
45
- edges.set(from, new Set());
46
- }
47
- if (!reverseEdges.has(to)) {
48
- reverseEdges.set(to, new Set());
49
- }
50
- edges.get(from)?.add(to);
51
- reverseEdges.get(to)?.add(from);
52
- }
53
-
54
- /**
55
- * Builds topological levels from graph adjacency maps.
56
- *
57
- * Levels are ordered from roots to leaves and each level preserves source order.
58
- *
59
- * @param nodes Graph node registry.
60
- * @param edges Parent -> children adjacency map.
61
- * @param reverseEdges Child -> parents adjacency map.
62
- * @returns Topological levels from root level to leaf level.
63
- * @throws Error when a cycle or unresolved dependency remains.
64
- */
65
- function computeLevels(
66
- nodes: Map<MarkerNodeId, ComponentGraphNode>,
67
- edges: Map<MarkerNodeId, Set<MarkerNodeId>>,
68
- reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>,
69
- ): MarkerNodeId[][] {
70
- const indegree = new Map<MarkerNodeId, number>();
71
- for (const nodeId of nodes.keys()) {
72
- indegree.set(nodeId, reverseEdges.get(nodeId)?.size ?? 0);
73
- }
74
-
75
- const levels: MarkerNodeId[][] = [];
76
- let frontier = [...nodes.values()]
77
- .filter((node) => (indegree.get(node.nodeId) ?? 0) === 0)
78
- .sort((a, b) => a.order - b.order)
79
- .map((node) => node.nodeId);
80
-
81
- const visited = new Set<MarkerNodeId>();
82
-
83
- while (frontier.length > 0) {
84
- levels.push(frontier);
85
- const next: MarkerNodeId[] = [];
86
-
87
- for (const current of frontier) {
88
- visited.add(current);
89
- for (const child of edges.get(current) ?? []) {
90
- const nextInDegree = (indegree.get(child) ?? 0) - 1;
91
- indegree.set(child, nextInDegree);
92
- if (nextInDegree === 0) {
93
- next.push(child);
94
- }
95
- }
96
- }
97
-
98
- frontier = next
99
- .filter((nodeId, index) => next.indexOf(nodeId) === index)
100
- .sort((a, b) => {
101
- const orderA = nodes.get(a)?.order ?? 0;
102
- const orderB = nodes.get(b)?.order ?? 0;
103
- return orderA - orderB;
104
- });
105
- }
106
-
107
- if (visited.size !== nodes.size) {
108
- throw new Error('[ecopages] Component marker graph contains a cycle or unresolved dependency links.');
109
- }
110
-
111
- return levels;
112
- }
113
-
114
- /**
115
- * Extracts marker graph metadata from rendered HTML and slot linkage data.
116
- *
117
- * This is the canonical graph builder used by marker execution.
118
- *
119
- * Algorithm summary:
120
- * 1. Parse markers from HTML in source order.
121
- * 2. Create nodes and derive edges from `slotChildrenRegistry`.
122
- * 3. Compute deterministic topological levels.
123
- *
124
- * Unknown child node ids in `slotChildrenRegistry` are ignored to keep the
125
- * extractor tolerant to stale references.
126
- *
127
- * @param html Rendered HTML containing `eco-marker` tokens.
128
- * @param slotChildrenRegistry Optional slot -> child linkage map.
129
- * @returns Component graph structure with levels ready for execution.
130
- */
131
- export function extractComponentGraph(html: string, slotChildrenRegistry: SlotChildrenRegistry = {}): ComponentGraph {
132
- const markers = parseComponentMarkers(html);
133
- const nodes = new Map<MarkerNodeId, ComponentGraphNode>();
134
- const edges = new Map<MarkerNodeId, Set<MarkerNodeId>>();
135
- const reverseEdges = new Map<MarkerNodeId, Set<MarkerNodeId>>();
136
-
137
- markers.forEach((marker, index) => {
138
- nodes.set(marker.nodeId, {
139
- ...marker,
140
- order: index,
141
- });
142
- });
143
-
144
- for (const marker of markers) {
145
- if (!marker.slotRef) {
146
- continue;
147
- }
148
- const linkedChildren = slotChildrenRegistry[marker.slotRef] ?? [];
149
- for (const childNodeId of linkedChildren) {
150
- if (!nodes.has(childNodeId)) {
151
- continue;
152
- }
153
- ensureEdgeMaps(edges, reverseEdges, marker.nodeId, childNodeId);
154
- }
155
- }
156
-
157
- const levels = computeLevels(nodes, edges, reverseEdges);
158
- return { nodes, edges, reverseEdges, levels };
159
- }
@@ -1,52 +0,0 @@
1
- /**
2
- * Stable marker node identifier used during one render graph resolution pass.
3
- *
4
- * @example
5
- * `n_12`
6
- */
7
- export type MarkerNodeId = `n_${string}`;
8
- /**
9
- * Marker payload used by graph extraction and execution.
10
- *
11
- * Each marker references:
12
- * - the owning integration renderer (`integration`)
13
- * - a component definition key (`componentRef`)
14
- * - a serialized props key (`propsRef`)
15
- * - optional child-slot linkage (`slotRef`)
16
- */
17
- export type ComponentMarker = {
18
- nodeId: MarkerNodeId;
19
- integration: string;
20
- componentRef: string;
21
- propsRef: string;
22
- slotRef?: string;
23
- };
24
- /**
25
- * Input contract for marker emission.
26
- *
27
- * This shape is intentionally close to `ComponentMarker` to keep emission and
28
- * parsing symmetric.
29
- */
30
- export type MarkerRenderInput = {
31
- nodeId: MarkerNodeId;
32
- integration: string;
33
- componentRef: string;
34
- propsRef: string;
35
- slotRef?: string;
36
- };
37
- /**
38
- * Creates the canonical `<eco-marker>` token used for deferred component rendering.
39
- *
40
- * @param input Marker payload fields.
41
- * @returns Serialized marker HTML token.
42
- */
43
- export declare function createComponentMarker(input: MarkerRenderInput): string;
44
- /**
45
- * Parses all valid `<eco-marker>` tokens from HTML output.
46
- *
47
- * Invalid markers (missing required attributes) are ignored by design.
48
- *
49
- * @param html Rendered HTML fragment or document.
50
- * @returns Parsed marker payloads in source order.
51
- */
52
- export declare function parseComponentMarkers(html: string): ComponentMarker[];
@@ -1,46 +0,0 @@
1
- function escapeAttribute(value) {
2
- return value.replace(/&/g, "&amp;").replace(/"/g, "&quot;").replace(/</g, "&lt;").replace(/>/g, "&gt;");
3
- }
4
- function readAttribute(tag, name) {
5
- const match = tag.match(new RegExp(`${name}="([^"]*)"`));
6
- return match?.[1];
7
- }
8
- function createComponentMarker(input) {
9
- const attributes = [
10
- `data-eco-node-id="${escapeAttribute(input.nodeId)}"`,
11
- `data-eco-integration="${escapeAttribute(input.integration)}"`,
12
- `data-eco-component-ref="${escapeAttribute(input.componentRef)}"`,
13
- `data-eco-props-ref="${escapeAttribute(input.propsRef)}"`
14
- ];
15
- if (input.slotRef) {
16
- attributes.push(`data-eco-slot-ref="${escapeAttribute(input.slotRef)}"`);
17
- }
18
- return `<eco-marker ${attributes.join(" ")}></eco-marker>`;
19
- }
20
- function parseComponentMarkers(html) {
21
- const markerRegex = /<eco-marker\b[^>]*><\/eco-marker>/g;
22
- const results = [];
23
- for (let match = markerRegex.exec(html); match; match = markerRegex.exec(html)) {
24
- const tag = match[0];
25
- const nodeId = readAttribute(tag, "data-eco-node-id");
26
- const integration = readAttribute(tag, "data-eco-integration");
27
- const componentRef = readAttribute(tag, "data-eco-component-ref");
28
- const propsRef = readAttribute(tag, "data-eco-props-ref");
29
- const slotRef = readAttribute(tag, "data-eco-slot-ref");
30
- if (!nodeId || !integration || !componentRef || !propsRef) {
31
- continue;
32
- }
33
- results.push({
34
- nodeId,
35
- integration,
36
- componentRef,
37
- propsRef,
38
- slotRef
39
- });
40
- }
41
- return results;
42
- }
43
- export {
44
- createComponentMarker,
45
- parseComponentMarkers
46
- };
@@ -1,117 +0,0 @@
1
- /**
2
- * Stable marker node identifier used during one render graph resolution pass.
3
- *
4
- * @example
5
- * `n_12`
6
- */
7
- export type MarkerNodeId = `n_${string}`;
8
-
9
- /**
10
- * Marker payload used by graph extraction and execution.
11
- *
12
- * Each marker references:
13
- * - the owning integration renderer (`integration`)
14
- * - a component definition key (`componentRef`)
15
- * - a serialized props key (`propsRef`)
16
- * - optional child-slot linkage (`slotRef`)
17
- */
18
- export type ComponentMarker = {
19
- nodeId: MarkerNodeId;
20
- integration: string;
21
- componentRef: string;
22
- propsRef: string;
23
- slotRef?: string;
24
- };
25
-
26
- /**
27
- * Input contract for marker emission.
28
- *
29
- * This shape is intentionally close to `ComponentMarker` to keep emission and
30
- * parsing symmetric.
31
- */
32
- export type MarkerRenderInput = {
33
- nodeId: MarkerNodeId;
34
- integration: string;
35
- componentRef: string;
36
- propsRef: string;
37
- slotRef?: string;
38
- };
39
-
40
- /**
41
- * Escapes marker attribute values for safe HTML output.
42
- *
43
- * @param value Raw attribute value.
44
- * @returns HTML-escaped attribute value.
45
- */
46
- function escapeAttribute(value: string): string {
47
- return value.replace(/&/g, '&amp;').replace(/"/g, '&quot;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
48
- }
49
-
50
- /**
51
- * Reads a single attribute value from a raw marker tag.
52
- *
53
- * @param tag Full marker tag text.
54
- * @param name Attribute name to read.
55
- * @returns Attribute value when present; otherwise `undefined`.
56
- */
57
- function readAttribute(tag: string, name: string): string | undefined {
58
- const match = tag.match(new RegExp(`${name}="([^"]*)"`));
59
- return match?.[1];
60
- }
61
-
62
- /**
63
- * Creates the canonical `<eco-marker>` token used for deferred component rendering.
64
- *
65
- * @param input Marker payload fields.
66
- * @returns Serialized marker HTML token.
67
- */
68
- export function createComponentMarker(input: MarkerRenderInput): string {
69
- const attributes = [
70
- `data-eco-node-id="${escapeAttribute(input.nodeId)}"`,
71
- `data-eco-integration="${escapeAttribute(input.integration)}"`,
72
- `data-eco-component-ref="${escapeAttribute(input.componentRef)}"`,
73
- `data-eco-props-ref="${escapeAttribute(input.propsRef)}"`,
74
- ];
75
-
76
- if (input.slotRef) {
77
- attributes.push(`data-eco-slot-ref="${escapeAttribute(input.slotRef)}"`);
78
- }
79
-
80
- return `<eco-marker ${attributes.join(' ')}></eco-marker>`;
81
- }
82
-
83
- /**
84
- * Parses all valid `<eco-marker>` tokens from HTML output.
85
- *
86
- * Invalid markers (missing required attributes) are ignored by design.
87
- *
88
- * @param html Rendered HTML fragment or document.
89
- * @returns Parsed marker payloads in source order.
90
- */
91
- export function parseComponentMarkers(html: string): ComponentMarker[] {
92
- const markerRegex = /<eco-marker\b[^>]*><\/eco-marker>/g;
93
- const results: ComponentMarker[] = [];
94
-
95
- for (let match = markerRegex.exec(html); match; match = markerRegex.exec(html)) {
96
- const tag = match[0];
97
- const nodeId = readAttribute(tag, 'data-eco-node-id');
98
- const integration = readAttribute(tag, 'data-eco-integration');
99
- const componentRef = readAttribute(tag, 'data-eco-component-ref');
100
- const propsRef = readAttribute(tag, 'data-eco-props-ref');
101
- const slotRef = readAttribute(tag, 'data-eco-slot-ref');
102
-
103
- if (!nodeId || !integration || !componentRef || !propsRef) {
104
- continue;
105
- }
106
-
107
- results.push({
108
- nodeId: nodeId as MarkerNodeId,
109
- integration,
110
- componentRef,
111
- propsRef,
112
- slotRef,
113
- });
114
- }
115
-
116
- return results;
117
- }
@@ -1,10 +0,0 @@
1
- import type { EcoComponent } from '../../public-types.js';
2
- /**
3
- * Resolves a stable component reference for marker emission and lookup.
4
- *
5
- * Build-time metadata remains the preferred source. When a component is
6
- * imported directly from source on the server and metadata has not been
7
- * injected, fall back to a process-local stable runtime reference so explicit
8
- * request-time rendering can still resolve deferred boundaries.
9
- */
10
- export declare function getComponentReference(component: EcoComponent): string;
@@ -1,19 +0,0 @@
1
- const runtimeComponentRefs = /* @__PURE__ */ new WeakMap();
2
- let nextRuntimeComponentRef = 0;
3
- function getComponentReference(component) {
4
- const metadataRef = component.config?.__eco?.id ?? component.config?.__eco?.file;
5
- if (metadataRef) {
6
- return metadataRef;
7
- }
8
- const existingRef = runtimeComponentRefs.get(component);
9
- if (existingRef) {
10
- return existingRef;
11
- }
12
- nextRuntimeComponentRef += 1;
13
- const runtimeRef = `eco-runtime-component-${nextRuntimeComponentRef}`;
14
- runtimeComponentRefs.set(component, runtimeRef);
15
- return runtimeRef;
16
- }
17
- export {
18
- getComponentReference
19
- };