@ecopages/core 0.2.0-alpha.9 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (357) hide show
  1. package/CHANGELOG.md +18 -11
  2. package/README.md +23 -26
  3. package/package.json +76 -58
  4. package/src/adapters/README.md +2 -2
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +4 -12
  11. package/src/adapters/bun/create-app.js +4 -5
  12. package/src/adapters/bun/hmr-manager.d.ts +4 -4
  13. package/src/adapters/bun/hmr-manager.js +8 -8
  14. package/src/adapters/bun/index.d.ts +1 -1
  15. package/src/adapters/bun/index.js +2 -2
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +6 -5
  18. package/src/adapters/bun/server-lifecycle.d.ts +4 -4
  19. package/src/adapters/bun/server-lifecycle.js +2 -2
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +1 -5
  23. package/src/adapters/index.js +1 -7
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +2 -2
  28. package/src/adapters/node/node-hmr-manager.js +3 -3
  29. package/src/adapters/node/server-adapter.d.ts +4 -4
  30. package/src/adapters/node/server-adapter.js +13 -12
  31. package/src/adapters/node/static-content-server.d.ts +1 -1
  32. package/src/adapters/node/static-content-server.js +1 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/adapters/shared/define-api-handler.d.ts +1 -1
  35. package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
  36. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
  37. package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
  38. package/src/adapters/shared/fs-server-response-factory.js +1 -1
  39. package/src/adapters/shared/fs-server-response-matcher.d.ts +1 -1
  40. package/src/adapters/shared/hmr-entrypoint-registrar.js +1 -1
  41. package/src/adapters/shared/hmr-html-response.d.ts +1 -1
  42. package/src/adapters/shared/render-context.d.ts +2 -1
  43. package/src/adapters/shared/render-context.js +3 -1
  44. package/src/adapters/shared/runtime-bootstrap.d.ts +1 -1
  45. package/src/adapters/shared/runtime-bootstrap.js +1 -1
  46. package/src/adapters/shared/server-adapter.d.ts +1 -1
  47. package/src/adapters/shared/server-adapter.js +5 -1
  48. package/src/adapters/shared/server-route-handler.d.ts +4 -4
  49. package/src/adapters/shared/server-route-handler.js +3 -3
  50. package/src/adapters/shared/server-static-builder.d.ts +5 -5
  51. package/src/adapters/shared/server-static-builder.js +5 -4
  52. package/src/build/README.md +19 -13
  53. package/src/build/build-adapter.d.ts +67 -20
  54. package/src/build/build-adapter.js +420 -19
  55. package/src/build/dev-build-coordinator.d.ts +10 -12
  56. package/src/build/dev-build-coordinator.js +8 -15
  57. package/src/build/esbuild-build-adapter.d.ts +6 -0
  58. package/src/build/esbuild-build-adapter.js +94 -11
  59. package/src/build/runtime-build-executor.d.ts +5 -4
  60. package/src/build/runtime-build-executor.js +5 -3
  61. package/src/build/runtime-specifier-alias-plugin.js +19 -15
  62. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  63. package/src/build/runtime-specifier-aliases.js +95 -0
  64. package/src/config/README.md +5 -2
  65. package/src/config/config-builder.d.ts +25 -2
  66. package/src/config/config-builder.js +44 -7
  67. package/src/declarations.d.ts +1 -1
  68. package/src/dev/sc-server.d.ts +1 -1
  69. package/src/dev/sc-server.js +1 -1
  70. package/src/eco/eco.browser.d.ts +2 -0
  71. package/src/eco/eco.browser.js +83 -0
  72. package/src/eco/eco.js +19 -48
  73. package/src/eco/eco.types.d.ts +1 -1
  74. package/src/eco/eco.utils.d.ts +1 -40
  75. package/src/eco/eco.utils.js +5 -35
  76. package/src/eco/global-injector-map.d.ts +1 -1
  77. package/src/eco/lazy-injector-map.d.ts +1 -1
  78. package/src/hmr/hmr-strategy.d.ts +16 -13
  79. package/src/hmr/hmr-strategy.js +22 -7
  80. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  81. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  82. package/src/hmr/strategies/js-hmr-strategy.d.ts +2 -2
  83. package/src/hmr/strategies/js-hmr-strategy.js +2 -2
  84. package/src/index.browser.d.ts +2 -2
  85. package/src/index.browser.js +1 -1
  86. package/src/index.d.ts +3 -2
  87. package/src/index.js +15 -4
  88. package/src/integrations/ghtml/ghtml-renderer.d.ts +6 -1
  89. package/src/integrations/ghtml/ghtml-renderer.js +29 -28
  90. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -2
  91. package/src/integrations/ghtml/ghtml.plugin.js +2 -2
  92. package/src/plugins/README.md +1 -0
  93. package/src/plugins/eco-component-meta-plugin.d.ts +12 -1
  94. package/src/plugins/eco-component-meta-plugin.js +26 -20
  95. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  96. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  97. package/src/plugins/integration-plugin.d.ts +99 -33
  98. package/src/plugins/integration-plugin.js +68 -21
  99. package/src/plugins/processor.d.ts +2 -2
  100. package/src/plugins/processor.js +2 -2
  101. package/src/plugins/source-transform.d.ts +46 -0
  102. package/src/plugins/source-transform.js +71 -0
  103. package/src/route-renderer/GRAPH.md +54 -84
  104. package/src/route-renderer/README.md +14 -20
  105. package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
  106. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  107. package/src/route-renderer/orchestration/integration-renderer.d.ts +233 -76
  108. package/src/route-renderer/orchestration/integration-renderer.js +500 -143
  109. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +93 -0
  110. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
  111. package/src/route-renderer/orchestration/render-execution.service.d.ts +11 -71
  112. package/src/route-renderer/orchestration/render-execution.service.js +65 -80
  113. package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
  114. package/src/route-renderer/orchestration/render-output.utils.js +65 -0
  115. package/src/route-renderer/orchestration/render-preparation.service.d.ts +2 -8
  116. package/src/route-renderer/orchestration/render-preparation.service.js +10 -17
  117. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  118. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  119. package/src/route-renderer/page-loading/dependency-resolver.d.ts +2 -2
  120. package/src/route-renderer/page-loading/dependency-resolver.js +10 -8
  121. package/src/route-renderer/page-loading/page-module-loader.d.ts +6 -4
  122. package/src/route-renderer/page-loading/page-module-loader.js +7 -5
  123. package/src/route-renderer/route-renderer.d.ts +5 -3
  124. package/src/route-renderer/route-renderer.js +13 -3
  125. package/src/router/README.md +79 -8
  126. package/src/router/client/navigation-coordinator.js +2 -2
  127. package/src/router/server/fs-router-scanner.d.ts +1 -1
  128. package/src/router/server/fs-router-scanner.js +6 -1
  129. package/src/router/server/fs-router.d.ts +1 -1
  130. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +3 -3
  131. package/src/services/assets/asset-processing-service/asset-processing.service.js +6 -6
  132. package/src/services/assets/asset-processing-service/asset.factory.d.ts +1 -1
  133. package/src/services/assets/asset-processing-service/asset.factory.js +2 -2
  134. package/src/services/assets/asset-processing-service/index.d.ts +5 -5
  135. package/src/services/assets/asset-processing-service/index.js +5 -5
  136. package/src/services/assets/asset-processing-service/processor.interface.d.ts +2 -2
  137. package/src/services/assets/asset-processing-service/processor.registry.d.ts +2 -2
  138. package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +1 -1
  139. package/src/services/assets/asset-processing-service/processors/base/base-processor.js +1 -1
  140. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +3 -3
  141. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +2 -2
  142. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -5
  143. package/src/services/assets/asset-processing-service/processors/index.js +5 -5
  144. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +2 -2
  145. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +1 -1
  146. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +4 -3
  147. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +15 -3
  148. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +3 -3
  149. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +1 -1
  150. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
  151. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +1 -1
  152. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  153. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +1 -1
  154. package/src/services/assets/browser-bundle.service.d.ts +1 -1
  155. package/src/services/assets/browser-bundle.service.js +2 -2
  156. package/src/services/html/html-rewriter-provider.service.js +4 -1
  157. package/src/services/html/html-transformer.service.d.ts +2 -2
  158. package/src/services/html/html-transformer.service.js +4 -10
  159. package/src/services/invalidation/development-invalidation.service.d.ts +1 -1
  160. package/src/services/invalidation/development-invalidation.service.js +1 -0
  161. package/src/services/module-loading/app-module-loader.service.d.ts +25 -0
  162. package/src/services/module-loading/app-module-loader.service.js +31 -0
  163. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +9 -1
  164. package/src/services/module-loading/app-server-module-transpiler.service.js +77 -2
  165. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  166. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  167. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  168. package/src/{adapters/node/bootstrap-dependency-resolver.d.ts → services/module-loading/node-bootstrap-plugin.d.ts} +2 -24
  169. package/src/{adapters/node/bootstrap-dependency-resolver.js → services/module-loading/node-bootstrap-plugin.js} +42 -22
  170. package/src/services/module-loading/page-module-import.service.d.ts +4 -0
  171. package/src/services/module-loading/page-module-import.service.js +38 -9
  172. package/src/services/module-loading/server-module-transpiler.service.d.ts +3 -0
  173. package/src/services/module-loading/server-module-transpiler.service.js +4 -1
  174. package/src/services/runtime-state/dev-graph.service.d.ts +6 -6
  175. package/src/services/runtime-state/dev-graph.service.js +10 -10
  176. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +1 -1
  177. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +1 -1
  178. package/src/services/runtime-state/server-invalidation-state.service.d.ts +1 -1
  179. package/src/static-site-generator/static-site-generator.d.ts +2 -2
  180. package/src/static-site-generator/static-site-generator.js +1 -1
  181. package/src/{internal-types.d.ts → types/internal-types.d.ts} +24 -14
  182. package/src/{public-types.d.ts → types/public-types.d.ts} +30 -14
  183. package/src/types/public-types.js +0 -0
  184. package/src/utils/html-escaping.d.ts +7 -0
  185. package/src/utils/html-escaping.js +6 -0
  186. package/src/utils/locals-utils.d.ts +1 -1
  187. package/src/utils/parse-cli-args.d.ts +4 -1
  188. package/src/utils/parse-cli-args.js +16 -1
  189. package/src/utils/resolve-work-dir.js +1 -1
  190. package/src/watchers/project-watcher.d.ts +4 -4
  191. package/src/watchers/project-watcher.js +4 -10
  192. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  193. package/src/adapters/abstract/application-adapter.ts +0 -337
  194. package/src/adapters/abstract/router-adapter.ts +0 -30
  195. package/src/adapters/abstract/server-adapter.ts +0 -79
  196. package/src/adapters/bun/client-bridge.ts +0 -62
  197. package/src/adapters/bun/create-app.ts +0 -189
  198. package/src/adapters/bun/hmr-manager.ts +0 -409
  199. package/src/adapters/bun/index.ts +0 -2
  200. package/src/adapters/bun/server-adapter.ts +0 -499
  201. package/src/adapters/bun/server-lifecycle.ts +0 -124
  202. package/src/adapters/index.ts +0 -6
  203. package/src/adapters/node/bootstrap-dependency-resolver.ts +0 -301
  204. package/src/adapters/node/create-app.ts +0 -179
  205. package/src/adapters/node/index.d.ts +0 -6
  206. package/src/adapters/node/index.js +0 -11
  207. package/src/adapters/node/index.ts +0 -16
  208. package/src/adapters/node/node-client-bridge.ts +0 -79
  209. package/src/adapters/node/node-hmr-manager.ts +0 -381
  210. package/src/adapters/node/runtime-adapter.d.ts +0 -46
  211. package/src/adapters/node/runtime-adapter.js +0 -306
  212. package/src/adapters/node/runtime-adapter.ts +0 -439
  213. package/src/adapters/node/server-adapter.ts +0 -488
  214. package/src/adapters/node/static-content-server.ts +0 -239
  215. package/src/adapters/node/write-runtime-manifest.d.ts +0 -26
  216. package/src/adapters/node/write-runtime-manifest.js +0 -12
  217. package/src/adapters/node/write-runtime-manifest.ts +0 -38
  218. package/src/adapters/shared/api-response.ts +0 -104
  219. package/src/adapters/shared/application-adapter.ts +0 -199
  220. package/src/adapters/shared/define-api-handler.ts +0 -66
  221. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -140
  222. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -127
  223. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  224. package/src/adapters/shared/fs-server-response-matcher.ts +0 -205
  225. package/src/adapters/shared/hmr-entrypoint-registrar.ts +0 -149
  226. package/src/adapters/shared/hmr-html-response.ts +0 -52
  227. package/src/adapters/shared/render-context.ts +0 -120
  228. package/src/adapters/shared/runtime-bootstrap.ts +0 -79
  229. package/src/adapters/shared/server-adapter.ts +0 -489
  230. package/src/adapters/shared/server-route-handler.ts +0 -153
  231. package/src/adapters/shared/server-static-builder.ts +0 -166
  232. package/src/build/build-adapter.ts +0 -361
  233. package/src/build/build-manifest.ts +0 -54
  234. package/src/build/build-types.ts +0 -83
  235. package/src/build/dev-build-coordinator.ts +0 -221
  236. package/src/build/esbuild-build-adapter.ts +0 -559
  237. package/src/build/runtime-build-executor.ts +0 -34
  238. package/src/build/runtime-specifier-alias-plugin.ts +0 -58
  239. package/src/config/config-builder.ts +0 -706
  240. package/src/constants.ts +0 -54
  241. package/src/create-app.ts +0 -87
  242. package/src/dev/sc-server.ts +0 -143
  243. package/src/eco/component-render-context.d.ts +0 -105
  244. package/src/eco/component-render-context.js +0 -87
  245. package/src/eco/component-render-context.ts +0 -224
  246. package/src/eco/eco.ts +0 -242
  247. package/src/eco/eco.types.ts +0 -221
  248. package/src/eco/global-injector-map.ts +0 -112
  249. package/src/eco/lazy-injector-map.ts +0 -120
  250. package/src/eco/module-dependencies.ts +0 -75
  251. package/src/errors/http-error.ts +0 -72
  252. package/src/errors/index.ts +0 -2
  253. package/src/errors/locals-access-error.ts +0 -7
  254. package/src/global/app-logger.ts +0 -4
  255. package/src/hmr/client/hmr-runtime.ts +0 -152
  256. package/src/hmr/hmr-strategy.ts +0 -172
  257. package/src/hmr/hmr.postcss.test.e2e.ts +0 -41
  258. package/src/hmr/hmr.test.e2e.ts +0 -66
  259. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  260. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  261. package/src/index.browser.ts +0 -3
  262. package/src/index.ts +0 -5
  263. package/src/integrations/ghtml/ghtml-renderer.ts +0 -96
  264. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  265. package/src/internal-types.ts +0 -232
  266. package/src/plugins/alias-resolver-plugin.ts +0 -63
  267. package/src/plugins/eco-component-meta-plugin.ts +0 -481
  268. package/src/plugins/integration-plugin.ts +0 -226
  269. package/src/plugins/processor.ts +0 -240
  270. package/src/plugins/runtime-capability.ts +0 -14
  271. package/src/public-types.ts +0 -1317
  272. package/src/route-renderer/component-graph/component-graph-executor.d.ts +0 -32
  273. package/src/route-renderer/component-graph/component-graph-executor.js +0 -31
  274. package/src/route-renderer/component-graph/component-graph-executor.ts +0 -84
  275. package/src/route-renderer/component-graph/component-graph.d.ts +0 -42
  276. package/src/route-renderer/component-graph/component-graph.js +0 -72
  277. package/src/route-renderer/component-graph/component-graph.ts +0 -159
  278. package/src/route-renderer/component-graph/component-marker.d.ts +0 -52
  279. package/src/route-renderer/component-graph/component-marker.js +0 -46
  280. package/src/route-renderer/component-graph/component-marker.ts +0 -117
  281. package/src/route-renderer/component-graph/component-reference.d.ts +0 -10
  282. package/src/route-renderer/component-graph/component-reference.js +0 -19
  283. package/src/route-renderer/component-graph/component-reference.ts +0 -29
  284. package/src/route-renderer/component-graph/marker-graph-resolver.d.ts +0 -77
  285. package/src/route-renderer/component-graph/marker-graph-resolver.js +0 -95
  286. package/src/route-renderer/component-graph/marker-graph-resolver.ts +0 -155
  287. package/src/route-renderer/orchestration/integration-renderer.ts +0 -790
  288. package/src/route-renderer/orchestration/render-execution.service.ts +0 -230
  289. package/src/route-renderer/orchestration/render-preparation.service.ts +0 -476
  290. package/src/route-renderer/page-loading/dependency-resolver.ts +0 -612
  291. package/src/route-renderer/page-loading/page-module-loader.ts +0 -181
  292. package/src/route-renderer/route-renderer.ts +0 -115
  293. package/src/router/client/link-intent.test.browser.ts +0 -51
  294. package/src/router/client/link-intent.ts +0 -92
  295. package/src/router/client/navigation-coordinator.ts +0 -433
  296. package/src/router/server/fs-router-scanner.ts +0 -219
  297. package/src/router/server/fs-router.ts +0 -122
  298. package/src/services/assets/asset-processing-service/asset-processing.service.ts +0 -401
  299. package/src/services/assets/asset-processing-service/asset.factory.ts +0 -105
  300. package/src/services/assets/asset-processing-service/assets.types.ts +0 -113
  301. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +0 -95
  302. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +0 -78
  303. package/src/services/assets/asset-processing-service/index.ts +0 -5
  304. package/src/services/assets/asset-processing-service/processor.interface.ts +0 -27
  305. package/src/services/assets/asset-processing-service/processor.registry.ts +0 -18
  306. package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +0 -82
  307. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +0 -95
  308. package/src/services/assets/asset-processing-service/processors/index.ts +0 -5
  309. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  310. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  311. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +0 -85
  312. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  313. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -80
  314. package/src/services/assets/browser-bundle.service.ts +0 -53
  315. package/src/services/cache/cache.types.ts +0 -126
  316. package/src/services/cache/index.ts +0 -18
  317. package/src/services/cache/memory-cache-store.ts +0 -130
  318. package/src/services/cache/page-cache-service.ts +0 -202
  319. package/src/services/cache/page-request-cache-coordinator.service.ts +0 -131
  320. package/src/services/html/html-rewriter-provider.service.ts +0 -103
  321. package/src/services/html/html-transformer.service.ts +0 -279
  322. package/src/services/invalidation/development-invalidation.service.ts +0 -261
  323. package/src/services/module-loading/app-server-module-transpiler.service.ts +0 -52
  324. package/src/services/module-loading/page-module-import.service.ts +0 -200
  325. package/src/services/module-loading/server-loader.service.d.ts +0 -96
  326. package/src/services/module-loading/server-loader.service.js +0 -32
  327. package/src/services/module-loading/server-loader.service.ts +0 -130
  328. package/src/services/module-loading/server-module-transpiler.service.ts +0 -105
  329. package/src/services/runtime-manifest/node-runtime-manifest.service.d.ts +0 -35
  330. package/src/services/runtime-manifest/node-runtime-manifest.service.js +0 -60
  331. package/src/services/runtime-manifest/node-runtime-manifest.service.ts +0 -101
  332. package/src/services/runtime-state/dev-graph.service.ts +0 -217
  333. package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +0 -136
  334. package/src/services/runtime-state/runtime-specifier-registry.service.ts +0 -96
  335. package/src/services/runtime-state/server-invalidation-state.service.ts +0 -68
  336. package/src/services/validation/schema-validation-service.ts +0 -204
  337. package/src/services/validation/standard-schema.types.ts +0 -68
  338. package/src/static-site-generator/static-site-generator.ts +0 -462
  339. package/src/utils/css.d.ts +0 -1
  340. package/src/utils/css.js +0 -7
  341. package/src/utils/css.ts +0 -5
  342. package/src/utils/deep-merge.ts +0 -47
  343. package/src/utils/hash.ts +0 -5
  344. package/src/utils/html.ts +0 -1
  345. package/src/utils/invariant.ts +0 -15
  346. package/src/utils/locals-utils.ts +0 -37
  347. package/src/utils/parse-cli-args.ts +0 -83
  348. package/src/utils/path-utils.module.ts +0 -14
  349. package/src/utils/resolve-work-dir.ts +0 -45
  350. package/src/utils/runtime.ts +0 -44
  351. package/src/utils/server-utils.module.ts +0 -67
  352. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  353. package/src/watchers/project-watcher.ts +0 -363
  354. /package/src/{constants.d.ts → config/constants.d.ts} +0 -0
  355. /package/src/{constants.js → config/constants.js} +0 -0
  356. /package/src/{internal-types.js → services/module-loading/module-loading-types.js} +0 -0
  357. /package/src/{public-types.js → types/internal-types.js} +0 -0
