@ecopages/core 0.2.0-alpha.22 → 0.2.0-alpha.24

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 (515) hide show
  1. package/package.json +93 -226
  2. package/src/adapters/abstract/application-adapter.test.ts +172 -0
  3. package/src/adapters/abstract/application-adapter.ts +379 -0
  4. package/src/adapters/abstract/router-adapter.ts +30 -0
  5. package/src/adapters/abstract/server-adapter.ts +79 -0
  6. package/src/adapters/bun/client-bridge.ts +62 -0
  7. package/src/adapters/bun/create-app.ts +180 -0
  8. package/src/adapters/bun/hmr-manager.test.ts +267 -0
  9. package/src/adapters/bun/hmr-manager.ts +406 -0
  10. package/src/adapters/bun/index.ts +2 -0
  11. package/src/adapters/bun/server-adapter.ts +500 -0
  12. package/src/adapters/bun/server-lifecycle.ts +124 -0
  13. package/src/adapters/create-app.test.ts +10 -0
  14. package/src/adapters/create-app.ts +91 -0
  15. package/src/adapters/index.ts +2 -0
  16. package/src/adapters/node/create-app.test.ts +53 -0
  17. package/src/adapters/node/create-app.ts +183 -0
  18. package/src/adapters/node/node-client-bridge.test.ts +198 -0
  19. package/src/adapters/node/node-client-bridge.ts +79 -0
  20. package/src/adapters/node/node-hmr-manager.test.ts +322 -0
  21. package/src/adapters/node/node-hmr-manager.ts +378 -0
  22. package/src/adapters/node/server-adapter.ts +502 -0
  23. package/src/adapters/node/static-content-server.test.ts +60 -0
  24. package/src/adapters/node/static-content-server.ts +239 -0
  25. package/src/adapters/shared/api-response.test.ts +97 -0
  26. package/src/adapters/shared/api-response.ts +104 -0
  27. package/src/adapters/shared/application-adapter.ts +199 -0
  28. package/src/adapters/shared/define-api-handler.ts +66 -0
  29. package/src/adapters/shared/explicit-static-route-matcher.test.ts +381 -0
  30. package/src/adapters/shared/explicit-static-route-matcher.ts +140 -0
  31. package/src/adapters/shared/file-route-middleware-pipeline.test.ts +90 -0
  32. package/src/adapters/shared/file-route-middleware-pipeline.ts +127 -0
  33. package/src/adapters/shared/fs-server-response-factory.test.ts +187 -0
  34. package/src/adapters/shared/fs-server-response-factory.ts +118 -0
  35. package/src/adapters/shared/fs-server-response-matcher.test.ts +285 -0
  36. package/src/adapters/shared/fs-server-response-matcher.ts +189 -0
  37. package/src/adapters/shared/hmr-entrypoint-registrar.ts +149 -0
  38. package/src/adapters/shared/hmr-html-response.ts +52 -0
  39. package/src/adapters/shared/hmr-manager.contract.test.ts +232 -0
  40. package/src/adapters/shared/hmr-manager.dispatch.test.ts +220 -0
  41. package/src/adapters/shared/render-context.test.ts +150 -0
  42. package/src/adapters/shared/render-context.ts +123 -0
  43. package/src/adapters/shared/runtime-bootstrap.ts +79 -0
  44. package/src/adapters/shared/server-adapter.test.ts +77 -0
  45. package/src/adapters/shared/server-adapter.ts +493 -0
  46. package/src/adapters/shared/server-route-handler.test.ts +110 -0
  47. package/src/adapters/shared/server-route-handler.ts +153 -0
  48. package/src/adapters/shared/server-static-builder.test.ts +338 -0
  49. package/src/adapters/shared/server-static-builder.ts +170 -0
  50. package/src/build/build-adapter-serialization.test.ts +281 -0
  51. package/src/build/build-adapter.test.ts +1240 -0
  52. package/src/build/build-adapter.ts +1012 -0
  53. package/src/build/build-manifest.ts +54 -0
  54. package/src/build/build-types.ts +83 -0
  55. package/src/build/dev-build-coordinator.ts +220 -0
  56. package/src/build/esbuild-build-adapter.ts +660 -0
  57. package/src/build/runtime-build-executor.test.ts +81 -0
  58. package/src/build/runtime-build-executor.ts +40 -0
  59. package/src/build/runtime-specifier-alias-plugin.test.ts +67 -0
  60. package/src/build/runtime-specifier-alias-plugin.ts +62 -0
  61. package/src/build/runtime-specifier-aliases.ts +135 -0
  62. package/src/config/config-builder.test.ts +443 -0
  63. package/src/config/config-builder.ts +742 -0
  64. package/src/config/config-builder.typecheck.test.ts +96 -0
  65. package/src/config/{constants.d.ts → constants.ts} +22 -13
  66. package/src/dev/sc-server.ts +143 -0
  67. package/src/eco/eco.browser.test.ts +43 -0
  68. package/src/eco/eco.browser.ts +118 -0
  69. package/src/eco/eco.test.ts +654 -0
  70. package/src/eco/eco.ts +205 -0
  71. package/src/eco/eco.types.ts +221 -0
  72. package/src/eco/eco.utils.test.ts +219 -0
  73. package/src/eco/eco.utils.ts +5 -0
  74. package/src/eco/global-injector-map.test.ts +42 -0
  75. package/src/eco/global-injector-map.ts +112 -0
  76. package/src/eco/lazy-injector-map.test.ts +66 -0
  77. package/src/eco/lazy-injector-map.ts +120 -0
  78. package/src/eco/module-dependencies.test.ts +30 -0
  79. package/src/eco/module-dependencies.ts +75 -0
  80. package/src/errors/http-error.test.ts +134 -0
  81. package/src/errors/http-error.ts +72 -0
  82. package/src/errors/{index.d.ts → index.ts} +2 -2
  83. package/src/errors/locals-access-error.ts +7 -0
  84. package/src/global/app-logger.ts +4 -0
  85. package/src/global/utils.test.ts +12 -0
  86. 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
  87. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  88. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  89. package/src/hmr/client/hmr-runtime.ts +160 -0
  90. package/src/hmr/hmr-strategy.test.ts +124 -0
  91. package/src/hmr/hmr-strategy.ts +177 -0
  92. package/src/hmr/hmr.postcss.test.e2e.ts +41 -0
  93. package/src/hmr/hmr.test.e2e.ts +66 -0
  94. package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
  95. package/src/hmr/strategies/js-hmr-strategy.test.ts +335 -0
  96. package/src/hmr/strategies/js-hmr-strategy.ts +320 -0
  97. package/src/index.browser.ts +3 -0
  98. package/src/index.ts +15 -0
  99. package/src/integrations/ghtml/ghtml-renderer.test.ts +253 -0
  100. package/src/integrations/ghtml/ghtml-renderer.ts +97 -0
  101. package/src/integrations/ghtml/ghtml.constants.ts +1 -0
  102. package/src/integrations/ghtml/ghtml.plugin.ts +28 -0
  103. package/src/plugins/alias-resolver-plugin.test.ts +41 -0
  104. package/src/plugins/alias-resolver-plugin.ts +63 -0
  105. package/src/plugins/eco-component-meta-plugin.test.ts +406 -0
  106. package/src/plugins/eco-component-meta-plugin.ts +495 -0
  107. package/src/plugins/foreign-jsx-override-plugin.test.ts +65 -0
  108. package/src/plugins/foreign-jsx-override-plugin.ts +67 -0
  109. package/src/plugins/integration-plugin.test.ts +156 -0
  110. package/src/plugins/integration-plugin.ts +311 -0
  111. package/src/plugins/processor.test.ts +148 -0
  112. package/src/plugins/processor.ts +240 -0
  113. package/src/plugins/{runtime-capability.d.ts → runtime-capability.ts} +8 -3
  114. package/src/plugins/source-transform.test.ts +82 -0
  115. package/src/plugins/source-transform.ts +123 -0
  116. package/src/route-renderer/orchestration/boundary-planning.service.ts +146 -0
  117. package/src/route-renderer/orchestration/component-render-context.ts +318 -0
  118. package/src/route-renderer/orchestration/integration-renderer.test.ts +2088 -0
  119. package/src/route-renderer/orchestration/integration-renderer.ts +1285 -0
  120. package/src/route-renderer/orchestration/page-packaging.service.test.ts +76 -0
  121. package/src/route-renderer/orchestration/page-packaging.service.ts +85 -0
  122. package/src/route-renderer/orchestration/processed-asset-dedupe.ts +25 -0
  123. package/src/route-renderer/orchestration/queued-boundary-runtime.service.test.ts +319 -0
  124. package/src/route-renderer/orchestration/queued-boundary-runtime.service.ts +289 -0
  125. package/src/route-renderer/orchestration/render-execution.service.test.ts +196 -0
  126. package/src/route-renderer/orchestration/render-execution.service.ts +182 -0
  127. package/src/route-renderer/orchestration/render-output.utils.ts +302 -0
  128. package/src/route-renderer/orchestration/render-preparation.service.test.ts +569 -0
  129. package/src/route-renderer/orchestration/render-preparation.service.ts +508 -0
  130. package/src/route-renderer/orchestration/route-shell-composer.service.ts +162 -0
  131. package/src/route-renderer/orchestration/template-serialization.test.ts +110 -0
  132. package/src/route-renderer/orchestration/template-serialization.ts +117 -0
  133. package/src/route-renderer/page-loading/component-dependency-collection.ts +196 -0
  134. package/src/route-renderer/page-loading/declared-asset-collection.ts +156 -0
  135. package/src/route-renderer/page-loading/dependency-resolver.test.ts +665 -0
  136. package/src/route-renderer/page-loading/dependency-resolver.ts +150 -0
  137. package/src/route-renderer/page-loading/ecopages-virtual-imports.ts +75 -0
  138. package/src/route-renderer/page-loading/lazy-entry-collection.ts +167 -0
  139. package/src/route-renderer/page-loading/lazy-trigger-planning.ts +74 -0
  140. package/src/route-renderer/page-loading/module-declaration-aggregation.ts +60 -0
  141. package/src/route-renderer/page-loading/module-declaration-scripts.ts +16 -0
  142. package/src/route-renderer/page-loading/page-dependency-bundling.ts +205 -0
  143. package/src/route-renderer/page-loading/page-module-loader.test.ts +183 -0
  144. package/src/route-renderer/page-loading/page-module-loader.ts +184 -0
  145. package/src/route-renderer/route-renderer.ts +136 -0
  146. package/src/router/client/link-intent.test.browser.ts +51 -0
  147. package/src/router/client/link-intent.ts +92 -0
  148. package/src/router/client/navigation-coordinator.test.ts +237 -0
  149. package/src/router/client/navigation-coordinator.ts +453 -0
  150. package/src/router/server/fs-router-scanner.test.ts +83 -0
  151. package/src/router/server/fs-router-scanner.ts +224 -0
  152. package/src/router/server/fs-router.test.ts +214 -0
  153. package/src/router/server/fs-router.ts +122 -0
  154. package/src/services/assets/asset-processing-service/asset-dependency-keys.ts +66 -0
  155. package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +476 -0
  156. package/src/services/assets/asset-processing-service/asset-processing.service.ts +345 -0
  157. package/src/services/assets/asset-processing-service/asset.factory.test.ts +63 -0
  158. package/src/services/assets/asset-processing-service/asset.factory.ts +105 -0
  159. package/src/services/assets/asset-processing-service/assets.types.ts +125 -0
  160. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +74 -0
  161. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +96 -0
  162. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +67 -0
  163. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +78 -0
  164. package/src/services/assets/asset-processing-service/grouped-content-bundles.ts +104 -0
  165. package/src/services/assets/asset-processing-service/index.ts +5 -0
  166. package/src/services/assets/asset-processing-service/{processor.interface.d.ts → processor.interface.ts} +10 -5
  167. package/src/services/assets/asset-processing-service/processor.registry.ts +18 -0
  168. package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +59 -0
  169. package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +83 -0
  170. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +174 -0
  171. package/src/services/assets/asset-processing-service/processors/index.ts +5 -0
  172. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.test.ts +192 -0
  173. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +134 -0
  174. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +326 -0
  175. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +110 -0
  176. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.test.ts +227 -0
  177. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +87 -0
  178. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +261 -0
  179. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +71 -0
  180. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +81 -0
  181. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.ts +65 -0
  182. package/src/services/assets/browser-bundle.service.test.ts +66 -0
  183. package/src/services/assets/browser-bundle.service.ts +109 -0
  184. package/src/services/cache/cache.types.ts +126 -0
  185. package/src/services/cache/index.ts +18 -0
  186. package/src/services/cache/memory-cache-store.test.ts +225 -0
  187. package/src/services/cache/memory-cache-store.ts +130 -0
  188. package/src/services/cache/page-cache-service.test.ts +175 -0
  189. package/src/services/cache/page-cache-service.ts +202 -0
  190. package/src/services/cache/page-request-cache-coordinator.service.test.ts +79 -0
  191. package/src/services/cache/page-request-cache-coordinator.service.ts +131 -0
  192. package/src/services/html/html-rewriter-provider.service.test.ts +183 -0
  193. package/src/services/html/html-rewriter-provider.service.ts +104 -0
  194. package/src/services/html/html-transformer.service.test.ts +479 -0
  195. package/src/services/html/html-transformer.service.ts +275 -0
  196. package/src/services/invalidation/development-invalidation.service.test.ts +87 -0
  197. package/src/services/invalidation/development-invalidation.service.ts +262 -0
  198. package/src/services/module-loading/app-module-loader.service.ts +9 -0
  199. package/src/services/module-loading/app-server-module-transpiler.service.test.ts +130 -0
  200. package/src/services/module-loading/app-server-module-transpiler.service.ts +143 -0
  201. package/src/services/module-loading/host-module-loader-registry.ts +15 -0
  202. package/src/services/module-loading/{module-loading-types.d.ts → module-loading-types.ts} +1 -0
  203. package/src/services/module-loading/node-bootstrap-plugin.test.ts +335 -0
  204. package/src/services/module-loading/node-bootstrap-plugin.ts +297 -0
  205. package/src/services/module-loading/page-module-import.service.test.ts +504 -0
  206. package/src/services/module-loading/page-module-import.service.ts +252 -0
  207. package/src/services/module-loading/server-module-transpiler.service.test.ts +243 -0
  208. package/src/services/module-loading/server-module-transpiler.service.ts +104 -0
  209. package/src/services/module-loading/source-module-support.ts +19 -0
  210. package/src/services/runtime-state/dev-graph.service.ts +217 -0
  211. package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +136 -0
  212. package/src/services/runtime-state/runtime-specifier-registry.service.ts +96 -0
  213. package/src/services/runtime-state/server-invalidation-state.service.ts +68 -0
  214. package/src/services/validation/schema-validation-service.test.ts +223 -0
  215. package/src/services/validation/schema-validation-service.ts +204 -0
  216. package/src/services/validation/{standard-schema.types.d.ts → standard-schema.types.ts} +20 -17
  217. package/src/static-site-generator/static-site-generator.test.ts +316 -0
  218. package/src/static-site-generator/static-site-generator.ts +462 -0
  219. package/src/types/internal-types.ts +242 -0
  220. package/src/types/public-types.ts +1443 -0
  221. package/src/utils/deep-merge.test.ts +114 -0
  222. package/src/utils/deep-merge.ts +47 -0
  223. package/src/utils/hash.ts +5 -0
  224. package/src/utils/html-escaping.ts +9 -0
  225. package/src/utils/invariant.test.ts +22 -0
  226. package/src/utils/invariant.ts +15 -0
  227. package/src/utils/locals-utils.ts +37 -0
  228. package/src/utils/parse-cli-args.test.ts +69 -0
  229. package/src/utils/parse-cli-args.ts +105 -0
  230. package/src/utils/path-utils.module.ts +14 -0
  231. package/src/utils/path-utils.test.ts +15 -0
  232. package/src/utils/resolve-work-dir.ts +45 -0
  233. package/src/utils/runtime.ts +44 -0
  234. package/src/utils/server-utils.module.ts +67 -0
  235. package/src/utils/server-utils.test.ts +38 -0
  236. package/src/watchers/project-watcher.integration.test.ts +337 -0
  237. package/src/watchers/project-watcher.test-helpers.ts +41 -0
  238. package/src/watchers/project-watcher.test.ts +768 -0
  239. package/src/watchers/project-watcher.ts +357 -0
  240. package/CHANGELOG.md +0 -51
  241. package/src/adapters/abstract/application-adapter.d.ts +0 -194
  242. package/src/adapters/abstract/application-adapter.js +0 -121
  243. package/src/adapters/abstract/router-adapter.d.ts +0 -26
  244. package/src/adapters/abstract/router-adapter.js +0 -5
  245. package/src/adapters/abstract/server-adapter.d.ts +0 -69
  246. package/src/adapters/abstract/server-adapter.js +0 -15
  247. package/src/adapters/bun/client-bridge.d.ts +0 -34
  248. package/src/adapters/bun/client-bridge.js +0 -48
  249. package/src/adapters/bun/create-app.d.ts +0 -52
  250. package/src/adapters/bun/create-app.js +0 -116
  251. package/src/adapters/bun/hmr-manager.d.ts +0 -143
  252. package/src/adapters/bun/hmr-manager.js +0 -333
  253. package/src/adapters/bun/index.d.ts +0 -2
  254. package/src/adapters/bun/index.js +0 -8
  255. package/src/adapters/bun/server-adapter.d.ts +0 -155
  256. package/src/adapters/bun/server-adapter.js +0 -374
  257. package/src/adapters/bun/server-lifecycle.d.ts +0 -63
  258. package/src/adapters/bun/server-lifecycle.js +0 -92
  259. package/src/adapters/create-app.d.ts +0 -20
  260. package/src/adapters/create-app.js +0 -66
  261. package/src/adapters/index.d.ts +0 -2
  262. package/src/adapters/index.js +0 -8
  263. package/src/adapters/node/create-app.d.ts +0 -18
  264. package/src/adapters/node/create-app.js +0 -149
  265. package/src/adapters/node/node-client-bridge.d.ts +0 -26
  266. package/src/adapters/node/node-client-bridge.js +0 -66
  267. package/src/adapters/node/node-hmr-manager.d.ts +0 -133
  268. package/src/adapters/node/node-hmr-manager.js +0 -311
  269. package/src/adapters/node/server-adapter.d.ts +0 -161
  270. package/src/adapters/node/server-adapter.js +0 -359
  271. package/src/adapters/node/static-content-server.d.ts +0 -60
  272. package/src/adapters/node/static-content-server.js +0 -194
  273. package/src/adapters/shared/api-response.d.ts +0 -52
  274. package/src/adapters/shared/api-response.js +0 -96
  275. package/src/adapters/shared/application-adapter.d.ts +0 -18
  276. package/src/adapters/shared/application-adapter.js +0 -90
  277. package/src/adapters/shared/define-api-handler.d.ts +0 -25
  278. package/src/adapters/shared/define-api-handler.js +0 -15
  279. package/src/adapters/shared/explicit-static-route-matcher.d.ts +0 -38
  280. package/src/adapters/shared/explicit-static-route-matcher.js +0 -103
  281. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +0 -65
  282. package/src/adapters/shared/file-route-middleware-pipeline.js +0 -99
  283. package/src/adapters/shared/fs-server-response-factory.d.ts +0 -19
  284. package/src/adapters/shared/fs-server-response-factory.js +0 -97
  285. package/src/adapters/shared/fs-server-response-matcher.d.ts +0 -67
  286. package/src/adapters/shared/fs-server-response-matcher.js +0 -147
  287. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +0 -55
  288. package/src/adapters/shared/hmr-entrypoint-registrar.js +0 -87
  289. package/src/adapters/shared/hmr-html-response.d.ts +0 -22
  290. package/src/adapters/shared/hmr-html-response.js +0 -32
  291. package/src/adapters/shared/render-context.d.ts +0 -15
  292. package/src/adapters/shared/render-context.js +0 -72
  293. package/src/adapters/shared/runtime-bootstrap.d.ts +0 -38
  294. package/src/adapters/shared/runtime-bootstrap.js +0 -43
  295. package/src/adapters/shared/server-adapter.d.ts +0 -97
  296. package/src/adapters/shared/server-adapter.js +0 -390
  297. package/src/adapters/shared/server-route-handler.d.ts +0 -89
  298. package/src/adapters/shared/server-route-handler.js +0 -111
  299. package/src/adapters/shared/server-static-builder.d.ts +0 -70
  300. package/src/adapters/shared/server-static-builder.js +0 -100
  301. package/src/build/build-adapter.d.ts +0 -239
  302. package/src/build/build-adapter.js +0 -642
  303. package/src/build/build-manifest.d.ts +0 -27
  304. package/src/build/build-manifest.js +0 -30
  305. package/src/build/build-types.d.ts +0 -57
  306. package/src/build/build-types.js +0 -0
  307. package/src/build/dev-build-coordinator.d.ts +0 -72
  308. package/src/build/dev-build-coordinator.js +0 -154
  309. package/src/build/esbuild-build-adapter.d.ts +0 -78
  310. package/src/build/esbuild-build-adapter.js +0 -505
  311. package/src/build/runtime-build-executor.d.ts +0 -14
  312. package/src/build/runtime-build-executor.js +0 -22
  313. package/src/build/runtime-specifier-alias-plugin.d.ts +0 -15
  314. package/src/build/runtime-specifier-alias-plugin.js +0 -35
  315. package/src/build/runtime-specifier-aliases.d.ts +0 -5
  316. package/src/build/runtime-specifier-aliases.js +0 -95
  317. package/src/config/config-builder.d.ts +0 -252
  318. package/src/config/config-builder.js +0 -603
  319. package/src/config/constants.js +0 -25
  320. package/src/dev/sc-server.d.ts +0 -30
  321. package/src/dev/sc-server.js +0 -111
  322. package/src/eco/eco.browser.d.ts +0 -2
  323. package/src/eco/eco.browser.js +0 -83
  324. package/src/eco/eco.d.ts +0 -9
  325. package/src/eco/eco.js +0 -85
  326. package/src/eco/eco.types.d.ts +0 -178
  327. package/src/eco/eco.types.js +0 -0
  328. package/src/eco/eco.utils.d.ts +0 -1
  329. package/src/eco/eco.utils.js +0 -10
  330. package/src/eco/global-injector-map.d.ts +0 -16
  331. package/src/eco/global-injector-map.js +0 -80
  332. package/src/eco/lazy-injector-map.d.ts +0 -8
  333. package/src/eco/lazy-injector-map.js +0 -70
  334. package/src/eco/module-dependencies.d.ts +0 -18
  335. package/src/eco/module-dependencies.js +0 -49
  336. package/src/errors/http-error.d.ts +0 -31
  337. package/src/errors/http-error.js +0 -50
  338. package/src/errors/index.js +0 -4
  339. package/src/errors/locals-access-error.d.ts +0 -4
  340. package/src/errors/locals-access-error.js +0 -9
  341. package/src/global/app-logger.d.ts +0 -2
  342. package/src/global/app-logger.js +0 -6
  343. package/src/hmr/client/hmr-runtime.d.ts +0 -5
  344. package/src/hmr/client/hmr-runtime.js +0 -109
  345. package/src/hmr/hmr-strategy.d.ts +0 -162
  346. package/src/hmr/hmr-strategy.js +0 -44
  347. package/src/hmr/hmr.postcss.test.e2e.d.ts +0 -1
  348. package/src/hmr/hmr.postcss.test.e2e.js +0 -31
  349. package/src/hmr/hmr.test.e2e.d.ts +0 -1
  350. package/src/hmr/hmr.test.e2e.js +0 -43
  351. package/src/hmr/strategies/default-hmr-strategy.d.ts +0 -43
  352. package/src/hmr/strategies/default-hmr-strategy.js +0 -34
  353. package/src/hmr/strategies/js-hmr-strategy.d.ts +0 -139
  354. package/src/hmr/strategies/js-hmr-strategy.js +0 -178
  355. package/src/index.browser.d.ts +0 -3
  356. package/src/index.browser.js +0 -4
  357. package/src/index.d.ts +0 -6
  358. package/src/index.js +0 -21
  359. package/src/integrations/ghtml/ghtml-renderer.d.ts +0 -20
  360. package/src/integrations/ghtml/ghtml-renderer.js +0 -63
  361. package/src/integrations/ghtml/ghtml.constants.d.ts +0 -1
  362. package/src/integrations/ghtml/ghtml.constants.js +0 -4
  363. package/src/integrations/ghtml/ghtml.plugin.d.ts +0 -16
  364. package/src/integrations/ghtml/ghtml.plugin.js +0 -20
  365. package/src/plugins/alias-resolver-plugin.d.ts +0 -2
  366. package/src/plugins/alias-resolver-plugin.js +0 -53
  367. package/src/plugins/eco-component-meta-plugin.d.ts +0 -108
  368. package/src/plugins/eco-component-meta-plugin.js +0 -163
  369. package/src/plugins/foreign-jsx-override-plugin.d.ts +0 -31
  370. package/src/plugins/foreign-jsx-override-plugin.js +0 -35
  371. package/src/plugins/integration-plugin.d.ts +0 -219
  372. package/src/plugins/integration-plugin.js +0 -196
  373. package/src/plugins/processor.d.ts +0 -95
  374. package/src/plugins/processor.js +0 -136
  375. package/src/plugins/runtime-capability.js +0 -0
  376. package/src/plugins/source-transform.d.ts +0 -46
  377. package/src/plugins/source-transform.js +0 -71
  378. package/src/route-renderer/orchestration/boundary-planning.service.d.ts +0 -25
  379. package/src/route-renderer/orchestration/boundary-planning.service.js +0 -97
  380. package/src/route-renderer/orchestration/component-render-context.d.ts +0 -83
  381. package/src/route-renderer/orchestration/component-render-context.js +0 -147
  382. package/src/route-renderer/orchestration/integration-renderer.d.ts +0 -554
  383. package/src/route-renderer/orchestration/integration-renderer.js +0 -957
  384. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +0 -89
  385. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +0 -155
  386. package/src/route-renderer/orchestration/render-execution.service.d.ts +0 -43
  387. package/src/route-renderer/orchestration/render-execution.service.js +0 -106
  388. package/src/route-renderer/orchestration/render-output.utils.d.ts +0 -46
  389. package/src/route-renderer/orchestration/render-output.utils.js +0 -65
  390. package/src/route-renderer/orchestration/render-preparation.service.d.ts +0 -120
  391. package/src/route-renderer/orchestration/render-preparation.service.js +0 -341
  392. package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +0 -50
  393. package/src/route-renderer/orchestration/route-shell-composer.service.js +0 -81
  394. package/src/route-renderer/orchestration/template-serialization.d.ts +0 -38
  395. package/src/route-renderer/orchestration/template-serialization.js +0 -45
  396. package/src/route-renderer/page-loading/dependency-resolver.d.ts +0 -35
  397. package/src/route-renderer/page-loading/dependency-resolver.js +0 -444
  398. package/src/route-renderer/page-loading/page-module-loader.d.ts +0 -90
  399. package/src/route-renderer/page-loading/page-module-loader.js +0 -127
  400. package/src/route-renderer/route-renderer.d.ts +0 -67
  401. package/src/route-renderer/route-renderer.js +0 -103
  402. package/src/router/client/link-intent.js +0 -34
  403. package/src/router/client/link-intent.test.browser.d.ts +0 -1
  404. package/src/router/client/link-intent.test.browser.js +0 -43
  405. package/src/router/client/navigation-coordinator.d.ts +0 -149
  406. package/src/router/client/navigation-coordinator.js +0 -215
  407. package/src/router/server/fs-router-scanner.d.ts +0 -41
  408. package/src/router/server/fs-router-scanner.js +0 -161
  409. package/src/router/server/fs-router.d.ts +0 -26
  410. package/src/router/server/fs-router.js +0 -100
  411. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +0 -120
  412. package/src/services/assets/asset-processing-service/asset-processing.service.js +0 -331
  413. package/src/services/assets/asset-processing-service/asset.factory.d.ts +0 -17
  414. package/src/services/assets/asset-processing-service/asset.factory.js +0 -82
  415. package/src/services/assets/asset-processing-service/assets.types.d.ts +0 -89
  416. package/src/services/assets/asset-processing-service/assets.types.js +0 -0
  417. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +0 -55
  418. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +0 -48
  419. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +0 -20
  420. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +0 -41
  421. package/src/services/assets/asset-processing-service/index.d.ts +0 -5
  422. package/src/services/assets/asset-processing-service/index.js +0 -5
  423. package/src/services/assets/asset-processing-service/processor.interface.js +0 -6
  424. package/src/services/assets/asset-processing-service/processor.registry.d.ts +0 -8
  425. package/src/services/assets/asset-processing-service/processor.registry.js +0 -15
  426. package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +0 -24
  427. package/src/services/assets/asset-processing-service/processors/base/base-processor.js +0 -64
  428. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +0 -17
  429. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +0 -72
  430. package/src/services/assets/asset-processing-service/processors/index.d.ts +0 -5
  431. package/src/services/assets/asset-processing-service/processors/index.js +0 -5
  432. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +0 -5
  433. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +0 -57
  434. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +0 -9
  435. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +0 -88
  436. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
  437. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +0 -75
  438. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +0 -5
  439. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  440. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +0 -9
  441. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +0 -66
  442. package/src/services/assets/browser-bundle.service.d.ts +0 -32
  443. package/src/services/assets/browser-bundle.service.js +0 -33
  444. package/src/services/cache/cache.types.d.ts +0 -107
  445. package/src/services/cache/cache.types.js +0 -0
  446. package/src/services/cache/index.d.ts +0 -7
  447. package/src/services/cache/index.js +0 -7
  448. package/src/services/cache/memory-cache-store.d.ts +0 -42
  449. package/src/services/cache/memory-cache-store.js +0 -98
  450. package/src/services/cache/page-cache-service.d.ts +0 -70
  451. package/src/services/cache/page-cache-service.js +0 -152
  452. package/src/services/cache/page-request-cache-coordinator.service.d.ts +0 -75
  453. package/src/services/cache/page-request-cache-coordinator.service.js +0 -109
  454. package/src/services/html/html-rewriter-provider.service.d.ts +0 -37
  455. package/src/services/html/html-rewriter-provider.service.js +0 -68
  456. package/src/services/html/html-transformer.service.d.ts +0 -77
  457. package/src/services/html/html-transformer.service.js +0 -215
  458. package/src/services/invalidation/development-invalidation.service.d.ts +0 -74
  459. package/src/services/invalidation/development-invalidation.service.js +0 -190
  460. package/src/services/module-loading/app-module-loader.service.d.ts +0 -28
  461. package/src/services/module-loading/app-module-loader.service.js +0 -35
  462. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +0 -24
  463. package/src/services/module-loading/app-server-module-transpiler.service.js +0 -109
  464. package/src/services/module-loading/host-module-loader-registry.d.ts +0 -4
  465. package/src/services/module-loading/host-module-loader-registry.js +0 -15
  466. package/src/services/module-loading/module-loading-types.js +0 -0
  467. package/src/services/module-loading/node-bootstrap-plugin.d.ts +0 -42
  468. package/src/services/module-loading/node-bootstrap-plugin.js +0 -204
  469. package/src/services/module-loading/page-module-import.service.d.ts +0 -76
  470. package/src/services/module-loading/page-module-import.service.js +0 -173
  471. package/src/services/module-loading/server-module-transpiler.service.d.ts +0 -72
  472. package/src/services/module-loading/server-module-transpiler.service.js +0 -64
  473. package/src/services/runtime-state/dev-graph.service.d.ts +0 -118
  474. package/src/services/runtime-state/dev-graph.service.js +0 -162
  475. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +0 -41
  476. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +0 -85
  477. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +0 -69
  478. package/src/services/runtime-state/runtime-specifier-registry.service.js +0 -37
  479. package/src/services/runtime-state/server-invalidation-state.service.d.ts +0 -26
  480. package/src/services/runtime-state/server-invalidation-state.service.js +0 -35
  481. package/src/services/validation/schema-validation-service.d.ts +0 -122
  482. package/src/services/validation/schema-validation-service.js +0 -101
  483. package/src/services/validation/standard-schema.types.js +0 -0
  484. package/src/static-site-generator/static-site-generator.d.ts +0 -104
  485. package/src/static-site-generator/static-site-generator.js +0 -338
  486. package/src/types/internal-types.d.ts +0 -231
  487. package/src/types/internal-types.js +0 -0
  488. package/src/types/public-types.d.ts +0 -1219
  489. package/src/types/public-types.js +0 -0
  490. package/src/utils/deep-merge.d.ts +0 -14
  491. package/src/utils/deep-merge.js +0 -32
  492. package/src/utils/hash.d.ts +0 -1
  493. package/src/utils/hash.js +0 -7
  494. package/src/utils/html-escaping.d.ts +0 -7
  495. package/src/utils/html-escaping.js +0 -6
  496. package/src/utils/html.js +0 -4
  497. package/src/utils/invariant.d.ts +0 -5
  498. package/src/utils/invariant.js +0 -11
  499. package/src/utils/locals-utils.d.ts +0 -15
  500. package/src/utils/locals-utils.js +0 -24
  501. package/src/utils/parse-cli-args.d.ts +0 -27
  502. package/src/utils/parse-cli-args.js +0 -62
  503. package/src/utils/path-utils.module.d.ts +0 -5
  504. package/src/utils/path-utils.module.js +0 -14
  505. package/src/utils/resolve-work-dir.d.ts +0 -11
  506. package/src/utils/resolve-work-dir.js +0 -31
  507. package/src/utils/runtime.d.ts +0 -11
  508. package/src/utils/runtime.js +0 -40
  509. package/src/utils/server-utils.module.d.ts +0 -19
  510. package/src/utils/server-utils.module.js +0 -56
  511. package/src/watchers/project-watcher.d.ts +0 -136
  512. package/src/watchers/project-watcher.js +0 -275
  513. package/src/watchers/project-watcher.test-helpers.d.ts +0 -4
  514. package/src/watchers/project-watcher.test-helpers.js +0 -52
  515. /package/src/utils/{html.d.ts → html.ts} +0 -0
