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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (391) hide show
  1. package/CHANGELOG.md +26 -64
  2. package/README.md +212 -14
  3. package/package.json +116 -66
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +4 -12
  11. package/src/adapters/bun/create-app.js +4 -5
  12. package/src/adapters/bun/hmr-manager.d.ts +80 -21
  13. package/src/adapters/bun/hmr-manager.js +168 -62
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +40 -34
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +89 -18
  28. package/src/adapters/node/node-hmr-manager.js +185 -95
  29. package/src/adapters/node/server-adapter.d.ts +6 -35
  30. package/src/adapters/node/server-adapter.js +44 -105
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
  36. package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
  37. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
  38. package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
  39. package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
  40. package/src/adapters/shared/fs-server-response-factory.js +1 -1
  41. package/src/adapters/shared/fs-server-response-matcher.d.ts +8 -12
  42. package/src/adapters/shared/fs-server-response-matcher.js +10 -18
  43. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  44. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  45. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  46. package/src/adapters/shared/hmr-html-response.js +32 -0
  47. package/src/adapters/shared/render-context.d.ts +2 -1
  48. package/src/adapters/shared/render-context.js +6 -3
  49. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  50. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  51. package/src/adapters/shared/server-adapter.d.ts +13 -3
  52. package/src/adapters/shared/server-adapter.js +42 -5
  53. package/src/adapters/shared/server-route-handler.d.ts +4 -4
  54. package/src/adapters/shared/server-route-handler.js +6 -15
  55. package/src/adapters/shared/server-static-builder.d.ts +38 -6
  56. package/src/adapters/shared/server-static-builder.js +64 -10
  57. package/src/build/README.md +107 -0
  58. package/src/build/build-adapter.d.ts +168 -3
  59. package/src/build/build-adapter.js +604 -16
  60. package/src/build/build-manifest.d.ts +27 -0
  61. package/src/build/build-manifest.js +30 -0
  62. package/src/build/dev-build-coordinator.d.ts +72 -0
  63. package/src/build/dev-build-coordinator.js +154 -0
  64. package/src/build/esbuild-build-adapter.d.ts +15 -6
  65. package/src/build/esbuild-build-adapter.js +189 -74
  66. package/src/build/runtime-build-executor.d.ts +14 -0
  67. package/src/build/runtime-build-executor.js +22 -0
  68. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  69. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  70. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  71. package/src/build/runtime-specifier-aliases.js +95 -0
  72. package/src/config/README.md +36 -0
  73. package/src/config/config-builder.d.ts +52 -27
  74. package/src/config/config-builder.js +260 -49
  75. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  76. package/src/{constants.js → config/constants.js} +4 -0
  77. package/src/declarations.d.ts +19 -14
  78. package/src/dev/sc-server.d.ts +1 -1
  79. package/src/dev/sc-server.js +1 -1
  80. package/src/eco/README.md +70 -16
  81. package/src/eco/eco.browser.d.ts +2 -0
  82. package/src/eco/eco.browser.js +83 -0
  83. package/src/eco/eco.js +32 -57
  84. package/src/eco/eco.types.d.ts +12 -4
  85. package/src/eco/eco.utils.d.ts +1 -40
  86. package/src/eco/eco.utils.js +5 -35
  87. package/src/eco/global-injector-map.d.ts +1 -1
  88. package/src/eco/lazy-injector-map.d.ts +1 -1
  89. package/src/hmr/README.md +26 -0
  90. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  91. package/src/hmr/client/hmr-runtime.js +30 -7
  92. package/src/hmr/hmr-strategy.d.ts +16 -13
  93. package/src/hmr/hmr-strategy.js +22 -7
  94. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  95. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  96. package/src/hmr/hmr.test.e2e.js +26 -33
  97. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  98. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  99. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -43
  100. package/src/hmr/strategies/js-hmr-strategy.js +72 -73
  101. package/src/index.browser.d.ts +2 -2
  102. package/src/index.browser.js +1 -1
  103. package/src/index.d.ts +4 -3
  104. package/src/index.js +16 -5
  105. package/src/integrations/ghtml/ghtml-renderer.d.ts +7 -2
  106. package/src/integrations/ghtml/ghtml-renderer.js +33 -30
  107. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  108. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  109. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  110. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  111. package/src/plugins/README.md +35 -0
  112. package/src/plugins/alias-resolver-plugin.js +17 -3
  113. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  114. package/src/plugins/eco-component-meta-plugin.js +27 -21
  115. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  116. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  117. package/src/plugins/integration-plugin.d.ts +145 -28
  118. package/src/plugins/integration-plugin.js +109 -13
  119. package/src/plugins/processor.d.ts +15 -2
  120. package/src/plugins/processor.js +16 -2
  121. package/src/plugins/runtime-capability.d.ts +9 -0
  122. package/src/plugins/source-transform.d.ts +46 -0
  123. package/src/plugins/source-transform.js +71 -0
  124. package/src/route-renderer/GRAPH.md +64 -98
  125. package/src/route-renderer/README.md +67 -46
  126. package/src/route-renderer/orchestration/boundary-planning.service.d.ts +25 -0
  127. package/src/route-renderer/orchestration/boundary-planning.service.js +97 -0
  128. package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
  129. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  130. package/src/route-renderer/orchestration/integration-renderer.d.ts +554 -0
  131. package/src/route-renderer/orchestration/integration-renderer.js +957 -0
  132. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +89 -0
  133. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
  134. package/src/route-renderer/orchestration/render-execution.service.d.ts +43 -0
  135. package/src/route-renderer/orchestration/render-execution.service.js +106 -0
  136. package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
  137. package/src/route-renderer/orchestration/render-output.utils.js +65 -0
  138. package/src/route-renderer/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +18 -10
  139. package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +115 -17
  140. package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +50 -0
  141. package/src/route-renderer/orchestration/route-shell-composer.service.js +81 -0
  142. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  143. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  144. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  145. package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +28 -12
  146. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  147. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  148. package/src/route-renderer/route-renderer.d.ts +45 -4
  149. package/src/route-renderer/route-renderer.js +38 -3
  150. package/src/router/README.md +97 -0
  151. package/src/router/client/link-intent.d.ts +53 -0
  152. package/src/router/client/link-intent.js +34 -0
  153. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  154. package/src/router/client/link-intent.test.browser.js +43 -0
  155. package/src/router/client/navigation-coordinator.d.ts +149 -0
  156. package/src/router/client/navigation-coordinator.js +215 -0
  157. package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
  158. package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +14 -8
  159. package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
  160. package/src/router/{fs-router.js → server/fs-router.js} +1 -1
  161. package/src/services/README.md +29 -0
  162. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
  163. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +91 -10
  164. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  165. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  166. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
  167. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  168. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
  169. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  170. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  171. package/src/services/assets/asset-processing-service/index.d.ts +5 -0
  172. package/src/services/assets/asset-processing-service/index.js +5 -0
  173. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  174. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  175. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  176. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
  177. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +5 -4
  178. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +15 -23
  179. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  180. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  181. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +2 -2
  182. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +1 -1
  183. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  184. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +16 -4
  185. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  186. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +6 -5
  187. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
  188. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +1 -1
  189. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +5 -2
  191. package/src/services/assets/browser-bundle.service.d.ts +32 -0
  192. package/src/services/assets/browser-bundle.service.js +33 -0
  193. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  194. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  195. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  196. package/src/services/html/html-rewriter-provider.service.js +68 -0
  197. package/src/services/html/html-transformer.service.d.ts +77 -0
  198. package/src/services/html/html-transformer.service.js +215 -0
  199. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  200. package/src/services/invalidation/development-invalidation.service.js +190 -0
  201. package/src/services/module-loading/app-module-loader.service.d.ts +28 -0
  202. package/src/services/module-loading/app-module-loader.service.js +35 -0
  203. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  204. package/src/services/module-loading/app-server-module-transpiler.service.js +109 -0
  205. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  206. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  207. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  208. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  209. package/src/services/module-loading/node-bootstrap-plugin.js +204 -0
  210. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  211. package/src/services/module-loading/page-module-import.service.js +173 -0
  212. package/src/services/module-loading/server-module-transpiler.service.d.ts +72 -0
  213. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  214. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  215. package/src/services/runtime-state/dev-graph.service.js +162 -0
  216. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  217. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  218. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
  219. package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
  220. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  221. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  222. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  223. package/src/static-site-generator/README.md +26 -0
  224. package/src/static-site-generator/static-site-generator.d.ts +50 -3
  225. package/src/static-site-generator/static-site-generator.js +71 -5
  226. package/src/{internal-types.d.ts → types/internal-types.d.ts} +53 -22
  227. package/src/types/internal-types.js +0 -0
  228. package/src/{public-types.d.ts → types/public-types.d.ts} +146 -21
  229. package/src/types/public-types.js +0 -0
  230. package/src/utils/html-escaping.d.ts +7 -0
  231. package/src/utils/html-escaping.js +6 -0
  232. package/src/utils/locals-utils.d.ts +1 -1
  233. package/src/utils/parse-cli-args.d.ts +4 -1
  234. package/src/utils/parse-cli-args.js +16 -1
  235. package/src/utils/resolve-work-dir.d.ts +11 -0
  236. package/src/utils/resolve-work-dir.js +31 -0
  237. package/src/watchers/project-watcher.d.ts +40 -24
  238. package/src/watchers/project-watcher.js +129 -92
  239. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  240. package/src/watchers/project-watcher.test-helpers.js +1 -0
  241. package/src/adapters/abstract/application-adapter.ts +0 -337
  242. package/src/adapters/abstract/router-adapter.ts +0 -30
  243. package/src/adapters/abstract/server-adapter.ts +0 -79
  244. package/src/adapters/bun/client-bridge.ts +0 -62
  245. package/src/adapters/bun/create-app.ts +0 -189
  246. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  247. package/src/adapters/bun/define-api-handler.ts +0 -114
  248. package/src/adapters/bun/hmr-manager.ts +0 -281
  249. package/src/adapters/bun/index.ts +0 -3
  250. package/src/adapters/bun/server-adapter.ts +0 -492
  251. package/src/adapters/bun/server-lifecycle.ts +0 -154
  252. package/src/adapters/index.ts +0 -6
  253. package/src/adapters/node/create-app.ts +0 -179
  254. package/src/adapters/node/index.d.ts +0 -4
  255. package/src/adapters/node/index.js +0 -8
  256. package/src/adapters/node/index.ts +0 -9
  257. package/src/adapters/node/node-client-bridge.ts +0 -79
  258. package/src/adapters/node/node-hmr-manager.ts +0 -271
  259. package/src/adapters/node/server-adapter.ts +0 -561
  260. package/src/adapters/node/static-content-server.ts +0 -203
  261. package/src/adapters/shared/api-response.ts +0 -104
  262. package/src/adapters/shared/application-adapter.ts +0 -199
  263. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  264. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  265. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  266. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  267. package/src/adapters/shared/render-context.ts +0 -105
  268. package/src/adapters/shared/server-adapter.ts +0 -442
  269. package/src/adapters/shared/server-route-handler.ts +0 -166
  270. package/src/adapters/shared/server-static-builder.ts +0 -82
  271. package/src/build/build-adapter.ts +0 -132
  272. package/src/build/build-types.ts +0 -83
  273. package/src/build/esbuild-build-adapter.ts +0 -510
  274. package/src/config/config-builder.ts +0 -474
  275. package/src/constants.ts +0 -39
  276. package/src/create-app.ts +0 -87
  277. package/src/define-api-handler.js +0 -15
  278. package/src/define-api-handler.ts +0 -66
  279. package/src/dev/sc-server.ts +0 -143
  280. package/src/eco/component-render-context.d.ts +0 -105
  281. package/src/eco/component-render-context.js +0 -77
  282. package/src/eco/component-render-context.ts +0 -202
  283. package/src/eco/eco.ts +0 -221
  284. package/src/eco/eco.types.ts +0 -202
  285. package/src/eco/global-injector-map.ts +0 -112
  286. package/src/eco/lazy-injector-map.ts +0 -120
  287. package/src/eco/module-dependencies.ts +0 -75
  288. package/src/errors/http-error.ts +0 -72
  289. package/src/errors/index.ts +0 -2
  290. package/src/errors/locals-access-error.ts +0 -7
  291. package/src/global/app-logger.ts +0 -4
  292. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
  293. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  294. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  295. package/src/hmr/client/hmr-runtime.ts +0 -121
  296. package/src/hmr/hmr-strategy.ts +0 -172
  297. package/src/hmr/hmr.test.e2e.ts +0 -75
  298. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  299. package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
  300. package/src/index.browser.ts +0 -3
  301. package/src/index.ts +0 -5
  302. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  303. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  304. package/src/internal-types.ts +0 -212
  305. package/src/plugins/alias-resolver-plugin.ts +0 -45
  306. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  307. package/src/plugins/integration-plugin.ts +0 -184
  308. package/src/plugins/processor.ts +0 -220
  309. package/src/public-types.ts +0 -1255
  310. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  311. package/src/route-renderer/component-graph-executor.js +0 -31
  312. package/src/route-renderer/component-graph-executor.ts +0 -84
  313. package/src/route-renderer/component-graph.d.ts +0 -42
  314. package/src/route-renderer/component-graph.js +0 -72
  315. package/src/route-renderer/component-graph.ts +0 -159
  316. package/src/route-renderer/component-marker.d.ts +0 -52
  317. package/src/route-renderer/component-marker.js +0 -46
  318. package/src/route-renderer/component-marker.ts +0 -117
  319. package/src/route-renderer/dependency-resolver.ts +0 -596
  320. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  321. package/src/route-renderer/html-post-processing.service.js +0 -86
  322. package/src/route-renderer/html-post-processing.service.ts +0 -103
  323. package/src/route-renderer/integration-renderer.d.ts +0 -339
  324. package/src/route-renderer/integration-renderer.js +0 -526
  325. package/src/route-renderer/integration-renderer.ts +0 -696
  326. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  327. package/src/route-renderer/marker-graph-resolver.js +0 -93
  328. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  329. package/src/route-renderer/page-module-loader.d.ts +0 -61
  330. package/src/route-renderer/page-module-loader.ts +0 -153
  331. package/src/route-renderer/render-execution.service.d.ts +0 -69
  332. package/src/route-renderer/render-execution.service.js +0 -91
  333. package/src/route-renderer/render-execution.service.ts +0 -158
  334. package/src/route-renderer/render-preparation.service.ts +0 -358
  335. package/src/route-renderer/route-renderer.ts +0 -80
  336. package/src/router/fs-router-scanner.ts +0 -217
  337. package/src/router/fs-router.ts +0 -122
  338. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  339. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  340. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  341. package/src/services/asset-processing-service/assets.types.ts +0 -112
  342. package/src/services/asset-processing-service/index.d.ts +0 -3
  343. package/src/services/asset-processing-service/index.js +0 -3
  344. package/src/services/asset-processing-service/index.ts +0 -3
  345. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  346. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  347. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  348. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  349. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  350. package/src/services/asset-processing-service/processors/index.js +0 -5
  351. package/src/services/asset-processing-service/processors/index.ts +0 -5
  352. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  353. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  354. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  355. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  356. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  357. package/src/services/cache/cache.types.ts +0 -126
  358. package/src/services/cache/index.ts +0 -18
  359. package/src/services/cache/memory-cache-store.ts +0 -130
  360. package/src/services/cache/page-cache-service.ts +0 -202
  361. package/src/services/html-transformer.service.d.ts +0 -50
  362. package/src/services/html-transformer.service.js +0 -163
  363. package/src/services/html-transformer.service.ts +0 -217
  364. package/src/services/page-module-import.service.d.ts +0 -37
  365. package/src/services/page-module-import.service.js +0 -88
  366. package/src/services/page-module-import.service.ts +0 -129
  367. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  368. package/src/services/schema-validation-service.ts +0 -204
  369. package/src/services/validation/standard-schema.types.ts +0 -68
  370. package/src/static-site-generator/static-site-generator.ts +0 -359
  371. package/src/utils/css.d.ts +0 -1
  372. package/src/utils/css.js +0 -7
  373. package/src/utils/css.ts +0 -5
  374. package/src/utils/deep-merge.ts +0 -47
  375. package/src/utils/hash.ts +0 -5
  376. package/src/utils/html.ts +0 -1
  377. package/src/utils/invariant.ts +0 -15
  378. package/src/utils/locals-utils.ts +0 -37
  379. package/src/utils/parse-cli-args.ts +0 -83
  380. package/src/utils/path-utils.module.ts +0 -14
  381. package/src/utils/runtime.ts +0 -44
  382. package/src/utils/server-utils.module.ts +0 -67
  383. package/src/watchers/project-watcher.test-helpers.ts +0 -40
  384. package/src/watchers/project-watcher.ts +0 -306
  385. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  386. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  387. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  388. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  389. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  390. /package/src/{public-types.js → services/module-loading/module-loading-types.js} +0 -0
  391. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -0,0 +1,215 @@