@@ -1,45 +0,0 @@
1
- import path from 'node:path';
2
- import { DEFAULT_ECOPAGES_WORK_DIR } from '../constants.ts';
3
-
4
- type InternalPathConfig = {
5
- rootDir?: string;
6
- workDir?: string;
7
- absolutePaths?: {
8
- workDir?: string;
9
- distDir?: string;
10
- };
11
- };
12
-
13
- function isInsideNodeModules(directory: string): boolean {
14
- return path.normalize(directory).split(path.sep).includes('node_modules');
15
- }
16
-
17
- export function resolveInternalWorkDir(appConfig: InternalPathConfig): string {
18
- if (appConfig.absolutePaths?.workDir) {
19
- return appConfig.absolutePaths.workDir;
20
- }
21
-
22
- if (appConfig.rootDir) {
23
- return path.join(appConfig.rootDir, appConfig.workDir ?? DEFAULT_ECOPAGES_WORK_DIR);
24
- }
25
-
26
- if (appConfig.workDir) {
27
- return appConfig.workDir;
28
- }
29
-
30
- return DEFAULT_ECOPAGES_WORK_DIR;
31
- }
32
-
33
- export function resolveInternalExecutionDir(appConfig: InternalPathConfig): string {
34
- const workDir = resolveInternalWorkDir(appConfig);
35
-
36
- if (!isInsideNodeModules(workDir)) {
37
- return workDir;
38
- }
39
-
40
- if (appConfig.rootDir) {
41
- return path.join(appConfig.rootDir, DEFAULT_ECOPAGES_WORK_DIR);
42
- }
43
-
44
- return DEFAULT_ECOPAGES_WORK_DIR;
45
- }
@@ -1,44 +0,0 @@
1
- import { createHash } from 'node:crypto';
2
-
3
- export const RUNTIME_ERRORS = {
4
- BUN_RUNTIME_REQUIRED: 'Bun runtime is required',
5
- } as const;
6
-
7
- type RuntimeBun = typeof Bun;
8
-
9
- export function getBunRuntime(): RuntimeBun | undefined {
10
- return (globalThis as { Bun?: RuntimeBun }).Bun;
11
- }
12
-
13
- export function getRequiredBunRuntime(): RuntimeBun {
14
- const bun = getBunRuntime();
15
-
16
- if (!bun) {
17
- throw new Error(RUNTIME_ERRORS.BUN_RUNTIME_REQUIRED);
18
- }
19
-
20
- return bun;
21
- }
22
-
23
- export function getRuntimeArgv(): string[] {
24
- return process.argv;
25
- }
26
-
27
- export function isDevelopmentRuntime(): boolean {
28
- return process.env.NODE_ENV === 'development';
29
- }
30
-
31
- export function isProductionRuntime(): boolean {
32
- return process.env.NODE_ENV === 'production';
33
- }
34
-
35
- export function runtimeHash(content: string | Buffer<ArrayBufferLike>): number | bigint {
36
- const bun = getBunRuntime();
37
-
38
- if (bun) {
39
- return bun.hash(content);
40
- }
41
-
42
- const hex = createHash('sha256').update(content).digest('hex').slice(0, 16);
43
- return BigInt(`0x${hex}`);
44
- }
@@ -1,67 +0,0 @@
1
- const ContentTypeMap = new Map<string, string>([
2
- ['jpg', 'image/jpeg'],
3
- ['jpeg', 'image/jpeg'],
4
- ['png', 'image/png'],
5
- ['gif', 'image/gif'],
6
- ['bmp', 'image/bmp'],
7
- ['svg', 'image/svg+xml'],
8
- ['tiff', 'image/tiff'],
9
- ['webp', 'image/webp'],
10
- ['avif', 'image/avif'],
11
- ['ico', 'image/x-icon'],
12
- ['mp3', 'audio/mpeg'],
13
- ['ogg', 'audio/ogg'],
14
- ['wav', 'audio/wav'],
15
- ['mp4', 'video/mp4'],
16
- ['webm', 'video/webm'],
17
- ['ogv', 'video/ogg'],
18
- ['mov', 'video/quicktime'],
19
- ['txt', 'text/plain'],
20
- ['html', 'text/html'],
21
- ['css', 'text/css'],
22
- ['js', 'text/javascript'],
23
- ['mjs', 'text/javascript'],
24
- ['json', 'application/json'],
25
- ['map', 'application/json'],
26
- ['xml', 'application/xml'],
27
- ['webmanifest', 'application/manifest+json'],
28
- ['wasm', 'application/wasm'],
29
- ['csv', 'text/csv'],
30
- ['ttf', 'font/ttf'],
31
- ['woff', 'font/woff'],
32
- ['woff2', 'font/woff2'],
33
- ['otf', 'font/otf'],
34
- ['eot', 'application/vnd.ms-fontobject'],
35
- ['gz', 'application/x-gzip'],
36
- ['zip', 'application/zip'],
37
- ['pdf', 'application/pdf'],
38
- ['doc', 'application/msword'],
39
- ]);
40
-
41
- /**
42
- * Get the content type of a file based on its extension.
43
- * @param file - The file name.
44
- * @returns The content type.
45
- */
46
- export const getContentType = (file: string): string => {
47
- const extension = file.split('.').pop() || 'txt';
48
- return ContentTypeMap.get(extension) || 'text/plain';
49
- };
50
-
51
- /**
52
- * Check if a file path has a known static file extension.
53
- * @param file - The file name or path.
54
- * @returns true if the extension is recognized.
55
- */
56
- export const hasKnownExtension = (file: string): boolean => {
57
- const extension = file.split('.').pop();
58
- return extension !== undefined && ContentTypeMap.has(extension);
59
- };
60
-
61
- /**
62
- * A module for server utilities.
63
- */
64
- export const ServerUtils = {
65
- getContentType,
66
- hasKnownExtension,
67
- };
@@ -1,41 +0,0 @@
1
- import { vi } from 'vitest';
2
- import type { IHmrManager } from '../internal-types';
3
- import type { ClientBridge } from '../adapters/bun/client-bridge';
4
-
5
- export const createMockHmrManager = (): IHmrManager =>
6
- ({
7
- handleFileChange: vi.fn(async () => {}),
8
- broadcast: vi.fn(() => {}),
9
- setEnabled: vi.fn(() => {}),
10
- setPlugins: vi.fn(() => {}),
11
- registerEntrypoint: vi.fn(async () => ''),
12
- registerScriptEntrypoint: vi.fn(async () => ''),
13
- registerSpecifierMap: vi.fn(() => {}),
14
- registerStrategy: vi.fn(() => {}),
15
- isEnabled: vi.fn(() => true),
16
- getOutputUrl: vi.fn(() => undefined),
17
- getWatchedFiles: vi.fn(() => new Map()),
18
- getSpecifierMap: vi.fn(() => new Map()),
19
- getDistDir: vi.fn(() => ''),
20
- getPlugins: vi.fn(() => []),
21
- getDefaultContext: vi.fn(() => ({
22
- getWatchedFiles: () => new Map(),
23
- getSpecifierMap: () => new Map(),
24
- getDistDir: () => '',
25
- getPlugins: () => [],
26
- getSrcDir: () => '',
27
- getLayoutsDir: () => '',
28
- })),
29
- }) as unknown as IHmrManager;
30
-
31
- export const createMockBridge = (): ClientBridge =>
32
- ({
33
- reload: vi.fn(() => {}),
34
- error: vi.fn(() => {}),
35
- cssUpdate: vi.fn(() => {}),
36
- update: vi.fn(() => {}),
37
- subscribe: vi.fn(() => {}),
38
- unsubscribe: vi.fn(() => {}),
39
- broadcast: vi.fn(() => {}),
40
- subscriberCount: 0,
41
- }) as unknown as ClientBridge;
@@ -1,363 +0,0 @@
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 '../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 {() => 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: () => 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: () => 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
- 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
- triggerRouterRefresh(changedPath: string) {
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
- 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
- const processorPaths: string[] = [];
302
- for (const processor of this.appConfig.processors.values()) {
303
- const watchConfig = processor.getWatchConfig();
304
- if (!watchConfig) continue;
305
- processorPaths.push(...watchConfig.paths);
306
- }
307
-
308
- if (fileSystem.exists(this.appConfig.absolutePaths.includesDir)) {
309
- processorPaths.push(this.appConfig.absolutePaths.includesDir);
310
- }
311
-
312
- if (fileSystem.exists(this.appConfig.absolutePaths.srcDir)) {
313
- processorPaths.push(this.appConfig.absolutePaths.srcDir);
314
- }
315
-
316
- if (fileSystem.exists(this.appConfig.absolutePaths.pagesDir)) {
317
- processorPaths.push(this.appConfig.absolutePaths.pagesDir);
318
- }
319
-
320
- if (fileSystem.exists(this.appConfig.absolutePaths.publicDir)) {
321
- processorPaths.push(this.appConfig.absolutePaths.publicDir);
322
- }
323
-
324
- if (this.appConfig.additionalWatchPaths.length) {
325
- processorPaths.push(...this.appConfig.additionalWatchPaths);
326
- }
327
-
328
- this.watcher = chokidar.watch(processorPaths, {
329
- ignoreInitial: true,
330
- ignorePermissionErrors: true,
331
- awaitWriteFinish: {
332
- stabilityThreshold: 50,
333
- pollInterval: 50,
334
- },
335
- });
336
- }
337
-
338
- this.watcher.add(this.appConfig.absolutePaths.srcDir);
339
-
340
- this.watcher
341
- .on('change', (p) => this.enqueueChange(() => this.handleFileChange(p, 'change')))
342
- .on('add', (p) => {
343
- this.enqueueChange(() => this.handleFileChange(p, 'add'));
344
- this.triggerRouterRefresh(p);
345
- })
346
- .on('addDir', (p) => this.triggerRouterRefresh(p))
347
- .on('unlink', (p) => {
348
- this.enqueueChange(() => this.handleFileChange(p, 'unlink'));
349
- this.triggerRouterRefresh(p);
350
- })
351
- .on('unlinkDir', (p) => this.triggerRouterRefresh(p))
352
- .on('error', (error) => this.handleError(error));
353
-
354
- for (const processor of this.appConfig.processors.values()) {
355
- const watchConfig = processor.getWatchConfig();
356
- if (watchConfig?.onError) {
357
- this.watcher.on('error', watchConfig.onError as (error: unknown) => void);
358
- }
359
- }
360
-
361
- return this.watcher;
362
- }
363
- }
File without changes
File without changes