@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
@@ -14,10 +14,11 @@ import {
14
14
  runWithRequestContext,
15
15
  setRequestContextParams,
16
16
  requireRequestContext,
17
+ getRequestContext,
18
+ _getRequestContext,
17
19
  createRequestContext,
18
20
  } from "../server/request-context.js";
19
21
  import * as rscDeps from "@vitejs/plugin-rsc/rsc";
20
-
21
22
  import type {
22
23
  RscPayload,
23
24
  CreateRSCHandlerOptions,
@@ -82,6 +83,11 @@ import {
82
83
  mayNeedSSR,
83
84
  SSR_SETUP_VAR,
84
85
  } from "./ssr-setup.js";
86
+ import {
87
+ classifyRequest,
88
+ type RequestPlan,
89
+ type ExecutableRequestPlan,
90
+ } from "../router/request-classification.js";
85
91
 
86
92
  /**
87
93
  * Create an RSC request handler.
@@ -161,10 +167,13 @@ export function createRSCHandler<
161
167
  phase: ErrorPhase,
162
168
  context: Parameters<typeof invokeOnError<TEnv>>[3],
163
169
  ): void {
164
- if (error != null && typeof error === "object") {
165
- const reportedErrors = requireRequestContext()._reportedErrors;
166
- if (reportedErrors.has(error)) return;
167
- reportedErrors.add(error);
170
+ // Guard: abort signal handlers fire asynchronously outside the ALS
171
+ // request scope, so the context may be gone. Skip dedup in that
172
+ // case — the error is from a cancelled stream, not a real failure.
173
+ const reqCtx = _getRequestContext();
174
+ if (error != null && typeof error === "object" && reqCtx) {
175
+ if (reqCtx._reportedErrors.has(error)) return;
176
+ reqCtx._reportedErrors.add(error);
168
177
  }
169
178
  invokeOnError(router.onError, error, phase, context, "RSC");
170
179
  }
@@ -452,6 +461,9 @@ export function createRSCHandler<
452
461
  // - Server components during rendering
453
462
  // - Error boundaries
454
463
  // - Streaming
464
+ // Store basename on request context (scoped per-request via existing ALS)
465
+ requestContext._basename = router.basename;
466
+
455
467
  return runWithRequestContext(requestContext, async () => {
456
468
  // Core handler logic (wrapped by middleware)
457
469
  const coreHandler = async (): Promise<Response> => {
@@ -527,7 +539,9 @@ export function createRSCHandler<
527
539
  });
528
540
  };
529
541
 
530
- // Core request handling logic (separated for middleware wrapping)
542
+ // Core request handling logic (separated for middleware wrapping).
543
+ // Uses the classify → execute model: classifyRequest produces a RequestPlan,
544
+ // then execution dispatches on the plan mode.
531
545
  async function coreRequestHandler(
532
546
  request: Request,
533
547
  env: TEnv,
@@ -535,71 +549,112 @@ export function createRSCHandler<
535
549
  variables: Record<string, any>,
536
550
  nonce: string | undefined,
537
551
  ): Promise<Response> {
538
- const previewStart = performance.now();
539
- const preview = await router.previewMatch(request, { env });
540
- const previewDur = performance.now() - previewStart;
541
552
  const handlerTiming: string[] = variables.__handlerTiming || [];
542
- handlerTiming.push(`handler-preview-match;dur=${previewDur.toFixed(2)}`);
543
- // Response route short-circuit: skip entire RSC pipeline
544
- if (preview?.responseType && preview.handler) {
545
- const responseOutcome = await withTimeout(
546
- handleResponseRoute(
547
- handlerCtx,
548
- preview as ResponseRouteMatch,
549
- request,
550
- env,
551
- url,
552
- variables,
553
+
554
+ // Debug manifest endpoint: handled before classification since it
555
+ // doesn't need a route match and needs trie access from the closure.
556
+ const isDev = process.env.NODE_ENV !== "production";
557
+ if (
558
+ url.searchParams.has("__debug_manifest") &&
559
+ (isDev || router.allowDebugManifest)
560
+ ) {
561
+ const trie = getRouterTrie(router.id) ?? getRouteTrie();
562
+ const routeManifest = getRequiredRouteMap();
563
+ const { extractAncestryFromTrie } =
564
+ await import("../build/route-trie.js");
565
+ return new Response(
566
+ JSON.stringify(
567
+ {
568
+ routerId: router.id,
569
+ routeManifest,
570
+ routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
571
+ routeTrie: trie,
572
+ precomputedEntries: getPrecomputedEntries(),
573
+ },
574
+ null,
575
+ 2,
553
576
  ),
554
- router.timeouts.renderStartMs,
555
- "render-start",
577
+ {
578
+ headers: { "Content-Type": "application/json" },
579
+ },
556
580
  );
557
- if (responseOutcome.timedOut) {
558
- return handleTimeoutResponse(
559
- request,
560
- env,
561
- url,
562
- "render-start",
563
- responseOutcome.durationMs,
564
- preview?.routeKey,
565
- );
581
+ }
582
+
583
+ // ---- 1. Classify ----
584
+ // classifyRequest may throw RouteNotFoundError for unknown routes.
585
+ // In that case, fall through to a full-render plan so the pipeline
586
+ // can render the 404 page via the existing error handling path.
587
+ const classifyStart = performance.now();
588
+ let plan: RequestPlan<TEnv>;
589
+ try {
590
+ plan = await classifyRequest<TEnv>(request, url, {
591
+ findMatch: router.findMatch,
592
+ routerVersion: version,
593
+ routerId: router.id,
594
+ });
595
+ } catch (error) {
596
+ if (
597
+ error instanceof RouteNotFoundError ||
598
+ (error instanceof Error && error.name === "RouteNotFoundError")
599
+ ) {
600
+ // Let the render path handle 404 — match()/matchPartial() will
601
+ // re-throw RouteNotFoundError and the catch block in
602
+ // executeRenderWithMiddleware renders the not-found page.
603
+ plan = {
604
+ mode: "full-render",
605
+ route: {
606
+ matched: null as any,
607
+ manifestEntry: null as any,
608
+ entries: [],
609
+ routeKey: "",
610
+ localRouteName: "",
611
+ params: {},
612
+ routeMiddleware: [],
613
+ cacheScope: null,
614
+ isPassthrough: false,
615
+ },
616
+ negotiated: false,
617
+ };
618
+ } else {
619
+ throw error;
620
+ }
621
+ }
622
+ const classifyDur = performance.now() - classifyStart;
623
+ handlerTiming.push(`handler-classify;dur=${classifyDur.toFixed(2)}`);
624
+
625
+ // ---- 2. Terminal plans (no execution needed) ----
626
+ if (plan.mode === "redirect") {
627
+ // Redirects are handled by the pipeline (match/matchPartial),
628
+ // but for partial requests we short-circuit with a Flight redirect.
629
+ if (url.searchParams.has("_rsc_partial")) {
630
+ return createRedirectFlightResponse(plan.redirectUrl);
566
631
  }
567
- return responseOutcome.result;
632
+ // Full requests: let the pipeline handle the redirect via match()
633
+ // which returns { redirect: url }. Fall through to full-render.
568
634
  }
569
635
 
570
- // Kick off SSR module loading + stream mode resolution in parallel with
571
- // segment resolution. Placed after the response-route short-circuit so
572
- // response/mime routes never pay for SSR work.
573
- if (mayNeedSSR(request, url)) {
574
- variables[SSR_SETUP_VAR] = startSSRSetup(
575
- handlerCtx,
576
- request,
577
- env,
578
- url,
579
- router.debugPerformance
580
- ? () => requireRequestContext()._metricsStore
581
- : undefined,
636
+ if (plan.mode === "version-mismatch") {
637
+ console.log(
638
+ `[RSC] Version mismatch: client=${url.searchParams.get("_rsc_v")}, server=${version}. Forcing reload.`,
582
639
  );
640
+ return createResponseWithMergedHeaders(null, {
641
+ status: 200,
642
+ headers: {
643
+ "X-RSC-Reload": plan.reloadUrl,
644
+ "content-type": "text/x-component;charset=utf-8",
645
+ },
646
+ });
583
647
  }
584
648
 
585
- const routeReverse = createReverseFunction(getRequiredRouteMap());
586
-
587
- const isAction =
588
- request.headers.has("rsc-action") || url.searchParams.has("_rsc_action");
589
- const isLoaderFetch = url.searchParams.has("_rsc_loader");
590
- const actionId =
591
- request.headers.get("rsc-action") || url.searchParams.get("_rsc_action");
592
-
593
- // Origin guard: reject cross-origin actions, loader fetches, and
594
- // PE form submissions before any execution. Regular page navigations
595
- // (GET without _rsc_loader/_rsc_action) are not affected.
596
- const originPhase: OriginCheckPhase | null = isAction
597
- ? "action"
598
- : isLoaderFetch
599
- ? "loader"
600
- : request.method === "POST"
601
- ? "pe-form"
602
- : null;
649
+ // ---- 3. Origin guard (gate for action/loader/PE modes) ----
650
+ const originPhase: OriginCheckPhase | null =
651
+ plan.mode === "action"
652
+ ? "action"
653
+ : plan.mode === "loader"
654
+ ? "loader"
655
+ : plan.mode === "pe-render"
656
+ ? "pe-form"
657
+ : null;
603
658
  if (originPhase) {
604
659
  const originResult = await checkRequestOrigin(
605
660
  request,
@@ -649,13 +704,33 @@ export function createRSCHandler<
649
704
  }
650
705
  }
651
706
 
652
- // Get handle store from request context
707
+ // ---- 4. Execute ----
708
+ return executeRequest(
709
+ plan as ExecutableRequestPlan<TEnv>,
710
+ request,
711
+ env,
712
+ url,
713
+ variables,
714
+ nonce,
715
+ );
716
+ }
717
+
718
+ // Execute a classified request plan. Dispatches to the appropriate handler
719
+ // based on plan.mode. Lives in the createRSCHandler closure for access to
720
+ // handlerCtx, router, callOnError, etc.
721
+ // Only receives executable plans (version-mismatch is handled above).
722
+ async function executeRequest(
723
+ plan: ExecutableRequestPlan<TEnv>,
724
+ request: Request,
725
+ env: TEnv,
726
+ url: URL,
727
+ variables: Record<string, any>,
728
+ nonce: string | undefined,
729
+ ): Promise<Response> {
730
+ // Common setup
653
731
  const handleStore = requireRequestContext()._handleStore;
654
732
 
655
733
  // Wire up error reporting for late streaming-handle failures
656
- // (LateHandlePushError: handle pushed after stream completion).
657
- // Without this, these errors are only caught by React's error boundary
658
- // and never reach the router's onError callback or telemetry.
659
734
  handleStore.onError = (error: Error) => {
660
735
  const reqCtx = requireRequestContext();
661
736
  callOnError(error, "handler", {
@@ -685,37 +760,106 @@ export function createRSCHandler<
685
760
  };
686
761
 
687
762
  // Set route params early so all execution paths can access ctx.params.
688
- if (preview?.params) {
689
- setRequestContextParams(preview.params, preview.routeKey);
763
+ // Also store the classified snapshot so match/matchPartial can reuse it
764
+ // instead of calling resolveRoute again.
765
+ if (plan.mode !== "redirect") {
766
+ setRequestContextParams(plan.route.params, plan.route.routeKey);
767
+ requireRequestContext()._classifiedRoute = plan.route;
690
768
  }
691
769
 
692
- // Progressive enhancement runs before the normal action/render paths.
693
- // Route middleware wraps the PE re-render so handlers see the same
694
- // context variables regardless of JS/no-JS transport.
695
- const progressiveResult = await handleProgressiveEnhancement(
696
- handlerCtx,
697
- request,
698
- env,
699
- url,
700
- isAction,
701
- handleStore,
702
- nonce,
703
- {
704
- routeMiddleware: preview?.routeMiddleware,
770
+ const routeReverse = createReverseFunction(getRequiredRouteMap());
771
+
772
+ // ---- Response route: skip entire RSC pipeline ----
773
+ if (plan.mode === "response") {
774
+ // Build ResponseRouteMatch from plan fields. handleResponseRoute
775
+ // expects a flat object with params at the top level.
776
+ const responseMatch: ResponseRouteMatch = {
777
+ responseType: plan.responseType,
778
+ handler: plan.handler,
779
+ params: plan.route.params,
780
+ negotiated: plan.negotiated,
781
+ manifestEntry: plan.manifestEntry,
782
+ routeMiddleware: plan.routeMiddleware,
783
+ };
784
+ const responseOutcome = await withTimeout(
785
+ handleResponseRoute(
786
+ handlerCtx,
787
+ responseMatch,
788
+ request,
789
+ env,
790
+ url,
791
+ variables,
792
+ ),
793
+ router.timeouts.renderStartMs,
794
+ "render-start",
795
+ );
796
+ if (responseOutcome.timedOut) {
797
+ return handleTimeoutResponse(
798
+ request,
799
+ env,
800
+ url,
801
+ "render-start",
802
+ responseOutcome.durationMs,
803
+ plan.route.routeKey,
804
+ );
805
+ }
806
+ const response = responseOutcome.result;
807
+ if (plan.negotiated) {
808
+ response.headers.append("Vary", "Accept");
809
+ }
810
+ return response;
811
+ }
812
+
813
+ // SSR setup: kick off in parallel for modes that need HTML rendering.
814
+ // Placed after response-route short-circuit so response/mime routes
815
+ // never pay for SSR work.
816
+ if (plan.mode !== "loader" && mayNeedSSR(request, url)) {
817
+ variables[SSR_SETUP_VAR] = startSSRSetup(
818
+ handlerCtx,
819
+ request,
820
+ env,
821
+ url,
822
+ router.debugPerformance
823
+ ? () => requireRequestContext()._metricsStore
824
+ : undefined,
825
+ );
826
+ }
827
+
828
+ // ---- Loader fetch ----
829
+ if (plan.mode === "loader") {
830
+ return handleLoaderFetch(
831
+ handlerCtx,
832
+ request,
833
+ env,
834
+ url,
705
835
  variables,
706
- routeReverse,
707
- },
708
- );
709
- if (progressiveResult) {
710
- return progressiveResult;
836
+ plan.route.params,
837
+ );
838
+ }
839
+
840
+ // ---- Progressive enhancement ----
841
+ if (plan.mode === "pe-render") {
842
+ const peResult = await handleProgressiveEnhancement(
843
+ handlerCtx,
844
+ request,
845
+ env,
846
+ url,
847
+ false, // isAction = false for PE
848
+ handleStore,
849
+ nonce,
850
+ {
851
+ routeMiddleware: plan.route.routeMiddleware,
852
+ variables,
853
+ routeReverse,
854
+ },
855
+ );
856
+ if (peResult) return peResult;
857
+ // PE handler returned null (not a PE form) — fall through to render
711
858
  }
712
859
 
713
- // --- Action execution: runs BEFORE route middleware ---
714
- // Route middleware wraps rendering only. For actions, the action runs
715
- // first in the global middleware context, then route middleware wraps
716
- // the revalidation pass (identical to a normal render).
717
- let actionContinuation: ActionContinuation | undefined;
718
- if (isAction && actionId) {
860
+ // ---- Action: execute action, then revalidate wrapped in route middleware ----
861
+ if (plan.mode === "action") {
862
+ let actionContinuation: ActionContinuation | undefined;
719
863
  try {
720
864
  const actionOutcome = await withTimeout(
721
865
  executeServerAction(
@@ -723,7 +867,7 @@ export function createRSCHandler<
723
867
  request,
724
868
  env,
725
869
  url,
726
- actionId,
870
+ plan.actionId,
727
871
  handleStore,
728
872
  ),
729
873
  router.timeouts.actionMs,
@@ -736,8 +880,8 @@ export function createRSCHandler<
736
880
  url,
737
881
  "action",
738
882
  actionOutcome.durationMs,
739
- preview?.routeKey,
740
- actionId,
883
+ plan.route.routeKey,
884
+ plan.actionId,
741
885
  );
742
886
  }
743
887
  const result = actionOutcome.result;
@@ -749,341 +893,297 @@ export function createRSCHandler<
749
893
  request,
750
894
  url,
751
895
  env,
752
- actionId,
896
+ actionId: plan.actionId,
753
897
  handledByBoundary: false,
754
898
  });
755
899
  console.error(`[RSC] Action error:`, error);
756
900
  throw error;
757
901
  }
758
- }
759
902
 
760
- // --- Rendering (action revalidation or navigation) ---
761
- // Route middleware wraps this same code path for both cases.
762
- const renderHandler = async () => {
763
- const response = await coreRequestHandlerInner(
903
+ // Revalidation render wrapped in route middleware.
904
+ // Actions from client-side navigation include _rsc_partial preserve
905
+ // the partial flag so the revalidation returns a Flight stream, not HTML.
906
+ // App-switch is already excluded by classifyRequest (would be full-render).
907
+ const isPartialAction = url.searchParams.has("_rsc_partial");
908
+ return executeRenderWithMiddleware(
909
+ plan.route.routeMiddleware,
910
+ plan.negotiated,
911
+ plan.route.routeKey,
912
+ routeReverse,
764
913
  request,
765
914
  env,
766
915
  url,
767
916
  variables,
768
917
  nonce,
769
- preview?.params,
770
- preview?.routeKey,
771
918
  handleStore,
919
+ isPartialAction,
772
920
  actionContinuation,
773
921
  );
774
- if (preview?.negotiated) {
775
- response.headers.append("Vary", "Accept");
776
- }
777
- return response;
778
- };
779
-
780
- // Wrap the render path (with or without route middleware) in a
781
- // renderStartMs timeout so slow renders are caught before output.
782
- const executeRender = async (): Promise<Response> => {
783
- if (preview?.routeMiddleware && preview.routeMiddleware.length > 0) {
784
- const mwResponse = await executeMiddleware(
785
- buildRouteMiddlewareEntries<TEnv>(preview.routeMiddleware),
786
- request,
787
- env,
788
- variables,
789
- renderHandler,
790
- routeReverse,
791
- );
792
-
793
- if (
794
- url.searchParams.has("_rsc_partial") ||
795
- url.searchParams.has("_rsc_action")
796
- ) {
797
- const intercepted = interceptRedirectForPartial(
798
- mwResponse,
799
- createRedirectFlightResponse,
800
- );
801
- if (intercepted) return intercepted;
802
- }
803
-
804
- return finalizeResponse(mwResponse);
805
- }
922
+ }
806
923
 
807
- // No route middleware, proceed directly
808
- return renderHandler();
809
- };
924
+ // ---- Full render / Partial render (or PE that fell through) ----
925
+ if (plan.mode === "full-render" || plan.mode === "partial-render") {
926
+ const isPartial = plan.mode === "partial-render";
927
+ return executeRenderWithMiddleware(
928
+ plan.route.routeMiddleware,
929
+ plan.negotiated,
930
+ plan.route.routeKey,
931
+ routeReverse,
932
+ request,
933
+ env,
934
+ url,
935
+ variables,
936
+ nonce,
937
+ handleStore,
938
+ isPartial,
939
+ );
940
+ }
810
941
 
811
- const renderOutcome = await withTimeout(
812
- executeRender(),
813
- router.timeouts.renderStartMs,
814
- "render-start",
815
- );
816
- if (renderOutcome.timedOut) {
817
- return handleTimeoutResponse(
942
+ // PE that fell through (handleProgressiveEnhancement returned null)
943
+ // falls back to full render
944
+ if (plan.mode === "pe-render") {
945
+ return executeRenderWithMiddleware(
946
+ plan.route.routeMiddleware,
947
+ false,
948
+ plan.route.routeKey,
949
+ routeReverse,
818
950
  request,
819
951
  env,
820
952
  url,
821
- "render-start",
822
- renderOutcome.durationMs,
823
- preview?.routeKey,
953
+ variables,
954
+ nonce,
955
+ handleStore,
956
+ false,
824
957
  );
825
958
  }
826
- return renderOutcome.result;
959
+
960
+ // Redirect plan that wasn't handled above (full-page redirect — let
961
+ // the pipeline handle it via match() which returns { redirect: url })
962
+ return executeRenderWithMiddleware(
963
+ plan.route.routeMiddleware,
964
+ false,
965
+ plan.route.routeKey,
966
+ routeReverse,
967
+ request,
968
+ env,
969
+ url,
970
+ variables,
971
+ nonce,
972
+ handleStore,
973
+ false,
974
+ );
827
975
  }
828
976
 
829
- // Inner request handler: rendering logic wrapped by route middleware.
830
- // Handles action revalidation (when actionContinuation is present),
831
- // loader fetches, and regular RSC rendering.
832
- async function coreRequestHandlerInner(
977
+ // Shared render execution: wraps handleRscRendering (or revalidateAfterAction)
978
+ // in route middleware and timeout handling. Consolidates the pattern used by
979
+ // action-revalidate, full-render, and partial-render modes.
980
+ async function executeRenderWithMiddleware(
981
+ routeMiddleware: import("../router/middleware-types.js").CollectedMiddleware[],
982
+ negotiated: boolean,
983
+ routeKey: string,
984
+ routeReverse: ReturnType<typeof createReverseFunction>,
833
985
  request: Request,
834
986
  env: TEnv,
835
987
  url: URL,
836
988
  variables: Record<string, any>,
837
989
  nonce: string | undefined,
838
- routeParams?: Record<string, string>,
839
- routeKey?: string,
840
- handleStore?: ReturnType<typeof requireRequestContext>["_handleStore"],
990
+ handleStore: ReturnType<typeof requireRequestContext>["_handleStore"],
991
+ isPartial: boolean,
841
992
  actionContinuation?: ActionContinuation,
842
993
  ): Promise<Response> {
843
- const isPartial = url.searchParams.has("_rsc_partial");
844
- const isAction =
845
- request.headers.has("rsc-action") || url.searchParams.has("_rsc_action");
846
-
847
- // Version mismatch detection - client may have stale code after HMR/deployment
848
- // If versions don't match, tell the client to reload
849
- const clientVersion = url.searchParams.get("_rsc_v");
850
- if (version && clientVersion && clientVersion !== version) {
851
- console.log(
852
- `[RSC] Version mismatch: client=${clientVersion}, server=${version}. Forcing reload.`,
853
- );
994
+ const renderHandler = async (): Promise<Response> => {
995
+ try {
996
+ let response: Response;
997
+ if (actionContinuation) {
998
+ response = await revalidateAfterAction(
999
+ handlerCtx,
1000
+ request,
1001
+ env,
1002
+ url,
1003
+ handleStore,
1004
+ actionContinuation,
1005
+ );
1006
+ } else {
1007
+ response = await handleRscRendering(
1008
+ handlerCtx,
1009
+ request,
1010
+ env,
1011
+ url,
1012
+ isPartial,
1013
+ handleStore,
1014
+ nonce,
1015
+ );
1016
+ }
1017
+ if (negotiated) {
1018
+ response.headers.append("Vary", "Accept");
1019
+ }
1020
+ return response;
1021
+ } catch (error) {
1022
+ // Check if middleware/handler returned Response
1023
+ if (error instanceof Response) {
1024
+ // During partial (client-side navigation), a 200 Response from a handler
1025
+ // means the route serves raw content (JSON, text, etc.), not JSX.
1026
+ // Signal the browser to hard-navigate so it renders the raw response.
1027
+ if (isPartial && error.status === 200) {
1028
+ console.warn(
1029
+ `[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
1030
+ `Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
1031
+ );
1032
+ return createResponseWithMergedHeaders(null, {
1033
+ status: 200,
1034
+ headers: {
1035
+ "X-RSC-Reload": stripInternalParams(url).toString(),
1036
+ "content-type": "text/x-component;charset=utf-8",
1037
+ },
1038
+ });
1039
+ }
854
1040
 
855
- // For actions, reload current page (referer) if same origin.
856
- // For navigation, load the target URL.
857
- // Validate referer origin to prevent open redirect via crafted header.
858
- let reloadUrl = stripInternalParams(url).toString();
859
- if (isAction) {
860
- const referer = request.headers.get("referer");
861
- if (referer) {
862
- try {
863
- const refererUrl = new URL(referer);
864
- if (refererUrl.origin === url.origin) {
865
- reloadUrl = referer;
866
- }
867
- } catch {
868
- // Malformed referer, fall back to cleanUrl
1041
+ if (isPartial) {
1042
+ const intercepted = interceptRedirectForPartial(
1043
+ error,
1044
+ createRedirectFlightResponse,
1045
+ );
1046
+ if (intercepted) return intercepted;
869
1047
  }
1048
+
1049
+ return error;
870
1050
  }
871
- }
872
1051
 
873
- // Return special response that tells client to reload
874
- return createResponseWithMergedHeaders(null, {
875
- status: 200,
876
- headers: {
877
- "X-RSC-Reload": reloadUrl,
878
- "content-type": "text/x-component;charset=utf-8",
879
- },
880
- });
881
- }
882
- // Debug manifest endpoint: ?__debug_manifest on any route.
883
- // Always available in dev, requires allowDebugManifest option in production.
884
- const isDev = process.env.NODE_ENV !== "production";
885
- if (
886
- url.searchParams.has("__debug_manifest") &&
887
- (isDev || router.allowDebugManifest)
888
- ) {
889
- const trie = getRouterTrie(router.id) ?? getRouteTrie();
890
- const routeManifest = getRequiredRouteMap();
891
- const { extractAncestryFromTrie } =
892
- await import("../build/route-trie.js");
893
- return new Response(
894
- JSON.stringify(
895
- {
896
- routerId: router.id,
897
- routeManifest,
898
- routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
899
- routeTrie: trie,
900
- precomputedEntries: getPrecomputedEntries(),
901
- },
902
- null,
903
- 2,
904
- ),
905
- {
906
- headers: { "Content-Type": "application/json" },
907
- },
908
- );
909
- }
1052
+ // Render 404 page for unmatched routes
1053
+ const isRouteNotFound =
1054
+ error instanceof RouteNotFoundError ||
1055
+ (error instanceof Error && error.name === "RouteNotFoundError");
1056
+ if (isRouteNotFound) {
1057
+ callOnError(error, "routing", {
1058
+ request,
1059
+ url,
1060
+ env,
1061
+ handledByBoundary: true,
1062
+ });
910
1063
 
911
- const store = handleStore ?? requireRequestContext()._handleStore;
1064
+ const notFoundOption = router.notFound;
1065
+ const notFoundComponent =
1066
+ typeof notFoundOption === "function"
1067
+ ? notFoundOption({ pathname: url.pathname })
1068
+ : (notFoundOption ?? createElement("h1", null, "Not Found"));
1069
+
1070
+ const notFoundSegment = {
1071
+ id: "notFound",
1072
+ namespace: "notFound",
1073
+ type: "route" as const,
1074
+ index: 0,
1075
+ component: notFoundComponent,
1076
+ params: {},
1077
+ };
1078
+
1079
+ const payload: RscPayload = {
1080
+ metadata: {
1081
+ pathname: url.pathname,
1082
+ routerId: router.id,
1083
+ basename: router.basename,
1084
+ segments: [notFoundSegment],
1085
+ matched: [],
1086
+ diff: [],
1087
+ isPartial: false,
1088
+ rootLayout: router.rootLayout,
1089
+ handles: handleStore.stream(),
1090
+ version,
1091
+ themeConfig: router.themeConfig,
1092
+ warmupEnabled: router.warmupEnabled,
1093
+ initialTheme: requireRequestContext().theme,
1094
+ },
1095
+ };
912
1096
 
913
- try {
914
- // Route params were already set in coreRequestHandler, but set again
915
- // for callers that enter coreRequestHandlerInner directly.
916
- if (routeParams) {
917
- setRequestContextParams(routeParams, routeKey);
918
- }
1097
+ const rscStream = renderToReadableStream(payload, {
1098
+ onError: (error: unknown) => {
1099
+ callOnError(error, "rendering", { request, url, env });
1100
+ },
1101
+ });
919
1102
 
920
- // ============================================================================
921
- // ACTION REVALIDATION (action already executed, revalidate segments)
922
- // ============================================================================
923
- if (actionContinuation) {
924
- return await revalidateAfterAction(
925
- handlerCtx,
926
- request,
927
- env,
928
- url,
929
- store,
930
- actionContinuation,
931
- );
932
- }
1103
+ const isRscRequest =
1104
+ isPartial ||
1105
+ (!request.headers.get("accept")?.includes("text/html") &&
1106
+ !url.searchParams.has("__html")) ||
1107
+ url.searchParams.has("__rsc");
933
1108
 
934
- // ============================================================================
935
- // LOADER FETCH EXECUTION (data fetching with RSC serialization)
936
- // ============================================================================
937
- const isLoaderRequest = url.searchParams.has("_rsc_loader");
938
- if (isLoaderRequest) {
939
- return handleLoaderFetch(
940
- handlerCtx,
941
- request,
942
- env,
943
- url,
944
- variables,
945
- routeParams,
946
- );
947
- }
1109
+ if (isRscRequest) {
1110
+ return createResponseWithMergedHeaders(rscStream, {
1111
+ status: 404,
1112
+ headers: { "content-type": "text/x-component;charset=utf-8" },
1113
+ });
1114
+ }
948
1115
 
949
- // ============================================================================
950
- // REGULAR RSC RENDERING (Navigation)
951
- // ============================================================================
952
- // Note: Must use "return await" for try/catch to catch async rejections
953
- return await handleRscRendering(
954
- handlerCtx,
955
- request,
956
- env,
957
- url,
958
- isPartial,
959
- store,
960
- nonce,
961
- );
962
- } catch (error) {
963
- // Check if middleware/handler returned Response
964
- if (error instanceof Response) {
965
- // During partial (client-side navigation), a 200 Response from a handler
966
- // means the route serves raw content (JSON, text, etc.), not JSX.
967
- // Signal the browser to hard-navigate so it renders the raw response.
968
- // Only for 200 — redirects (3xx) work already because the browser follows
969
- // them automatically to a URL that serves Flight data.
970
- if (isPartial && error.status === 200) {
971
- console.warn(
972
- `[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
973
- `Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
1116
+ const [ssrModule, streamMode] = await getSSRSetup(
1117
+ handlerCtx,
1118
+ request,
1119
+ env,
1120
+ url,
1121
+ requireRequestContext()._metricsStore,
974
1122
  );
975
- return createResponseWithMergedHeaders(null, {
976
- status: 200,
977
- headers: {
978
- "X-RSC-Reload": stripInternalParams(url).toString(),
979
- "content-type": "text/x-component;charset=utf-8",
980
- },
1123
+ const htmlStream = await ssrModule.renderHTML(rscStream, {
1124
+ nonce,
1125
+ streamMode,
981
1126
  });
982
- }
983
1127
 
984
- if (isPartial) {
985
- const intercepted = interceptRedirectForPartial(
986
- error,
987
- createRedirectFlightResponse,
988
- );
989
- if (intercepted) return intercepted;
1128
+ return createResponseWithMergedHeaders(htmlStream, {
1129
+ status: 404,
1130
+ headers: { "content-type": "text/html;charset=utf-8" },
1131
+ });
990
1132
  }
991
1133
 
992
- return error;
993
- }
994
-
995
- // Render 404 page for unmatched routes
996
- // Check both instanceof and error.name for cross-bundle compatibility
997
- const isRouteNotFound =
998
- error instanceof RouteNotFoundError ||
999
- (error instanceof Error && error.name === "RouteNotFoundError");
1000
- if (isRouteNotFound) {
1134
+ // Report unhandled errors
1001
1135
  callOnError(error, "routing", {
1002
1136
  request,
1003
1137
  url,
1004
1138
  env,
1005
- handledByBoundary: true, // Handled by notFound component
1139
+ handledByBoundary: false,
1006
1140
  });
1141
+ console.error(`[RSC] Error:`, error);
1142
+ throw error;
1143
+ }
1144
+ };
1007
1145
 
1008
- // Get notFound component from router options or use default
1009
- const notFoundOption = router.notFound;
1010
- const notFoundComponent =
1011
- typeof notFoundOption === "function"
1012
- ? notFoundOption({ pathname: url.pathname })
1013
- : (notFoundOption ?? createElement("h1", null, "Not Found"));
1014
-
1015
- // Create a simple segment for the 404 page
1016
- const notFoundSegment = {
1017
- id: "notFound",
1018
- namespace: "notFound",
1019
- type: "route" as const,
1020
- index: 0,
1021
- component: notFoundComponent,
1022
- params: {},
1023
- };
1024
-
1025
- const payload: RscPayload = {
1026
- metadata: {
1027
- pathname: url.pathname,
1028
- segments: [notFoundSegment],
1029
- matched: [],
1030
- diff: [],
1031
- isPartial: false,
1032
- rootLayout: router.rootLayout,
1033
- handles: store.stream(),
1034
- version,
1035
- themeConfig: router.themeConfig,
1036
- warmupEnabled: router.warmupEnabled,
1037
- initialTheme: requireRequestContext().theme,
1038
- // No routeName for not-found routes
1039
- },
1040
- };
1041
-
1042
- const rscStream = renderToReadableStream(payload);
1043
-
1044
- // Determine if this is an RSC request or HTML request.
1045
- // Partial requests are always RSC (see main isRscRequest comment).
1046
- const isRscRequest =
1047
- isPartial ||
1048
- (!request.headers.get("accept")?.includes("text/html") &&
1049
- !url.searchParams.has("__html")) ||
1050
- url.searchParams.has("__rsc");
1051
-
1052
- if (isRscRequest) {
1053
- return createResponseWithMergedHeaders(rscStream, {
1054
- status: 404,
1055
- headers: { "content-type": "text/x-component;charset=utf-8" },
1056
- });
1057
- }
1058
-
1059
- // Delegate to SSR for HTML response (reuse early setup if available)
1060
- const [ssrModule, streamMode] = await getSSRSetup(
1061
- handlerCtx,
1146
+ // Wrap the render path in a renderStartMs timeout
1147
+ const executeRender = async (): Promise<Response> => {
1148
+ if (routeMiddleware.length > 0) {
1149
+ const mwResponse = await executeMiddleware(
1150
+ buildRouteMiddlewareEntries<TEnv>(routeMiddleware),
1062
1151
  request,
1063
1152
  env,
1064
- url,
1065
- requireRequestContext()._metricsStore,
1153
+ variables,
1154
+ renderHandler,
1155
+ routeReverse,
1066
1156
  );
1067
- const htmlStream = await ssrModule.renderHTML(rscStream, {
1068
- nonce,
1069
- streamMode,
1070
- });
1071
1157
 
1072
- return createResponseWithMergedHeaders(htmlStream, {
1073
- status: 404,
1074
- headers: { "content-type": "text/html;charset=utf-8" },
1075
- });
1158
+ if (isPartial || actionContinuation) {
1159
+ const intercepted = interceptRedirectForPartial(
1160
+ mwResponse,
1161
+ createRedirectFlightResponse,
1162
+ );
1163
+ if (intercepted) return intercepted;
1164
+ }
1165
+
1166
+ return finalizeResponse(mwResponse);
1076
1167
  }
1077
1168
 
1078
- // Report unhandled errors
1079
- callOnError(error, "routing", {
1169
+ return renderHandler();
1170
+ };
1171
+
1172
+ const renderOutcome = await withTimeout(
1173
+ executeRender(),
1174
+ router.timeouts.renderStartMs,
1175
+ "render-start",
1176
+ );
1177
+ if (renderOutcome.timedOut) {
1178
+ return handleTimeoutResponse(
1080
1179
  request,
1081
- url,
1082
1180
  env,
1083
- handledByBoundary: false,
1084
- });
1085
- console.error(`[RSC] Error:`, error);
1086
- throw error;
1181
+ url,
1182
+ "render-start",
1183
+ renderOutcome.durationMs,
1184
+ routeKey,
1185
+ );
1087
1186
  }
1187
+ return renderOutcome.result;
1088
1188
  }
1089
1189
  }