1
+ const ECO_DOCUMENT_OWNER_ATTRIBUTE = "data-eco-document-owner";
2
+ function getEcoDocumentOwner(doc) {
3
+ const owner = doc.documentElement.getAttribute(ECO_DOCUMENT_OWNER_ATTRIBUTE);
4
+ return owner && owner.length > 0 ? owner : null;
5
+ }
6
+ function getCandidateOwners(currentOwner, registrations, excludedOwner) {
7
+ const owners = [];
8
+ if (currentOwner !== "none" && currentOwner !== excludedOwner) {
9
+ owners.push(currentOwner);
10
+ }
11
+ for (const owner of registrations.keys()) {
12
+ if (owner === currentOwner || owner === excludedOwner) {
13
+ continue;
14
+ }
15
+ owners.push(owner);
16
+ }
17
+ return owners;
18
+ }
19
+ function createEcoNavigationRuntime() {
20
+ const registrations = /* @__PURE__ */ new Map();
21
+ const listeners = /* @__PURE__ */ new Set();
22
+ let owner = "none";
23
+ let navigationSequence = 0;
24
+ let navigationAbortController = null;
25
+ const emit = (event) => {
26
+ for (const listener of listeners) {
27
+ listener(event);
28
+ }
29
+ };
30
+ const updateOwner = (nextOwner, reason) => {
31
+ if (owner === nextOwner) {
32
+ return;
33
+ }
34
+ const previousOwner = owner;
35
+ owner = nextOwner;
36
+ emit({
37
+ type: "owner-change",
38
+ owner: nextOwner,
39
+ previousOwner,
40
+ reason
41
+ });
42
+ };
43
+ const cancelNavigationTransaction = (navigationId, abortController) => {
44
+ if (navigationSequence !== navigationId || navigationAbortController !== abortController) {
45
+ return;
46
+ }
47
+ navigationSequence += 1;
48
+ navigationAbortController = null;
49
+ abortController.abort();
50
+ };
51
+ const completeNavigationTransaction = (navigationId, abortController) => {
52
+ if (navigationSequence !== navigationId || navigationAbortController !== abortController) {
53
+ return;
54
+ }
55
+ navigationAbortController = null;
56
+ };
57
+ const runtime = {
58
+ getOwnerState() {
59
+ const activeRuntime = registrations.get(owner);
60
+ return {
61
+ owner,
62
+ canHandleSpaNavigation: typeof activeRuntime?.navigate === "function"
63
+ };
64
+ },
65
+ hasPendingNavigationTransaction() {
66
+ return navigationAbortController !== null;
67
+ },
68
+ beginNavigationTransaction() {
69
+ navigationAbortController?.abort();
70
+ const abortController = new AbortController();
71
+ const navigationId = ++navigationSequence;
72
+ navigationAbortController = abortController;
73
+ return {
74
+ id: navigationId,
75
+ signal: abortController.signal,
76
+ isCurrent: () => navigationSequence === navigationId && navigationAbortController === abortController,
77
+ cancel: () => {
78
+ cancelNavigationTransaction(navigationId, abortController);
79
+ },
80
+ complete: () => {
81
+ completeNavigationTransaction(navigationId, abortController);
82
+ }
83
+ };
84
+ },
85
+ cancelCurrentNavigationTransaction() {
86
+ if (!navigationAbortController) {
87
+ return;
88
+ }
89
+ cancelNavigationTransaction(navigationSequence, navigationAbortController);
90
+ },
91
+ setOwner(nextOwner) {
92
+ updateOwner(nextOwner, "set");
93
+ },
94
+ claimOwnership(nextOwner) {
95
+ updateOwner(nextOwner, "claim");
96
+ },
97
+ releaseOwnership(currentOwner) {
98
+ if (owner !== currentOwner) {
99
+ return;
100
+ }
101
+ updateOwner("none", "release");
102
+ },
103
+ resolveDocumentOwner(doc, fallbackOwner = "none") {
104
+ return getEcoDocumentOwner(doc) ?? fallbackOwner;
105
+ },
106
+ adoptDocumentOwner(doc, fallbackOwner = "none") {
107
+ const nextOwner = runtime.resolveDocumentOwner(doc, fallbackOwner);
108
+ updateOwner(nextOwner, "document");
109
+ return nextOwner;
110
+ },
111
+ isOwnedByAnotherRuntime(candidateOwner) {
112
+ return owner !== "none" && owner !== candidateOwner;
113
+ },
114
+ subscribe(listener) {
115
+ listeners.add(listener);
116
+ return () => {
117
+ listeners.delete(listener);
118
+ };
119
+ },
120
+ register(registration) {
121
+ registrations.set(registration.owner, registration);
122
+ emit({
123
+ type: "registration-change",
124
+ owner: registration.owner,
125
+ status: "registered"
126
+ });
127
+ return () => {
128
+ const currentRegistration = registrations.get(registration.owner);
129
+ if (currentRegistration !== registration) {
130
+ return;
131
+ }
132
+ registrations.delete(registration.owner);
133
+ emit({
134
+ type: "registration-change",
135
+ owner: registration.owner,
136
+ status: "unregistered"
137
+ });
138
+ if (owner === registration.owner) {
139
+ updateOwner("none", "unregister");
140
+ }
141
+ };
142
+ },
143
+ async requestNavigation(request) {
144
+ for (const candidateOwner of getCandidateOwners(owner, registrations, request.source)) {
145
+ const registration = registrations.get(candidateOwner);
146
+ if (!registration?.navigate) {
147
+ continue;
148
+ }
149
+ const handled = await registration.navigate(request);
150
+ if (handled !== false) {
151
+ return true;
152
+ }
153
+ }
154
+ return false;
155
+ },
156
+ async requestHandoff(request) {
157
+ if (request.targetOwner === "none") {
158
+ return false;
159
+ }
160
+ if (request.isStaleSourceNavigation?.()) {
161
+ return true;
162
+ }
163
+ const registration = registrations.get(request.targetOwner);
164
+ if (!registration?.handoffNavigation) {
165
+ return false;
166
+ }
167
+ if (request.isStaleSourceNavigation?.()) {
168
+ return true;
169
+ }
170
+ const handled = await registration.handoffNavigation(request);
171
+ return handled !== false;
172
+ },
173
+ async reloadCurrentPage(request) {
174
+ for (const candidateOwner of getCandidateOwners(owner, registrations)) {
175
+ const registration = registrations.get(candidateOwner);
176
+ if (!registration?.reloadCurrentPage) {
177
+ continue;
178
+ }
179
+ await registration.reloadCurrentPage(request);
180
+ return true;
181
+ }
182
+ return false;
183
+ },
184
+ async cleanupOwner(targetOwner) {
185
+ if (targetOwner === "none") {
186
+ return;
187
+ }
188
+ const registration = registrations.get(targetOwner);
189
+ if (!registration?.cleanupBeforeHandoff) {
190
+ return;
191
+ }
192
+ await registration.cleanupBeforeHandoff();
193
+ if (owner === targetOwner) {
194
+ updateOwner("none", "release");
195
+ }
196
+ },
197
+ async cleanupCurrentOwner() {
198
+ await runtime.cleanupOwner(owner);
199
+ }
200
+ };
201
+ return runtime;
202
+ }
203
+ function getEcoNavigationRuntime(windowObject = window) {
204
+ const runtimeWindow = windowObject;
205
+ runtimeWindow.__ECO_PAGES__ = runtimeWindow.__ECO_PAGES__ || {};
206
+ if (!runtimeWindow.__ECO_PAGES__.navigation) {
207
+ runtimeWindow.__ECO_PAGES__.navigation = createEcoNavigationRuntime();
208
+ }
209
+ return runtimeWindow.__ECO_PAGES__.navigation;
210
+ }
211
+ export {
212
+ ECO_DOCUMENT_OWNER_ATTRIBUTE,
213
+ getEcoDocumentOwner,
214
+ getEcoNavigationRuntime
215
+ };
@@ -1,4 +1,4 @@
1
- import type { EcoPagesAppConfig, Routes } from '../internal-types.js';
1
+ import type { EcoPagesAppConfig, Routes } from '../../types/internal-types.js';
2
2
  type FSRouterScannerOptions = {
3
3
  buildMode: boolean;
4
4
  };
