@ecopages/core 0.2.0-alpha.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 (342) hide show
  1. package/CHANGELOG.md +89 -0
  2. package/LICENSE +21 -0
  3. package/README.md +32 -0
  4. package/package.json +279 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +168 -0
  6. package/src/adapters/abstract/application-adapter.js +109 -0
  7. package/src/adapters/abstract/application-adapter.ts +337 -0
  8. package/src/adapters/abstract/router-adapter.d.ts +26 -0
  9. package/src/adapters/abstract/router-adapter.js +5 -0
  10. package/src/adapters/abstract/router-adapter.ts +30 -0
  11. package/src/adapters/abstract/server-adapter.d.ts +69 -0
  12. package/src/adapters/abstract/server-adapter.js +15 -0
  13. package/src/adapters/abstract/server-adapter.ts +79 -0
  14. package/src/adapters/bun/client-bridge.d.ts +34 -0
  15. package/src/adapters/bun/client-bridge.js +48 -0
  16. package/src/adapters/bun/client-bridge.ts +62 -0
  17. package/src/adapters/bun/create-app.d.ts +60 -0
  18. package/src/adapters/bun/create-app.js +117 -0
  19. package/src/adapters/bun/create-app.ts +189 -0
  20. package/src/adapters/bun/define-api-handler.d.ts +61 -0
  21. package/src/adapters/bun/define-api-handler.js +15 -0
  22. package/src/adapters/bun/define-api-handler.ts +114 -0
  23. package/src/adapters/bun/hmr-manager.d.ts +84 -0
  24. package/src/adapters/bun/hmr-manager.js +227 -0
  25. package/src/adapters/bun/hmr-manager.ts +281 -0
  26. package/src/adapters/bun/index.d.ts +3 -0
  27. package/src/adapters/bun/index.js +8 -0
  28. package/src/adapters/bun/index.ts +3 -0
  29. package/src/adapters/bun/server-adapter.d.ts +155 -0
  30. package/src/adapters/bun/server-adapter.js +368 -0
  31. package/src/adapters/bun/server-adapter.ts +492 -0
  32. package/src/adapters/bun/server-lifecycle.d.ts +52 -0
  33. package/src/adapters/bun/server-lifecycle.js +120 -0
  34. package/src/adapters/bun/server-lifecycle.ts +154 -0
  35. package/src/adapters/index.d.ts +6 -0
  36. package/src/adapters/index.js +14 -0
  37. package/src/adapters/index.ts +6 -0
  38. package/src/adapters/node/create-app.d.ts +21 -0
  39. package/src/adapters/node/create-app.js +143 -0
  40. package/src/adapters/node/create-app.ts +179 -0
  41. package/src/adapters/node/index.d.ts +4 -0
  42. package/src/adapters/node/index.js +8 -0
  43. package/src/adapters/node/index.ts +9 -0
  44. package/src/adapters/node/node-client-bridge.d.ts +26 -0
  45. package/src/adapters/node/node-client-bridge.js +66 -0
  46. package/src/adapters/node/node-client-bridge.ts +79 -0
  47. package/src/adapters/node/node-hmr-manager.d.ts +62 -0
  48. package/src/adapters/node/node-hmr-manager.js +221 -0
  49. package/src/adapters/node/node-hmr-manager.ts +271 -0
  50. package/src/adapters/node/server-adapter.d.ts +190 -0
  51. package/src/adapters/node/server-adapter.js +420 -0
  52. package/src/adapters/node/server-adapter.ts +561 -0
  53. package/src/adapters/node/static-content-server.d.ts +24 -0
  54. package/src/adapters/node/static-content-server.js +166 -0
  55. package/src/adapters/node/static-content-server.ts +203 -0
  56. package/src/adapters/shared/api-response.d.ts +52 -0
  57. package/src/adapters/shared/api-response.js +96 -0
  58. package/src/adapters/shared/api-response.ts +104 -0
  59. package/src/adapters/shared/application-adapter.d.ts +18 -0
  60. package/src/adapters/shared/application-adapter.js +90 -0
  61. package/src/adapters/shared/application-adapter.ts +199 -0
  62. package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
  63. package/src/adapters/shared/explicit-static-route-matcher.js +100 -0
  64. package/src/adapters/shared/explicit-static-route-matcher.ts +134 -0
  65. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
  66. package/src/adapters/shared/file-route-middleware-pipeline.js +98 -0
  67. package/src/adapters/shared/file-route-middleware-pipeline.ts +123 -0
  68. package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
  69. package/src/adapters/shared/fs-server-response-factory.js +97 -0
  70. package/src/adapters/shared/fs-server-response-factory.ts +118 -0
  71. package/src/adapters/shared/fs-server-response-matcher.d.ts +71 -0
  72. package/src/adapters/shared/fs-server-response-matcher.js +155 -0
  73. package/src/adapters/shared/fs-server-response-matcher.ts +198 -0
  74. package/src/adapters/shared/render-context.d.ts +14 -0
  75. package/src/adapters/shared/render-context.js +69 -0
  76. package/src/adapters/shared/render-context.ts +105 -0
  77. package/src/adapters/shared/server-adapter.d.ts +87 -0
  78. package/src/adapters/shared/server-adapter.js +353 -0
  79. package/src/adapters/shared/server-adapter.ts +442 -0
  80. package/src/adapters/shared/server-route-handler.d.ts +89 -0
  81. package/src/adapters/shared/server-route-handler.js +120 -0
  82. package/src/adapters/shared/server-route-handler.ts +166 -0
  83. package/src/adapters/shared/server-static-builder.d.ts +38 -0
  84. package/src/adapters/shared/server-static-builder.js +46 -0
  85. package/src/adapters/shared/server-static-builder.ts +82 -0
  86. package/src/build/build-adapter.d.ts +74 -0
  87. package/src/build/build-adapter.js +54 -0
  88. package/src/build/build-adapter.ts +132 -0
  89. package/src/build/build-types.d.ts +57 -0
  90. package/src/build/build-types.js +0 -0
  91. package/src/build/build-types.ts +83 -0
  92. package/src/build/esbuild-build-adapter.d.ts +69 -0
  93. package/src/build/esbuild-build-adapter.js +390 -0
  94. package/src/build/esbuild-build-adapter.ts +510 -0
  95. package/src/config/config-builder.d.ts +227 -0
  96. package/src/config/config-builder.js +392 -0
  97. package/src/config/config-builder.ts +474 -0
  98. package/src/constants.d.ts +32 -0
  99. package/src/constants.js +21 -0
  100. package/src/constants.ts +39 -0
  101. package/src/create-app.d.ts +17 -0
  102. package/src/create-app.js +66 -0
  103. package/src/create-app.ts +87 -0
  104. package/src/declarations.d.ts +26 -0
  105. package/src/define-api-handler.d.ts +25 -0
  106. package/src/define-api-handler.js +15 -0
  107. package/src/define-api-handler.ts +66 -0
  108. package/src/dev/sc-server.d.ts +30 -0
  109. package/src/dev/sc-server.js +111 -0
  110. package/src/dev/sc-server.ts +143 -0
  111. package/src/eco/README.md +636 -0
  112. package/src/eco/component-render-context.d.ts +105 -0
  113. package/src/eco/component-render-context.js +77 -0
  114. package/src/eco/component-render-context.ts +202 -0
  115. package/src/eco/eco.d.ts +9 -0
  116. package/src/eco/eco.js +110 -0
  117. package/src/eco/eco.ts +221 -0
  118. package/src/eco/eco.types.d.ts +170 -0
  119. package/src/eco/eco.types.js +0 -0
  120. package/src/eco/eco.types.ts +202 -0
  121. package/src/eco/eco.utils.d.ts +40 -0
  122. package/src/eco/eco.utils.js +40 -0
  123. package/src/eco/eco.utils.ts +89 -0
  124. package/src/eco/global-injector-map.d.ts +16 -0
  125. package/src/eco/global-injector-map.js +80 -0
  126. package/src/eco/global-injector-map.ts +112 -0
  127. package/src/eco/lazy-injector-map.d.ts +8 -0
  128. package/src/eco/lazy-injector-map.js +70 -0
  129. package/src/eco/lazy-injector-map.ts +120 -0
  130. package/src/eco/module-dependencies.d.ts +18 -0
  131. package/src/eco/module-dependencies.js +49 -0
  132. package/src/eco/module-dependencies.ts +75 -0
  133. package/src/env.d.ts +20 -0
  134. package/src/errors/http-error.d.ts +31 -0
  135. package/src/errors/http-error.js +50 -0
  136. package/src/errors/http-error.ts +72 -0
  137. package/src/errors/index.d.ts +2 -0
  138. package/src/errors/index.js +4 -0
  139. package/src/errors/index.ts +2 -0
  140. package/src/errors/locals-access-error.d.ts +4 -0
  141. package/src/errors/locals-access-error.js +9 -0
  142. package/src/errors/locals-access-error.ts +7 -0
  143. package/src/global/app-logger.d.ts +2 -0
  144. package/src/global/app-logger.js +6 -0
  145. package/src/global/app-logger.ts +4 -0
  146. 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
  147. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  148. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  149. package/src/hmr/client/hmr-runtime.d.ts +10 -0
  150. package/src/hmr/client/hmr-runtime.js +86 -0
  151. package/src/hmr/client/hmr-runtime.ts +121 -0
  152. package/src/hmr/hmr-strategy.d.ts +159 -0
  153. package/src/hmr/hmr-strategy.js +29 -0
  154. package/src/hmr/hmr-strategy.ts +172 -0
  155. package/src/hmr/hmr.test.e2e.d.ts +1 -0
  156. package/src/hmr/hmr.test.e2e.js +50 -0
  157. package/src/hmr/hmr.test.e2e.ts +75 -0
  158. package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
  159. package/src/hmr/strategies/default-hmr-strategy.js +34 -0
  160. package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
  161. package/src/hmr/strategies/js-hmr-strategy.d.ts +136 -0
  162. package/src/hmr/strategies/js-hmr-strategy.js +179 -0
  163. package/src/hmr/strategies/js-hmr-strategy.ts +308 -0
  164. package/src/index.browser.d.ts +3 -0
  165. package/src/index.browser.js +4 -0
  166. package/src/index.browser.ts +3 -0
  167. package/src/index.d.ts +5 -0
  168. package/src/index.js +10 -0
  169. package/src/index.ts +5 -0
  170. package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
  171. package/src/integrations/ghtml/ghtml-renderer.js +60 -0
  172. package/src/integrations/ghtml/ghtml-renderer.ts +93 -0
  173. package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
  174. package/src/integrations/ghtml/ghtml.plugin.js +21 -0
  175. package/src/integrations/ghtml/ghtml.plugin.ts +32 -0
  176. package/src/internal-types.d.ts +200 -0
  177. package/src/internal-types.js +0 -0
  178. package/src/internal-types.ts +212 -0
  179. package/src/plugins/alias-resolver-plugin.d.ts +2 -0
  180. package/src/plugins/alias-resolver-plugin.js +39 -0
  181. package/src/plugins/alias-resolver-plugin.ts +45 -0
  182. package/src/plugins/eco-component-meta-plugin.d.ts +95 -0
  183. package/src/plugins/eco-component-meta-plugin.js +157 -0
  184. package/src/plugins/eco-component-meta-plugin.ts +474 -0
  185. package/src/plugins/integration-plugin.d.ts +102 -0
  186. package/src/plugins/integration-plugin.js +100 -0
  187. package/src/plugins/integration-plugin.ts +184 -0
  188. package/src/plugins/processor.d.ts +82 -0
  189. package/src/plugins/processor.js +122 -0
  190. package/src/plugins/processor.ts +220 -0
  191. package/src/public-types.d.ts +1094 -0
  192. package/src/public-types.js +0 -0
  193. package/src/public-types.ts +1255 -0
  194. package/src/route-renderer/GRAPH.md +387 -0
  195. package/src/route-renderer/README.md +135 -0
  196. package/src/route-renderer/component-graph-executor.d.ts +32 -0
  197. package/src/route-renderer/component-graph-executor.js +31 -0
  198. package/src/route-renderer/component-graph-executor.ts +84 -0
  199. package/src/route-renderer/component-graph.d.ts +42 -0
  200. package/src/route-renderer/component-graph.js +72 -0
  201. package/src/route-renderer/component-graph.ts +159 -0
  202. package/src/route-renderer/component-marker.d.ts +52 -0
  203. package/src/route-renderer/component-marker.js +46 -0
  204. package/src/route-renderer/component-marker.ts +117 -0
  205. package/src/route-renderer/dependency-resolver.d.ts +24 -0
  206. package/src/route-renderer/dependency-resolver.js +428 -0
  207. package/src/route-renderer/dependency-resolver.ts +596 -0
  208. package/src/route-renderer/html-post-processing.service.d.ts +40 -0
  209. package/src/route-renderer/html-post-processing.service.js +86 -0
  210. package/src/route-renderer/html-post-processing.service.ts +103 -0
  211. package/src/route-renderer/integration-renderer.d.ts +339 -0
  212. package/src/route-renderer/integration-renderer.js +526 -0
  213. package/src/route-renderer/integration-renderer.ts +696 -0
  214. package/src/route-renderer/marker-graph-resolver.d.ts +76 -0
  215. package/src/route-renderer/marker-graph-resolver.js +93 -0
  216. package/src/route-renderer/marker-graph-resolver.ts +153 -0
  217. package/src/route-renderer/page-module-loader.d.ts +61 -0
  218. package/src/route-renderer/page-module-loader.js +102 -0
  219. package/src/route-renderer/page-module-loader.ts +153 -0
  220. package/src/route-renderer/render-execution.service.d.ts +69 -0
  221. package/src/route-renderer/render-execution.service.js +91 -0
  222. package/src/route-renderer/render-execution.service.ts +158 -0
  223. package/src/route-renderer/render-preparation.service.d.ts +112 -0
  224. package/src/route-renderer/render-preparation.service.js +243 -0
  225. package/src/route-renderer/render-preparation.service.ts +358 -0
  226. package/src/route-renderer/route-renderer.d.ts +26 -0
  227. package/src/route-renderer/route-renderer.js +68 -0
  228. package/src/route-renderer/route-renderer.ts +80 -0
  229. package/src/router/fs-router-scanner.d.ts +41 -0
  230. package/src/router/fs-router-scanner.js +155 -0
  231. package/src/router/fs-router-scanner.ts +217 -0
  232. package/src/router/fs-router.d.ts +26 -0
  233. package/src/router/fs-router.js +100 -0
  234. package/src/router/fs-router.ts +122 -0
  235. package/src/services/asset-processing-service/asset-processing.service.d.ts +41 -0
  236. package/src/services/asset-processing-service/asset-processing.service.js +250 -0
  237. package/src/services/asset-processing-service/asset-processing.service.ts +306 -0
  238. package/src/services/asset-processing-service/asset.factory.d.ts +17 -0
  239. package/src/services/asset-processing-service/asset.factory.js +82 -0
  240. package/src/services/asset-processing-service/asset.factory.ts +105 -0
  241. package/src/services/asset-processing-service/assets.types.d.ts +88 -0
  242. package/src/services/asset-processing-service/assets.types.js +0 -0
  243. package/src/services/asset-processing-service/assets.types.ts +112 -0
  244. package/src/services/asset-processing-service/index.d.ts +3 -0
  245. package/src/services/asset-processing-service/index.js +3 -0
  246. package/src/services/asset-processing-service/index.ts +3 -0
  247. package/src/services/asset-processing-service/processor.interface.d.ts +22 -0
  248. package/src/services/asset-processing-service/processor.interface.js +6 -0
  249. package/src/services/asset-processing-service/processor.interface.ts +27 -0
  250. package/src/services/asset-processing-service/processor.registry.d.ts +8 -0
  251. package/src/services/asset-processing-service/processor.registry.js +15 -0
  252. package/src/services/asset-processing-service/processor.registry.ts +18 -0
  253. package/src/services/asset-processing-service/processors/base/base-processor.d.ts +24 -0
  254. package/src/services/asset-processing-service/processors/base/base-processor.js +59 -0
  255. package/src/services/asset-processing-service/processors/base/base-processor.ts +76 -0
  256. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +16 -0
  257. package/src/services/asset-processing-service/processors/base/base-script-processor.js +80 -0
  258. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +105 -0
  259. package/src/services/asset-processing-service/processors/index.d.ts +5 -0
  260. package/src/services/asset-processing-service/processors/index.js +5 -0
  261. package/src/services/asset-processing-service/processors/index.ts +5 -0
  262. package/src/services/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
  263. package/src/services/asset-processing-service/processors/script/content-script.processor.js +57 -0
  264. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +66 -0
  265. package/src/services/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
  266. package/src/services/asset-processing-service/processors/script/file-script.processor.js +76 -0
  267. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +88 -0
  268. package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
  269. package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +74 -0
  270. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +84 -0
  271. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
  272. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
  273. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +27 -0
  274. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
  275. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +63 -0
  276. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +77 -0
  277. package/src/services/cache/cache.types.d.ts +107 -0
  278. package/src/services/cache/cache.types.js +0 -0
  279. package/src/services/cache/cache.types.ts +126 -0
  280. package/src/services/cache/index.d.ts +7 -0
  281. package/src/services/cache/index.js +7 -0
  282. package/src/services/cache/index.ts +18 -0
  283. package/src/services/cache/memory-cache-store.d.ts +42 -0
  284. package/src/services/cache/memory-cache-store.js +98 -0
  285. package/src/services/cache/memory-cache-store.ts +130 -0
  286. package/src/services/cache/page-cache-service.d.ts +70 -0
  287. package/src/services/cache/page-cache-service.js +152 -0
  288. package/src/services/cache/page-cache-service.ts +202 -0
  289. package/src/services/html-transformer.service.d.ts +50 -0
  290. package/src/services/html-transformer.service.js +163 -0
  291. package/src/services/html-transformer.service.ts +217 -0
  292. package/src/services/page-module-import.service.d.ts +37 -0
  293. package/src/services/page-module-import.service.js +88 -0
  294. package/src/services/page-module-import.service.ts +129 -0
  295. package/src/services/page-request-cache-coordinator.service.d.ts +75 -0
  296. package/src/services/page-request-cache-coordinator.service.js +107 -0
  297. package/src/services/page-request-cache-coordinator.service.ts +128 -0
  298. package/src/services/schema-validation-service.d.ts +122 -0
  299. package/src/services/schema-validation-service.js +101 -0
  300. package/src/services/schema-validation-service.ts +204 -0
  301. package/src/services/validation/standard-schema.types.d.ts +65 -0
  302. package/src/services/validation/standard-schema.types.js +0 -0
  303. package/src/services/validation/standard-schema.types.ts +68 -0
  304. package/src/static-site-generator/static-site-generator.d.ts +57 -0
  305. package/src/static-site-generator/static-site-generator.js +272 -0
  306. package/src/static-site-generator/static-site-generator.ts +359 -0
  307. package/src/utils/css.d.ts +1 -0
  308. package/src/utils/css.js +7 -0
  309. package/src/utils/css.ts +5 -0
  310. package/src/utils/deep-merge.d.ts +14 -0
  311. package/src/utils/deep-merge.js +32 -0
  312. package/src/utils/deep-merge.ts +47 -0
  313. package/src/utils/hash.d.ts +1 -0
  314. package/src/utils/hash.js +7 -0
  315. package/src/utils/hash.ts +5 -0
  316. package/src/utils/html.d.ts +1 -0
  317. package/src/utils/html.js +4 -0
  318. package/src/utils/html.ts +1 -0
  319. package/src/utils/invariant.d.ts +5 -0
  320. package/src/utils/invariant.js +11 -0
  321. package/src/utils/invariant.ts +15 -0
  322. package/src/utils/locals-utils.d.ts +15 -0
  323. package/src/utils/locals-utils.js +24 -0
  324. package/src/utils/locals-utils.ts +37 -0
  325. package/src/utils/parse-cli-args.d.ts +24 -0
  326. package/src/utils/parse-cli-args.js +47 -0
  327. package/src/utils/parse-cli-args.ts +83 -0
  328. package/src/utils/path-utils.module.d.ts +5 -0
  329. package/src/utils/path-utils.module.js +14 -0
  330. package/src/utils/path-utils.module.ts +14 -0
  331. package/src/utils/runtime.d.ts +11 -0
  332. package/src/utils/runtime.js +40 -0
  333. package/src/utils/runtime.ts +44 -0
  334. package/src/utils/server-utils.module.d.ts +19 -0
  335. package/src/utils/server-utils.module.js +56 -0
  336. package/src/utils/server-utils.module.ts +67 -0
  337. package/src/watchers/project-watcher.d.ts +120 -0
  338. package/src/watchers/project-watcher.js +238 -0
  339. package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
  340. package/src/watchers/project-watcher.test-helpers.js +51 -0
  341. package/src/watchers/project-watcher.test-helpers.ts +40 -0
  342. package/src/watchers/project-watcher.ts +306 -0
