@rangojs/router 0.0.0-experimental.760a71d9 → 0.0.0-experimental.77

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 (926) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +130 -47
  3. package/dist/vite/index.js +716 -237
  4. package/package.json +3 -3
  5. package/skills/cache-guide/SKILL.md +32 -0
  6. package/skills/caching/SKILL.md +8 -0
  7. package/skills/handler-use/SKILL.md +362 -0
  8. package/skills/intercept/SKILL.md +20 -0
  9. package/skills/layout/SKILL.md +22 -0
  10. package/skills/links/SKILL.md +3 -1
  11. package/skills/loader/SKILL.md +53 -43
  12. package/skills/middleware/SKILL.md +2 -0
  13. package/skills/parallel/SKILL.md +126 -0
  14. package/skills/prerender/SKILL.md +110 -68
  15. package/skills/route/SKILL.md +55 -0
  16. package/skills/router-setup/SKILL.md +87 -2
  17. package/skills/typesafety/SKILL.md +10 -0
  18. package/src/__internal.ts +1 -1
  19. package/src/browser/app-version.ts +14 -0
  20. package/src/browser/navigation-bridge.ts +23 -4
  21. package/src/browser/navigation-client.ts +98 -46
  22. package/src/browser/navigation-store.ts +43 -8
  23. package/src/browser/partial-update.ts +32 -5
  24. package/src/browser/prefetch/cache.ts +16 -6
  25. package/src/browser/prefetch/fetch.ts +68 -6
  26. package/src/browser/prefetch/queue.ts +61 -29
  27. package/src/browser/prefetch/resource-ready.ts +77 -0
  28. package/src/browser/react/Link.tsx +67 -8
  29. package/src/browser/react/NavigationProvider.tsx +13 -4
  30. package/src/browser/react/context.ts +7 -2
  31. package/src/browser/react/use-handle.ts +9 -58
  32. package/src/browser/react/use-router.ts +21 -8
  33. package/src/browser/rsc-router.tsx +26 -3
  34. package/src/browser/scroll-restoration.ts +10 -8
  35. package/src/browser/segment-reconciler.ts +26 -0
  36. package/src/browser/server-action-bridge.ts +8 -6
  37. package/src/browser/types.ts +27 -5
  38. package/src/build/generate-manifest.ts +6 -6
  39. package/src/build/generate-route-types.ts +3 -0
  40. package/src/build/route-trie.ts +50 -24
  41. package/src/build/route-types/include-resolution.ts +8 -1
  42. package/src/build/route-types/router-processing.ts +211 -72
  43. package/src/build/route-types/scan-filter.ts +8 -1
  44. package/src/cache/cache-scope.ts +46 -5
  45. package/src/cache/taint.ts +55 -0
  46. package/src/client.tsx +2 -56
  47. package/src/context-var.ts +72 -2
  48. package/src/handle.ts +40 -0
  49. package/src/index.rsc.ts +3 -1
  50. package/src/index.ts +46 -6
  51. package/src/prerender/store.ts +5 -4
  52. package/src/prerender.ts +138 -77
  53. package/src/reverse.ts +25 -1
  54. package/src/route-definition/dsl-helpers.ts +194 -32
  55. package/src/route-definition/helpers-types.ts +67 -19
  56. package/src/route-definition/index.ts +3 -0
  57. package/src/route-definition/redirect.ts +9 -1
  58. package/src/route-definition/resolve-handler-use.ts +149 -0
  59. package/src/route-types.ts +11 -0
  60. package/src/router/content-negotiation.ts +100 -1
  61. package/src/router/handler-context.ts +82 -23
  62. package/src/router/intercept-resolution.ts +9 -4
  63. package/src/router/loader-resolution.ts +156 -21
  64. package/src/router/match-api.ts +124 -189
  65. package/src/router/match-middleware/background-revalidation.ts +12 -1
  66. package/src/router/match-middleware/cache-lookup.ts +40 -13
  67. package/src/router/match-middleware/cache-store.ts +21 -4
  68. package/src/router/match-middleware/segment-resolution.ts +53 -0
  69. package/src/router/match-result.ts +82 -4
  70. package/src/router/middleware-types.ts +6 -8
  71. package/src/router/middleware.ts +2 -5
  72. package/src/router/navigation-snapshot.ts +182 -0
  73. package/src/router/prerender-match.ts +110 -10
  74. package/src/router/preview-match.ts +30 -102
  75. package/src/router/request-classification.ts +310 -0
  76. package/src/router/route-snapshot.ts +245 -0
  77. package/src/router/router-context.ts +1 -0
  78. package/src/router/router-interfaces.ts +36 -4
  79. package/src/router/router-options.ts +37 -11
  80. package/src/router/segment-resolution/fresh.ts +80 -9
  81. package/src/router/segment-resolution/helpers.ts +29 -24
  82. package/src/router/segment-resolution/revalidation.ts +91 -8
  83. package/src/router/types.ts +1 -0
  84. package/src/router.ts +54 -5
  85. package/src/rsc/handler.ts +472 -372
  86. package/src/rsc/loader-fetch.ts +23 -3
  87. package/src/rsc/manifest-init.ts +5 -1
  88. package/src/rsc/progressive-enhancement.ts +14 -2
  89. package/src/rsc/rsc-rendering.ts +10 -1
  90. package/src/rsc/server-action.ts +8 -0
  91. package/src/rsc/ssr-setup.ts +2 -2
  92. package/src/rsc/types.ts +9 -1
  93. package/src/server/context.ts +50 -1
  94. package/src/server/handle-store.ts +19 -0
  95. package/src/server/loader-registry.ts +9 -8
  96. package/src/server/request-context.ts +175 -15
  97. package/src/ssr/index.tsx +3 -0
  98. package/src/static-handler.ts +18 -6
  99. package/src/types/cache-types.ts +4 -4
  100. package/src/types/handler-context.ts +37 -19
  101. package/src/types/loader-types.ts +36 -9
  102. package/src/types/route-entry.ts +1 -1
  103. package/src/types/segments.ts +1 -0
  104. package/src/urls/path-helper-types.ts +39 -6
  105. package/src/urls/path-helper.ts +47 -12
  106. package/src/urls/pattern-types.ts +12 -0
  107. package/src/urls/response-types.ts +16 -6
  108. package/src/use-loader.tsx +77 -5
  109. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  110. package/src/vite/discovery/discover-routers.ts +5 -1
  111. package/src/vite/discovery/prerender-collection.ts +128 -74
  112. package/src/vite/discovery/state.ts +13 -4
  113. package/src/vite/index.ts +4 -0
  114. package/src/vite/plugin-types.ts +60 -5
  115. package/src/vite/plugins/expose-id-utils.ts +12 -0
  116. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  117. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  118. package/src/vite/plugins/performance-tracks.ts +88 -0
  119. package/src/vite/plugins/refresh-cmd.ts +88 -26
  120. package/src/vite/rango.ts +19 -2
  121. package/src/vite/router-discovery.ts +178 -37
  122. package/src/vite/utils/prerender-utils.ts +37 -5
  123. package/src/vite/utils/shared-utils.ts +3 -2
  124. package/dist/__internal.d.ts +0 -83
  125. package/dist/__internal.d.ts.map +0 -1
  126. package/dist/__internal.js +0 -19
  127. package/dist/__internal.js.map +0 -1
  128. package/dist/__mocks__/version.d.ts +0 -7
  129. package/dist/__mocks__/version.d.ts.map +0 -1
  130. package/dist/__mocks__/version.js +0 -7
  131. package/dist/__mocks__/version.js.map +0 -1
  132. package/dist/__tests__/client-href.test.d.ts +0 -2
  133. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  134. package/dist/__tests__/client-href.test.js +0 -74
  135. package/dist/__tests__/client-href.test.js.map +0 -1
  136. package/dist/__tests__/component-utils.test.d.ts +0 -2
  137. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  138. package/dist/__tests__/component-utils.test.js +0 -51
  139. package/dist/__tests__/component-utils.test.js.map +0 -1
  140. package/dist/__tests__/event-controller.test.d.ts +0 -2
  141. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  142. package/dist/__tests__/event-controller.test.js +0 -538
  143. package/dist/__tests__/event-controller.test.js.map +0 -1
  144. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  145. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  146. package/dist/__tests__/helpers/route-tree.js +0 -374
  147. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  148. package/dist/__tests__/match-result.test.d.ts +0 -2
  149. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  150. package/dist/__tests__/match-result.test.js +0 -154
  151. package/dist/__tests__/match-result.test.js.map +0 -1
  152. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  153. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  154. package/dist/__tests__/navigation-store.test.js +0 -440
  155. package/dist/__tests__/navigation-store.test.js.map +0 -1
  156. package/dist/__tests__/partial-update.test.d.ts +0 -2
  157. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  158. package/dist/__tests__/partial-update.test.js +0 -1009
  159. package/dist/__tests__/partial-update.test.js.map +0 -1
  160. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  161. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  162. package/dist/__tests__/reverse-types.test.js +0 -656
  163. package/dist/__tests__/reverse-types.test.js.map +0 -1
  164. package/dist/__tests__/route-definition.test.d.ts +0 -2
  165. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  166. package/dist/__tests__/route-definition.test.js +0 -55
  167. package/dist/__tests__/route-definition.test.js.map +0 -1
  168. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  169. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  170. package/dist/__tests__/router-helpers.test.js +0 -377
  171. package/dist/__tests__/router-helpers.test.js.map +0 -1
  172. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  173. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  174. package/dist/__tests__/router-integration-2.test.js +0 -426
  175. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  176. package/dist/__tests__/router-integration.test.d.ts +0 -2
  177. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  178. package/dist/__tests__/router-integration.test.js +0 -1051
  179. package/dist/__tests__/router-integration.test.js.map +0 -1
  180. package/dist/__tests__/search-params.test.d.ts +0 -5
  181. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  182. package/dist/__tests__/search-params.test.js +0 -306
  183. package/dist/__tests__/search-params.test.js.map +0 -1
  184. package/dist/__tests__/segment-system.test.d.ts +0 -2
  185. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  186. package/dist/__tests__/segment-system.test.js +0 -627
  187. package/dist/__tests__/segment-system.test.js.map +0 -1
  188. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  189. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  190. package/dist/__tests__/static-handler-types.test.js +0 -63
  191. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  192. package/dist/__tests__/urls.test.d.ts +0 -2
  193. package/dist/__tests__/urls.test.d.ts.map +0 -1
  194. package/dist/__tests__/urls.test.js +0 -421
  195. package/dist/__tests__/urls.test.js.map +0 -1
  196. package/dist/__tests__/use-mount.test.d.ts +0 -2
  197. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  198. package/dist/__tests__/use-mount.test.js +0 -35
  199. package/dist/__tests__/use-mount.test.js.map +0 -1
  200. package/dist/bin/rango.d.ts +0 -2
  201. package/dist/bin/rango.d.ts.map +0 -1
  202. package/dist/bin/rango.js.map +0 -1
  203. package/dist/browser/event-controller.d.ts +0 -191
  204. package/dist/browser/event-controller.d.ts.map +0 -1
  205. package/dist/browser/event-controller.js +0 -559
  206. package/dist/browser/event-controller.js.map +0 -1
  207. package/dist/browser/index.d.ts +0 -2
  208. package/dist/browser/index.d.ts.map +0 -1
  209. package/dist/browser/index.js +0 -14
  210. package/dist/browser/index.js.map +0 -1
  211. package/dist/browser/link-interceptor.d.ts +0 -38
  212. package/dist/browser/link-interceptor.d.ts.map +0 -1
  213. package/dist/browser/link-interceptor.js +0 -99
  214. package/dist/browser/link-interceptor.js.map +0 -1
  215. package/dist/browser/logging.d.ts +0 -10
  216. package/dist/browser/logging.d.ts.map +0 -1
  217. package/dist/browser/logging.js +0 -29
  218. package/dist/browser/logging.js.map +0 -1
  219. package/dist/browser/lru-cache.d.ts +0 -17
  220. package/dist/browser/lru-cache.d.ts.map +0 -1
  221. package/dist/browser/lru-cache.js +0 -50
  222. package/dist/browser/lru-cache.js.map +0 -1
  223. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  224. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  225. package/dist/browser/merge-segment-loaders.js +0 -102
  226. package/dist/browser/merge-segment-loaders.js.map +0 -1
  227. package/dist/browser/navigation-bridge.d.ts +0 -102
  228. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  229. package/dist/browser/navigation-bridge.js +0 -708
  230. package/dist/browser/navigation-bridge.js.map +0 -1
  231. package/dist/browser/navigation-client.d.ts +0 -25
  232. package/dist/browser/navigation-client.d.ts.map +0 -1
  233. package/dist/browser/navigation-client.js +0 -157
  234. package/dist/browser/navigation-client.js.map +0 -1
  235. package/dist/browser/navigation-store.d.ts +0 -101
  236. package/dist/browser/navigation-store.d.ts.map +0 -1
  237. package/dist/browser/navigation-store.js +0 -625
  238. package/dist/browser/navigation-store.js.map +0 -1
  239. package/dist/browser/partial-update.d.ts +0 -75
  240. package/dist/browser/partial-update.d.ts.map +0 -1
  241. package/dist/browser/partial-update.js +0 -426
  242. package/dist/browser/partial-update.js.map +0 -1
  243. package/dist/browser/react/Link.d.ts +0 -86
  244. package/dist/browser/react/Link.d.ts.map +0 -1
  245. package/dist/browser/react/Link.js +0 -128
  246. package/dist/browser/react/Link.js.map +0 -1
  247. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  248. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  249. package/dist/browser/react/NavigationProvider.js +0 -216
  250. package/dist/browser/react/NavigationProvider.js.map +0 -1
  251. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  252. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  253. package/dist/browser/react/ScrollRestoration.js +0 -57
  254. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  255. package/dist/browser/react/context.d.ts +0 -46
  256. package/dist/browser/react/context.d.ts.map +0 -1
  257. package/dist/browser/react/context.js +0 -10
  258. package/dist/browser/react/context.js.map +0 -1
  259. package/dist/browser/react/index.d.ts +0 -11
  260. package/dist/browser/react/index.d.ts.map +0 -1
  261. package/dist/browser/react/index.js +0 -22
  262. package/dist/browser/react/index.js.map +0 -1
  263. package/dist/browser/react/location-state-shared.d.ts +0 -63
  264. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  265. package/dist/browser/react/location-state-shared.js +0 -81
  266. package/dist/browser/react/location-state-shared.js.map +0 -1
  267. package/dist/browser/react/location-state.d.ts +0 -23
  268. package/dist/browser/react/location-state.d.ts.map +0 -1
  269. package/dist/browser/react/location-state.js +0 -29
  270. package/dist/browser/react/location-state.js.map +0 -1
  271. package/dist/browser/react/mount-context.d.ts +0 -24
  272. package/dist/browser/react/mount-context.d.ts.map +0 -1
  273. package/dist/browser/react/mount-context.js +0 -24
  274. package/dist/browser/react/mount-context.js.map +0 -1
  275. package/dist/browser/react/use-action.d.ts +0 -64
  276. package/dist/browser/react/use-action.d.ts.map +0 -1
  277. package/dist/browser/react/use-action.js +0 -134
  278. package/dist/browser/react/use-action.js.map +0 -1
  279. package/dist/browser/react/use-client-cache.d.ts +0 -41
  280. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  281. package/dist/browser/react/use-client-cache.js +0 -39
  282. package/dist/browser/react/use-client-cache.js.map +0 -1
  283. package/dist/browser/react/use-handle.d.ts +0 -31
  284. package/dist/browser/react/use-handle.d.ts.map +0 -1
  285. package/dist/browser/react/use-handle.js +0 -144
  286. package/dist/browser/react/use-handle.js.map +0 -1
  287. package/dist/browser/react/use-href.d.ts +0 -33
  288. package/dist/browser/react/use-href.d.ts.map +0 -1
  289. package/dist/browser/react/use-href.js +0 -39
  290. package/dist/browser/react/use-href.js.map +0 -1
  291. package/dist/browser/react/use-link-status.d.ts +0 -37
  292. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  293. package/dist/browser/react/use-link-status.js +0 -99
  294. package/dist/browser/react/use-link-status.js.map +0 -1
  295. package/dist/browser/react/use-mount.d.ts +0 -25
  296. package/dist/browser/react/use-mount.d.ts.map +0 -1
  297. package/dist/browser/react/use-mount.js +0 -30
  298. package/dist/browser/react/use-mount.js.map +0 -1
  299. package/dist/browser/react/use-navigation.d.ts +0 -27
  300. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  301. package/dist/browser/react/use-navigation.js +0 -87
  302. package/dist/browser/react/use-navigation.js.map +0 -1
  303. package/dist/browser/react/use-segments.d.ts +0 -38
  304. package/dist/browser/react/use-segments.d.ts.map +0 -1
  305. package/dist/browser/react/use-segments.js +0 -130
  306. package/dist/browser/react/use-segments.js.map +0 -1
  307. package/dist/browser/request-controller.d.ts +0 -26
  308. package/dist/browser/request-controller.d.ts.map +0 -1
  309. package/dist/browser/request-controller.js +0 -147
  310. package/dist/browser/request-controller.js.map +0 -1
  311. package/dist/browser/rsc-router.d.ts +0 -129
  312. package/dist/browser/rsc-router.d.ts.map +0 -1
  313. package/dist/browser/rsc-router.js +0 -195
  314. package/dist/browser/rsc-router.js.map +0 -1
  315. package/dist/browser/scroll-restoration.d.ts +0 -93
  316. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  317. package/dist/browser/scroll-restoration.js +0 -321
  318. package/dist/browser/scroll-restoration.js.map +0 -1
  319. package/dist/browser/segment-structure-assert.d.ts +0 -17
  320. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  321. package/dist/browser/segment-structure-assert.js +0 -59
  322. package/dist/browser/segment-structure-assert.js.map +0 -1
  323. package/dist/browser/server-action-bridge.d.ts +0 -26
  324. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  325. package/dist/browser/server-action-bridge.js +0 -668
  326. package/dist/browser/server-action-bridge.js.map +0 -1
  327. package/dist/browser/shallow.d.ts +0 -12
  328. package/dist/browser/shallow.d.ts.map +0 -1
  329. package/dist/browser/shallow.js +0 -34
  330. package/dist/browser/shallow.js.map +0 -1
  331. package/dist/browser/types.d.ts +0 -369
  332. package/dist/browser/types.d.ts.map +0 -1
  333. package/dist/browser/types.js +0 -2
  334. package/dist/browser/types.js.map +0 -1
  335. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  336. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  337. package/dist/build/__tests__/generate-cli.test.js +0 -237
  338. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  339. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  340. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  341. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  342. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  343. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  344. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  345. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  346. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  347. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  348. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  349. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  350. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  351. package/dist/build/generate-manifest.d.ts +0 -81
  352. package/dist/build/generate-manifest.d.ts.map +0 -1
  353. package/dist/build/generate-manifest.js +0 -276
  354. package/dist/build/generate-manifest.js.map +0 -1
  355. package/dist/build/generate-route-types.d.ts +0 -115
  356. package/dist/build/generate-route-types.d.ts.map +0 -1
  357. package/dist/build/generate-route-types.js +0 -740
  358. package/dist/build/generate-route-types.js.map +0 -1
  359. package/dist/build/index.d.ts +0 -21
  360. package/dist/build/index.d.ts.map +0 -1
  361. package/dist/build/index.js +0 -21
  362. package/dist/build/index.js.map +0 -1
  363. package/dist/build/route-trie.d.ts +0 -71
  364. package/dist/build/route-trie.d.ts.map +0 -1
  365. package/dist/build/route-trie.js +0 -175
  366. package/dist/build/route-trie.js.map +0 -1
  367. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  368. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  369. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  370. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  371. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  372. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  373. package/dist/cache/__tests__/document-cache.test.js +0 -345
  374. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  375. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  376. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  377. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  378. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  379. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  380. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  381. package/dist/cache/__tests__/memory-store.test.js +0 -367
  382. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  383. package/dist/cache/cache-scope.d.ts +0 -102
  384. package/dist/cache/cache-scope.d.ts.map +0 -1
  385. package/dist/cache/cache-scope.js +0 -440
  386. package/dist/cache/cache-scope.js.map +0 -1
  387. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  388. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  389. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  390. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  391. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  392. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  393. package/dist/cache/cf/cf-cache-store.js +0 -242
  394. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  395. package/dist/cache/cf/index.d.ts +0 -14
  396. package/dist/cache/cf/index.d.ts.map +0 -1
  397. package/dist/cache/cf/index.js +0 -17
  398. package/dist/cache/cf/index.js.map +0 -1
  399. package/dist/cache/document-cache.d.ts +0 -64
  400. package/dist/cache/document-cache.d.ts.map +0 -1
  401. package/dist/cache/document-cache.js +0 -228
  402. package/dist/cache/document-cache.js.map +0 -1
  403. package/dist/cache/index.d.ts +0 -19
  404. package/dist/cache/index.d.ts.map +0 -1
  405. package/dist/cache/index.js +0 -21
  406. package/dist/cache/index.js.map +0 -1
  407. package/dist/cache/memory-segment-store.d.ts +0 -110
  408. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  409. package/dist/cache/memory-segment-store.js +0 -117
  410. package/dist/cache/memory-segment-store.js.map +0 -1
  411. package/dist/cache/memory-store.d.ts +0 -41
  412. package/dist/cache/memory-store.d.ts.map +0 -1
  413. package/dist/cache/memory-store.js +0 -191
  414. package/dist/cache/memory-store.js.map +0 -1
  415. package/dist/cache/types.d.ts +0 -317
  416. package/dist/cache/types.d.ts.map +0 -1
  417. package/dist/cache/types.js +0 -12
  418. package/dist/cache/types.js.map +0 -1
  419. package/dist/client.d.ts +0 -248
  420. package/dist/client.d.ts.map +0 -1
  421. package/dist/client.js +0 -367
  422. package/dist/client.js.map +0 -1
  423. package/dist/client.rsc.d.ts +0 -26
  424. package/dist/client.rsc.d.ts.map +0 -1
  425. package/dist/client.rsc.js +0 -46
  426. package/dist/client.rsc.js.map +0 -1
  427. package/dist/component-utils.d.ts +0 -36
  428. package/dist/component-utils.d.ts.map +0 -1
  429. package/dist/component-utils.js +0 -61
  430. package/dist/component-utils.js.map +0 -1
  431. package/dist/components/DefaultDocument.d.ts +0 -13
  432. package/dist/components/DefaultDocument.d.ts.map +0 -1
  433. package/dist/components/DefaultDocument.js +0 -15
  434. package/dist/components/DefaultDocument.js.map +0 -1
  435. package/dist/debug.d.ts +0 -58
  436. package/dist/debug.d.ts.map +0 -1
  437. package/dist/debug.js +0 -157
  438. package/dist/debug.js.map +0 -1
  439. package/dist/default-error-boundary.d.ts +0 -11
  440. package/dist/default-error-boundary.d.ts.map +0 -1
  441. package/dist/default-error-boundary.js +0 -45
  442. package/dist/default-error-boundary.js.map +0 -1
  443. package/dist/deps/browser.d.ts +0 -2
  444. package/dist/deps/browser.d.ts.map +0 -1
  445. package/dist/deps/browser.js +0 -3
  446. package/dist/deps/browser.js.map +0 -1
  447. package/dist/deps/html-stream-client.d.ts +0 -2
  448. package/dist/deps/html-stream-client.d.ts.map +0 -1
  449. package/dist/deps/html-stream-client.js +0 -3
  450. package/dist/deps/html-stream-client.js.map +0 -1
  451. package/dist/deps/html-stream-server.d.ts +0 -2
  452. package/dist/deps/html-stream-server.d.ts.map +0 -1
  453. package/dist/deps/html-stream-server.js +0 -3
  454. package/dist/deps/html-stream-server.js.map +0 -1
  455. package/dist/deps/rsc.d.ts +0 -2
  456. package/dist/deps/rsc.d.ts.map +0 -1
  457. package/dist/deps/rsc.js +0 -4
  458. package/dist/deps/rsc.js.map +0 -1
  459. package/dist/deps/ssr.d.ts +0 -2
  460. package/dist/deps/ssr.d.ts.map +0 -1
  461. package/dist/deps/ssr.js +0 -3
  462. package/dist/deps/ssr.js.map +0 -1
  463. package/dist/errors.d.ts +0 -174
  464. package/dist/errors.d.ts.map +0 -1
  465. package/dist/errors.js +0 -241
  466. package/dist/errors.js.map +0 -1
  467. package/dist/handle.d.ts +0 -78
  468. package/dist/handle.d.ts.map +0 -1
  469. package/dist/handle.js +0 -82
  470. package/dist/handle.js.map +0 -1
  471. package/dist/handles/MetaTags.d.ts +0 -14
  472. package/dist/handles/MetaTags.d.ts.map +0 -1
  473. package/dist/handles/MetaTags.js +0 -136
  474. package/dist/handles/MetaTags.js.map +0 -1
  475. package/dist/handles/index.d.ts +0 -6
  476. package/dist/handles/index.d.ts.map +0 -1
  477. package/dist/handles/index.js +0 -6
  478. package/dist/handles/index.js.map +0 -1
  479. package/dist/handles/meta.d.ts +0 -39
  480. package/dist/handles/meta.d.ts.map +0 -1
  481. package/dist/handles/meta.js +0 -202
  482. package/dist/handles/meta.js.map +0 -1
  483. package/dist/host/__tests__/errors.test.d.ts +0 -2
  484. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  485. package/dist/host/__tests__/errors.test.js +0 -76
  486. package/dist/host/__tests__/errors.test.js.map +0 -1
  487. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  488. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  489. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  490. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  491. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  492. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  493. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  494. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  495. package/dist/host/__tests__/router.test.d.ts +0 -2
  496. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  497. package/dist/host/__tests__/router.test.js +0 -241
  498. package/dist/host/__tests__/router.test.js.map +0 -1
  499. package/dist/host/__tests__/testing.test.d.ts +0 -2
  500. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  501. package/dist/host/__tests__/testing.test.js +0 -64
  502. package/dist/host/__tests__/testing.test.js.map +0 -1
  503. package/dist/host/__tests__/utils.test.d.ts +0 -2
  504. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  505. package/dist/host/__tests__/utils.test.js +0 -29
  506. package/dist/host/__tests__/utils.test.js.map +0 -1
  507. package/dist/host/cookie-handler.d.ts +0 -34
  508. package/dist/host/cookie-handler.d.ts.map +0 -1
  509. package/dist/host/cookie-handler.js +0 -124
  510. package/dist/host/cookie-handler.js.map +0 -1
  511. package/dist/host/errors.d.ts +0 -56
  512. package/dist/host/errors.d.ts.map +0 -1
  513. package/dist/host/errors.js +0 -79
  514. package/dist/host/errors.js.map +0 -1
  515. package/dist/host/index.d.ts +0 -29
  516. package/dist/host/index.d.ts.map +0 -1
  517. package/dist/host/index.js +0 -32
  518. package/dist/host/index.js.map +0 -1
  519. package/dist/host/pattern-matcher.d.ts +0 -36
  520. package/dist/host/pattern-matcher.d.ts.map +0 -1
  521. package/dist/host/pattern-matcher.js +0 -172
  522. package/dist/host/pattern-matcher.js.map +0 -1
  523. package/dist/host/router.d.ts +0 -26
  524. package/dist/host/router.d.ts.map +0 -1
  525. package/dist/host/router.js +0 -218
  526. package/dist/host/router.js.map +0 -1
  527. package/dist/host/testing.d.ts +0 -36
  528. package/dist/host/testing.d.ts.map +0 -1
  529. package/dist/host/testing.js +0 -55
  530. package/dist/host/testing.js.map +0 -1
  531. package/dist/host/types.d.ts +0 -115
  532. package/dist/host/types.d.ts.map +0 -1
  533. package/dist/host/types.js +0 -7
  534. package/dist/host/types.js.map +0 -1
  535. package/dist/host/utils.d.ts +0 -21
  536. package/dist/host/utils.d.ts.map +0 -1
  537. package/dist/host/utils.js +0 -23
  538. package/dist/host/utils.js.map +0 -1
  539. package/dist/href-client.d.ts +0 -131
  540. package/dist/href-client.d.ts.map +0 -1
  541. package/dist/href-client.js +0 -64
  542. package/dist/href-client.js.map +0 -1
  543. package/dist/href-context.d.ts +0 -29
  544. package/dist/href-context.d.ts.map +0 -1
  545. package/dist/href-context.js +0 -21
  546. package/dist/href-context.js.map +0 -1
  547. package/dist/index.d.ts +0 -73
  548. package/dist/index.d.ts.map +0 -1
  549. package/dist/index.js +0 -91
  550. package/dist/index.js.map +0 -1
  551. package/dist/index.rsc.d.ts +0 -32
  552. package/dist/index.rsc.d.ts.map +0 -1
  553. package/dist/index.rsc.js +0 -40
  554. package/dist/index.rsc.js.map +0 -1
  555. package/dist/internal-debug.d.ts +0 -2
  556. package/dist/internal-debug.d.ts.map +0 -1
  557. package/dist/internal-debug.js +0 -5
  558. package/dist/internal-debug.js.map +0 -1
  559. package/dist/loader.d.ts +0 -14
  560. package/dist/loader.d.ts.map +0 -1
  561. package/dist/loader.js +0 -20
  562. package/dist/loader.js.map +0 -1
  563. package/dist/loader.rsc.d.ts +0 -19
  564. package/dist/loader.rsc.d.ts.map +0 -1
  565. package/dist/loader.rsc.js +0 -99
  566. package/dist/loader.rsc.js.map +0 -1
  567. package/dist/network-error-thrower.d.ts +0 -17
  568. package/dist/network-error-thrower.d.ts.map +0 -1
  569. package/dist/network-error-thrower.js +0 -14
  570. package/dist/network-error-thrower.js.map +0 -1
  571. package/dist/outlet-context.d.ts +0 -13
  572. package/dist/outlet-context.d.ts.map +0 -1
  573. package/dist/outlet-context.js +0 -3
  574. package/dist/outlet-context.js.map +0 -1
  575. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  576. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  577. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  578. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  579. package/dist/prerender/param-hash.d.ts +0 -16
  580. package/dist/prerender/param-hash.d.ts.map +0 -1
  581. package/dist/prerender/param-hash.js +0 -36
  582. package/dist/prerender/param-hash.js.map +0 -1
  583. package/dist/prerender/store.d.ts +0 -38
  584. package/dist/prerender/store.d.ts.map +0 -1
  585. package/dist/prerender/store.js +0 -61
  586. package/dist/prerender/store.js.map +0 -1
  587. package/dist/prerender.d.ts +0 -66
  588. package/dist/prerender.d.ts.map +0 -1
  589. package/dist/prerender.js +0 -57
  590. package/dist/prerender.js.map +0 -1
  591. package/dist/reverse.d.ts +0 -196
  592. package/dist/reverse.d.ts.map +0 -1
  593. package/dist/reverse.js +0 -78
  594. package/dist/reverse.js.map +0 -1
  595. package/dist/root-error-boundary.d.ts +0 -33
  596. package/dist/root-error-boundary.d.ts.map +0 -1
  597. package/dist/root-error-boundary.js +0 -165
  598. package/dist/root-error-boundary.js.map +0 -1
  599. package/dist/route-content-wrapper.d.ts +0 -46
  600. package/dist/route-content-wrapper.d.ts.map +0 -1
  601. package/dist/route-content-wrapper.js +0 -77
  602. package/dist/route-content-wrapper.js.map +0 -1
  603. package/dist/route-definition.d.ts +0 -421
  604. package/dist/route-definition.d.ts.map +0 -1
  605. package/dist/route-definition.js +0 -868
  606. package/dist/route-definition.js.map +0 -1
  607. package/dist/route-map-builder.d.ts +0 -155
  608. package/dist/route-map-builder.d.ts.map +0 -1
  609. package/dist/route-map-builder.js +0 -237
  610. package/dist/route-map-builder.js.map +0 -1
  611. package/dist/route-types.d.ts +0 -165
  612. package/dist/route-types.d.ts.map +0 -1
  613. package/dist/route-types.js +0 -7
  614. package/dist/route-types.js.map +0 -1
  615. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  616. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  617. package/dist/router/__tests__/handler-context.test.js +0 -65
  618. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  619. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  620. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  621. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  622. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  623. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  624. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  625. package/dist/router/__tests__/match-context.test.js +0 -92
  626. package/dist/router/__tests__/match-context.test.js.map +0 -1
  627. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  628. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  629. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  630. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  631. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  632. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  633. package/dist/router/__tests__/match-result.test.js +0 -457
  634. package/dist/router/__tests__/match-result.test.js.map +0 -1
  635. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  636. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  637. package/dist/router/__tests__/on-error.test.js +0 -678
  638. package/dist/router/__tests__/on-error.test.js.map +0 -1
  639. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  640. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  641. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  642. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  643. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  644. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  645. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  646. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  647. package/dist/router/error-handling.d.ts +0 -77
  648. package/dist/router/error-handling.d.ts.map +0 -1
  649. package/dist/router/error-handling.js +0 -202
  650. package/dist/router/error-handling.js.map +0 -1
  651. package/dist/router/handler-context.d.ts +0 -20
  652. package/dist/router/handler-context.d.ts.map +0 -1
  653. package/dist/router/handler-context.js +0 -198
  654. package/dist/router/handler-context.js.map +0 -1
  655. package/dist/router/intercept-resolution.d.ts +0 -66
  656. package/dist/router/intercept-resolution.d.ts.map +0 -1
  657. package/dist/router/intercept-resolution.js +0 -246
  658. package/dist/router/intercept-resolution.js.map +0 -1
  659. package/dist/router/loader-resolution.d.ts +0 -64
  660. package/dist/router/loader-resolution.d.ts.map +0 -1
  661. package/dist/router/loader-resolution.js +0 -284
  662. package/dist/router/loader-resolution.js.map +0 -1
  663. package/dist/router/logging.d.ts +0 -15
  664. package/dist/router/logging.d.ts.map +0 -1
  665. package/dist/router/logging.js +0 -99
  666. package/dist/router/logging.js.map +0 -1
  667. package/dist/router/manifest.d.ts +0 -22
  668. package/dist/router/manifest.d.ts.map +0 -1
  669. package/dist/router/manifest.js +0 -181
  670. package/dist/router/manifest.js.map +0 -1
  671. package/dist/router/match-api.d.ts +0 -35
  672. package/dist/router/match-api.d.ts.map +0 -1
  673. package/dist/router/match-api.js +0 -406
  674. package/dist/router/match-api.js.map +0 -1
  675. package/dist/router/match-context.d.ts +0 -206
  676. package/dist/router/match-context.d.ts.map +0 -1
  677. package/dist/router/match-context.js +0 -17
  678. package/dist/router/match-context.js.map +0 -1
  679. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  680. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  681. package/dist/router/match-middleware/background-revalidation.js +0 -75
  682. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  683. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  684. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  685. package/dist/router/match-middleware/cache-lookup.js +0 -257
  686. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  687. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  688. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  689. package/dist/router/match-middleware/cache-store.js +0 -108
  690. package/dist/router/match-middleware/cache-store.js.map +0 -1
  691. package/dist/router/match-middleware/index.d.ts +0 -81
  692. package/dist/router/match-middleware/index.d.ts.map +0 -1
  693. package/dist/router/match-middleware/index.js +0 -80
  694. package/dist/router/match-middleware/index.js.map +0 -1
  695. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  696. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  697. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  698. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  699. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  700. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  701. package/dist/router/match-middleware/segment-resolution.js +0 -53
  702. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  703. package/dist/router/match-pipelines.d.ts +0 -147
  704. package/dist/router/match-pipelines.d.ts.map +0 -1
  705. package/dist/router/match-pipelines.js +0 -82
  706. package/dist/router/match-pipelines.js.map +0 -1
  707. package/dist/router/match-result.d.ts +0 -126
  708. package/dist/router/match-result.d.ts.map +0 -1
  709. package/dist/router/match-result.js +0 -93
  710. package/dist/router/match-result.js.map +0 -1
  711. package/dist/router/metrics.d.ts +0 -20
  712. package/dist/router/metrics.d.ts.map +0 -1
  713. package/dist/router/metrics.js +0 -47
  714. package/dist/router/metrics.js.map +0 -1
  715. package/dist/router/middleware.d.ts +0 -249
  716. package/dist/router/middleware.d.ts.map +0 -1
  717. package/dist/router/middleware.js +0 -434
  718. package/dist/router/middleware.js.map +0 -1
  719. package/dist/router/middleware.test.d.ts +0 -2
  720. package/dist/router/middleware.test.d.ts.map +0 -1
  721. package/dist/router/middleware.test.js +0 -816
  722. package/dist/router/middleware.test.js.map +0 -1
  723. package/dist/router/pattern-matching.d.ts +0 -149
  724. package/dist/router/pattern-matching.d.ts.map +0 -1
  725. package/dist/router/pattern-matching.js +0 -349
  726. package/dist/router/pattern-matching.js.map +0 -1
  727. package/dist/router/revalidation.d.ts +0 -44
  728. package/dist/router/revalidation.d.ts.map +0 -1
  729. package/dist/router/revalidation.js +0 -147
  730. package/dist/router/revalidation.js.map +0 -1
  731. package/dist/router/router-context.d.ts +0 -135
  732. package/dist/router/router-context.d.ts.map +0 -1
  733. package/dist/router/router-context.js +0 -36
  734. package/dist/router/router-context.js.map +0 -1
  735. package/dist/router/segment-resolution.d.ts +0 -127
  736. package/dist/router/segment-resolution.d.ts.map +0 -1
  737. package/dist/router/segment-resolution.js +0 -919
  738. package/dist/router/segment-resolution.js.map +0 -1
  739. package/dist/router/trie-matching.d.ts +0 -40
  740. package/dist/router/trie-matching.d.ts.map +0 -1
  741. package/dist/router/trie-matching.js +0 -127
  742. package/dist/router/trie-matching.js.map +0 -1
  743. package/dist/router/types.d.ts +0 -136
  744. package/dist/router/types.d.ts.map +0 -1
  745. package/dist/router/types.js +0 -7
  746. package/dist/router/types.js.map +0 -1
  747. package/dist/router.d.ts +0 -753
  748. package/dist/router.d.ts.map +0 -1
  749. package/dist/router.gen.d.ts +0 -6
  750. package/dist/router.gen.d.ts.map +0 -1
  751. package/dist/router.gen.js +0 -6
  752. package/dist/router.gen.js.map +0 -1
  753. package/dist/router.js +0 -1304
  754. package/dist/router.js.map +0 -1
  755. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  756. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  757. package/dist/rsc/__tests__/helpers.test.js +0 -140
  758. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  759. package/dist/rsc/handler.d.ts +0 -45
  760. package/dist/rsc/handler.d.ts.map +0 -1
  761. package/dist/rsc/handler.js +0 -1172
  762. package/dist/rsc/handler.js.map +0 -1
  763. package/dist/rsc/helpers.d.ts +0 -16
  764. package/dist/rsc/helpers.d.ts.map +0 -1
  765. package/dist/rsc/helpers.js +0 -55
  766. package/dist/rsc/helpers.js.map +0 -1
  767. package/dist/rsc/index.d.ts +0 -22
  768. package/dist/rsc/index.d.ts.map +0 -1
  769. package/dist/rsc/index.js +0 -23
  770. package/dist/rsc/index.js.map +0 -1
  771. package/dist/rsc/nonce.d.ts +0 -9
  772. package/dist/rsc/nonce.d.ts.map +0 -1
  773. package/dist/rsc/nonce.js +0 -18
  774. package/dist/rsc/nonce.js.map +0 -1
  775. package/dist/rsc/types.d.ts +0 -206
  776. package/dist/rsc/types.d.ts.map +0 -1
  777. package/dist/rsc/types.js +0 -8
  778. package/dist/rsc/types.js.map +0 -1
  779. package/dist/search-params.d.ts +0 -103
  780. package/dist/search-params.d.ts.map +0 -1
  781. package/dist/search-params.js +0 -74
  782. package/dist/search-params.js.map +0 -1
  783. package/dist/segment-system.d.ts +0 -75
  784. package/dist/segment-system.d.ts.map +0 -1
  785. package/dist/segment-system.js +0 -336
  786. package/dist/segment-system.js.map +0 -1
  787. package/dist/server/context.d.ts +0 -245
  788. package/dist/server/context.d.ts.map +0 -1
  789. package/dist/server/context.js +0 -197
  790. package/dist/server/context.js.map +0 -1
  791. package/dist/server/fetchable-loader-store.d.ts +0 -18
  792. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  793. package/dist/server/fetchable-loader-store.js +0 -18
  794. package/dist/server/fetchable-loader-store.js.map +0 -1
  795. package/dist/server/handle-store.d.ts +0 -85
  796. package/dist/server/handle-store.d.ts.map +0 -1
  797. package/dist/server/handle-store.js +0 -142
  798. package/dist/server/handle-store.js.map +0 -1
  799. package/dist/server/loader-registry.d.ts +0 -55
  800. package/dist/server/loader-registry.d.ts.map +0 -1
  801. package/dist/server/loader-registry.js +0 -132
  802. package/dist/server/loader-registry.js.map +0 -1
  803. package/dist/server/request-context.d.ts +0 -226
  804. package/dist/server/request-context.d.ts.map +0 -1
  805. package/dist/server/request-context.js +0 -290
  806. package/dist/server/request-context.js.map +0 -1
  807. package/dist/server/root-layout.d.ts +0 -4
  808. package/dist/server/root-layout.d.ts.map +0 -1
  809. package/dist/server/root-layout.js +0 -5
  810. package/dist/server/root-layout.js.map +0 -1
  811. package/dist/server.d.ts +0 -15
  812. package/dist/server.d.ts.map +0 -1
  813. package/dist/server.js +0 -20
  814. package/dist/server.js.map +0 -1
  815. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  816. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  817. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  818. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  819. package/dist/ssr/index.d.ts +0 -98
  820. package/dist/ssr/index.d.ts.map +0 -1
  821. package/dist/ssr/index.js +0 -158
  822. package/dist/ssr/index.js.map +0 -1
  823. package/dist/static-handler.d.ts +0 -50
  824. package/dist/static-handler.d.ts.map +0 -1
  825. package/dist/static-handler.gen.d.ts +0 -5
  826. package/dist/static-handler.gen.d.ts.map +0 -1
  827. package/dist/static-handler.gen.js +0 -5
  828. package/dist/static-handler.gen.js.map +0 -1
  829. package/dist/static-handler.js +0 -29
  830. package/dist/static-handler.js.map +0 -1
  831. package/dist/theme/ThemeProvider.d.ts +0 -20
  832. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  833. package/dist/theme/ThemeProvider.js +0 -240
  834. package/dist/theme/ThemeProvider.js.map +0 -1
  835. package/dist/theme/ThemeScript.d.ts +0 -48
  836. package/dist/theme/ThemeScript.d.ts.map +0 -1
  837. package/dist/theme/ThemeScript.js +0 -13
  838. package/dist/theme/ThemeScript.js.map +0 -1
  839. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  840. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  841. package/dist/theme/__tests__/theme.test.js +0 -103
  842. package/dist/theme/__tests__/theme.test.js.map +0 -1
  843. package/dist/theme/constants.d.ts +0 -29
  844. package/dist/theme/constants.d.ts.map +0 -1
  845. package/dist/theme/constants.js +0 -48
  846. package/dist/theme/constants.js.map +0 -1
  847. package/dist/theme/index.d.ts +0 -31
  848. package/dist/theme/index.d.ts.map +0 -1
  849. package/dist/theme/index.js +0 -36
  850. package/dist/theme/index.js.map +0 -1
  851. package/dist/theme/theme-context.d.ts +0 -40
  852. package/dist/theme/theme-context.d.ts.map +0 -1
  853. package/dist/theme/theme-context.js +0 -60
  854. package/dist/theme/theme-context.js.map +0 -1
  855. package/dist/theme/theme-script.d.ts +0 -27
  856. package/dist/theme/theme-script.d.ts.map +0 -1
  857. package/dist/theme/theme-script.js +0 -147
  858. package/dist/theme/theme-script.js.map +0 -1
  859. package/dist/theme/types.d.ts +0 -163
  860. package/dist/theme/types.d.ts.map +0 -1
  861. package/dist/theme/types.js +0 -11
  862. package/dist/theme/types.js.map +0 -1
  863. package/dist/theme/use-theme.d.ts +0 -12
  864. package/dist/theme/use-theme.d.ts.map +0 -1
  865. package/dist/theme/use-theme.js +0 -40
  866. package/dist/theme/use-theme.js.map +0 -1
  867. package/dist/types.d.ts +0 -1479
  868. package/dist/types.d.ts.map +0 -1
  869. package/dist/types.js +0 -10
  870. package/dist/types.js.map +0 -1
  871. package/dist/urls.d.ts +0 -441
  872. package/dist/urls.d.ts.map +0 -1
  873. package/dist/urls.gen.d.ts +0 -8
  874. package/dist/urls.gen.d.ts.map +0 -1
  875. package/dist/urls.gen.js +0 -8
  876. package/dist/urls.gen.js.map +0 -1
  877. package/dist/urls.js +0 -443
  878. package/dist/urls.js.map +0 -1
  879. package/dist/use-loader.d.ts +0 -127
  880. package/dist/use-loader.d.ts.map +0 -1
  881. package/dist/use-loader.js +0 -237
  882. package/dist/use-loader.js.map +0 -1
  883. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  884. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  885. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  886. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  887. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  888. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  889. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  890. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  891. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  892. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  893. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  894. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  895. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  896. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  897. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  898. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  899. package/dist/vite/ast-handler-extract.d.ts +0 -49
  900. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  901. package/dist/vite/ast-handler-extract.js +0 -249
  902. package/dist/vite/ast-handler-extract.js.map +0 -1
  903. package/dist/vite/expose-action-id.d.ts +0 -19
  904. package/dist/vite/expose-action-id.d.ts.map +0 -1
  905. package/dist/vite/expose-action-id.js +0 -250
  906. package/dist/vite/expose-action-id.js.map +0 -1
  907. package/dist/vite/expose-id-utils.d.ts +0 -69
  908. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  909. package/dist/vite/expose-id-utils.js +0 -289
  910. package/dist/vite/expose-id-utils.js.map +0 -1
  911. package/dist/vite/expose-internal-ids.d.ts +0 -22
  912. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  913. package/dist/vite/expose-internal-ids.js +0 -886
  914. package/dist/vite/expose-internal-ids.js.map +0 -1
  915. package/dist/vite/index.d.ts +0 -149
  916. package/dist/vite/index.d.ts.map +0 -1
  917. package/dist/vite/index.js.map +0 -1
  918. package/dist/vite/index.named-routes.gen.ts +0 -103
  919. package/dist/vite/package-resolution.d.ts +0 -43
  920. package/dist/vite/package-resolution.d.ts.map +0 -1
  921. package/dist/vite/package-resolution.js +0 -112
  922. package/dist/vite/package-resolution.js.map +0 -1
  923. package/dist/vite/virtual-entries.d.ts +0 -25
  924. package/dist/vite/virtual-entries.d.ts.map +0 -1
  925. package/dist/vite/virtual-entries.js +0 -110
  926. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1,1172 +0,0 @@