@@ -18,9 +18,9 @@ export declare class FSRouterScanner {
18
18
  private origin;
19
19
  private templatesExt;
20
20
  private options;
21
- private appConfig;
21
+ readonly appConfig: EcoPagesAppConfig;
22
22
  routes: Routes;
23
- private pageModuleImportService;
23
+ private serverModuleTranspiler;
24
24
  constructor({ dir, origin, templatesExt, options, appConfig, }: {
25
25
  dir: string;
26
26
  origin: string;
@@ -1,9 +1,10 @@
1
1
  import path from "node:path";
2
- import { appLogger } from "../global/app-logger.js";
2
+ import { appLogger } from "../../global/app-logger.js";
3
3
  import { fileSystem } from "@ecopages/file-system";
4
- import { invariant } from "../utils/invariant.js";
4
+ import { invariant } from "../../utils/invariant.js";
5
5
  import { existsSync } from "node:fs";
6
- import { PageModuleImportService } from "../services/page-module-import.service.js";
6
+ import { getAppServerModuleTranspiler } from "../../services/module-loading/app-server-module-transpiler.service.js";
7
+ import { resolveInternalExecutionDir } from "../../utils/resolve-work-dir.js";
7
8
  class FSRouterScanner {
8
9
  dir;
9
10
  origin = "";
@@ -11,7 +12,7 @@ class FSRouterScanner {
11
12
  options;
12
13
  appConfig;
13
14
  routes = {};
14
- pageModuleImportService = new PageModuleImportService();
15
+ serverModuleTranspiler;
15
16
  constructor({
16
17
  dir,
17
18
  origin,
@@ -24,6 +25,7 @@ class FSRouterScanner {
24
25
  this.templatesExt = templatesExt;
25
26
  this.options = options;
26
27
  this.appConfig = appConfig;
28
+ this.serverModuleTranspiler = getAppServerModuleTranspiler(appConfig);
27
29
  }
28
30
  getRoutePath(path2) {
29
31
  const cleanedRoute = this.templatesExt.reduce((route, ext) => route.replace(ext, ""), path2).replace(/\/?index$/, "");
@@ -90,10 +92,9 @@ class FSRouterScanner {
90
92
  return this.createRoute("dynamic", { filePath, route, routePath });
91
93
  }
92
94
  async importPageModule(filePath) {
93
- return this.pageModuleImportService.importModule({
95
+ return this.serverModuleTranspiler.importModule({
94
96
  filePath,
95
- rootDir: this.appConfig.rootDir,
96
- outdir: path.join(this.appConfig.absolutePaths.distDir, ".server-route-modules"),
97
+ outdir: path.join(resolveInternalExecutionDir(this.appConfig), ".server-route-modules"),
97
98
  externalPackages: false,
98
99
  transpileErrorMessage: (details) => `Error transpiling route module: ${details}`,
99
100
  noOutputMessage: (targetFilePath) => `No transpiled output generated for route module: ${targetFilePath}`
@@ -112,7 +113,12 @@ class FSRouterScanner {
112
113
  const filePath = path.join(this.dir, file);
113
114
  const isCatchAll = filePath.includes("[...");
114
115
  const isDynamic = !isCatchAll && filePath.includes("[") && filePath.includes("]");
115
- const kind = isCatchAll ? "catch-all" : isDynamic ? "dynamic" : "exact";
116
+ let kind = "exact";
117
+ if (isCatchAll) {
118
+ kind = "catch-all";
119
+ } else if (isDynamic) {
120
+ kind = "dynamic";
121
+ }
116
122
  return { route, routePath, filePath, kind };
117
123
  }
118
124
  async scan() {
@@ -1,4 +1,4 @@
1
- import type { MatchResult, Route, Routes } from '../internal-types.js';
1
+ import type { MatchResult, Route, Routes } from '../../types/internal-types.js';
2
2
  import type { FSRouterScanner } from './fs-router-scanner.js';
3
3
  /**
4
4
  * A class that manages the routes of the file system.
@@ -1,4 +1,4 @@
1
- import { appLogger } from "../global/app-logger.js";
1
+ import { appLogger } from "../../global/app-logger.js";
2
2
  class FSRouter {
3
3
  origin;
4
4
  assetPrefix;
@@ -0,0 +1,29 @@
1
+ # Core Services
2
+
3
+ This directory contains the app-owned service layer used by runtime startup, rendering, asset processing, browser bundling, and development invalidation.
4
+
5
+ ## Purpose
6
+
7
+ Services in this directory exist to keep cross-cutting framework logic out of adapters, integrations, and processors.
8
+
9
+ Typical responsibilities include:
10
+
11
+ - server-module loading and transpilation
12
+ - browser bundle coordination
13
+ - asset processing and runtime asset declaration helpers
14
+ - runtime specifier registry management
15
+ - server invalidation state and entrypoint dependency graphs
16
+ - HTML finalization and dependency injection
17
+
18
+ ## Main Areas
19
+
20
+ - `module-loading/`: framework-owned config/app bootstrap loading and server-side source loading
21
+ - `assets/`: shared browser build coordination and processed asset pipelines
22
+ - `invalidation/`: file-change classification and invalidation policy
23
+ - `runtime-state/`: app-owned invalidation state, dependency graphs, and runtime specifier registry
24
+ - `runtime-manifest/`: node runtime manifest derivation and persistence
25
+ - `html/`: final HTML dependency injection and rewriter selection
26
+
27
+ ## Design Rule
28
+
29
+ If a concern affects more than one integration or more than one runtime adapter, it usually belongs here instead of in a package-specific implementation.
@@ -0,0 +1,120 @@
1
+ import type { EcoPagesAppConfig, IHmrManager } from '../../../types/internal-types.js';
2
+ import type { AssetDefinition, AssetKind, AssetSource, ProcessedAsset } from './assets.types.js';
3
+ import { ProcessorRegistry } from './processor.registry.js';
4
+ /**
5
+ * Processes declared component and page asset dependencies for one app instance.
6
+ *
7
+ * @remarks
8
+ * This service is the shared bridge between dependency declarations and emitted
9
+ * runtime-ready assets. It owns deduplication, processor dispatch, cache reuse,
10
+ * output URL normalization, and production gzip preparation so route rendering
11
+ * and HMR flows do not need to understand processor-specific behavior.
12
+ */
13
+ export declare class AssetProcessingService {
14
+ static readonly RESOLVED_ASSETS_DIR = "assets";
15
+ private registry;
16
+ private hmrManager?;
17
+ private cache;
18
+ private readonly config;
19
+ /**
20
+ * Creates the asset-processing service bound to one finalized app config.
21
+ */
22
+ constructor(config: EcoPagesAppConfig);
23
+ /**
24
+ * Set the HMR manager for the asset processing service.
25
+ * @param hmrManager The HMR manager to set.
26
+ */
27
+ setHmrManager(hmrManager: IHmrManager): void;
28
+ getHmrManager(): IHmrManager | undefined;
29
+ /**
30
+ * Register a processor for a specific asset kind and source.
31
+ * @param kind The asset kind.
32
+ * @param variant The asset source.
33
+ * @param processor The processor to register.
34
+ */
35
+ registerProcessor(kind: AssetKind, variant: AssetSource, processor: any): void;
36
+ /**
37
+ * Processes one dependency list into normalized emitted assets.
38
+ *
39
+ * @remarks
40
+ * Dependencies are deduplicated before processor execution so repeated
41
+ * declarations across the render tree reuse the same emitted outputs and cache
42
+ * entries.
43
+ */
44
+ processDependencies(deps: AssetDefinition[], key: string): Promise<ProcessedAsset[]>;
45
+ /**
46
+ * Removes duplicate dependency declarations while preserving first-seen order.
47
+ */
48
+ private deduplicateDependencies;
49
+ /**
50
+ * Builds the cache signature fragment for script dependencies that can vary by
51
+ * bundling policy.
52
+ */
53
+ private getScriptDependencyBuildSignature;
54
+ /**
55
+ * Derives the stable cache key for one dependency declaration.
56
+ */
57
+ private getDependencyKey;
58
+ /**
59
+ * Hashes content used in dependency cache and signature keys.
60
+ */
61
+ private generateHash;
62
+ /**
63
+ * Processes deduplicated dependencies grouped by processor type.
64
+ *
65
+ * @remarks
66
+ * Grouping keeps cache and processor behavior isolated by asset kind/source
67
+ * pair, while still allowing the overall dependency set to resolve in
68
+ * parallel.
69
+ */
70
+ private processDependenciesParallel;
71
+ /**
72
+ * Groups dependencies by processor bucket.
73
+ */
74
+ private groupDependenciesByType;
75
+ /**
76
+ * Converts a dist-local file path into its public URL.
77
+ */
78
+ private getSrcUrl;
79
+ /**
80
+ * Normalizes the public source URL for one processed asset.
81
+ */
82
+ private resolveProcessedAssetSrcUrl;
83
+ /**
84
+ * Returns whether a value should be interpreted as a filesystem path instead
85
+ * of an already-public URL.
86
+ */
87
+ private isFilesystemPath;
88
+ /**
89
+ * Applies post-processing for emitted production assets.
90
+ *
91
+ * @remarks
92
+ * Current optimization is intentionally conservative: only generated CSS and
93
+ * JavaScript files inside the app dist directory are gzipped.
94
+ */
95
+ private optimizeDependencies;
96
+ /**
97
+ * Returns the cached processed asset for a dependency key when available.
98
+ */
99
+ private getCachedAsset;
100
+ /**
101
+ * Stores one processed asset in the dependency cache.
102
+ */
103
+ private setCachedAsset;
104
+ /**
105
+ * Clears all cached processed assets.
106
+ */
107
+ clearCache(): void;
108
+ /**
109
+ * Removes cached assets that were produced from the given file path.
110
+ */
111
+ invalidateCacheForFile(filepath: string): void;
112
+ /**
113
+ * Creates a service prewired with the default core processors.
114
+ */
115
+ static createWithDefaultProcessors(appConfig: EcoPagesAppConfig): AssetProcessingService;
116
+ /**
117
+ * Returns the processor registry owned by this service.
118
+ */
119
+ getRegistry(): ProcessorRegistry;
120
+ }
@@ -1,25 +1,29 @@
1
1
  import path from "node:path";
2
- import { RESOLVED_ASSETS_DIR } from "../../constants";
3
- import { appLogger } from "../../global/app-logger";
4
- import { rapidhash } from "../../utils/hash";
2
+ import { RESOLVED_ASSETS_DIR } from "../../../config/constants.js";
3
+ import { appLogger } from "../../../global/app-logger.js";
4
+ import { rapidhash } from "../../../utils/hash.js";
5
5
  import { fileSystem } from "@ecopages/file-system";
6
- import { isHmrAware } from "./processor.interface";
7
- import { ProcessorRegistry } from "./processor.registry";
6
+ import { isHmrAware } from "./processor.interface.js";
7
+ import { ProcessorRegistry } from "./processor.registry.js";
8
8
  import {
9
9
  ContentScriptProcessor,
10
10
  ContentStylesheetProcessor,
11
11
  FileScriptProcessor,
12
12
  FileStylesheetProcessor,
13
13
  NodeModuleScriptProcessor
14
- } from "./processors";
14
+ } from "./processors/index.js";
15
15
  class AssetProcessingService {
16
- constructor(config) {
17
- this.config = config;
18
- }
19
16
  static RESOLVED_ASSETS_DIR = RESOLVED_ASSETS_DIR;
20
17
  registry = new ProcessorRegistry();
21
18
  hmrManager;
22
19
  cache = /* @__PURE__ */ new Map();
20
+ config;
21
+ /**
22
+ * Creates the asset-processing service bound to one finalized app config.
23
+ */
24
+ constructor(config) {
25
+ this.config = config;
26
+ }
23
27
  /**
24
28
  * Set the HMR manager for the asset processing service.
25
29
  * @param hmrManager The HMR manager to set.
@@ -47,6 +51,14 @@ class AssetProcessingService {
47
51
  }
48
52
  this.registry.register(kind, variant, processor);
49
53
  }
54
+ /**
55
+ * Processes one dependency list into normalized emitted assets.
56
+ *
57
+ * @remarks
58
+ * Dependencies are deduplicated before processor execution so repeated
59
+ * declarations across the render tree reuse the same emitted outputs and cache
60
+ * entries.
61
+ */
50
62
  async processDependencies(deps, key) {
51
63
  const depsDir = path.join(this.config.absolutePaths.distDir, RESOLVED_ASSETS_DIR);
52
64
  fileSystem.ensureDir(depsDir);
@@ -55,6 +67,9 @@ class AssetProcessingService {
55
67
  await this.optimizeDependencies(results);
56
68
  return results;
57
69
  }
70
+ /**
71
+ * Removes duplicate dependency declarations while preserving first-seen order.
72
+ */
58
73
  deduplicateDependencies(deps) {
59
74
  const seen = /* @__PURE__ */ new Map();
60
75
  for (const dep of deps) {
@@ -65,6 +80,10 @@ class AssetProcessingService {
65
80
  }
66
81
  return Array.from(seen.values());
67
82
  }
83
+ /**
84
+ * Builds the cache signature fragment for script dependencies that can vary by
85
+ * bundling policy.
86
+ */
68
87
  getScriptDependencyBuildSignature(dep) {
69
88
  if (dep.kind !== "script") {
70
89
  return void 0;
@@ -81,6 +100,9 @@ class AssetProcessingService {
81
100
  };
82
101
  return this.generateHash(JSON.stringify(signature));
83
102
  }
103
+ /**
104
+ * Derives the stable cache key for one dependency declaration.
105
+ */
84
106
  getDependencyKey(dep) {
85
107
  const parts = [dep.kind, dep.source];
86
108
  if ("filepath" in dep) {
@@ -99,9 +121,20 @@ class AssetProcessingService {
99
121
  }
100
122
  return parts.join(":");
101
123
  }
124
+ /**
125
+ * Hashes content used in dependency cache and signature keys.
126
+ */
102
127
  generateHash(content) {
103
128
  return rapidhash(content).toString();
104
129
  }
130
+ /**
131
+ * Processes deduplicated dependencies grouped by processor type.
132
+ *
133
+ * @remarks
134
+ * Grouping keeps cache and processor behavior isolated by asset kind/source
135
+ * pair, while still allowing the overall dependency set to resolve in
136
+ * parallel.
137
+ */
105
138
  async processDependenciesParallel(deps, key) {
106
139
  const grouped = this.groupDependenciesByType(deps);
107
140
  const groupPromises = Object.entries(grouped).map(async ([, typeDeps]) => {
@@ -147,6 +180,9 @@ class AssetProcessingService {
147
180
  const allTypeResults = await Promise.all(groupPromises);
148
181
  return allTypeResults.flat();
149
182
  }
183
+ /**
184
+ * Groups dependencies by processor bucket.
185
+ */
150
186
  groupDependenciesByType(deps) {
151
187
  return deps.reduce(
152
188
  (acc, dep) => {
@@ -158,6 +194,9 @@ class AssetProcessingService {
158
194
  {}
159
195
  );
160
196
  }
197
+ /**
198
+ * Converts a dist-local file path into its public URL.
199
+ */
161
200
  getSrcUrl(filepath) {
162
201
  const distDir = this.config.absolutePaths.distDir;
163
202
  if (!filepath.startsWith(distDir)) return void 0;
@@ -165,6 +204,9 @@ class AssetProcessingService {
165
204
  const urlPath = relativePath.startsWith("/") ? relativePath : `/${relativePath}`;
166
205
  return urlPath.replace(/\\/g, "/");
167
206
  }
207
+ /**
208
+ * Normalizes the public source URL for one processed asset.
209
+ */
168
210
  resolveProcessedAssetSrcUrl(processed) {
169
211
  if (processed.srcUrl) {
170
212
  if (this.isFilesystemPath(processed.srcUrl)) {
@@ -179,6 +221,10 @@ class AssetProcessingService {
179
221
  }
180
222
  return void 0;
181
223
  }
224
+ /**
225
+ * Returns whether a value should be interpreted as a filesystem path instead
226
+ * of an already-public URL.
227
+ */
182
228
  isFilesystemPath(value) {
183
229
  if (value.startsWith("http://") || value.startsWith("https://") || value.startsWith("//")) {
184
230
  return false;
@@ -192,6 +238,13 @@ class AssetProcessingService {
192
238
  }
193
239
  return /^[A-Za-z]:\\/.test(value);
194
240
  }
241
+ /**
242
+ * Applies post-processing for emitted production assets.
243
+ *
244
+ * @remarks
245
+ * Current optimization is intentionally conservative: only generated CSS and
246
+ * JavaScript files inside the app dist directory are gzipped.
247
+ */
195
248
  async optimizeDependencies(processedAssets) {
196
249
  if (process.env.NODE_ENV !== "production") {
197
250
  return;
@@ -215,16 +268,38 @@ class AssetProcessingService {
215
268
  }
216
269
  }
217
270
  }
271
+ /**
272
+ * Returns the cached processed asset for a dependency key when available.
273
+ */
218
274
  getCachedAsset(dep, depKey) {
275
+ if (process.env.NODE_ENV !== "production" && dep.source === "file" && dep.kind === "stylesheet") {
276
+ return null;
277
+ }
219
278
  const cached = this.cache.get(depKey);
220
- return cached?.asset ?? null;
279
+ if (!cached) {
280
+ return null;
281
+ }
282
+ if (cached.asset.filepath && !fileSystem.exists(cached.asset.filepath)) {
283
+ this.cache.delete(depKey);
284
+ return null;
285
+ }
286
+ return cached.asset;
221
287
  }
288
+ /**
289
+ * Stores one processed asset in the dependency cache.
290
+ */
222
291
  setCachedAsset(dep, depKey, asset) {
223
292
  this.cache.set(depKey, { asset });
224
293
  }
294
+ /**
295
+ * Clears all cached processed assets.
296
+ */
225
297
  clearCache() {
226
298
  this.cache.clear();
227
299
  }
300
+ /**
301
+ * Removes cached assets that were produced from the given file path.
302
+ */
228
303
  invalidateCacheForFile(filepath) {
229
304
  for (const [key, value] of this.cache.entries()) {
230
305
  if (value.asset.filepath === filepath) {
@@ -232,6 +307,9 @@ class AssetProcessingService {
232
307
  }
233
308
  }
234
309
  }
310
+ /**
311
+ * Creates a service prewired with the default core processors.
312
+ */
235
313
  static createWithDefaultProcessors(appConfig) {
236
314
  const service = new AssetProcessingService(appConfig);
237
315
  service.registerProcessor("script", "content", new ContentScriptProcessor({ appConfig }));
@@ -241,6 +319,9 @@ class AssetProcessingService {
241
319
  service.registerProcessor("stylesheet", "file", new FileStylesheetProcessor({ appConfig }));
242
320
  return service;
243
321
  }
322
+ /**
323
+ * Returns the processor registry owned by this service.
324
+ */
244
325
  getRegistry() {
245
326
  return this.registry;
246
327
  }
@@ -1,4 +1,4 @@
1
- import type { ContentScriptAsset, ContentStylesheetAsset, FileScriptAsset, FileStylesheetAsset, InlineContentScriptAsset, InlineContentStylesheetAsset, InlineFileScriptAsset, JsonScriptAsset, NodeModuleScriptAsset } from './assets.types';
1
+ import type { ContentScriptAsset, ContentStylesheetAsset, FileScriptAsset, FileStylesheetAsset, InlineContentScriptAsset, InlineContentStylesheetAsset, InlineFileScriptAsset, JsonScriptAsset, NodeModuleScriptAsset } from './assets.types.js';
2
2
  type CreateAssetOptions<T> = Omit<T, 'kind' | 'source' | 'inline'>;
3
3
  export declare class AssetFactory {
4
4
  static readonly RESOLVED_ASSETS_DIR = "assets";
@@ -1,5 +1,5 @@
1
- import { RESOLVED_ASSETS_DIR, RESOLVED_ASSETS_VENDORS_DIR } from "../../constants";
2
- import { deepMerge } from "../../utils/deep-merge";
1
+ import { RESOLVED_ASSETS_DIR, RESOLVED_ASSETS_VENDORS_DIR } from "../../../config/constants.js";
2
+ import { deepMerge } from "../../../utils/deep-merge.js";
3
3
  class AssetFactory {
4
4
  static RESOLVED_ASSETS_DIR = RESOLVED_ASSETS_DIR;
5
5
  static RESOLVED_ASSETS_VENDORS_DIR = RESOLVED_ASSETS_VENDORS_DIR;