@@ -0,0 +1,76 @@
1
+ import type { ComponentRenderInput, ComponentRenderResult, EcoComponent } from '../public-types.js';
2
+ import type { ProcessedAsset } from '../services/asset-processing-service/index.js';
3
+ import type { MarkerNodeId } from './component-marker.js';
4
+ /**
5
+ * Serializable graph-context payload used during post-render marker resolution.
6
+ *
7
+ * `propsByRef` stores serialized props captured during the first render pass,
8
+ * while `slotChildrenByRef` preserves parent-child marker relationships for
9
+ * slot-like composition.
10
+ */
11
+ export type MarkerGraphContext = {
12
+ propsByRef?: Record<string, Record<string, unknown>>;
13
+ slotChildrenByRef?: Record<string, MarkerNodeId[]>;
14
+ };
15
+ /**
16
+ * Minimal renderer contract needed for deferred component resolution.
17
+ *
18
+ * The marker graph resolver intentionally depends only on component-level render
19
+ * capabilities, not on the full integration renderer abstraction.
20
+ */
21
+ export interface MarkerGraphComponentRenderer {
22
+ renderComponent(input: ComponentRenderInput): Promise<ComponentRenderResult>;
23
+ }
24
+ export interface MarkerGraphResolverOptions {
25
+ html: string;
26
+ componentsToResolve: EcoComponent[];
27
+ graphContext: MarkerGraphContext;
28
+ resolveRenderer: (integrationName: string) => MarkerGraphComponentRenderer;
29
+ applyAttributesToFirstElement: (html: string, attributes: Record<string, string>) => string;
30
+ }
31
+ /**
32
+ * Resolves deferred `eco-marker` tokens after the first render pass.
33
+ *
34
+ * This service owns the second-stage orchestration for cross-integration
35
+ * component rendering. It builds a component reference registry, constructs a
36
+ * deterministic marker DAG, resolves leaf nodes before parents, and collects any
37
+ * component-level assets emitted during that process.
38
+ *
39
+ * Responsibility split:
40
+ * - core resolves marker structure, refs, child ordering, and renderer dispatch
41
+ * - the target integration renderer resolves the actual component render through
42
+ * `renderComponent()` once the marker has been decoded into component input
43
+ */
44
+ export declare class MarkerGraphResolver {
45
+ /**
46
+ * Resolves every marker in the supplied HTML and returns the final HTML plus
47
+ * any assets produced by nested component renders.
48
+ *
49
+ * The resolver is intentionally fail-fast: missing component refs or props refs
50
+ * indicate a broken render graph and should surface immediately instead of
51
+ * producing partial output.
52
+ *
53
+ * The resolver does not render integration-specific HTML itself. Instead, it
54
+ * reconstructs `ComponentRenderInput` from the marker payload and then delegates
55
+ * the actual rendering to the target integration renderer.
56
+ *
57
+ * @param options Marker graph resolution inputs for one render pass.
58
+ * @returns Resolved HTML and collected component assets.
59
+ */
60
+ resolve(options: MarkerGraphResolverOptions): Promise<{
61
+ html: string;
62
+ assets: ProcessedAsset[];
63
+ }>;
64
+ /**
65
+ * Builds a reference registry from the root component set and all nested
66
+ * declared component dependencies.
67
+ *
68
+ * Component refs are keyed by `__eco.id` when available, falling back to
69
+ * `__eco.file`. Traversal is depth-first and deduplicated by component
70
+ * identity to remain stable in shared dependency graphs.
71
+ *
72
+ * @param components Root components participating in resolution.
73
+ * @returns Lookup table from component ref to component definition.
74
+ */
75
+ private buildComponentRefRegistry;
76
+ }
@@ -0,0 +1,93 @@
1
+ import { extractComponentGraph } from "./component-graph.js";
2
+ import { resolveComponentGraph } from "./component-graph-executor.js";
3
+ class MarkerGraphResolver {
4
+ /**
5
+ * Resolves every marker in the supplied HTML and returns the final HTML plus
6
+ * any assets produced by nested component renders.
7
+ *
8
+ * The resolver is intentionally fail-fast: missing component refs or props refs
9
+ * indicate a broken render graph and should surface immediately instead of
10
+ * producing partial output.
11
+ *
12
+ * The resolver does not render integration-specific HTML itself. Instead, it
13
+ * reconstructs `ComponentRenderInput` from the marker payload and then delegates
14
+ * the actual rendering to the target integration renderer.
15
+ *
16
+ * @param options Marker graph resolution inputs for one render pass.
17
+ * @returns Resolved HTML and collected component assets.
18
+ */
19
+ async resolve(options) {
20
+ const registry = this.buildComponentRefRegistry(options.componentsToResolve);
21
+ const graph = extractComponentGraph(options.html, options.graphContext.slotChildrenByRef ?? {});
22
+ const resolvedNodeHtml = /* @__PURE__ */ new Map();
23
+ const assets = [];
24
+ const resolvedHtml = await resolveComponentGraph(options.html, graph, async (marker) => {
25
+ const component = registry.get(marker.componentRef);
26
+ if (!component) {
27
+ throw new Error(`[ecopages] Missing component reference for marker: ${marker.componentRef}`);
28
+ }
29
+ const props = options.graphContext.propsByRef?.[marker.propsRef];
30
+ if (!props) {
31
+ throw new Error(`[ecopages] Missing props reference for marker: ${marker.propsRef}`);
32
+ }
33
+ let children;
34
+ if (marker.slotRef) {
35
+ const childNodeIds = options.graphContext.slotChildrenByRef?.[marker.slotRef] ?? [];
36
+ if (childNodeIds.length > 0) {
37
+ children = childNodeIds.map((childNodeId) => resolvedNodeHtml.get(childNodeId) ?? "").join("");
38
+ }
39
+ }
40
+ const renderer = options.resolveRenderer(marker.integration);
41
+ const componentRender = await renderer.renderComponent({
42
+ component,
43
+ props,
44
+ children
45
+ });
46
+ if (componentRender.assets?.length) {
47
+ assets.push(...componentRender.assets);
48
+ }
49
+ const htmlWithAttributes = componentRender.canAttachAttributes && componentRender.rootAttributes ? options.applyAttributesToFirstElement(componentRender.html, componentRender.rootAttributes) : componentRender.html;
50
+ resolvedNodeHtml.set(marker.nodeId, htmlWithAttributes);
51
+ return { html: htmlWithAttributes };
52
+ });
53
+ return {
54
+ html: resolvedHtml,
55
+ assets
56
+ };
57
+ }
58
+ /**
59
+ * Builds a reference registry from the root component set and all nested
60
+ * declared component dependencies.
61
+ *
62
+ * Component refs are keyed by `__eco.id` when available, falling back to
63
+ * `__eco.file`. Traversal is depth-first and deduplicated by component
64
+ * identity to remain stable in shared dependency graphs.
65
+ *
66
+ * @param components Root components participating in resolution.
67
+ * @returns Lookup table from component ref to component definition.
68
+ */
69
+ buildComponentRefRegistry(components) {
70
+ const registry = /* @__PURE__ */ new Map();
71
+ const stack = [...components];
72
+ const seen = /* @__PURE__ */ new Set();
73
+ while (stack.length > 0) {
74
+ const current = stack.pop();
75
+ if (!current || seen.has(current)) {
76
+ continue;
77
+ }
78
+ seen.add(current);
79
+ const ref = current.config?.__eco?.id ?? current.config?.__eco?.file;
80
+ if (ref) {
81
+ registry.set(ref, current);
82
+ }
83
+ const nested = current.config?.dependencies?.components ?? [];
84
+ for (const component of nested) {
85
+ stack.push(component);
86
+ }
87
+ }
88
+ return registry;
89
+ }
90
+ }
91
+ export {
92
+ MarkerGraphResolver
93
+ };
@@ -0,0 +1,153 @@
1
+ import type { ComponentRenderInput, ComponentRenderResult, EcoComponent } from '../public-types.ts';
2
+ import type { ProcessedAsset } from '../services/asset-processing-service/index.ts';
3
+ import type { MarkerNodeId } from './component-marker.ts';
4
+ import { extractComponentGraph } from './component-graph.ts';
5
+ import { resolveComponentGraph } from './component-graph-executor.ts';
6
+
7
+ /**
8
+ * Serializable graph-context payload used during post-render marker resolution.
9
+ *
10
+ * `propsByRef` stores serialized props captured during the first render pass,
11
+ * while `slotChildrenByRef` preserves parent-child marker relationships for
12
+ * slot-like composition.
13
+ */
14
+ export type MarkerGraphContext = {
15
+ propsByRef?: Record<string, Record<string, unknown>>;
16
+ slotChildrenByRef?: Record<string, MarkerNodeId[]>;
17
+ };
18
+
19
+ /**
20
+ * Minimal renderer contract needed for deferred component resolution.
21
+ *
22
+ * The marker graph resolver intentionally depends only on component-level render
23
+ * capabilities, not on the full integration renderer abstraction.
24
+ */
25
+ export interface MarkerGraphComponentRenderer {
26
+ renderComponent(input: ComponentRenderInput): Promise<ComponentRenderResult>;
27
+ }
28
+
29
+ export interface MarkerGraphResolverOptions {
30
+ html: string;
31
+ componentsToResolve: EcoComponent[];
32
+ graphContext: MarkerGraphContext;
33
+ resolveRenderer: (integrationName: string) => MarkerGraphComponentRenderer;
34
+ applyAttributesToFirstElement: (html: string, attributes: Record<string, string>) => string;
35
+ }
36
+
37
+ /**
38
+ * Resolves deferred `eco-marker` tokens after the first render pass.
39
+ *
40
+ * This service owns the second-stage orchestration for cross-integration
41
+ * component rendering. It builds a component reference registry, constructs a
42
+ * deterministic marker DAG, resolves leaf nodes before parents, and collects any
43
+ * component-level assets emitted during that process.
44
+ *
45
+ * Responsibility split:
46
+ * - core resolves marker structure, refs, child ordering, and renderer dispatch
47
+ * - the target integration renderer resolves the actual component render through
48
+ * `renderComponent()` once the marker has been decoded into component input
49
+ */
50
+ export class MarkerGraphResolver {
51
+ /**
52
+ * Resolves every marker in the supplied HTML and returns the final HTML plus
53
+ * any assets produced by nested component renders.
54
+ *
55
+ * The resolver is intentionally fail-fast: missing component refs or props refs
56
+ * indicate a broken render graph and should surface immediately instead of
57
+ * producing partial output.
58
+ *
59
+ * The resolver does not render integration-specific HTML itself. Instead, it
60
+ * reconstructs `ComponentRenderInput` from the marker payload and then delegates
61
+ * the actual rendering to the target integration renderer.
62
+ *
63
+ * @param options Marker graph resolution inputs for one render pass.
64
+ * @returns Resolved HTML and collected component assets.
65
+ */
66
+ async resolve(options: MarkerGraphResolverOptions): Promise<{ html: string; assets: ProcessedAsset[] }> {
67
+ const registry = this.buildComponentRefRegistry(options.componentsToResolve);
68
+ const graph = extractComponentGraph(options.html, options.graphContext.slotChildrenByRef ?? {});
69
+ const resolvedNodeHtml = new Map<MarkerNodeId, string>();
70
+ const assets: ProcessedAsset[] = [];
71
+
72
+ const resolvedHtml = await resolveComponentGraph(options.html, graph, async (marker) => {
73
+ const component = registry.get(marker.componentRef);
74
+ if (!component) {
75
+ throw new Error(`[ecopages] Missing component reference for marker: ${marker.componentRef}`);
76
+ }
77
+
78
+ const props = options.graphContext.propsByRef?.[marker.propsRef];
79
+ if (!props) {
80
+ throw new Error(`[ecopages] Missing props reference for marker: ${marker.propsRef}`);
81
+ }
82
+
83
+ let children: string | undefined;
84
+ if (marker.slotRef) {
85
+ const childNodeIds = options.graphContext.slotChildrenByRef?.[marker.slotRef] ?? [];
86
+ if (childNodeIds.length > 0) {
87
+ children = childNodeIds.map((childNodeId) => resolvedNodeHtml.get(childNodeId) ?? '').join('');
88
+ }
89
+ }
90
+
91
+ const renderer = options.resolveRenderer(marker.integration);
92
+ const componentRender = await renderer.renderComponent({
93
+ component,
94
+ props,
95
+ children,
96
+ });
97
+
98
+ if (componentRender.assets?.length) {
99
+ assets.push(...componentRender.assets);
100
+ }
101
+
102
+ const htmlWithAttributes =
103
+ componentRender.canAttachAttributes && componentRender.rootAttributes
104
+ ? options.applyAttributesToFirstElement(componentRender.html, componentRender.rootAttributes)
105
+ : componentRender.html;
106
+
107
+ resolvedNodeHtml.set(marker.nodeId, htmlWithAttributes);
108
+ return { html: htmlWithAttributes };
109
+ });
110
+
111
+ return {
112
+ html: resolvedHtml,
113
+ assets,
114
+ };
115
+ }
116
+
117
+ /**
118
+ * Builds a reference registry from the root component set and all nested
119
+ * declared component dependencies.
120
+ *
121
+ * Component refs are keyed by `__eco.id` when available, falling back to
122
+ * `__eco.file`. Traversal is depth-first and deduplicated by component
123
+ * identity to remain stable in shared dependency graphs.
124
+ *
125
+ * @param components Root components participating in resolution.
126
+ * @returns Lookup table from component ref to component definition.
127
+ */
128
+ private buildComponentRefRegistry(components: EcoComponent[]): Map<string, EcoComponent> {
129
+ const registry = new Map<string, EcoComponent>();
130
+ const stack = [...components];
131
+ const seen = new Set<EcoComponent>();
132
+
133
+ while (stack.length > 0) {
134
+ const current = stack.pop();
135
+ if (!current || seen.has(current)) {
136
+ continue;
137
+ }
138
+ seen.add(current);
139
+
140
+ const ref = current.config?.__eco?.id ?? current.config?.__eco?.file;
141
+ if (ref) {
142
+ registry.set(ref, current);
143
+ }
144
+
145
+ const nested = current.config?.dependencies?.components ?? [];
146
+ for (const component of nested) {
147
+ stack.push(component);
148
+ }
149
+ }
150
+
151
+ return registry;
152
+ }
153
+ }
@@ -0,0 +1,61 @@
1
+ import type { EcoPageFile, GetMetadata, GetMetadataContext, GetStaticProps, PageMetadataProps, RouteRendererOptions, EcoPageComponent } from '../public-types.js';
2
+ import type { EcoPagesAppConfig } from '../internal-types.js';
3
+ /**
4
+ * Handles page module loading plus static props/metadata resolution.
5
+ */
6
+ export declare class PageModuleLoaderService {
7
+ private appConfig;
8
+ private runtimeOrigin;
9
+ private pageModuleImportService;
10
+ constructor(appConfig: EcoPagesAppConfig, runtimeOrigin: string);
11
+ /**
12
+ * Imports a page module from source.
13
+ * Uses direct dynamic import in Bun and transpile+import fallback for other runtimes.
14
+ */
15
+ importPageFile(file: string): Promise<EcoPageFile>;
16
+ /**
17
+ * Executes `getStaticProps` with Ecopages runtime context.
18
+ * Returns an empty props object when no static props function is defined.
19
+ */
20
+ getStaticPropsForPage(options: {
21
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
22
+ params?: RouteRendererOptions['params'];
23
+ }): Promise<{
24
+ props: Record<string, unknown>;
25
+ metadata?: PageMetadataProps;
26
+ }>;
27
+ /**
28
+ * Builds final page metadata using app-level defaults as a baseline.
29
+ * If `getMetadata` exists, its result overlays defaults so page-level fields take precedence.
30
+ */
31
+ getMetadataPropsForPage(options: {
32
+ getMetadata: GetMetadata | undefined;
33
+ context: GetMetadataContext;
34
+ }): Promise<PageMetadataProps>;
35
+ /**
36
+ * Loads a page module and normalizes integration-facing exports.
37
+ * When both component static methods and module exports exist, component statics win.
38
+ */
39
+ resolvePageModule(options: {
40
+ file: string;
41
+ importPageFileFn?: (file: string) => Promise<EcoPageFile>;
42
+ }): Promise<{
43
+ Page: EcoPageFile['default'] | EcoPageComponent<any>;
44
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
45
+ getMetadata?: GetMetadata;
46
+ integrationSpecificProps: Record<string, unknown>;
47
+ }>;
48
+ /**
49
+ * Resolves render-time page data in order: static props first, then metadata derived from those props.
50
+ */
51
+ resolvePageData(options: {
52
+ pageModule: {
53
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
54
+ getMetadata?: GetMetadata;
55
+ };
56
+ routeOptions: RouteRendererOptions;
57
+ }): Promise<{
58
+ props: Record<string, unknown>;
59
+ metadata: PageMetadataProps;
60
+ }>;
61
+ }
@@ -0,0 +1,102 @@
1
+ import { invariant } from "../utils/invariant.js";
2
+ import { PageModuleImportService } from "../services/page-module-import.service.js";
3
+ class PageModuleLoaderService {
4
+ constructor(appConfig, runtimeOrigin) {
5
+ this.appConfig = appConfig;
6
+ this.runtimeOrigin = runtimeOrigin;
7
+ this.pageModuleImportService = new PageModuleImportService();
8
+ }
9
+ pageModuleImportService;
10
+ /**
11
+ * Imports a page module from source.
12
+ * Uses direct dynamic import in Bun and transpile+import fallback for other runtimes.
13
+ */
14
+ async importPageFile(file) {
15
+ try {
16
+ return await this.pageModuleImportService.importModule({
17
+ filePath: file,
18
+ rootDir: this.appConfig.rootDir,
19
+ outdir: `${this.appConfig.absolutePaths.distDir}/.server-modules`,
20
+ transpileErrorMessage: (details) => `Error transpiling page file: ${details}`,
21
+ noOutputMessage: (targetFilePath) => `No transpiled output generated for page: ${targetFilePath}`
22
+ });
23
+ } catch (error) {
24
+ invariant(false, `Error importing page file: ${error}`);
25
+ }
26
+ }
27
+ /**
28
+ * Executes `getStaticProps` with Ecopages runtime context.
29
+ * Returns an empty props object when no static props function is defined.
30
+ */
31
+ async getStaticPropsForPage(options) {
32
+ const { getStaticProps, params } = options;
33
+ return getStaticProps ? await getStaticProps({
34
+ pathname: { params: params ?? {} },
35
+ appConfig: this.appConfig,
36
+ runtimeOrigin: this.runtimeOrigin
37
+ }).then((data) => data).catch((err) => {
38
+ throw new Error(`Error fetching static props: ${err.message}`);
39
+ }) : {
40
+ props: {},
41
+ metadata: void 0
42
+ };
43
+ }
44
+ /**
45
+ * Builds final page metadata using app-level defaults as a baseline.
46
+ * If `getMetadata` exists, its result overlays defaults so page-level fields take precedence.
47
+ */
48
+ async getMetadataPropsForPage(options) {
49
+ const { getMetadata, context } = options;
50
+ let metadata = this.appConfig.defaultMetadata;
51
+ if (getMetadata) {
52
+ const dynamicMetadata = await getMetadata({
53
+ params: context.params,
54
+ query: context.query,
55
+ props: context.props,
56
+ appConfig: this.appConfig
57
+ });
58
+ metadata = { ...metadata, ...dynamicMetadata };
59
+ }
60
+ return metadata;
61
+ }
62
+ /**
63
+ * Loads a page module and normalizes integration-facing exports.
64
+ * When both component static methods and module exports exist, component statics win.
65
+ */
66
+ async resolvePageModule(options) {
67
+ const module = await (options.importPageFileFn ?? ((file) => this.importPageFile(file)))(options.file);
68
+ const {
69
+ default: Page,
70
+ getStaticProps: moduleGetStaticProps,
71
+ getMetadata: moduleGetMetadata,
72
+ ...integrationSpecificProps
73
+ } = module;
74
+ return {
75
+ Page,
76
+ getStaticProps: Page.staticProps ?? moduleGetStaticProps,
77
+ getMetadata: Page.metadata ?? moduleGetMetadata,
78
+ integrationSpecificProps
79
+ };
80
+ }
81
+ /**
82
+ * Resolves render-time page data in order: static props first, then metadata derived from those props.
83
+ */
84
+ async resolvePageData(options) {
85
+ const { props } = await this.getStaticPropsForPage({
86
+ getStaticProps: options.pageModule.getStaticProps,
87
+ params: options.routeOptions.params
88
+ });
89
+ const metadata = await this.getMetadataPropsForPage({
90
+ getMetadata: options.pageModule.getMetadata,
91
+ context: {
92
+ props,
93
+ params: options.routeOptions.params ?? {},
94
+ query: options.routeOptions.query ?? {}
95
+ }
96
+ });
97
+ return { props, metadata };
98
+ }
99
+ }
100
+ export {
101
+ PageModuleLoaderService
102
+ };
@@ -0,0 +1,153 @@
1
+ import { invariant } from '../utils/invariant.ts';
2
+ import type {
3
+ EcoPageFile,
4
+ GetMetadata,
5
+ GetMetadataContext,
6
+ GetStaticProps,
7
+ PageMetadataProps,
8
+ RouteRendererOptions,
9
+ EcoPageComponent,
10
+ } from '../public-types.ts';
11
+ import type { EcoPagesAppConfig } from '../internal-types.ts';
12
+ import { PageModuleImportService } from '../services/page-module-import.service.ts';
13
+
14
+ /**
15
+ * Handles page module loading plus static props/metadata resolution.
16
+ */
17
+ export class PageModuleLoaderService {
18
+ private pageModuleImportService: PageModuleImportService;
19
+
20
+ constructor(
21
+ private appConfig: EcoPagesAppConfig,
22
+ private runtimeOrigin: string,
23
+ ) {
24
+ this.pageModuleImportService = new PageModuleImportService();
25
+ }
26
+
27
+ /**
28
+ * Imports a page module from source.
29
+ * Uses direct dynamic import in Bun and transpile+import fallback for other runtimes.
30
+ */
31
+ async importPageFile(file: string): Promise<EcoPageFile> {
32
+ try {
33
+ return await this.pageModuleImportService.importModule<EcoPageFile>({
34
+ filePath: file,
35
+ rootDir: this.appConfig.rootDir,
36
+ outdir: `${this.appConfig.absolutePaths.distDir}/.server-modules`,
37
+ transpileErrorMessage: (details) => `Error transpiling page file: ${details}`,
38
+ noOutputMessage: (targetFilePath) => `No transpiled output generated for page: ${targetFilePath}`,
39
+ });
40
+ } catch (error) {
41
+ invariant(false, `Error importing page file: ${error}`);
42
+ }
43
+ }
44
+
45
+ /**
46
+ * Executes `getStaticProps` with Ecopages runtime context.
47
+ * Returns an empty props object when no static props function is defined.
48
+ */
49
+ async getStaticPropsForPage(options: {
50
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
51
+ params?: RouteRendererOptions['params'];
52
+ }): Promise<{
53
+ props: Record<string, unknown>;
54
+ metadata?: PageMetadataProps;
55
+ }> {
56
+ const { getStaticProps, params } = options;
57
+ return getStaticProps
58
+ ? await getStaticProps({
59
+ pathname: { params: params ?? {} },
60
+ appConfig: this.appConfig,
61
+ runtimeOrigin: this.runtimeOrigin,
62
+ })
63
+ .then((data) => data)
64
+ .catch((err) => {
65
+ throw new Error(`Error fetching static props: ${err.message}`);
66
+ })
67
+ : {
68
+ props: {},
69
+ metadata: undefined,
70
+ };
71
+ }
72
+
73
+ /**
74
+ * Builds final page metadata using app-level defaults as a baseline.
75
+ * If `getMetadata` exists, its result overlays defaults so page-level fields take precedence.
76
+ */
77
+ async getMetadataPropsForPage(options: {
78
+ getMetadata: GetMetadata | undefined;
79
+ context: GetMetadataContext;
80
+ }): Promise<PageMetadataProps> {
81
+ const { getMetadata, context } = options;
82
+ let metadata: PageMetadataProps = this.appConfig.defaultMetadata;
83
+ if (getMetadata) {
84
+ const dynamicMetadata = await getMetadata({
85
+ params: context.params,
86
+ query: context.query,
87
+ props: context.props,
88
+ appConfig: this.appConfig,
89
+ });
90
+ metadata = { ...metadata, ...dynamicMetadata };
91
+ }
92
+ return metadata;
93
+ }
94
+
95
+ /**
96
+ * Loads a page module and normalizes integration-facing exports.
97
+ * When both component static methods and module exports exist, component statics win.
98
+ */
99
+ async resolvePageModule(options: {
100
+ file: string;
101
+ importPageFileFn?: (file: string) => Promise<EcoPageFile>;
102
+ }): Promise<{
103
+ Page: EcoPageFile['default'] | EcoPageComponent<any>;
104
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
105
+ getMetadata?: GetMetadata;
106
+ integrationSpecificProps: Record<string, unknown>;
107
+ }> {
108
+ const module = await (options.importPageFileFn ?? ((file) => this.importPageFile(file)))(options.file);
109
+ const {
110
+ default: Page,
111
+ getStaticProps: moduleGetStaticProps,
112
+ getMetadata: moduleGetMetadata,
113
+ ...integrationSpecificProps
114
+ } = module;
115
+
116
+ return {
117
+ Page,
118
+ getStaticProps: Page.staticProps ?? moduleGetStaticProps,
119
+ getMetadata: Page.metadata ?? moduleGetMetadata,
120
+ integrationSpecificProps,
121
+ };
122
+ }
123
+
124
+ /**
125
+ * Resolves render-time page data in order: static props first, then metadata derived from those props.
126
+ */
127
+ async resolvePageData(options: {
128
+ pageModule: {
129
+ getStaticProps?: GetStaticProps<Record<string, unknown>>;
130
+ getMetadata?: GetMetadata;
131
+ };
132
+ routeOptions: RouteRendererOptions;
133
+ }): Promise<{
134
+ props: Record<string, unknown>;
135
+ metadata: PageMetadataProps;
136
+ }> {
137
+ const { props } = await this.getStaticPropsForPage({
138
+ getStaticProps: options.pageModule.getStaticProps,
139
+ params: options.routeOptions.params,
140
+ });
141
+
142
+ const metadata = await this.getMetadataPropsForPage({
143
+ getMetadata: options.pageModule.getMetadata,
144
+ context: {
145
+ props,
146
+ params: options.routeOptions.params ?? {},
147
+ query: options.routeOptions.query ?? {},
148
+ } as GetMetadataContext,
149
+ });
150
+
151
+ return { props, metadata };
152
+ }
153
+ }