1
- /// <reference types="@vitejs/plugin-rsc/types" />
2
- /// <reference path="../vite/version.d.ts" />
3
- /**
4
- * RSC Request Handler
5
- *
6
- * Main request handler for RSC rendering, server actions, loader fetching,
7
- * and progressive enhancement (no-JS form submissions).
8
- */
9
- import { createElement } from "react";
10
- import { renderSegments } from "../segment-system.js";
11
- import { RouteNotFoundError, RouterError } from "../errors.js";
12
- import { getLoaderLazy } from "../server/loader-registry.js";
13
- import { matchMiddleware, executeMiddleware, executeLoaderMiddleware, } from "../router/middleware.js";
14
- import { runWithRequestContext, setRequestContextParams, requireRequestContext, createRequestContext, } from "../server/request-context.js";
15
- import * as rscDeps from "@vitejs/plugin-rsc/rsc";
16
- import { hasBodyContent, createResponseWithMergedHeaders } from "./helpers.js";
17
- import { generateNonce } from "./nonce.js";
18
- import { VERSION } from "@rangojs/router:version";
19
- import { invokeOnError } from "../router/error-handling.js";
20
- import { getGlobalRouteMap, hasCachedManifest, setCachedManifest, getRouteTrie, setRouteTrie, getPrecomputedEntries, waitForManifestReady, getRouterManifest, getRouterTrie, setRouterManifest, setRouterTrie, } from "../route-map-builder.js";
21
- /**
22
- * Build a ResponseError payload from a caught error.
23
- * RouterError messages are always exposed (developer-crafted).
24
- * Standard Error messages are hidden in production.
25
- */
26
- function createResponseErrorPayload(error, isDev) {
27
- if (error instanceof RouterError) {
28
- return {
29
- message: error.message,
30
- code: error.code,
31
- ...(error.type ? { type: error.type } : {}),
32
- ...(isDev && error.stack ? { stack: error.stack } : {}),
33
- };
34
- }
35
- if (error instanceof Error) {
36
- return {
37
- message: isDev ? error.message : "Internal Server Error",
38
- ...(isDev && error.stack ? { stack: error.stack } : {}),
39
- };
40
- }
41
- return {
42
- message: isDev ? String(error) : "Internal Server Error",
43
- };
44
- }
45
- /**
46
- * Create an RSC request handler.
47
- *
48
- * **Recommended:** Use `router.createHandler()` instead for simpler setup:
49
- * ```tsx
50
- * const router = createRouter({ document, urls, nonce: () => true });
51
- * export const fetch = router.createHandler();
52
- * ```
53
- *
54
- * This function is still useful for advanced cases like per-request cache
55
- * configuration (e.g., Cloudflare Workers with ExecutionContext).
56
- *
57
- * @example Basic usage (deps and loadSSRModule have sensible defaults)
58
- * ```tsx
59
- * import { createRSCHandler } from "@rangojs/router/rsc";
60
- * import { router } from "./router.js";
61
- *
62
- * export default createRSCHandler({ router });
63
- * ```
64
- *
65
- * @example With custom deps (advanced)
66
- * ```tsx
67
- * import { createRSCHandler } from "@rangojs/router/rsc";
68
- * import * as rsc from "@vitejs/plugin-rsc/rsc";
69
- * import { router } from "./router.js";
70
- *
71
- * export default createRSCHandler({
72
- * router,
73
- * deps: rsc,
74
- * loadSSRModule: () => import.meta.viteRsc.loadModule("ssr", "index"),
75
- * });
76
- * ```
77
- */
78
- export function createRSCHandler(options) {
79
- const { router, version = VERSION, nonce: nonceProvider } = options;
80
- // Use provided deps or default to @vitejs/plugin-rsc/rsc exports
81
- const deps = options.deps ?? rscDeps;
82
- const { renderToReadableStream, decodeReply, createTemporaryReferenceSet, loadServerAction, decodeAction, decodeFormState, } = deps;
83
- // Use provided loadSSRModule or default to vite RSC module loader
84
- const loadSSRModule = options.loadSSRModule ??
85
- (() => import.meta.viteRsc.loadModule("ssr", "index"));
86
- /**
87
- * Wrapper for invokeOnError that binds the router's onError callback.
88
- * Uses the shared utility from router/error-handling.ts for consistent behavior.
89
- */
90
- function callOnError(error, phase, context) {
91
- invokeOnError(router.onError, error, phase, context, "RSC");
92
- }
93
- return async function handler(request, env = {}) {
94
- const handlerStart = performance.now();
95
- // Connection warmup: return 204 immediately before any processing
96
- if (router.warmupEnabled && request.method === "HEAD") {
97
- const warmupUrl = new URL(request.url);
98
- if (warmupUrl.searchParams.has("_rsc_warmup")) {
99
- return new Response(null, { status: 204 });
100
- }
101
- }
102
- // Resolve nonce if provider is set
103
- const nonceStart = performance.now();
104
- let nonce;
105
- if (nonceProvider) {
106
- const result = await nonceProvider(request, env);
107
- nonce = result === true ? generateNonce() : result;
108
- }
109
- const nonceDur = performance.now() - nonceStart;
110
- const url = new URL(request.url);
111
- // Match global middleware
112
- const mwMatchStart = performance.now();
113
- const matchedMiddleware = matchMiddleware(url.pathname, router.middleware);
114
- const mwMatchDur = performance.now() - mwMatchStart;
115
- // Shared variables between middleware and route handlers
116
- // Initialize from env.Variables if provided (allows pre-seeding from worker entry)
117
- const variables = {
118
- ...(env?.Variables ?? {}),
119
- };
120
- // Store nonce in variables so middleware can access via ctx.get('nonce')
121
- if (nonce) {
122
- variables.nonce = nonce;
123
- }
124
- // Resolve cache store configuration
125
- // Priority: options.cache (handler override) > router.cache (router default)
126
- // Store is enabled only if: config provided, enabled, and no ?__no_cache query param
127
- let cacheStore = undefined;
128
- const cacheOption = options.cache ?? router.cache;
129
- if (cacheOption && !url.searchParams.has("__no_cache")) {
130
- const cacheConfig = typeof cacheOption === "function" ? cacheOption(env) : cacheOption;
131
- if (cacheConfig.enabled !== false) {
132
- cacheStore = cacheConfig.store;
133
- }
134
- }
135
- // Route manifest is populated at startup via the virtual module
136
- // (virtual:rsc-router/routes-manifest). In build/production, it's inlined
137
- // into the bundle. In dev mode (Node), the discovery plugin populates it
138
- // via setManifestReadyPromise(). In dev mode (Cloudflare), Miniflare runs
139
- // in a separate isolate where module-level state doesn't carry over, so
140
- // we generate inline from the router's urlpatterns.
141
- //
142
- // In multi-router setups (e.g. createHostRouter), each router must have
143
- // its own per-router manifest. We check per-router data first: even if
144
- // the global manifest was set by a different router, this router still
145
- // needs its own trie and manifest for correct matching.
146
- const manifestCacheStart = performance.now();
147
- const hasRouterData = getRouterManifest(router.id) !== undefined;
148
- if (!hasRouterData) {
149
- if (!hasCachedManifest()) {
150
- const readyPromise = waitForManifestReady();
151
- if (readyPromise) {
152
- await readyPromise;
153
- }
154
- }
155
- if (!getRouterManifest(router.id) && router.urlpatterns) {
156
- // Cloudflare dev: generate manifest inline for this router.
157
- // Each router generates its own manifest independently so
158
- // multi-router setups (host routing) work correctly.
159
- const { generateManifest } = await import("../build/generate-manifest.js");
160
- const generated = generateManifest(router.urlpatterns);
161
- if (generated._routeAncestry &&
162
- Object.keys(generated._routeAncestry).length > 0) {
163
- const { buildRouteTrie } = await import("../build/route-trie.js");
164
- // Map each route to its include() staticPrefix so the trie
165
- // returns the correct sp for lazy entry lookup in findMatch.
166
- const routeToStaticPrefix = {};
167
- for (const name of Object.keys(generated.routeManifest)) {
168
- routeToStaticPrefix[name] = "";
169
- }
170
- // Override with prefix from include() entries so the trie
171
- // returns the correct sp for lazy entry lookup in findMatch.
172
- // Walk recursively to include routes in nested includes.
173
- if (generated.prefixTree) {
174
- const visitPrefixNode = (node) => {
175
- const sp = node.staticPrefix || "";
176
- for (const route of (node.routes || [])) {
177
- routeToStaticPrefix[route] = sp;
178
- }
179
- for (const child of Object.values(node.children || {})) {
180
- visitPrefixNode(child);
181
- }
182
- };
183
- for (const node of Object.values(generated.prefixTree)) {
184
- visitPrefixNode(node);
185
- }
186
- }
187
- const trie = buildRouteTrie(generated.routeManifest, generated._routeAncestry, routeToStaticPrefix, generated.routeTrailingSlash, generated.prerenderRoutes ? new Set(generated.prerenderRoutes) : undefined, generated.passthroughRoutes ? new Set(generated.passthroughRoutes) : undefined, generated.responseTypeRoutes);
188
- setRouterTrie(router.id, trie);
189
- // Set global trie only if not already set by another router
190
- if (!getRouteTrie()) {
191
- setRouteTrie(trie);
192
- }
193
- }
194
- setRouterManifest(router.id, generated.routeManifest);
195
- // Merge into global manifest (needed for reverse/href across routers)
196
- const existing = hasCachedManifest() ? getGlobalRouteMap() : {};
197
- setCachedManifest({ ...existing, ...generated.routeManifest });
198
- }
199
- if (!getRouterManifest(router.id) && !hasCachedManifest()) {
200
- throw new Error('Route manifest not available. Ensure "virtual:rsc-router/routes-manifest" is imported in your entry file.');
201
- }
202
- }
203
- const manifestCacheDur = performance.now() - manifestCacheStart;
204
- // Note: Route map for useHref() is loaded lazily via getGlobalRouteMap()
205
- // This allows it to include all routes from lazy includes after manifest loading
206
- // Create unified request context with all methods
207
- // Includes: stub response, handle store, loader memoization, use(), cookies, headers, cache store
208
- // params starts empty, populated after route matching via setRequestContextParams
209
- const ctxCreateStart = performance.now();
210
- const requestContext = createRequestContext({
211
- env,
212
- request,
213
- url,
214
- variables,
215
- cacheStore,
216
- executionContext: env.ctx,
217
- themeConfig: router.themeConfig,
218
- });
219
- const ctxCreateDur = performance.now() - ctxCreateStart;
220
- // Accumulate handler-level timing for Server-Timing header
221
- const handlerTiming = [
222
- `handler-nonce;dur=${nonceDur.toFixed(2)}`,
223
- `handler-mw-match;dur=${mwMatchDur.toFixed(2)}`,
224
- `handler-manifest-cache;dur=${manifestCacheDur.toFixed(2)}`,
225
- `handler-ctx-create;dur=${ctxCreateDur.toFixed(2)}`,
226
- ];
227
- // Store timing data in variables for downstream access
228
- variables.__handlerTiming = handlerTiming;
229
- variables.__handlerStart = handlerStart;
230
- // Wrap entire request handling in request context
231
- // Makes context available via getRequestContext() throughout:
232
- // - Middleware execution
233
- // - Route handlers and loaders
234
- // - Server components during rendering
235
- // - Error boundaries
236
- // - Streaming
237
- return runWithRequestContext(requestContext, async () => {
238
- // Core handler logic (wrapped by middleware)
239
- const coreHandler = async () => {
240
- return coreRequestHandler(request, env, url, variables, nonce);
241
- };
242
- // Execute middleware chain if any, otherwise call core handler directly
243
- if (matchedMiddleware.length > 0) {
244
- return executeMiddleware(matchedMiddleware, request, env, variables, coreHandler);
245
- }
246
- return coreHandler();
247
- });
248
- };
249
- // Core request handling logic (separated for middleware wrapping)
250
- async function coreRequestHandler(request, env, url, variables, nonce) {
251
- // First, check for route-level middleware
252
- const previewStart = performance.now();
253
- const preview = await router.previewMatch(request, env);
254
- const previewDur = performance.now() - previewStart;
255
- const handlerTiming = variables.__handlerTiming || [];
256
- handlerTiming.push(`handler-preview-match;dur=${previewDur.toFixed(2)}`);
257
- // Response route short-circuit: skip entire RSC pipeline
258
- if (preview?.responseType && preview.handler) {
259
- const isPartial = url.searchParams.has("_rsc_partial");
260
- // Partial requests (client-side navigation) to response routes
261
- // get X-RSC-Reload to trigger hard navigation in the browser
262
- if (isPartial) {
263
- const cleanUrl = new URL(url);
264
- cleanUrl.searchParams.delete("_rsc_partial");
265
- cleanUrl.searchParams.delete("_rsc_segments");
266
- cleanUrl.searchParams.delete("_rsc_v");
267
- cleanUrl.searchParams.delete("_rsc_stale");
268
- cleanUrl.searchParams.delete("_rsc_action");
269
- cleanUrl.searchParams.delete("_rsc_prev");
270
- return createResponseWithMergedHeaders(null, {
271
- status: 200,
272
- headers: {
273
- "X-RSC-Reload": cleanUrl.toString(),
274
- "content-type": "text/x-component;charset=utf-8",
275
- },
276
- });
277
- }
278
- // Build lightweight context for response handler
279
- const bindings = env?.Bindings ?? env;
280
- const reqCtx = requireRequestContext();
281
- const responseHandlerCtx = {
282
- request,
283
- params: preview.params || {},
284
- env: bindings,
285
- searchParams: url.searchParams,
286
- url,
287
- pathname: url.pathname,
288
- href: (name, hrefParams) => {
289
- if (name.startsWith("/")) {
290
- if (!hrefParams)
291
- return name;
292
- return name.replace(/:([^/]+)/g, (_, key) => {
293
- const value = hrefParams[key];
294
- if (value === undefined)
295
- throw new Error(`Missing param "${key}" for path "${name}"`);
296
- return encodeURIComponent(value);
297
- });
298
- }
299
- return name;
300
- },
301
- get: (key) => variables[key],
302
- header: (name, value) => reqCtx.header(name, value),
303
- setCookie: (name, value, options) => reqCtx.setCookie(name, value, options),
304
- };
305
- // Call handler directly, wrapped by route middleware if present
306
- const callHandler = async () => {
307
- // JSON response routes: wrap in { data } / { error } envelope
308
- if (preview.responseType === "json") {
309
- const errorCtx = { request, url, env };
310
- try {
311
- const result = await preview.handler(responseHandlerCtx);
312
- if (result instanceof Response) {
313
- const mergedHeaders = {};
314
- result.headers.forEach((value, key) => {
315
- mergedHeaders[key] = value;
316
- });
317
- return createResponseWithMergedHeaders(result.body, {
318
- status: result.status,
319
- headers: mergedHeaders,
320
- });
321
- }
322
- return createResponseWithMergedHeaders(JSON.stringify({ data: result }), { status: 200, headers: { "content-type": "application/json;charset=utf-8" } });
323
- }
324
- catch (error) {
325
- callOnError(error, "handler", errorCtx);
326
- const isDev = process.env.NODE_ENV !== "production";
327
- const status = error instanceof RouterError ? error.status : 500;
328
- return createResponseWithMergedHeaders(JSON.stringify({ error: createResponseErrorPayload(error, isDev) }), { status, headers: { "content-type": "application/json;charset=utf-8" } });
329
- }
330
- }
331
- // Non-JSON response routes: catch errors and return plain Response
332
- const errorCtx = { request, url, env };
333
- try {
334
- const result = await preview.handler(responseHandlerCtx);
335
- if (result instanceof Response) {
336
- // Handler returned a Response directly -- pass through
337
- const mergedHeaders = {};
338
- result.headers.forEach((value, key) => {
339
- mergedHeaders[key] = value;
340
- });
341
- return createResponseWithMergedHeaders(result.body, {
342
- status: result.status,
343
- headers: mergedHeaders,
344
- });
345
- }
346
- // Auto-wrap based on response type tag
347
- switch (preview.responseType) {
348
- case "text":
349
- return createResponseWithMergedHeaders(String(result), { status: 200, headers: { "content-type": "text/plain;charset=utf-8" } });
350
- case "html":
351
- return createResponseWithMergedHeaders(String(result), { status: 200, headers: { "content-type": "text/html;charset=utf-8" } });
352
- case "xml":
353
- return createResponseWithMergedHeaders(String(result), { status: 200, headers: { "content-type": "application/xml;charset=utf-8" } });
354
- case "md":
355
- return createResponseWithMergedHeaders(String(result), { status: 200, headers: { "content-type": "text/markdown;charset=utf-8" } });
356
- default:
357
- // image, stream, any -- must return Response
358
- throw new Error(`Response route handler for "${preview.responseType}" must return a Response object, got ${typeof result}`);
359
- }
360
- }
361
- catch (error) {
362
- callOnError(error, "handler", errorCtx);
363
- const isDev = process.env.NODE_ENV !== "production";
364
- const status = error instanceof RouterError ? error.status : 500;
365
- const message = error instanceof RouterError
366
- ? error.message
367
- : isDev && error instanceof Error
368
- ? error.message
369
- : "Internal Server Error";
370
- return createResponseWithMergedHeaders(message, {
371
- status,
372
- headers: { "content-type": "text/plain;charset=utf-8" },
373
- });
374
- }
375
- };
376
- // Wrap callHandler to append Vary: Accept on content-negotiated responses
377
- const callHandlerWithVary = async () => {
378
- const response = await callHandler();
379
- if (preview.negotiated) {
380
- response.headers.append("Vary", "Accept");
381
- }
382
- return response;
383
- };
384
- if (preview.routeMiddleware && preview.routeMiddleware.length > 0) {
385
- const middlewareEntries = preview.routeMiddleware.map((mw) => ({
386
- entry: {
387
- pattern: null,
388
- regex: null,
389
- paramNames: [],
390
- handler: mw.handler,
391
- mountPrefix: null,
392
- },
393
- params: mw.params,
394
- }));
395
- return executeMiddleware(middlewareEntries, request, env, variables, callHandlerWithVary);
396
- }
397
- return callHandlerWithVary();
398
- }
399
- // Wrap RSC handler to append Vary: Accept on content-negotiated routes
400
- const rscHandler = async () => {
401
- const response = await coreRequestHandlerInner(request, env, url, variables, nonce);
402
- if (preview?.negotiated) {
403
- response.headers.append("Vary", "Accept");
404
- }
405
- return response;
406
- };
407
- if (preview?.routeMiddleware && preview.routeMiddleware.length > 0) {
408
- // Convert route middleware to app middleware format for execution
409
- const middlewareEntries = preview.routeMiddleware.map((mw) => ({
410
- entry: {
411
- pattern: null,
412
- regex: null,
413
- paramNames: [],
414
- handler: mw.handler,
415
- mountPrefix: null,
416
- },
417
- params: mw.params,
418
- }));
419
- // Execute route middleware wrapping the actual request handling
420
- return executeMiddleware(middlewareEntries, request, env, variables, rscHandler);
421
- }
422
- // No route middleware, proceed directly
423
- return rscHandler();
424
- }
425
- // Inner request handler (actual RSC logic, wrapped by route middleware if any)
426
- async function coreRequestHandlerInner(request, env, url, variables, nonce) {
427
- const isPartial = url.searchParams.has("_rsc_partial");
428
- const isAction = request.headers.has("rsc-action") || url.searchParams.has("_rsc_action");
429
- const actionId = request.headers.get("rsc-action") || url.searchParams.get("_rsc_action");
430
- // Version mismatch detection - client may have stale code after HMR/deployment
431
- // If versions don't match, tell the client to reload
432
- const clientVersion = url.searchParams.get("_rsc_v");
433
- if (version && clientVersion && clientVersion !== version) {
434
- console.log(`[RSC] Version mismatch: client=${clientVersion}, server=${version}. Forcing reload.`);
435
- // Clean URL by removing RSC params
436
- const cleanUrl = new URL(url);
437
- cleanUrl.searchParams.delete("_rsc_partial");
438
- cleanUrl.searchParams.delete("_rsc_segments");
439
- cleanUrl.searchParams.delete("_rsc_v");
440
- cleanUrl.searchParams.delete("_rsc_stale");
441
- cleanUrl.searchParams.delete("_rsc_action");
442
- cleanUrl.searchParams.delete("_rsc_prev");
443
- // For actions, reload current page (referer)
444
- // For navigation, load the target URL
445
- const reloadUrl = isAction
446
- ? request.headers.get("referer") || cleanUrl.toString()
447
- : cleanUrl.toString();
448
- // Return special response that tells client to reload
449
- return createResponseWithMergedHeaders(null, {
450
- status: 200,
451
- headers: {
452
- "X-RSC-Reload": reloadUrl,
453
- "content-type": "text/x-component;charset=utf-8",
454
- },
455
- });
456
- }
457
- // Debug manifest endpoint: ?__debug_manifest on any route.
458
- // Always available in dev, requires allowDebugManifest option in production.
459
- const isDev = process.env.NODE_ENV !== "production";
460
- if (url.searchParams.has("__debug_manifest") &&
461
- (isDev || router.allowDebugManifest)) {
462
- const trie = getRouterTrie(router.id) ?? getRouteTrie();
463
- const routeManifest = getRouterManifest(router.id) ?? getGlobalRouteMap();
464
- const { extractAncestryFromTrie } = await import("../build/route-trie.js");
465
- return new Response(JSON.stringify({
466
- routerId: router.id,
467
- routeManifest,
468
- routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
469
- routeTrie: trie,
470
- precomputedEntries: getPrecomputedEntries(),
471
- }, null, 2), {
472
- headers: { "Content-Type": "application/json" },
473
- });
474
- }
475
- // Get handle store from request context (created at start of request)
476
- const handleStore = requireRequestContext()._handleStore;
477
- try {
478
- // ============================================================================
479
- // PROGRESSIVE ENHANCEMENT: No-JS Form Submissions
480
- // ============================================================================
481
- const progressiveResult = await handleProgressiveEnhancement(request, env, url, isAction, handleStore, nonce);
482
- if (progressiveResult) {
483
- return progressiveResult;
484
- }
485
- // ============================================================================
486
- // SERVER ACTION EXECUTION (JavaScript-enabled client)
487
- // ============================================================================
488
- if (isAction && actionId) {
489
- return handleServerAction(request, env, url, actionId, handleStore);
490
- }
491
- // ============================================================================
492
- // LOADER FETCH EXECUTION (data fetching with RSC serialization)
493
- // ============================================================================
494
- const isLoaderRequest = url.searchParams.has("_rsc_loader");
495
- if (isLoaderRequest) {
496
- return handleLoaderFetch(request, env, url, variables);
497
- }
498
- // ============================================================================
499
- // REGULAR RSC RENDERING (Navigation)
500
- // ============================================================================
501
- // Note: Must use "return await" for try/catch to catch async rejections
502
- return await handleRscRendering(request, env, url, isPartial, handleStore, nonce);
503
- }
504
- catch (error) {
505
- // Check if middleware/handler returned Response
506
- if (error instanceof Response) {
507
- // During partial (client-side navigation), a 200 Response from a handler
508
- // means the route serves raw content (JSON, text, etc.), not JSX.
509
- // Signal the browser to hard-navigate so it renders the raw response.
510
- // Only for 200 — redirects (3xx) work already because the browser follows
511
- // them automatically to a URL that serves Flight data.
512
- if (isPartial && error.status === 200) {
513
- console.warn(`[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
514
- `Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`);
515
- const cleanUrl = new URL(url);
516
- cleanUrl.searchParams.delete("_rsc_partial");
517
- cleanUrl.searchParams.delete("_rsc_segments");
518
- cleanUrl.searchParams.delete("_rsc_v");
519
- cleanUrl.searchParams.delete("_rsc_stale");
520
- cleanUrl.searchParams.delete("_rsc_action");
521
- cleanUrl.searchParams.delete("_rsc_prev");
522
- return createResponseWithMergedHeaders(null, {
523
- status: 200,
524
- headers: {
525
- "X-RSC-Reload": cleanUrl.toString(),
526
- "content-type": "text/x-component;charset=utf-8",
527
- },
528
- });
529
- }
530
- return error;
531
- }
532
- // Render 404 page for unmatched routes
533
- // Check both instanceof and error.name for cross-bundle compatibility
534
- const isRouteNotFound = error instanceof RouteNotFoundError ||
535
- (error instanceof Error && error.name === "RouteNotFoundError");
536
- if (isRouteNotFound) {
537
- callOnError(error, "routing", {
538
- request,
539
- url,
540
- env,
541
- handledByBoundary: true, // Handled by notFound component
542
- });
543
- // Get notFound component from router options or use default
544
- const notFoundOption = router.notFound;
545
- const notFoundComponent = typeof notFoundOption === "function"
546
- ? notFoundOption({ pathname: url.pathname })
547
- : (notFoundOption ?? createElement("h1", null, "Not Found"));
548
- // Create a simple segment for the 404 page
549
- const notFoundSegment = {
550
- id: "notFound",
551
- namespace: "notFound",
552
- type: "route",
553
- index: 0,
554
- component: notFoundComponent,
555
- params: {},
556
- };
557
- // Render with rootLayout to maintain app shell
558
- const root = await renderSegments([notFoundSegment], {
559
- rootLayout: router.rootLayout,
560
- // No routeName for not-found routes
561
- });
562
- const payload = {
563
- root,
564
- metadata: {
565
- pathname: url.pathname,
566
- segments: [notFoundSegment],
567
- matched: [],
568
- diff: [],
569
- isPartial: false,
570
- handles: handleStore.stream(),
571
- version,
572
- themeConfig: router.themeConfig,
573
- warmupEnabled: router.warmupEnabled,
574
- initialTheme: requireRequestContext().theme,
575
- // No routeName for not-found routes
576
- },
577
- };
578
- const rscStream = renderToReadableStream(payload);
579
- // Determine if this is an RSC request or HTML request
580
- const isRscRequest = (!request.headers.get("accept")?.includes("text/html") &&
581
- !url.searchParams.has("__html")) ||
582
- url.searchParams.has("__rsc");
583
- if (isRscRequest) {
584
- return createResponseWithMergedHeaders(rscStream, {
585
- status: 404,
586
- headers: { "content-type": "text/x-component;charset=utf-8" },
587
- });
588
- }
589
- // Delegate to SSR for HTML response
590
- const ssrModule = await loadSSRModule();
591
- const htmlStream = await ssrModule.renderHTML(rscStream, { nonce });
592
- return createResponseWithMergedHeaders(htmlStream, {
593
- status: 404,
594
- headers: { "content-type": "text/html;charset=utf-8" },
595
- });
596
- }
597
- // Report unhandled errors
598
- callOnError(error, "routing", {
599
- request,
600
- url,
601
- env,
602
- handledByBoundary: false,
603
- });
604
- console.error(`[RSC] Error:`, error);
605
- throw error;
606
- }
607
- }
608
- // ============================================================================
609
- // PROGRESSIVE ENHANCEMENT HANDLER
610
- // When JavaScript is disabled, React renders forms with hidden fields
611
- // ($ACTION_REF_*, $ACTION_KEY) containing the action reference.
612
- // We detect these and return HTML instead of RSC stream.
613
- // ============================================================================
614
- async function handleProgressiveEnhancement(request, env, url, isAction, handleStore, nonce) {
615
- const contentType = request.headers.get("content-type") || "";
616
- const isFormSubmission = contentType.includes("multipart/form-data") ||
617
- contentType.includes("application/x-www-form-urlencoded");
618
- if (request.method !== "POST" || isAction || !isFormSubmission) {
619
- return null;
620
- }
621
- // Clone the request to read FormData without consuming it
622
- const formData = await request.clone().formData();
623
- // Look for React's progressive enhancement hidden fields
624
- let isDirectAction = false;
625
- let isUseActionState = false;
626
- let directActionId = null;
627
- formData.forEach((_value, key) => {
628
- if (key.startsWith("$ACTION_ID_")) {
629
- isDirectAction = true;
630
- directActionId = key.slice("$ACTION_ID_".length);
631
- }
632
- else if (key.startsWith("$ACTION_REF_")) {
633
- isUseActionState = true;
634
- }
635
- });
636
- if (!isDirectAction && !isUseActionState) {
637
- return null;
638
- }
639
- // Execute action and return HTML
640
- let actionResult = undefined;
641
- let reactFormState = null;
642
- if (isUseActionState) {
643
- try {
644
- const boundAction = await decodeAction(formData);
645
- actionResult = await boundAction();
646
- }
647
- catch (error) {
648
- callOnError(error, "action", {
649
- request,
650
- url,
651
- env,
652
- handledByBoundary: false,
653
- });
654
- console.error("[RSC] Progressive enhancement action error:", error);
655
- }
656
- }
657
- else if (isDirectAction && directActionId) {
658
- const temporaryReferences = createTemporaryReferenceSet();
659
- let args = [];
660
- try {
661
- args = await decodeReply(formData, { temporaryReferences });
662
- }
663
- catch {
664
- args = [formData];
665
- }
666
- try {
667
- const loadedAction = await loadServerAction(directActionId);
668
- actionResult = await loadedAction.apply(null, args);
669
- }
670
- catch (error) {
671
- callOnError(error, "action", {
672
- request,
673
- url,
674
- env,
675
- actionId: directActionId,
676
- handledByBoundary: false,
677
- });
678
- console.error("[RSC] Progressive enhancement action error:", error);
679
- }
680
- }
681
- // Decode form state for useActionState progressive enhancement
682
- try {
683
- reactFormState = await decodeFormState(actionResult, formData);
684
- }
685
- catch (error) {
686
- callOnError(error, "action", {
687
- request,
688
- url,
689
- env,
690
- handledByBoundary: false,
691
- });
692
- console.error("[RSC] Failed to decode form state:", error);
693
- }
694
- // Re-render the page and return HTML
695
- const renderRequest = new Request(url.toString(), {
696
- method: "GET",
697
- headers: new Headers({ accept: "text/html" }),
698
- });
699
- const match = await router.match(renderRequest, env);
700
- if (match.redirect) {
701
- return createResponseWithMergedHeaders(null, {
702
- status: 308,
703
- headers: { Location: match.redirect },
704
- });
705
- }
706
- const root = renderSegments(match.segments, {
707
- rootLayout: router.rootLayout,
708
- });
709
- const payload = {
710
- root,
711
- metadata: {
712
- pathname: url.pathname,
713
- segments: match.segments,
714
- matched: match.matched,
715
- diff: match.diff,
716
- isPartial: false,
717
- rootLayout: router.rootLayout,
718
- handles: handleStore.stream(),
719
- version,
720
- themeConfig: router.themeConfig,
721
- warmupEnabled: router.warmupEnabled,
722
- initialTheme: requireRequestContext().theme,
723
- },
724
- formState: actionResult,
725
- };
726
- const rscStream = renderToReadableStream(payload);
727
- const ssrModule = await loadSSRModule();
728
- const htmlStream = await ssrModule.renderHTML(rscStream, {
729
- formState: reactFormState,
730
- nonce,
731
- });
732
- return createResponseWithMergedHeaders(htmlStream, {
733
- headers: { "content-type": "text/html;charset=utf-8" },
734
- });
735
- }
736
- // ============================================================================
737
- // SERVER ACTION HANDLER
738
- // ============================================================================
739
- async function handleServerAction(request, env, url, actionId, handleStore) {
740
- const temporaryReferences = createTemporaryReferenceSet();
741
- // Decode action arguments from request body
742
- const contentType = request.headers.get("content-type") || "";
743
- let args = [];
744
- let actionFormData;
745
- try {
746
- const body = contentType.includes("multipart/form-data")
747
- ? await request.formData()
748
- : await request.text();
749
- if (body instanceof FormData) {
750
- actionFormData = body;
751
- }
752
- if (hasBodyContent(body)) {
753
- args = await decodeReply(body, { temporaryReferences });
754
- }
755
- }
756
- catch (error) {
757
- callOnError(error, "action", {
758
- request,
759
- url,
760
- env,
761
- actionId,
762
- handledByBoundary: false,
763
- });
764
- throw new Error(`Failed to decode action arguments: ${error}`, {
765
- cause: error,
766
- });
767
- }
768
- // Execute the server action
769
- let returnValue;
770
- let actionStatus = 200;
771
- let loadedAction;
772
- try {
773
- loadedAction = await loadServerAction(actionId);
774
- const data = await loadedAction.apply(null, args);
775
- returnValue = { ok: true, data };
776
- }
777
- catch (error) {
778
- returnValue = { ok: false, data: error };
779
- actionStatus = 500;
780
- // Try to render error boundary
781
- const errorResult = await router.matchError(request, env, error, "route");
782
- // Report the action error (handledByBoundary indicates if error boundary will render)
783
- callOnError(error, "action", {
784
- request,
785
- url,
786
- env,
787
- actionId,
788
- handledByBoundary: !!errorResult,
789
- });
790
- if (errorResult) {
791
- setRequestContextParams(errorResult.params);
792
- const payload = {
793
- root: null,
794
- metadata: {
795
- pathname: url.pathname,
796
- segments: errorResult.segments,
797
- isPartial: true,
798
- matched: errorResult.matched,
799
- diff: errorResult.diff,
800
- isError: true,
801
- handles: handleStore.stream(),
802
- version,
803
- },
804
- returnValue,
805
- };
806
- const rscStream = renderToReadableStream(payload, {
807
- temporaryReferences,
808
- });
809
- return createResponseWithMergedHeaders(rscStream, {
810
- status: actionStatus,
811
- headers: { "content-type": "text/x-component;charset=utf-8" },
812
- });
813
- }
814
- }
815
- // Revalidate after action
816
- const resolvedActionId = loadedAction?.$id ??
817
- loadedAction?.$$id ??
818
- actionId;
819
- const actionContext = {
820
- actionId: resolvedActionId,
821
- actionUrl: new URL(request.url),
822
- actionResult: returnValue.data,
823
- formData: actionFormData,
824
- };
825
- const matchResult = await router.matchPartial(request, env, actionContext);
826
- if (!matchResult) {
827
- // Fall back to full render
828
- const fullMatch = await router.match(request, env);
829
- setRequestContextParams(fullMatch.params);
830
- if (fullMatch.redirect) {
831
- return createResponseWithMergedHeaders(null, {
832
- status: 308,
833
- headers: { Location: fullMatch.redirect },
834
- });
835
- }
836
- const renderStart = performance.now();
837
- const root = renderSegments(fullMatch.segments, {
838
- rootLayout: router.rootLayout,
839
- isAction: true,
840
- });
841
- const renderDuration = performance.now() - renderStart;
842
- const serverTiming = fullMatch.serverTiming
843
- ? `${fullMatch.serverTiming}, rendering;dur=${renderDuration.toFixed(2)}`
844
- : `rendering;dur=${renderDuration.toFixed(2)}`;
845
- const payload = {
846
- root,
847
- metadata: {
848
- pathname: url.pathname,
849
- segments: fullMatch.segments,
850
- matched: fullMatch.matched,
851
- diff: fullMatch.diff,
852
- handles: handleStore.stream(),
853
- version,
854
- },
855
- returnValue,
856
- };
857
- const rscStream = renderToReadableStream(payload, {
858
- temporaryReferences,
859
- });
860
- const headers = {
861
- "content-type": "text/x-component;charset=utf-8",
862
- };
863
- if (serverTiming) {
864
- headers["Server-Timing"] = serverTiming;
865
- }
866
- return createResponseWithMergedHeaders(rscStream, {
867
- status: actionStatus,
868
- headers,
869
- });
870
- }
871
- // Return updated segments
872
- setRequestContextParams(matchResult.params);
873
- const renderStart = performance.now();
874
- const renderDuration = performance.now() - renderStart;
875
- const serverTiming = matchResult.serverTiming
876
- ? `${matchResult.serverTiming}, rendering;dur=${renderDuration.toFixed(2)}`
877
- : `rendering;dur=${renderDuration.toFixed(2)}`;
878
- const payload = {
879
- root: null,
880
- metadata: {
881
- pathname: url.pathname,
882
- segments: matchResult.segments,
883
- isPartial: true,
884
- matched: matchResult.matched,
885
- diff: matchResult.diff,
886
- slots: matchResult.slots,
887
- handles: handleStore.stream(),
888
- version,
889
- },
890
- returnValue,
891
- };
892
- const rscStream = renderToReadableStream(payload, {
893
- temporaryReferences,
894
- });
895
- const actionHeaders = {
896
- "content-type": "text/x-component;charset=utf-8",
897
- };
898
- if (serverTiming) {
899
- actionHeaders["Server-Timing"] = serverTiming;
900
- }
901
- return createResponseWithMergedHeaders(rscStream, {
902
- status: actionStatus,
903
- headers: actionHeaders,
904
- });
905
- }
906
- // ============================================================================
907
- // LOADER FETCH HANDLER
908
- // Supports GET (params in query string) and POST/PUT/PATCH/DELETE (JSON body)
909
- // ============================================================================
910
- async function handleLoaderFetch(request, env, url, variables) {
911
- const loaderId = url.searchParams.get("_rsc_loader");
912
- if (!loaderId) {
913
- return createResponseWithMergedHeaders("Missing _rsc_loader parameter", {
914
- status: 400,
915
- });
916
- }
917
- // Look up loader lazily
918
- const registeredLoader = await getLoaderLazy(loaderId);
919
- if (!registeredLoader) {
920
- return createResponseWithMergedHeaders(`Loader "${loaderId}" not found in registry`, { status: 404 });
921
- }
922
- // Parse params and body based on request method
923
- let loaderParams = {};
924
- let loaderBody = undefined;
925
- const isBodyMethod = request.method !== "GET" && request.method !== "HEAD";
926
- if (isBodyMethod) {
927
- try {
928
- const contentType = request.headers.get("content-type") || "";
929
- if (contentType.includes("application/json")) {
930
- const jsonBody = (await request.json());
931
- loaderParams = jsonBody.params ?? {};
932
- loaderBody = jsonBody.body;
933
- }
934
- }
935
- catch {
936
- return createResponseWithMergedHeaders("Invalid JSON body", {
937
- status: 400,
938
- });
939
- }
940
- }
941
- else {
942
- const loaderParamsJson = url.searchParams.get("_rsc_loader_params");
943
- if (loaderParamsJson) {
944
- try {
945
- loaderParams = JSON.parse(loaderParamsJson);
946
- }
947
- catch {
948
- return createResponseWithMergedHeaders("Invalid _rsc_loader_params JSON", { status: 400 });
949
- }
950
- }
951
- }
952
- // Execute the loader with middleware
953
- try {
954
- const { fn, middleware } = registeredLoader;
955
- return await executeLoaderMiddleware(middleware, request, env, loaderParams, variables, async () => {
956
- const ctx = requireRequestContext();
957
- const loaderCtx = {
958
- ...ctx,
959
- params: loaderParams,
960
- body: loaderBody,
961
- };
962
- const result = await fn(loaderCtx);
963
- const loaderPayload = { loaderResult: result };
964
- const rscStream = renderToReadableStream(loaderPayload);
965
- return createResponseWithMergedHeaders(rscStream, {
966
- headers: { "content-type": "text/x-component;charset=utf-8" },
967
- });
968
- });
969
- }
970
- catch (error) {
971
- const err = error instanceof Error ? error : new Error(String(error));
972
- const isDev = process.env.NODE_ENV !== "production";
973
- console.error("[RSC] Loader error:", error);
974
- callOnError(error, "loader", {
975
- request,
976
- url,
977
- env,
978
- loaderName: loaderId,
979
- handledByBoundary: false,
980
- });
981
- const errorPayload = {
982
- loaderResult: null,
983
- loaderError: {
984
- message: isDev ? err.message : "An error occurred",
985
- name: err.name,
986
- },
987
- };
988
- const rscStream = renderToReadableStream(errorPayload);
989
- return createResponseWithMergedHeaders(rscStream, {
990
- status: 500,
991
- headers: { "content-type": "text/x-component;charset=utf-8" },
992
- });
993
- }
994
- }
995
- // ============================================================================
996
- // RSC RENDERING HANDLER (Navigation)
997
- // ============================================================================
998
- async function handleRscRendering(request, env, url, isPartial, handleStore, nonce) {
999
- // Retrieve handler-level timing from variables
1000
- const reqCtx = requireRequestContext();
1001
- const handlerTimingArr = reqCtx.var.__handlerTiming || [];
1002
- const handlerStart = reqCtx.var.__handlerStart || 0;
1003
- let payload;
1004
- let serverTiming;
1005
- if (isPartial) {
1006
- // Partial render (navigation)
1007
- const result = await router.matchPartial(request, env);
1008
- if (!result) {
1009
- // Fall back to full render
1010
- const match = await router.match(request, env);
1011
- setRequestContextParams(match.params);
1012
- if (match.redirect) {
1013
- return createResponseWithMergedHeaders(null, {
1014
- status: 308,
1015
- headers: { Location: match.redirect },
1016
- });
1017
- }
1018
- const renderStart = performance.now();
1019
- const root = renderSegments(match.segments, {
1020
- rootLayout: router.rootLayout,
1021
- });
1022
- const renderDuration = performance.now() - renderStart;
1023
- serverTiming = match.serverTiming
1024
- ? `${match.serverTiming}, rendering;dur=${renderDuration.toFixed(2)}`
1025
- : `rendering;dur=${renderDuration.toFixed(2)}`;
1026
- payload = {
1027
- root,
1028
- metadata: {
1029
- pathname: url.pathname,
1030
- segments: match.segments,
1031
- matched: match.matched,
1032
- diff: match.diff,
1033
- isPartial: false,
1034
- handles: handleStore.stream(),
1035
- version,
1036
- themeConfig: router.themeConfig,
1037
- initialTheme: reqCtx.theme,
1038
- },
1039
- };
1040
- }
1041
- else {
1042
- setRequestContextParams(result.params);
1043
- serverTiming = result.serverTiming;
1044
- payload = {
1045
- root: null,
1046
- metadata: {
1047
- pathname: url.pathname,
1048
- segments: result.segments,
1049
- matched: result.matched,
1050
- diff: result.diff,
1051
- isPartial: true,
1052
- slots: result.slots,
1053
- handles: handleStore.stream(),
1054
- version,
1055
- },
1056
- };
1057
- }
1058
- }
1059
- else {
1060
- // Full render (initial page load)
1061
- const match = await router.match(request, env);
1062
- setRequestContextParams(match.params);
1063
- if (match.redirect) {
1064
- return createResponseWithMergedHeaders(null, {
1065
- status: 308,
1066
- headers: { Location: match.redirect },
1067
- });
1068
- }
1069
- // Caching is now handled in router.match() via cache provider in request context
1070
- // match.segments already contains cached or fresh segments as appropriate
1071
- if (url.searchParams.has("__prerender_collect")) {
1072
- // Build-time prerender collection: serialize segments and handle data
1073
- // to JSON for storage as build artifacts. At runtime the worker
1074
- // deserializes these and feeds them through the normal segment pipeline.
1075
- const nonLoaderSegments = match.segments.filter((s) => s.type !== "loader");
1076
- await handleStore.settled;
1077
- const { serializeSegments } = await import("../cache/cache-scope.js");
1078
- const serializedSegments = await serializeSegments(nonLoaderSegments);
1079
- const handles = {};
1080
- for (const seg of nonLoaderSegments) {
1081
- const segHandles = handleStore.getDataForSegment(seg.id);
1082
- if (Object.keys(segHandles).length > 0) {
1083
- handles[seg.id] = segHandles;
1084
- }
1085
- }
1086
- return new Response(JSON.stringify({
1087
- segments: serializedSegments,
1088
- handles,
1089
- routeName: match.routeName,
1090
- params: match.params,
1091
- }), { headers: { "Content-Type": "application/json" } });
1092
- }
1093
- else {
1094
- const renderStart = performance.now();
1095
- const root = renderSegments(match.segments, {
1096
- rootLayout: router.rootLayout,
1097
- });
1098
- const renderDuration = performance.now() - renderStart;
1099
- serverTiming = match.serverTiming
1100
- ? `${match.serverTiming}, rendering;dur=${renderDuration.toFixed(2)}`
1101
- : `rendering;dur=${renderDuration.toFixed(2)}`;
1102
- payload = {
1103
- root,
1104
- metadata: {
1105
- pathname: url.pathname,
1106
- segments: match.segments,
1107
- matched: match.matched,
1108
- diff: match.diff,
1109
- isPartial: false,
1110
- rootLayout: router.rootLayout,
1111
- handles: handleStore.stream(),
1112
- version,
1113
- themeConfig: router.themeConfig,
1114
- initialTheme: reqCtx.theme,
1115
- },
1116
- };
1117
- }
1118
- }
1119
- // Serialize to RSC stream
1120
- const rscSerializeStart = performance.now();
1121
- const rscStream = renderToReadableStream(payload);
1122
- const rscSerializeDur = performance.now() - rscSerializeStart;
1123
- // Determine if this is an RSC request or HTML request
1124
- const isRscRequest = (!request.headers.get("accept")?.includes("text/html") &&
1125
- !url.searchParams.has("__html")) ||
1126
- url.searchParams.has("__rsc");
1127
- // Build complete Server-Timing: handler phases + match/manifest + rendering + RSC serialize
1128
- const timingParts = [...handlerTimingArr];
1129
- if (serverTiming) {
1130
- timingParts.push(serverTiming);
1131
- }
1132
- timingParts.push(`rsc-serialize;dur=${rscSerializeDur.toFixed(2)}`);
1133
- if (isRscRequest) {
1134
- const fullTiming = timingParts.join(", ");
1135
- const rscHeaders = {
1136
- "content-type": "text/x-component;charset=utf-8",
1137
- vary: "accept",
1138
- };
1139
- if (fullTiming) {
1140
- rscHeaders["Server-Timing"] = fullTiming;
1141
- }
1142
- return createResponseWithMergedHeaders(rscStream, {
1143
- headers: rscHeaders,
1144
- });
1145
- }
1146
- // Delegate to SSR for HTML response
1147
- const ssrModuleStart = performance.now();
1148
- const ssrModule = await loadSSRModule();
1149
- const ssrModuleDur = performance.now() - ssrModuleStart;
1150
- timingParts.push(`ssr-module-load;dur=${ssrModuleDur.toFixed(2)}`);
1151
- const ssrRenderStart = performance.now();
1152
- const htmlStream = await ssrModule.renderHTML(rscStream, { nonce });
1153
- const ssrRenderDur = performance.now() - ssrRenderStart;
1154
- timingParts.push(`ssr-render-html;dur=${ssrRenderDur.toFixed(2)}`);
1155
- // Add total handler duration
1156
- if (handlerStart) {
1157
- const totalHandler = performance.now() - handlerStart;
1158
- timingParts.push(`handler-total;dur=${totalHandler.toFixed(2)}`);
1159
- }
1160
- const fullTiming = timingParts.join(", ");
1161
- const htmlHeaders = {
1162
- "content-type": "text/html;charset=utf-8",
1163
- };
1164
- if (fullTiming) {
1165
- htmlHeaders["Server-Timing"] = fullTiming;
1166
- }
1167
- return createResponseWithMergedHeaders(htmlStream, {
1168
- headers: htmlHeaders,
1169
- });
1170
- }
1171
- }
1172
- //# sourceMappingURL=handler.js.map