@@ -0,0 +1,357 @@
1
+ import path from 'node:path';
2
+ import chokidar, { type FSWatcher } from 'chokidar';
3
+ import { fileSystem } from '@ecopages/file-system';
4
+ import { appLogger } from '../global/app-logger.ts';
5
+ import type { EcoPagesAppConfig, IHmrManager, IClientBridge } from '../types/internal-types.ts';
6
+ import type { ProcessorWatchConfig, ProcessorWatchContext } from '../plugins/processor.ts';
7
+ import { DevelopmentInvalidationService } from '../services/invalidation/development-invalidation.service.ts';
8
+
9
+ /**
10
+ * Configuration options for the ProjectWatcher
11
+ * @interface ProjectWatcherConfig
12
+ * @property {EcoPagesAppConfig} config - The application configuration
13
+ * @property {() => Promise<void>} refreshRouterRoutesCallback - Callback to refresh router routes
14
+ * @property {IHmrManager} hmrManager - The HMR manager instance
15
+ * @property {ClientBridge} bridge - The client bridge instance
16
+ */
17
+ export interface ProjectWatcherConfig {
18
+ config: EcoPagesAppConfig;
19
+ refreshRouterRoutesCallback: () => Promise<void>;
20
+ hmrManager: IHmrManager;
21
+ bridge: IClientBridge;
22
+ }
23
+
24
+ /**
25
+ * ProjectWatcher handles file system changes for hot module replacement (HMR).
26
+ * It uses chokidar to watch for file changes and triggers appropriate actions:
27
+ * - Uncaches modules when files change
28
+ * - Refreshes router routes for page files
29
+ * - Triggers HMR server reload
30
+ * - Handles processor-specific file changes
31
+ *
32
+ * The watcher uses chokidar's built-in debouncing through `awaitWriteFinish`
33
+ * to handle rapid file changes efficiently:
34
+ * - stabilityThreshold: 50ms - Time to wait for writes to stabilize
35
+ * - pollInterval: 50ms - Interval to poll for file changes
36
+ *
37
+ * @class ProjectWatcher
38
+ */
39
+ export class ProjectWatcher {
40
+ /**
41
+ * Duplicate identical watcher events within this window are ignored.
42
+ *
43
+ * Some editors or save pipelines emit two near-identical filesystem change
44
+ * notifications for the same file. Ecopages should treat those as one logical
45
+ * update so HMR and route refresh work are not repeated unnecessarily.
46
+ */
47
+ private static readonly duplicateChangeWindowMs = 150;
48
+ private appConfig: EcoPagesAppConfig;
49
+ private refreshRouterRoutesCallback: () => Promise<void>;
50
+ private hmrManager: IHmrManager;
51
+ private bridge: IClientBridge;
52
+ private readonly invalidationService: DevelopmentInvalidationService;
53
+ private watcher: FSWatcher | null = null;
54
+ private lastHandledChange = new Map<string, number>();
55
+ private changeQueue: Promise<void> = Promise.resolve();
56
+
57
+ constructor({ config, refreshRouterRoutesCallback, hmrManager, bridge }: ProjectWatcherConfig) {
58
+ this.appConfig = config;
59
+ this.refreshRouterRoutesCallback = refreshRouterRoutesCallback;
60
+ this.hmrManager = hmrManager;
61
+ this.bridge = bridge;
62
+ this.invalidationService = new DevelopmentInvalidationService(config);
63
+ this.triggerRouterRefresh = this.triggerRouterRefresh.bind(this);
64
+ this.handleError = this.handleError.bind(this);
65
+ this.handleFileChange = this.handleFileChange.bind(this);
66
+ }
67
+
68
+ /**
69
+ * Uncaches modules in the source directory to ensure fresh imports.
70
+ * This is necessary for hot module replacement to work correctly.
71
+ * @private
72
+ */
73
+ private uncacheModules(): void {
74
+ if (typeof require === 'undefined') return;
75
+
76
+ const { srcDir, rootDir } = this.appConfig;
77
+ const regex = new RegExp(`${rootDir}/${srcDir}/.*`);
78
+
79
+ for (const key in require.cache) {
80
+ if (regex.test(key)) {
81
+ delete require.cache[key];
82
+ }
83
+ }
84
+ }
85
+
86
+ private isRouteSourceFile(filePath: string): boolean {
87
+ return this.invalidationService.isRouteSourceFile(filePath);
88
+ }
89
+
90
+ private isIncludeSourceFile(filePath: string): boolean {
91
+ return this.invalidationService.isIncludeSourceFile(filePath);
92
+ }
93
+
94
+ /**
95
+ * Handles public directory file changes by copying only the changed file.
96
+ * @param filePath - Absolute path of the changed file
97
+ */
98
+ private async handlePublicDirFileChange(filePath: string): Promise<void> {
99
+ try {
100
+ const relativePath = path.relative(this.appConfig.absolutePaths.publicDir, filePath);
101
+ const destPath = path.join(this.appConfig.absolutePaths.distDir, relativePath);
102
+
103
+ if (fileSystem.exists(filePath)) {
104
+ const destDir = path.dirname(destPath);
105
+ fileSystem.ensureDir(destDir);
106
+ await fileSystem.copyFileAsync(filePath, destPath);
107
+ }
108
+
109
+ this.bridge.reload();
110
+ } catch (error) {
111
+ appLogger.error(`Failed to copy public file: ${error instanceof Error ? error.message : String(error)}`);
112
+ this.bridge.reload();
113
+ }
114
+ }
115
+
116
+ /**
117
+ * Serializes file change handling so that concurrent chokidar events are
118
+ * processed one at a time, preventing overlapping builds and race conditions.
119
+ */
120
+ private enqueueChange(task: () => Promise<void>): void {
121
+ const queuedTask = this.changeQueue.then(task, task);
122
+ this.changeQueue = queuedTask.catch(() => undefined);
123
+ }
124
+
125
+ /**
126
+ * Handles file changes by uncaching modules, refreshing routes, and delegating appropriately.
127
+ * Follows 5-rule priority:
128
+ * 0. Public directory match? -> copy file and reload
129
+ * 1. additionalWatchPaths match? -> reload
130
+ * 2. Include template source? -> reload after processor notifications
131
+ * 3. Processor-owned asset? -> processor already handled it via notification, skip HMR
132
+ * 4. Otherwise -> HMR strategies
133
+ *
134
+ * Processors that watch a file extension as a dependency (e.g. PostCSS watching
135
+ * .tsx for Tailwind class scanning) are always notified first, but do not
136
+ * prevent the file from flowing through the normal HMR strategy pipeline.
137
+ *
138
+ * Duplicate identical watcher events for the same file are coalesced within a
139
+ * short window before any of the priority rules run.
140
+ * @param rawPath - Path of the changed file
141
+ * @param event - The type of file system event
142
+ */
143
+ private async handleFileChange(rawPath: string, event: 'change' | 'add' | 'unlink' = 'change'): Promise<void> {
144
+ const filePath = path.resolve(rawPath);
145
+ const now = Date.now();
146
+ const lastHandledAt = this.lastHandledChange.get(filePath);
147
+ if (lastHandledAt !== undefined && now - lastHandledAt < ProjectWatcher.duplicateChangeWindowMs) {
148
+ return;
149
+ }
150
+ this.lastHandledChange.set(filePath, now);
151
+
152
+ try {
153
+ const plan = this.invalidationService.planFileChange(filePath);
154
+
155
+ if (plan.category === 'public-asset') {
156
+ await this.handlePublicDirFileChange(filePath);
157
+ return;
158
+ }
159
+
160
+ this.uncacheModules();
161
+ if (plan.invalidateServerModules) {
162
+ this.invalidationService.invalidateServerModules([filePath]);
163
+ }
164
+
165
+ if (plan.refreshRoutes) {
166
+ await this.refreshRouterRoutesCallback();
167
+ }
168
+
169
+ if (plan.category === 'additional-watch') {
170
+ this.bridge.reload();
171
+ return;
172
+ }
173
+
174
+ await this.notifyProcessors(filePath, event);
175
+
176
+ if (plan.category === 'include-source') {
177
+ this.bridge.reload();
178
+ return;
179
+ }
180
+
181
+ if (plan.processorHandledAsset) {
182
+ return;
183
+ }
184
+
185
+ if (plan.delegateToHmr) {
186
+ await this.hmrManager.handleFileChange(filePath);
187
+ }
188
+ } catch (error) {
189
+ if (error instanceof Error) {
190
+ this.bridge.error(error.message);
191
+ this.handleError(error);
192
+ }
193
+ }
194
+ }
195
+
196
+ /**
197
+ * Notifies all processors whose watch config matches the given file extension.
198
+ * This is called before checking processor ownership so that dependency-only
199
+ * processors (e.g. PostCSS watching .tsx for class scanning) receive their
200
+ * notifications regardless of whether they own the file.
201
+ */
202
+ private async notifyProcessors(filePath: string, event: 'change' | 'add' | 'unlink'): Promise<void> {
203
+ const ctx: ProcessorWatchContext = { path: filePath, bridge: this.bridge };
204
+
205
+ for (const processor of this.appConfig.processors.values()) {
206
+ const watchConfig = processor.getWatchConfig();
207
+ if (!watchConfig) continue;
208
+
209
+ const { extensions = [] } = watchConfig;
210
+ if (extensions.length && !extensions.some((ext) => filePath.endsWith(ext))) {
211
+ continue;
212
+ }
213
+
214
+ const handler = this.getProcessorHandler(watchConfig, event);
215
+ if (handler) {
216
+ await handler(ctx);
217
+ }
218
+ }
219
+ }
220
+
221
+ private getProcessorHandler(
222
+ watchConfig: ProcessorWatchConfig,
223
+ event: 'change' | 'add' | 'unlink',
224
+ ): ((ctx: ProcessorWatchContext) => Promise<void>) | undefined {
225
+ switch (event) {
226
+ case 'change':
227
+ return watchConfig.onChange;
228
+ case 'add':
229
+ return watchConfig.onCreate;
230
+ case 'unlink':
231
+ return watchConfig.onDelete;
232
+ }
233
+ }
234
+
235
+ /**
236
+ * Checks if a file is in the public directory.
237
+ */
238
+ private isPublicDirFile(filePath: string): boolean {
239
+ return this.invalidationService.isPublicDirFile(filePath);
240
+ }
241
+
242
+ /**
243
+ * Checks if file path matches any additionalWatchPaths patterns.
244
+ */
245
+ private matchesAdditionalWatchPaths(filePath: string): boolean {
246
+ return this.invalidationService.matchesAdditionalWatchPaths(filePath);
247
+ }
248
+
249
+ /**
250
+ * Checks if a file is handled by a processor.
251
+ * Processors that declare asset capabilities own those file types.
252
+ * Processors without capabilities fall back to checking watch extensions.
253
+ */
254
+ private isHandledByProcessor(filePath: string): boolean {
255
+ return this.invalidationService.isProcessorOwnedAsset(filePath);
256
+ }
257
+
258
+ /**
259
+ * Triggers router refresh for page directory changes.
260
+ * This ensures the router is updated when pages are added or removed.
261
+ *
262
+ * @param {string} path - Path of the changed directory
263
+ */
264
+ async triggerRouterRefresh(changedPath: string): Promise<void> {
265
+ const resolvedPath = path.resolve(changedPath);
266
+ const isPageDir =
267
+ resolvedPath.startsWith(this.appConfig.absolutePaths.pagesDir) && path.extname(resolvedPath) === '';
268
+
269
+ if (isPageDir || this.isRouteSourceFile(resolvedPath)) {
270
+ await this.refreshRouterRoutesCallback();
271
+ }
272
+ }
273
+
274
+ /**
275
+ * Handles and logs errors that occur during file watching.
276
+ *
277
+ * @param {unknown} error - The error to handle
278
+ */
279
+ handleError(error: unknown) {
280
+ if (error instanceof Error) {
281
+ this.hmrManager.broadcast({ type: 'error', message: error.message });
282
+ }
283
+ appLogger.error(`Watcher error: ${error}`);
284
+ }
285
+
286
+ /**
287
+ * Creates and configures the file system watcher.
288
+ * This sets up:
289
+ * 1. Page file watching
290
+ * 2. Directory watching
291
+ * 3. Error handling
292
+ *
293
+ * Processor notifications are dispatched inside handleFileChange, ensuring
294
+ * a single unified event pipeline with no parallel chokidar bindings.
295
+ *
296
+ * Uses chokidar's built-in debouncing through `awaitWriteFinish` to handle
297
+ * rapid file changes efficiently.
298
+ */
299
+ public async createWatcherSubscription() {
300
+ if (this.watcher) {
301
+ return this.watcher;
302
+ }
303
+
304
+ const processorPaths: string[] = [];
305
+ for (const processor of this.appConfig.processors.values()) {
306
+ const watchConfig = processor.getWatchConfig();
307
+ if (!watchConfig) continue;
308
+ processorPaths.push(...watchConfig.paths);
309
+ }
310
+
311
+ if (fileSystem.exists(this.appConfig.absolutePaths.includesDir)) {
312
+ processorPaths.push(this.appConfig.absolutePaths.includesDir);
313
+ }
314
+
315
+ if (fileSystem.exists(this.appConfig.absolutePaths.srcDir)) {
316
+ processorPaths.push(this.appConfig.absolutePaths.srcDir);
317
+ }
318
+
319
+ if (fileSystem.exists(this.appConfig.absolutePaths.pagesDir)) {
320
+ processorPaths.push(this.appConfig.absolutePaths.pagesDir);
321
+ }
322
+
323
+ if (fileSystem.exists(this.appConfig.absolutePaths.publicDir)) {
324
+ processorPaths.push(this.appConfig.absolutePaths.publicDir);
325
+ }
326
+
327
+ if (this.appConfig.additionalWatchPaths.length) {
328
+ processorPaths.push(...this.appConfig.additionalWatchPaths);
329
+ }
330
+
331
+ this.watcher = chokidar.watch(processorPaths, {
332
+ ignoreInitial: true,
333
+ ignorePermissionErrors: true,
334
+ awaitWriteFinish: {
335
+ stabilityThreshold: 50,
336
+ pollInterval: 50,
337
+ },
338
+ });
339
+
340
+ this.watcher
341
+ .on('change', (p) => this.enqueueChange(() => this.handleFileChange(p, 'change')))
342
+ .on('add', (p) => this.enqueueChange(() => this.handleFileChange(p, 'add')))
343
+ .on('addDir', (p) => this.enqueueChange(() => this.triggerRouterRefresh(p)))
344
+ .on('unlink', (p) => this.enqueueChange(() => this.handleFileChange(p, 'unlink')))
345
+ .on('unlinkDir', (p) => this.enqueueChange(() => this.triggerRouterRefresh(p)))
346
+ .on('error', (error) => this.handleError(error));
347
+
348
+ for (const processor of this.appConfig.processors.values()) {
349
+ const watchConfig = processor.getWatchConfig();
350
+ if (watchConfig?.onError) {
351
+ this.watcher.on('error', watchConfig.onError as (error: unknown) => void);
352
+ }
353
+ }
354
+
355
+ return this.watcher;
356
+ }
357
+ }
package/CHANGELOG.md DELETED
@@ -1,51 +0,0 @@
1
- # Changelog
2
-
3
- All notable changes to `@ecopages/core` are documented here.
4
-
5
- > **Note:** Changelog tracking begins at version `0.2.0`. Changes prior to this release are not recorded here but are available in the git history.
6
-
7
- ## [UNRELEASED] — TBD
8
-
9
- ### Features
10
-
11
- - Added app-owned runtime and build ownership around `createApp()`, host module loading, the browser-safe `eco` export, `eco.html()`, `eco.layout()`, and the published `EcoPagesAppConfig` surface.
12
- - Added boundary-plan metadata and a compatibility `renderBoundary()` payload contract for mixed-renderer orchestration.
13
-
14
- ### Refactoring
15
-
16
- - Consolidated runtime state around shared module-loading services, app-owned build execution, and the universal `createApp()` boundary.
17
- - Simplified route-renderer orchestration around renderer-owned boundary runtimes, shared string-boundary queue helpers, and a smaller component render context.
18
- - Centralized shared integration renderer bootstrapping so package integrations only append renderer-specific config instead of duplicating core lifecycle wiring.
19
- - Moved shared queued boundary resolution to attachment-policy payloads and constructor-injectable planning services.
20
- - Extracted shared page, layout, and document-shell composition into a narrow `RouteShellComposer` while keeping renderer-owned boundary handoff in `IntegrationRenderer`.
21
- - Removed marker-era compatibility capture, the shared route-level fallback resolver, deprecated `@ecopages/core/node*` escape hatches, and other dead route-renderer internals.
22
-
23
- ### Bug Fixes
24
-
25
- - Fixed mixed-integration page, layout, document, and component rendering to resolve foreign boundaries inside their owning renderer across the built-in integrations.
26
- - Fixed host/runtime module loading, published build-helper exports, asset output normalization, explicit render flows, and static or preview build stability across Bun, Node, Vite, and Nitro.
27
- - Fixed development project watcher setup to register chokidar paths and handlers only once per app runtime.
28
- - Fixed development script-entry registration to build only the requested HMR entrypoint instead of fanning out across all watched script entrypoints during startup.
29
- - Fixed Node bootstrap runtime package linking to refresh dangling `.eco/node_modules` symlinks instead of failing with `EEXIST` during page transpilation.
30
- - Fixed request-time and static-generation page inspection to preserve integration-specific page loading without reusing the normal render module identity.
31
- - Fixed Node preview and static-generation React runtime resolution so app-owned page modules and server rendering share one React module identity.
32
- - Fixed Bun browser output normalization so batched multi-entrypoint HMR rebuilds match emitted files to their expected served paths instead of Bun output order.
33
- - Fixed render-preparation graph traversal so sparse component dependency arrays do not break custom 404 rendering or file-system response fallback flows.
34
-
35
- ### Documentation
36
-
37
- - Added architecture and API documentation for config, plugins, services, adapters, HMR, routing, and rendering.
38
-
39
- ### Tests
40
-
41
- - Added regression coverage for app-owned runtime services, Node fallback paths, and cross-runtime invalidation behavior.
42
- - Strengthened the core ghtml integration tests so route and explicit render paths await real outcomes and cover `renderToResponse` behavior.
43
- - Added core regression coverage for boundary plans, payload contracts, and typed mixed-boundary context flow.
44
-
45
- ---
46
-
47
- ## Migration Notes
48
-
49
- - `createApp` is now the recommended entrypoint. Import it from `@ecopages/core/create-app`.
50
- - `defineApiHandler` keeps the same call shape, but the handler context is now explicitly runtime-agnostic.
51
- - The old explicit `renderingMode` config option has been removed and full orchestration is always active.
@@ -1,194 +0,0 @@
1
- /**
2
- * This file defines the abstract class for application adapters in EcoPages.
3
- * It provides a common interface for different runtimes (e.g., Node.js, Deno) to implement.
4
- * The class includes methods for handling HTTP requests and managing application state.
5
- * It also includes a method for parsing command-line arguments.
6
- *
7
- * @module ApplicationAdapter
8
- */
9
- import type { SourceModuleLoader } from '../../services/module-loading/module-loading-types.js';
10
- import type { EcoPagesAppConfig } from '../../types/internal-types.js';
11
- import type { ApiHandler, ApiHandlerContext, ErrorHandler, Middleware, RouteOptions, StaticRoute, ViewLoader } from '../../types/public-types.js';
12
- import { type ReturnParseCliArgs } from '../../utils/parse-cli-args.js';
13
- /**
14
- * Runtime bootstrap options layered on top of the app config.
15
- *
16
- * These options let a host runtime embed Ecopages without mutating process
17
- * globals or app runtime state before calling `createApp()`.
18
- */
19
- export interface ApplicationRuntimeOptions {
20
- /**
21
- * Forces the app into the embedded-runtime CLI mode used by host
22
- * environments.
23
- *
24
- * When enabled and no explicit `hostModuleLoader` is provided, the
25
- * adapter auto-detects a host module loader from the global scope.
26
- */
27
- embedded?: boolean;
28
- /**
29
- * Explicit source module loader for request-time imports.
30
- *
31
- * When omitted in embedded mode, the adapter attempts automatic
32
- * detection from globals set by the host environment.
33
- */
34
- hostModuleLoader?: SourceModuleLoader;
35
- }
36
- /**
37
- * Configuration options for application adapters
38
- */
39
- export interface ApplicationAdapterOptions {
40
- appConfig: EcoPagesAppConfig;
41
- serverOptions?: Record<string, any>;
42
- runtime?: ApplicationRuntimeOptions;
43
- /**
44
- * Options for clearing the output directory before starting the server
45
- * @default false
46
- */
47
- clearOutput?: boolean;
48
- }
49
- /**
50
- * Common interface for application adapters
51
- */
52
- export interface ApplicationAdapter<T = any> {
53
- start(): Promise<T | void>;
54
- }
55
- /**
56
- * Handler function type for route handlers
57
- */
58
- export type RouteHandler<TRequest extends Request = Request, TServer = any, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>> = (context: TContext) => Promise<Response> | Response;
59
- export type RouteGroupDefinition<TRequest extends Request = Request, TServer = any> = {
60
- prefix: string;
61
- middleware?: readonly Middleware<TRequest, TServer, any>[];
62
- routes: readonly ApiHandler<string, TRequest, TServer>[];
63
- };
64
- /**
65
- * Abstract base class for application adapters across different runtimes
66
- */
67
- export declare abstract class AbstractApplicationAdapter<TOptions extends ApplicationAdapterOptions = ApplicationAdapterOptions, TServer = any, TRequest extends Request = any> implements ApplicationAdapter<TServer> {
68
- protected appConfig: EcoPagesAppConfig;
69
- protected serverOptions: Record<string, any>;
70
- protected cliArgs: ReturnParseCliArgs;
71
- protected runtimeOptions: ApplicationRuntimeOptions;
72
- protected apiHandlers: ApiHandler[];
73
- protected staticRoutes: StaticRoute[];
74
- protected errorHandler?: ErrorHandler;
75
- constructor(options: TOptions);
76
- private clearDistFolder;
77
- /**
78
- * Register a GET route handler.
79
- *
80
- * Use verb methods for inline route definitions.
81
- * For dynamic HTTP method registration, use `route(...)`.
82
- */
83
- abstract get<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
84
- /**
85
- * Register a POST route handler
86
- */
87
- abstract post<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
88
- /**
89
- * Register a PUT route handler
90
- */
91
- abstract put<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
92
- /**
93
- * Register a DELETE route handler
94
- */
95
- abstract delete<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
96
- /**
97
- * Register a PATCH route handler
98
- */
99
- abstract patch<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
100
- /**
101
- * Register an OPTIONS route handler
102
- */
103
- abstract options<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
104
- /**
105
- * Register a HEAD route handler
106
- */
107
- abstract head<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
108
- /**
109
- * Register a route with an explicit HTTP method.
110
- *
111
- * This is useful when the method is determined programmatically, or when
112
- * registering a pre-built route declaration object by forwarding its
113
- * `path`, `method`, and `handler` fields.
114
- */
115
- abstract route<P extends string>(path: P, method: ApiHandler['method'], handler: RouteHandler<TRequest, TServer>, options?: RouteOptions<TRequest, TServer>): this;
116
- /**
117
- * Register a pre-built API handler declaration.
118
- */
119
- abstract add(handler: ApiHandler<string, TRequest, TServer>): this;
120
- /**
121
- * Internal method to add route handlers to the API handlers array
122
- */
123
- protected addRouteHandler<P extends string, TSpecRequest extends TRequest = TRequest, TSpecServer extends TServer = TServer, TContext extends ApiHandlerContext<TSpecRequest, TSpecServer> = ApiHandlerContext<TSpecRequest, TSpecServer>>(path: P, method: ApiHandler['method'], handler: RouteHandler<TSpecRequest, TSpecServer, TContext>, middleware?: Middleware<TSpecRequest, TSpecServer, TContext>[], schema?: ApiHandler['schema']): this;
124
- /**
125
- * Create a route group with shared prefix and middleware.
126
- * Routes defined within the group inherit the prefix and middleware.
127
- *
128
- * Each adapter implements this with its own builder type to support
129
- * runtime-specific features (e.g., Bun's path parameter inference).
130
- * Implementations may also support passing a pre-built group object.
131
- *
132
- * @param prefix - URL prefix for all routes in the group (e.g., '/api/v1')
133
- * @param callback - Function that receives a builder to define routes
134
- * @param options - Optional group-level middleware
135
- */
136
- abstract group(prefix: string, callback: (builder: unknown) => void, options?: {
137
- middleware?: readonly Middleware<TRequest, TServer, any>[];
138
- }): this;
139
- abstract group(group: RouteGroupDefinition<TRequest, TServer>): this;
140
- /**
141
- * Get all registered API handlers
142
- */
143
- getApiHandlers(): ApiHandler[];
144
- /**
145
- * Register a view for static generation at build time.
146
- * The view must have staticPaths defined for dynamic routes.
147
- *
148
- * Uses a loader function to enable HMR in development.
149
- *
150
- * @param path - URL path pattern (e.g., '/posts/:slug')
151
- * @param loader - A function that dynamically imports the eco.page view module
152
- * @example
153
- * ```typescript
154
- * app.static('/login', () => import('./src/views/login.kita'))
155
- * app.static('/posts/:slug', () => import('./src/views/post-view.kita'))
156
- * ```
157
- */
158
- static<P>(path: string, loader: ViewLoader<P>): this;
159
- /**
160
- * Get all registered static routes
161
- */
162
- getStaticRoutes(): StaticRoute[];
163
- /**
164
- * Register a global error handler for all routes.
165
- * Useful for logging, monitoring integration, and custom error formatting.
166
- *
167
- * @example
168
- * ```typescript
169
- * app.onError(async (error, ctx) => {
170
- * logger.error(error);
171
- * return ctx.response.status(500).json({ error: 'Something went wrong' });
172
- * });
173
- * ```
174
- */
175
- onError(handler: ErrorHandler<TRequest, TServer>): this;
176
- /**
177
- * Get the registered error handler
178
- */
179
- getErrorHandler(): ErrorHandler | undefined;
180
- /**
181
- * Initialize the server adapter based on the runtime
182
- */
183
- protected abstract initializeServerAdapter(): Promise<any>;
184
- /**
185
- * Start the application server
186
- */
187
- abstract start(): Promise<TServer | void>;
188
- /**
189
- * Handles a standard Web request without requiring a bound network server.
190
- * This is the primary interoperability surface for embedding Ecopages inside
191
- * other runtimes and frameworks.
192
- */
193
- abstract fetch(request: TRequest): Promise<Response>;
194
- }