@rangojs/router 0.0.0-experimental.fa8a383a → 0.0.0-experimental.fb6e2f40

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 (916) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +130 -47
  3. package/dist/vite/index.js +421 -121
  4. package/package.json +2 -2
  5. package/skills/cache-guide/SKILL.md +32 -0
  6. package/skills/caching/SKILL.md +8 -0
  7. package/skills/links/SKILL.md +3 -1
  8. package/skills/loader/SKILL.md +53 -43
  9. package/skills/middleware/SKILL.md +2 -0
  10. package/skills/parallel/SKILL.md +67 -0
  11. package/skills/prerender/SKILL.md +110 -68
  12. package/skills/route/SKILL.md +31 -0
  13. package/skills/router-setup/SKILL.md +87 -2
  14. package/skills/typesafety/SKILL.md +10 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/app-version.ts +14 -0
  17. package/src/browser/navigation-bridge.ts +16 -3
  18. package/src/browser/navigation-client.ts +64 -40
  19. package/src/browser/navigation-store.ts +43 -8
  20. package/src/browser/partial-update.ts +37 -4
  21. package/src/browser/prefetch/fetch.ts +8 -2
  22. package/src/browser/prefetch/queue.ts +61 -29
  23. package/src/browser/prefetch/resource-ready.ts +77 -0
  24. package/src/browser/react/Link.tsx +44 -8
  25. package/src/browser/react/NavigationProvider.tsx +13 -4
  26. package/src/browser/react/context.ts +7 -2
  27. package/src/browser/react/use-handle.ts +9 -58
  28. package/src/browser/react/use-router.ts +21 -8
  29. package/src/browser/rsc-router.tsx +26 -3
  30. package/src/browser/scroll-restoration.ts +10 -8
  31. package/src/browser/server-action-bridge.ts +8 -6
  32. package/src/browser/types.ts +27 -5
  33. package/src/build/generate-manifest.ts +6 -6
  34. package/src/build/generate-route-types.ts +3 -0
  35. package/src/build/route-types/include-resolution.ts +8 -1
  36. package/src/build/route-types/router-processing.ts +211 -72
  37. package/src/build/route-types/scan-filter.ts +8 -1
  38. package/src/cache/cache-runtime.ts +15 -11
  39. package/src/cache/cache-scope.ts +46 -5
  40. package/src/cache/taint.ts +55 -0
  41. package/src/client.tsx +2 -56
  42. package/src/context-var.ts +72 -2
  43. package/src/handle.ts +40 -0
  44. package/src/index.rsc.ts +3 -1
  45. package/src/index.ts +8 -0
  46. package/src/prerender/store.ts +5 -4
  47. package/src/prerender.ts +138 -77
  48. package/src/reverse.ts +22 -1
  49. package/src/route-definition/dsl-helpers.ts +42 -19
  50. package/src/route-definition/helpers-types.ts +10 -6
  51. package/src/route-definition/index.ts +3 -0
  52. package/src/route-definition/redirect.ts +9 -1
  53. package/src/route-definition/resolve-handler-use.ts +149 -0
  54. package/src/route-types.ts +11 -0
  55. package/src/router/content-negotiation.ts +100 -1
  56. package/src/router/handler-context.ts +79 -23
  57. package/src/router/intercept-resolution.ts +9 -4
  58. package/src/router/loader-resolution.ts +122 -10
  59. package/src/router/match-api.ts +124 -189
  60. package/src/router/match-middleware/background-revalidation.ts +12 -1
  61. package/src/router/match-middleware/cache-lookup.ts +68 -13
  62. package/src/router/match-middleware/cache-store.ts +21 -4
  63. package/src/router/match-middleware/segment-resolution.ts +53 -0
  64. package/src/router/match-result.ts +11 -5
  65. package/src/router/metrics.ts +6 -1
  66. package/src/router/middleware-types.ts +6 -8
  67. package/src/router/middleware.ts +2 -5
  68. package/src/router/navigation-snapshot.ts +182 -0
  69. package/src/router/prerender-match.ts +110 -10
  70. package/src/router/preview-match.ts +30 -102
  71. package/src/router/request-classification.ts +310 -0
  72. package/src/router/route-snapshot.ts +245 -0
  73. package/src/router/router-context.ts +1 -0
  74. package/src/router/router-interfaces.ts +36 -4
  75. package/src/router/router-options.ts +37 -11
  76. package/src/router/segment-resolution/fresh.ts +101 -18
  77. package/src/router/segment-resolution/helpers.ts +29 -24
  78. package/src/router/segment-resolution/revalidation.ts +122 -26
  79. package/src/router/types.ts +1 -0
  80. package/src/router.ts +54 -5
  81. package/src/rsc/handler.ts +460 -377
  82. package/src/rsc/manifest-init.ts +5 -1
  83. package/src/rsc/progressive-enhancement.ts +4 -0
  84. package/src/rsc/rsc-rendering.ts +5 -0
  85. package/src/rsc/server-action.ts +2 -0
  86. package/src/rsc/ssr-setup.ts +2 -2
  87. package/src/rsc/types.ts +8 -1
  88. package/src/server/context.ts +50 -1
  89. package/src/server/loader-registry.ts +9 -8
  90. package/src/server/request-context.ts +146 -14
  91. package/src/ssr/index.tsx +3 -0
  92. package/src/static-handler.ts +18 -6
  93. package/src/types/cache-types.ts +4 -4
  94. package/src/types/handler-context.ts +137 -33
  95. package/src/types/loader-types.ts +36 -9
  96. package/src/types/route-entry.ts +1 -1
  97. package/src/urls/path-helper-types.ts +9 -2
  98. package/src/urls/path-helper.ts +47 -12
  99. package/src/urls/pattern-types.ts +12 -0
  100. package/src/urls/response-types.ts +16 -6
  101. package/src/use-loader.tsx +73 -4
  102. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  103. package/src/vite/discovery/discover-routers.ts +5 -1
  104. package/src/vite/discovery/prerender-collection.ts +14 -1
  105. package/src/vite/discovery/state.ts +13 -4
  106. package/src/vite/index.ts +4 -0
  107. package/src/vite/plugin-types.ts +60 -5
  108. package/src/vite/plugins/performance-tracks.ts +88 -0
  109. package/src/vite/plugins/refresh-cmd.ts +88 -26
  110. package/src/vite/rango.ts +19 -2
  111. package/src/vite/router-discovery.ts +153 -34
  112. package/src/vite/utils/prerender-utils.ts +18 -0
  113. package/src/vite/utils/shared-utils.ts +3 -2
  114. package/dist/__internal.d.ts +0 -83
  115. package/dist/__internal.d.ts.map +0 -1
  116. package/dist/__internal.js +0 -19
  117. package/dist/__internal.js.map +0 -1
  118. package/dist/__mocks__/version.d.ts +0 -7
  119. package/dist/__mocks__/version.d.ts.map +0 -1
  120. package/dist/__mocks__/version.js +0 -7
  121. package/dist/__mocks__/version.js.map +0 -1
  122. package/dist/__tests__/client-href.test.d.ts +0 -2
  123. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  124. package/dist/__tests__/client-href.test.js +0 -74
  125. package/dist/__tests__/client-href.test.js.map +0 -1
  126. package/dist/__tests__/component-utils.test.d.ts +0 -2
  127. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  128. package/dist/__tests__/component-utils.test.js +0 -51
  129. package/dist/__tests__/component-utils.test.js.map +0 -1
  130. package/dist/__tests__/event-controller.test.d.ts +0 -2
  131. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  132. package/dist/__tests__/event-controller.test.js +0 -538
  133. package/dist/__tests__/event-controller.test.js.map +0 -1
  134. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  135. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  136. package/dist/__tests__/helpers/route-tree.js +0 -374
  137. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  138. package/dist/__tests__/match-result.test.d.ts +0 -2
  139. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  140. package/dist/__tests__/match-result.test.js +0 -154
  141. package/dist/__tests__/match-result.test.js.map +0 -1
  142. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  143. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  144. package/dist/__tests__/navigation-store.test.js +0 -440
  145. package/dist/__tests__/navigation-store.test.js.map +0 -1
  146. package/dist/__tests__/partial-update.test.d.ts +0 -2
  147. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  148. package/dist/__tests__/partial-update.test.js +0 -1009
  149. package/dist/__tests__/partial-update.test.js.map +0 -1
  150. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  151. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  152. package/dist/__tests__/reverse-types.test.js +0 -656
  153. package/dist/__tests__/reverse-types.test.js.map +0 -1
  154. package/dist/__tests__/route-definition.test.d.ts +0 -2
  155. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  156. package/dist/__tests__/route-definition.test.js +0 -55
  157. package/dist/__tests__/route-definition.test.js.map +0 -1
  158. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  159. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  160. package/dist/__tests__/router-helpers.test.js +0 -377
  161. package/dist/__tests__/router-helpers.test.js.map +0 -1
  162. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  163. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  164. package/dist/__tests__/router-integration-2.test.js +0 -426
  165. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  166. package/dist/__tests__/router-integration.test.d.ts +0 -2
  167. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  168. package/dist/__tests__/router-integration.test.js +0 -1051
  169. package/dist/__tests__/router-integration.test.js.map +0 -1
  170. package/dist/__tests__/search-params.test.d.ts +0 -5
  171. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  172. package/dist/__tests__/search-params.test.js +0 -306
  173. package/dist/__tests__/search-params.test.js.map +0 -1
  174. package/dist/__tests__/segment-system.test.d.ts +0 -2
  175. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  176. package/dist/__tests__/segment-system.test.js +0 -627
  177. package/dist/__tests__/segment-system.test.js.map +0 -1
  178. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  179. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  180. package/dist/__tests__/static-handler-types.test.js +0 -63
  181. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  182. package/dist/__tests__/urls.test.d.ts +0 -2
  183. package/dist/__tests__/urls.test.d.ts.map +0 -1
  184. package/dist/__tests__/urls.test.js +0 -421
  185. package/dist/__tests__/urls.test.js.map +0 -1
  186. package/dist/__tests__/use-mount.test.d.ts +0 -2
  187. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  188. package/dist/__tests__/use-mount.test.js +0 -35
  189. package/dist/__tests__/use-mount.test.js.map +0 -1
  190. package/dist/bin/rango.d.ts +0 -2
  191. package/dist/bin/rango.d.ts.map +0 -1
  192. package/dist/bin/rango.js.map +0 -1
  193. package/dist/browser/event-controller.d.ts +0 -191
  194. package/dist/browser/event-controller.d.ts.map +0 -1
  195. package/dist/browser/event-controller.js +0 -559
  196. package/dist/browser/event-controller.js.map +0 -1
  197. package/dist/browser/index.d.ts +0 -2
  198. package/dist/browser/index.d.ts.map +0 -1
  199. package/dist/browser/index.js +0 -14
  200. package/dist/browser/index.js.map +0 -1
  201. package/dist/browser/link-interceptor.d.ts +0 -38
  202. package/dist/browser/link-interceptor.d.ts.map +0 -1
  203. package/dist/browser/link-interceptor.js +0 -99
  204. package/dist/browser/link-interceptor.js.map +0 -1
  205. package/dist/browser/logging.d.ts +0 -10
  206. package/dist/browser/logging.d.ts.map +0 -1
  207. package/dist/browser/logging.js +0 -29
  208. package/dist/browser/logging.js.map +0 -1
  209. package/dist/browser/lru-cache.d.ts +0 -17
  210. package/dist/browser/lru-cache.d.ts.map +0 -1
  211. package/dist/browser/lru-cache.js +0 -50
  212. package/dist/browser/lru-cache.js.map +0 -1
  213. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  214. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  215. package/dist/browser/merge-segment-loaders.js +0 -102
  216. package/dist/browser/merge-segment-loaders.js.map +0 -1
  217. package/dist/browser/navigation-bridge.d.ts +0 -102
  218. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  219. package/dist/browser/navigation-bridge.js +0 -708
  220. package/dist/browser/navigation-bridge.js.map +0 -1
  221. package/dist/browser/navigation-client.d.ts +0 -25
  222. package/dist/browser/navigation-client.d.ts.map +0 -1
  223. package/dist/browser/navigation-client.js +0 -157
  224. package/dist/browser/navigation-client.js.map +0 -1
  225. package/dist/browser/navigation-store.d.ts +0 -101
  226. package/dist/browser/navigation-store.d.ts.map +0 -1
  227. package/dist/browser/navigation-store.js +0 -625
  228. package/dist/browser/navigation-store.js.map +0 -1
  229. package/dist/browser/partial-update.d.ts +0 -75
  230. package/dist/browser/partial-update.d.ts.map +0 -1
  231. package/dist/browser/partial-update.js +0 -426
  232. package/dist/browser/partial-update.js.map +0 -1
  233. package/dist/browser/react/Link.d.ts +0 -86
  234. package/dist/browser/react/Link.d.ts.map +0 -1
  235. package/dist/browser/react/Link.js +0 -128
  236. package/dist/browser/react/Link.js.map +0 -1
  237. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  238. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  239. package/dist/browser/react/NavigationProvider.js +0 -216
  240. package/dist/browser/react/NavigationProvider.js.map +0 -1
  241. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  242. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  243. package/dist/browser/react/ScrollRestoration.js +0 -57
  244. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  245. package/dist/browser/react/context.d.ts +0 -46
  246. package/dist/browser/react/context.d.ts.map +0 -1
  247. package/dist/browser/react/context.js +0 -10
  248. package/dist/browser/react/context.js.map +0 -1
  249. package/dist/browser/react/index.d.ts +0 -11
  250. package/dist/browser/react/index.d.ts.map +0 -1
  251. package/dist/browser/react/index.js +0 -22
  252. package/dist/browser/react/index.js.map +0 -1
  253. package/dist/browser/react/location-state-shared.d.ts +0 -63
  254. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  255. package/dist/browser/react/location-state-shared.js +0 -81
  256. package/dist/browser/react/location-state-shared.js.map +0 -1
  257. package/dist/browser/react/location-state.d.ts +0 -23
  258. package/dist/browser/react/location-state.d.ts.map +0 -1
  259. package/dist/browser/react/location-state.js +0 -29
  260. package/dist/browser/react/location-state.js.map +0 -1
  261. package/dist/browser/react/mount-context.d.ts +0 -24
  262. package/dist/browser/react/mount-context.d.ts.map +0 -1
  263. package/dist/browser/react/mount-context.js +0 -24
  264. package/dist/browser/react/mount-context.js.map +0 -1
  265. package/dist/browser/react/use-action.d.ts +0 -64
  266. package/dist/browser/react/use-action.d.ts.map +0 -1
  267. package/dist/browser/react/use-action.js +0 -134
  268. package/dist/browser/react/use-action.js.map +0 -1
  269. package/dist/browser/react/use-client-cache.d.ts +0 -41
  270. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  271. package/dist/browser/react/use-client-cache.js +0 -39
  272. package/dist/browser/react/use-client-cache.js.map +0 -1
  273. package/dist/browser/react/use-handle.d.ts +0 -31
  274. package/dist/browser/react/use-handle.d.ts.map +0 -1
  275. package/dist/browser/react/use-handle.js +0 -144
  276. package/dist/browser/react/use-handle.js.map +0 -1
  277. package/dist/browser/react/use-href.d.ts +0 -33
  278. package/dist/browser/react/use-href.d.ts.map +0 -1
  279. package/dist/browser/react/use-href.js +0 -39
  280. package/dist/browser/react/use-href.js.map +0 -1
  281. package/dist/browser/react/use-link-status.d.ts +0 -37
  282. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  283. package/dist/browser/react/use-link-status.js +0 -99
  284. package/dist/browser/react/use-link-status.js.map +0 -1
  285. package/dist/browser/react/use-mount.d.ts +0 -25
  286. package/dist/browser/react/use-mount.d.ts.map +0 -1
  287. package/dist/browser/react/use-mount.js +0 -30
  288. package/dist/browser/react/use-mount.js.map +0 -1
  289. package/dist/browser/react/use-navigation.d.ts +0 -27
  290. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  291. package/dist/browser/react/use-navigation.js +0 -87
  292. package/dist/browser/react/use-navigation.js.map +0 -1
  293. package/dist/browser/react/use-segments.d.ts +0 -38
  294. package/dist/browser/react/use-segments.d.ts.map +0 -1
  295. package/dist/browser/react/use-segments.js +0 -130
  296. package/dist/browser/react/use-segments.js.map +0 -1
  297. package/dist/browser/request-controller.d.ts +0 -26
  298. package/dist/browser/request-controller.d.ts.map +0 -1
  299. package/dist/browser/request-controller.js +0 -147
  300. package/dist/browser/request-controller.js.map +0 -1
  301. package/dist/browser/rsc-router.d.ts +0 -129
  302. package/dist/browser/rsc-router.d.ts.map +0 -1
  303. package/dist/browser/rsc-router.js +0 -195
  304. package/dist/browser/rsc-router.js.map +0 -1
  305. package/dist/browser/scroll-restoration.d.ts +0 -93
  306. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  307. package/dist/browser/scroll-restoration.js +0 -321
  308. package/dist/browser/scroll-restoration.js.map +0 -1
  309. package/dist/browser/segment-structure-assert.d.ts +0 -17
  310. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  311. package/dist/browser/segment-structure-assert.js +0 -59
  312. package/dist/browser/segment-structure-assert.js.map +0 -1
  313. package/dist/browser/server-action-bridge.d.ts +0 -26
  314. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  315. package/dist/browser/server-action-bridge.js +0 -668
  316. package/dist/browser/server-action-bridge.js.map +0 -1
  317. package/dist/browser/shallow.d.ts +0 -12
  318. package/dist/browser/shallow.d.ts.map +0 -1
  319. package/dist/browser/shallow.js +0 -34
  320. package/dist/browser/shallow.js.map +0 -1
  321. package/dist/browser/types.d.ts +0 -369
  322. package/dist/browser/types.d.ts.map +0 -1
  323. package/dist/browser/types.js +0 -2
  324. package/dist/browser/types.js.map +0 -1
  325. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  326. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  327. package/dist/build/__tests__/generate-cli.test.js +0 -237
  328. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  329. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  330. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  331. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  332. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  333. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  334. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  335. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  336. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  337. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  338. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  339. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  340. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  341. package/dist/build/generate-manifest.d.ts +0 -81
  342. package/dist/build/generate-manifest.d.ts.map +0 -1
  343. package/dist/build/generate-manifest.js +0 -276
  344. package/dist/build/generate-manifest.js.map +0 -1
  345. package/dist/build/generate-route-types.d.ts +0 -115
  346. package/dist/build/generate-route-types.d.ts.map +0 -1
  347. package/dist/build/generate-route-types.js +0 -740
  348. package/dist/build/generate-route-types.js.map +0 -1
  349. package/dist/build/index.d.ts +0 -21
  350. package/dist/build/index.d.ts.map +0 -1
  351. package/dist/build/index.js +0 -21
  352. package/dist/build/index.js.map +0 -1
  353. package/dist/build/route-trie.d.ts +0 -71
  354. package/dist/build/route-trie.d.ts.map +0 -1
  355. package/dist/build/route-trie.js +0 -175
  356. package/dist/build/route-trie.js.map +0 -1
  357. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  358. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  359. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  360. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  361. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  362. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  363. package/dist/cache/__tests__/document-cache.test.js +0 -345
  364. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  365. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  366. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  367. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  368. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  369. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  370. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  371. package/dist/cache/__tests__/memory-store.test.js +0 -367
  372. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  373. package/dist/cache/cache-scope.d.ts +0 -102
  374. package/dist/cache/cache-scope.d.ts.map +0 -1
  375. package/dist/cache/cache-scope.js +0 -440
  376. package/dist/cache/cache-scope.js.map +0 -1
  377. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  378. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  379. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  380. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  381. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  382. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  383. package/dist/cache/cf/cf-cache-store.js +0 -242
  384. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  385. package/dist/cache/cf/index.d.ts +0 -14
  386. package/dist/cache/cf/index.d.ts.map +0 -1
  387. package/dist/cache/cf/index.js +0 -17
  388. package/dist/cache/cf/index.js.map +0 -1
  389. package/dist/cache/document-cache.d.ts +0 -64
  390. package/dist/cache/document-cache.d.ts.map +0 -1
  391. package/dist/cache/document-cache.js +0 -228
  392. package/dist/cache/document-cache.js.map +0 -1
  393. package/dist/cache/index.d.ts +0 -19
  394. package/dist/cache/index.d.ts.map +0 -1
  395. package/dist/cache/index.js +0 -21
  396. package/dist/cache/index.js.map +0 -1
  397. package/dist/cache/memory-segment-store.d.ts +0 -110
  398. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  399. package/dist/cache/memory-segment-store.js +0 -117
  400. package/dist/cache/memory-segment-store.js.map +0 -1
  401. package/dist/cache/memory-store.d.ts +0 -41
  402. package/dist/cache/memory-store.d.ts.map +0 -1
  403. package/dist/cache/memory-store.js +0 -191
  404. package/dist/cache/memory-store.js.map +0 -1
  405. package/dist/cache/types.d.ts +0 -317
  406. package/dist/cache/types.d.ts.map +0 -1
  407. package/dist/cache/types.js +0 -12
  408. package/dist/cache/types.js.map +0 -1
  409. package/dist/client.d.ts +0 -248
  410. package/dist/client.d.ts.map +0 -1
  411. package/dist/client.js +0 -367
  412. package/dist/client.js.map +0 -1
  413. package/dist/client.rsc.d.ts +0 -26
  414. package/dist/client.rsc.d.ts.map +0 -1
  415. package/dist/client.rsc.js +0 -46
  416. package/dist/client.rsc.js.map +0 -1
  417. package/dist/component-utils.d.ts +0 -36
  418. package/dist/component-utils.d.ts.map +0 -1
  419. package/dist/component-utils.js +0 -61
  420. package/dist/component-utils.js.map +0 -1
  421. package/dist/components/DefaultDocument.d.ts +0 -13
  422. package/dist/components/DefaultDocument.d.ts.map +0 -1
  423. package/dist/components/DefaultDocument.js +0 -15
  424. package/dist/components/DefaultDocument.js.map +0 -1
  425. package/dist/debug.d.ts +0 -58
  426. package/dist/debug.d.ts.map +0 -1
  427. package/dist/debug.js +0 -157
  428. package/dist/debug.js.map +0 -1
  429. package/dist/default-error-boundary.d.ts +0 -11
  430. package/dist/default-error-boundary.d.ts.map +0 -1
  431. package/dist/default-error-boundary.js +0 -45
  432. package/dist/default-error-boundary.js.map +0 -1
  433. package/dist/deps/browser.d.ts +0 -2
  434. package/dist/deps/browser.d.ts.map +0 -1
  435. package/dist/deps/browser.js +0 -3
  436. package/dist/deps/browser.js.map +0 -1
  437. package/dist/deps/html-stream-client.d.ts +0 -2
  438. package/dist/deps/html-stream-client.d.ts.map +0 -1
  439. package/dist/deps/html-stream-client.js +0 -3
  440. package/dist/deps/html-stream-client.js.map +0 -1
  441. package/dist/deps/html-stream-server.d.ts +0 -2
  442. package/dist/deps/html-stream-server.d.ts.map +0 -1
  443. package/dist/deps/html-stream-server.js +0 -3
  444. package/dist/deps/html-stream-server.js.map +0 -1
  445. package/dist/deps/rsc.d.ts +0 -2
  446. package/dist/deps/rsc.d.ts.map +0 -1
  447. package/dist/deps/rsc.js +0 -4
  448. package/dist/deps/rsc.js.map +0 -1
  449. package/dist/deps/ssr.d.ts +0 -2
  450. package/dist/deps/ssr.d.ts.map +0 -1
  451. package/dist/deps/ssr.js +0 -3
  452. package/dist/deps/ssr.js.map +0 -1
  453. package/dist/errors.d.ts +0 -174
  454. package/dist/errors.d.ts.map +0 -1
  455. package/dist/errors.js +0 -241
  456. package/dist/errors.js.map +0 -1
  457. package/dist/handle.d.ts +0 -78
  458. package/dist/handle.d.ts.map +0 -1
  459. package/dist/handle.js +0 -82
  460. package/dist/handle.js.map +0 -1
  461. package/dist/handles/MetaTags.d.ts +0 -14
  462. package/dist/handles/MetaTags.d.ts.map +0 -1
  463. package/dist/handles/MetaTags.js +0 -136
  464. package/dist/handles/MetaTags.js.map +0 -1
  465. package/dist/handles/index.d.ts +0 -6
  466. package/dist/handles/index.d.ts.map +0 -1
  467. package/dist/handles/index.js +0 -6
  468. package/dist/handles/index.js.map +0 -1
  469. package/dist/handles/meta.d.ts +0 -39
  470. package/dist/handles/meta.d.ts.map +0 -1
  471. package/dist/handles/meta.js +0 -202
  472. package/dist/handles/meta.js.map +0 -1
  473. package/dist/host/__tests__/errors.test.d.ts +0 -2
  474. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  475. package/dist/host/__tests__/errors.test.js +0 -76
  476. package/dist/host/__tests__/errors.test.js.map +0 -1
  477. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  478. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  479. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  480. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  481. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  482. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  483. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  484. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  485. package/dist/host/__tests__/router.test.d.ts +0 -2
  486. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  487. package/dist/host/__tests__/router.test.js +0 -241
  488. package/dist/host/__tests__/router.test.js.map +0 -1
  489. package/dist/host/__tests__/testing.test.d.ts +0 -2
  490. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  491. package/dist/host/__tests__/testing.test.js +0 -64
  492. package/dist/host/__tests__/testing.test.js.map +0 -1
  493. package/dist/host/__tests__/utils.test.d.ts +0 -2
  494. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  495. package/dist/host/__tests__/utils.test.js +0 -29
  496. package/dist/host/__tests__/utils.test.js.map +0 -1
  497. package/dist/host/cookie-handler.d.ts +0 -34
  498. package/dist/host/cookie-handler.d.ts.map +0 -1
  499. package/dist/host/cookie-handler.js +0 -124
  500. package/dist/host/cookie-handler.js.map +0 -1
  501. package/dist/host/errors.d.ts +0 -56
  502. package/dist/host/errors.d.ts.map +0 -1
  503. package/dist/host/errors.js +0 -79
  504. package/dist/host/errors.js.map +0 -1
  505. package/dist/host/index.d.ts +0 -29
  506. package/dist/host/index.d.ts.map +0 -1
  507. package/dist/host/index.js +0 -32
  508. package/dist/host/index.js.map +0 -1
  509. package/dist/host/pattern-matcher.d.ts +0 -36
  510. package/dist/host/pattern-matcher.d.ts.map +0 -1
  511. package/dist/host/pattern-matcher.js +0 -172
  512. package/dist/host/pattern-matcher.js.map +0 -1
  513. package/dist/host/router.d.ts +0 -26
  514. package/dist/host/router.d.ts.map +0 -1
  515. package/dist/host/router.js +0 -218
  516. package/dist/host/router.js.map +0 -1
  517. package/dist/host/testing.d.ts +0 -36
  518. package/dist/host/testing.d.ts.map +0 -1
  519. package/dist/host/testing.js +0 -55
  520. package/dist/host/testing.js.map +0 -1
  521. package/dist/host/types.d.ts +0 -115
  522. package/dist/host/types.d.ts.map +0 -1
  523. package/dist/host/types.js +0 -7
  524. package/dist/host/types.js.map +0 -1
  525. package/dist/host/utils.d.ts +0 -21
  526. package/dist/host/utils.d.ts.map +0 -1
  527. package/dist/host/utils.js +0 -23
  528. package/dist/host/utils.js.map +0 -1
  529. package/dist/href-client.d.ts +0 -131
  530. package/dist/href-client.d.ts.map +0 -1
  531. package/dist/href-client.js +0 -64
  532. package/dist/href-client.js.map +0 -1
  533. package/dist/href-context.d.ts +0 -29
  534. package/dist/href-context.d.ts.map +0 -1
  535. package/dist/href-context.js +0 -21
  536. package/dist/href-context.js.map +0 -1
  537. package/dist/index.d.ts +0 -73
  538. package/dist/index.d.ts.map +0 -1
  539. package/dist/index.js +0 -91
  540. package/dist/index.js.map +0 -1
  541. package/dist/index.rsc.d.ts +0 -32
  542. package/dist/index.rsc.d.ts.map +0 -1
  543. package/dist/index.rsc.js +0 -40
  544. package/dist/index.rsc.js.map +0 -1
  545. package/dist/internal-debug.d.ts +0 -2
  546. package/dist/internal-debug.d.ts.map +0 -1
  547. package/dist/internal-debug.js +0 -5
  548. package/dist/internal-debug.js.map +0 -1
  549. package/dist/loader.d.ts +0 -14
  550. package/dist/loader.d.ts.map +0 -1
  551. package/dist/loader.js +0 -20
  552. package/dist/loader.js.map +0 -1
  553. package/dist/loader.rsc.d.ts +0 -19
  554. package/dist/loader.rsc.d.ts.map +0 -1
  555. package/dist/loader.rsc.js +0 -99
  556. package/dist/loader.rsc.js.map +0 -1
  557. package/dist/network-error-thrower.d.ts +0 -17
  558. package/dist/network-error-thrower.d.ts.map +0 -1
  559. package/dist/network-error-thrower.js +0 -14
  560. package/dist/network-error-thrower.js.map +0 -1
  561. package/dist/outlet-context.d.ts +0 -13
  562. package/dist/outlet-context.d.ts.map +0 -1
  563. package/dist/outlet-context.js +0 -3
  564. package/dist/outlet-context.js.map +0 -1
  565. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  566. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  567. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  568. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  569. package/dist/prerender/param-hash.d.ts +0 -16
  570. package/dist/prerender/param-hash.d.ts.map +0 -1
  571. package/dist/prerender/param-hash.js +0 -36
  572. package/dist/prerender/param-hash.js.map +0 -1
  573. package/dist/prerender/store.d.ts +0 -38
  574. package/dist/prerender/store.d.ts.map +0 -1
  575. package/dist/prerender/store.js +0 -61
  576. package/dist/prerender/store.js.map +0 -1
  577. package/dist/prerender.d.ts +0 -66
  578. package/dist/prerender.d.ts.map +0 -1
  579. package/dist/prerender.js +0 -57
  580. package/dist/prerender.js.map +0 -1
  581. package/dist/reverse.d.ts +0 -196
  582. package/dist/reverse.d.ts.map +0 -1
  583. package/dist/reverse.js +0 -78
  584. package/dist/reverse.js.map +0 -1
  585. package/dist/root-error-boundary.d.ts +0 -33
  586. package/dist/root-error-boundary.d.ts.map +0 -1
  587. package/dist/root-error-boundary.js +0 -165
  588. package/dist/root-error-boundary.js.map +0 -1
  589. package/dist/route-content-wrapper.d.ts +0 -46
  590. package/dist/route-content-wrapper.d.ts.map +0 -1
  591. package/dist/route-content-wrapper.js +0 -77
  592. package/dist/route-content-wrapper.js.map +0 -1
  593. package/dist/route-definition.d.ts +0 -421
  594. package/dist/route-definition.d.ts.map +0 -1
  595. package/dist/route-definition.js +0 -868
  596. package/dist/route-definition.js.map +0 -1
  597. package/dist/route-map-builder.d.ts +0 -155
  598. package/dist/route-map-builder.d.ts.map +0 -1
  599. package/dist/route-map-builder.js +0 -237
  600. package/dist/route-map-builder.js.map +0 -1
  601. package/dist/route-types.d.ts +0 -165
  602. package/dist/route-types.d.ts.map +0 -1
  603. package/dist/route-types.js +0 -7
  604. package/dist/route-types.js.map +0 -1
  605. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  606. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  607. package/dist/router/__tests__/handler-context.test.js +0 -65
  608. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  609. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  610. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  611. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  612. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  613. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  614. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  615. package/dist/router/__tests__/match-context.test.js +0 -92
  616. package/dist/router/__tests__/match-context.test.js.map +0 -1
  617. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  618. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  619. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  620. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  621. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  622. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  623. package/dist/router/__tests__/match-result.test.js +0 -457
  624. package/dist/router/__tests__/match-result.test.js.map +0 -1
  625. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  626. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  627. package/dist/router/__tests__/on-error.test.js +0 -678
  628. package/dist/router/__tests__/on-error.test.js.map +0 -1
  629. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  630. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  631. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  632. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  633. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  634. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  635. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  636. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  637. package/dist/router/error-handling.d.ts +0 -77
  638. package/dist/router/error-handling.d.ts.map +0 -1
  639. package/dist/router/error-handling.js +0 -202
  640. package/dist/router/error-handling.js.map +0 -1
  641. package/dist/router/handler-context.d.ts +0 -20
  642. package/dist/router/handler-context.d.ts.map +0 -1
  643. package/dist/router/handler-context.js +0 -198
  644. package/dist/router/handler-context.js.map +0 -1
  645. package/dist/router/intercept-resolution.d.ts +0 -66
  646. package/dist/router/intercept-resolution.d.ts.map +0 -1
  647. package/dist/router/intercept-resolution.js +0 -246
  648. package/dist/router/intercept-resolution.js.map +0 -1
  649. package/dist/router/loader-resolution.d.ts +0 -64
  650. package/dist/router/loader-resolution.d.ts.map +0 -1
  651. package/dist/router/loader-resolution.js +0 -284
  652. package/dist/router/loader-resolution.js.map +0 -1
  653. package/dist/router/logging.d.ts +0 -15
  654. package/dist/router/logging.d.ts.map +0 -1
  655. package/dist/router/logging.js +0 -99
  656. package/dist/router/logging.js.map +0 -1
  657. package/dist/router/manifest.d.ts +0 -22
  658. package/dist/router/manifest.d.ts.map +0 -1
  659. package/dist/router/manifest.js +0 -181
  660. package/dist/router/manifest.js.map +0 -1
  661. package/dist/router/match-api.d.ts +0 -35
  662. package/dist/router/match-api.d.ts.map +0 -1
  663. package/dist/router/match-api.js +0 -406
  664. package/dist/router/match-api.js.map +0 -1
  665. package/dist/router/match-context.d.ts +0 -206
  666. package/dist/router/match-context.d.ts.map +0 -1
  667. package/dist/router/match-context.js +0 -17
  668. package/dist/router/match-context.js.map +0 -1
  669. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  670. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  671. package/dist/router/match-middleware/background-revalidation.js +0 -75
  672. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  673. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  674. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  675. package/dist/router/match-middleware/cache-lookup.js +0 -257
  676. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  677. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  678. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  679. package/dist/router/match-middleware/cache-store.js +0 -108
  680. package/dist/router/match-middleware/cache-store.js.map +0 -1
  681. package/dist/router/match-middleware/index.d.ts +0 -81
  682. package/dist/router/match-middleware/index.d.ts.map +0 -1
  683. package/dist/router/match-middleware/index.js +0 -80
  684. package/dist/router/match-middleware/index.js.map +0 -1
  685. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  686. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  687. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  688. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  689. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  690. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  691. package/dist/router/match-middleware/segment-resolution.js +0 -53
  692. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  693. package/dist/router/match-pipelines.d.ts +0 -147
  694. package/dist/router/match-pipelines.d.ts.map +0 -1
  695. package/dist/router/match-pipelines.js +0 -82
  696. package/dist/router/match-pipelines.js.map +0 -1
  697. package/dist/router/match-result.d.ts +0 -126
  698. package/dist/router/match-result.d.ts.map +0 -1
  699. package/dist/router/match-result.js +0 -93
  700. package/dist/router/match-result.js.map +0 -1
  701. package/dist/router/metrics.d.ts +0 -20
  702. package/dist/router/metrics.d.ts.map +0 -1
  703. package/dist/router/metrics.js +0 -47
  704. package/dist/router/metrics.js.map +0 -1
  705. package/dist/router/middleware.d.ts +0 -249
  706. package/dist/router/middleware.d.ts.map +0 -1
  707. package/dist/router/middleware.js +0 -434
  708. package/dist/router/middleware.js.map +0 -1
  709. package/dist/router/middleware.test.d.ts +0 -2
  710. package/dist/router/middleware.test.d.ts.map +0 -1
  711. package/dist/router/middleware.test.js +0 -816
  712. package/dist/router/middleware.test.js.map +0 -1
  713. package/dist/router/pattern-matching.d.ts +0 -149
  714. package/dist/router/pattern-matching.d.ts.map +0 -1
  715. package/dist/router/pattern-matching.js +0 -349
  716. package/dist/router/pattern-matching.js.map +0 -1
  717. package/dist/router/revalidation.d.ts +0 -44
  718. package/dist/router/revalidation.d.ts.map +0 -1
  719. package/dist/router/revalidation.js +0 -147
  720. package/dist/router/revalidation.js.map +0 -1
  721. package/dist/router/router-context.d.ts +0 -135
  722. package/dist/router/router-context.d.ts.map +0 -1
  723. package/dist/router/router-context.js +0 -36
  724. package/dist/router/router-context.js.map +0 -1
  725. package/dist/router/segment-resolution.d.ts +0 -127
  726. package/dist/router/segment-resolution.d.ts.map +0 -1
  727. package/dist/router/segment-resolution.js +0 -919
  728. package/dist/router/segment-resolution.js.map +0 -1
  729. package/dist/router/trie-matching.d.ts +0 -40
  730. package/dist/router/trie-matching.d.ts.map +0 -1
  731. package/dist/router/trie-matching.js +0 -127
  732. package/dist/router/trie-matching.js.map +0 -1
  733. package/dist/router/types.d.ts +0 -136
  734. package/dist/router/types.d.ts.map +0 -1
  735. package/dist/router/types.js +0 -7
  736. package/dist/router/types.js.map +0 -1
  737. package/dist/router.d.ts +0 -753
  738. package/dist/router.d.ts.map +0 -1
  739. package/dist/router.gen.d.ts +0 -6
  740. package/dist/router.gen.d.ts.map +0 -1
  741. package/dist/router.gen.js +0 -6
  742. package/dist/router.gen.js.map +0 -1
  743. package/dist/router.js +0 -1304
  744. package/dist/router.js.map +0 -1
  745. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  746. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  747. package/dist/rsc/__tests__/helpers.test.js +0 -140
  748. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  749. package/dist/rsc/handler.d.ts +0 -45
  750. package/dist/rsc/handler.d.ts.map +0 -1
  751. package/dist/rsc/handler.js +0 -1172
  752. package/dist/rsc/handler.js.map +0 -1
  753. package/dist/rsc/helpers.d.ts +0 -16
  754. package/dist/rsc/helpers.d.ts.map +0 -1
  755. package/dist/rsc/helpers.js +0 -55
  756. package/dist/rsc/helpers.js.map +0 -1
  757. package/dist/rsc/index.d.ts +0 -22
  758. package/dist/rsc/index.d.ts.map +0 -1
  759. package/dist/rsc/index.js +0 -23
  760. package/dist/rsc/index.js.map +0 -1
  761. package/dist/rsc/nonce.d.ts +0 -9
  762. package/dist/rsc/nonce.d.ts.map +0 -1
  763. package/dist/rsc/nonce.js +0 -18
  764. package/dist/rsc/nonce.js.map +0 -1
  765. package/dist/rsc/types.d.ts +0 -206
  766. package/dist/rsc/types.d.ts.map +0 -1
  767. package/dist/rsc/types.js +0 -8
  768. package/dist/rsc/types.js.map +0 -1
  769. package/dist/search-params.d.ts +0 -103
  770. package/dist/search-params.d.ts.map +0 -1
  771. package/dist/search-params.js +0 -74
  772. package/dist/search-params.js.map +0 -1
  773. package/dist/segment-system.d.ts +0 -75
  774. package/dist/segment-system.d.ts.map +0 -1
  775. package/dist/segment-system.js +0 -336
  776. package/dist/segment-system.js.map +0 -1
  777. package/dist/server/context.d.ts +0 -245
  778. package/dist/server/context.d.ts.map +0 -1
  779. package/dist/server/context.js +0 -197
  780. package/dist/server/context.js.map +0 -1
  781. package/dist/server/fetchable-loader-store.d.ts +0 -18
  782. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  783. package/dist/server/fetchable-loader-store.js +0 -18
  784. package/dist/server/fetchable-loader-store.js.map +0 -1
  785. package/dist/server/handle-store.d.ts +0 -85
  786. package/dist/server/handle-store.d.ts.map +0 -1
  787. package/dist/server/handle-store.js +0 -142
  788. package/dist/server/handle-store.js.map +0 -1
  789. package/dist/server/loader-registry.d.ts +0 -55
  790. package/dist/server/loader-registry.d.ts.map +0 -1
  791. package/dist/server/loader-registry.js +0 -132
  792. package/dist/server/loader-registry.js.map +0 -1
  793. package/dist/server/request-context.d.ts +0 -226
  794. package/dist/server/request-context.d.ts.map +0 -1
  795. package/dist/server/request-context.js +0 -290
  796. package/dist/server/request-context.js.map +0 -1
  797. package/dist/server/root-layout.d.ts +0 -4
  798. package/dist/server/root-layout.d.ts.map +0 -1
  799. package/dist/server/root-layout.js +0 -5
  800. package/dist/server/root-layout.js.map +0 -1
  801. package/dist/server.d.ts +0 -15
  802. package/dist/server.d.ts.map +0 -1
  803. package/dist/server.js +0 -20
  804. package/dist/server.js.map +0 -1
  805. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  806. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  807. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  808. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  809. package/dist/ssr/index.d.ts +0 -98
  810. package/dist/ssr/index.d.ts.map +0 -1
  811. package/dist/ssr/index.js +0 -158
  812. package/dist/ssr/index.js.map +0 -1
  813. package/dist/static-handler.d.ts +0 -50
  814. package/dist/static-handler.d.ts.map +0 -1
  815. package/dist/static-handler.gen.d.ts +0 -5
  816. package/dist/static-handler.gen.d.ts.map +0 -1
  817. package/dist/static-handler.gen.js +0 -5
  818. package/dist/static-handler.gen.js.map +0 -1
  819. package/dist/static-handler.js +0 -29
  820. package/dist/static-handler.js.map +0 -1
  821. package/dist/theme/ThemeProvider.d.ts +0 -20
  822. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  823. package/dist/theme/ThemeProvider.js +0 -240
  824. package/dist/theme/ThemeProvider.js.map +0 -1
  825. package/dist/theme/ThemeScript.d.ts +0 -48
  826. package/dist/theme/ThemeScript.d.ts.map +0 -1
  827. package/dist/theme/ThemeScript.js +0 -13
  828. package/dist/theme/ThemeScript.js.map +0 -1
  829. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  830. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  831. package/dist/theme/__tests__/theme.test.js +0 -103
  832. package/dist/theme/__tests__/theme.test.js.map +0 -1
  833. package/dist/theme/constants.d.ts +0 -29
  834. package/dist/theme/constants.d.ts.map +0 -1
  835. package/dist/theme/constants.js +0 -48
  836. package/dist/theme/constants.js.map +0 -1
  837. package/dist/theme/index.d.ts +0 -31
  838. package/dist/theme/index.d.ts.map +0 -1
  839. package/dist/theme/index.js +0 -36
  840. package/dist/theme/index.js.map +0 -1
  841. package/dist/theme/theme-context.d.ts +0 -40
  842. package/dist/theme/theme-context.d.ts.map +0 -1
  843. package/dist/theme/theme-context.js +0 -60
  844. package/dist/theme/theme-context.js.map +0 -1
  845. package/dist/theme/theme-script.d.ts +0 -27
  846. package/dist/theme/theme-script.d.ts.map +0 -1
  847. package/dist/theme/theme-script.js +0 -147
  848. package/dist/theme/theme-script.js.map +0 -1
  849. package/dist/theme/types.d.ts +0 -163
  850. package/dist/theme/types.d.ts.map +0 -1
  851. package/dist/theme/types.js +0 -11
  852. package/dist/theme/types.js.map +0 -1
  853. package/dist/theme/use-theme.d.ts +0 -12
  854. package/dist/theme/use-theme.d.ts.map +0 -1
  855. package/dist/theme/use-theme.js +0 -40
  856. package/dist/theme/use-theme.js.map +0 -1
  857. package/dist/types.d.ts +0 -1479
  858. package/dist/types.d.ts.map +0 -1
  859. package/dist/types.js +0 -10
  860. package/dist/types.js.map +0 -1
  861. package/dist/urls.d.ts +0 -441
  862. package/dist/urls.d.ts.map +0 -1
  863. package/dist/urls.gen.d.ts +0 -8
  864. package/dist/urls.gen.d.ts.map +0 -1
  865. package/dist/urls.gen.js +0 -8
  866. package/dist/urls.gen.js.map +0 -1
  867. package/dist/urls.js +0 -443
  868. package/dist/urls.js.map +0 -1
  869. package/dist/use-loader.d.ts +0 -127
  870. package/dist/use-loader.d.ts.map +0 -1
  871. package/dist/use-loader.js +0 -237
  872. package/dist/use-loader.js.map +0 -1
  873. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  874. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  875. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  876. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  877. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  878. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  879. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  880. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  881. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  882. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  883. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  884. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  885. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  886. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  887. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  888. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  889. package/dist/vite/ast-handler-extract.d.ts +0 -49
  890. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  891. package/dist/vite/ast-handler-extract.js +0 -249
  892. package/dist/vite/ast-handler-extract.js.map +0 -1
  893. package/dist/vite/expose-action-id.d.ts +0 -19
  894. package/dist/vite/expose-action-id.d.ts.map +0 -1
  895. package/dist/vite/expose-action-id.js +0 -250
  896. package/dist/vite/expose-action-id.js.map +0 -1
  897. package/dist/vite/expose-id-utils.d.ts +0 -69
  898. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  899. package/dist/vite/expose-id-utils.js +0 -289
  900. package/dist/vite/expose-id-utils.js.map +0 -1
  901. package/dist/vite/expose-internal-ids.d.ts +0 -22
  902. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  903. package/dist/vite/expose-internal-ids.js +0 -886
  904. package/dist/vite/expose-internal-ids.js.map +0 -1
  905. package/dist/vite/index.d.ts +0 -149
  906. package/dist/vite/index.d.ts.map +0 -1
  907. package/dist/vite/index.js.map +0 -1
  908. package/dist/vite/index.named-routes.gen.ts +0 -103
  909. package/dist/vite/package-resolution.d.ts +0 -43
  910. package/dist/vite/package-resolution.d.ts.map +0 -1
  911. package/dist/vite/package-resolution.js +0 -112
  912. package/dist/vite/package-resolution.js.map +0 -1
  913. package/dist/vite/virtual-entries.d.ts +0 -25
  914. package/dist/vite/virtual-entries.d.ts.map +0 -1
  915. package/dist/vite/virtual-entries.js +0 -110
  916. package/dist/vite/virtual-entries.js.map +0 -1
@@ -14,10 +14,10 @@ import {
14
14
  runWithRequestContext,
15
15
  setRequestContextParams,
16
16
  requireRequestContext,
17
+ getRequestContext,
17
18
  createRequestContext,
18
19
  } from "../server/request-context.js";
19
20
  import * as rscDeps from "@vitejs/plugin-rsc/rsc";
20
-
21
21
  import type {
22
22
  RscPayload,
23
23
  CreateRSCHandlerOptions,
@@ -82,6 +82,11 @@ import {
82
82
  mayNeedSSR,
83
83
  SSR_SETUP_VAR,
84
84
  } from "./ssr-setup.js";
85
+ import {
86
+ classifyRequest,
87
+ type RequestPlan,
88
+ type ExecutableRequestPlan,
89
+ } from "../router/request-classification.js";
85
90
 
86
91
  /**
87
92
  * Create an RSC request handler.
@@ -452,6 +457,9 @@ export function createRSCHandler<
452
457
  // - Server components during rendering
453
458
  // - Error boundaries
454
459
  // - Streaming
460
+ // Store basename on request context (scoped per-request via existing ALS)
461
+ requestContext._basename = router.basename;
462
+
455
463
  return runWithRequestContext(requestContext, async () => {
456
464
  // Core handler logic (wrapped by middleware)
457
465
  const coreHandler = async (): Promise<Response> => {
@@ -490,7 +498,6 @@ export function createRSCHandler<
490
498
  // has completed so :post spans are captured in the timeline.
491
499
  // Handler timing parts are always emitted (even without debug metrics)
492
500
  // so non-debug requests still get bootstrap Server-Timing entries.
493
- const finalizeStart = performance.now();
494
501
  const handlerTimingArr: string[] = variables.__handlerTiming || [];
495
502
  // Preserve any existing Server-Timing set by response routes or middleware
496
503
  const existingTiming = response.headers.get("Server-Timing");
@@ -507,14 +514,6 @@ export function createRSCHandler<
507
514
  const totalStart = earlyMetricsStore
508
515
  ? handlerStart
509
516
  : metricsStore.requestStart;
510
- // response-finalize measures the gap between render completion and
511
- // handler return: header assembly, onResponse callbacks, etc.
512
- appendMetric(
513
- metricsStore,
514
- "response-finalize",
515
- finalizeStart,
516
- performance.now() - finalizeStart,
517
- );
518
517
  appendMetric(
519
518
  metricsStore,
520
519
  "handler:total",
@@ -536,7 +535,9 @@ export function createRSCHandler<
536
535
  });
537
536
  };
538
537
 
539
- // Core request handling logic (separated for middleware wrapping)
538
+ // Core request handling logic (separated for middleware wrapping).
539
+ // Uses the classify → execute model: classifyRequest produces a RequestPlan,
540
+ // then execution dispatches on the plan mode.
540
541
  async function coreRequestHandler(
541
542
  request: Request,
542
543
  env: TEnv,
@@ -544,71 +545,112 @@ export function createRSCHandler<
544
545
  variables: Record<string, any>,
545
546
  nonce: string | undefined,
546
547
  ): Promise<Response> {
547
- const previewStart = performance.now();
548
- const preview = await router.previewMatch(request, { env });
549
- const previewDur = performance.now() - previewStart;
550
548
  const handlerTiming: string[] = variables.__handlerTiming || [];
551
- handlerTiming.push(`handler-preview-match;dur=${previewDur.toFixed(2)}`);
552
- // Response route short-circuit: skip entire RSC pipeline
553
- if (preview?.responseType && preview.handler) {
554
- const responseOutcome = await withTimeout(
555
- handleResponseRoute(
556
- handlerCtx,
557
- preview as ResponseRouteMatch,
558
- request,
559
- env,
560
- url,
561
- variables,
549
+
550
+ // Debug manifest endpoint: handled before classification since it
551
+ // doesn't need a route match and needs trie access from the closure.
552
+ const isDev = process.env.NODE_ENV !== "production";
553
+ if (
554
+ url.searchParams.has("__debug_manifest") &&
555
+ (isDev || router.allowDebugManifest)
556
+ ) {
557
+ const trie = getRouterTrie(router.id) ?? getRouteTrie();
558
+ const routeManifest = getRequiredRouteMap();
559
+ const { extractAncestryFromTrie } =
560
+ await import("../build/route-trie.js");
561
+ return new Response(
562
+ JSON.stringify(
563
+ {
564
+ routerId: router.id,
565
+ routeManifest,
566
+ routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
567
+ routeTrie: trie,
568
+ precomputedEntries: getPrecomputedEntries(),
569
+ },
570
+ null,
571
+ 2,
562
572
  ),
563
- router.timeouts.renderStartMs,
564
- "render-start",
573
+ {
574
+ headers: { "Content-Type": "application/json" },
575
+ },
565
576
  );
566
- if (responseOutcome.timedOut) {
567
- return handleTimeoutResponse(
568
- request,
569
- env,
570
- url,
571
- "render-start",
572
- responseOutcome.durationMs,
573
- preview?.routeKey,
574
- );
577
+ }
578
+
579
+ // ---- 1. Classify ----
580
+ // classifyRequest may throw RouteNotFoundError for unknown routes.
581
+ // In that case, fall through to a full-render plan so the pipeline
582
+ // can render the 404 page via the existing error handling path.
583
+ const classifyStart = performance.now();
584
+ let plan: RequestPlan<TEnv>;
585
+ try {
586
+ plan = await classifyRequest<TEnv>(request, url, {
587
+ findMatch: router.findMatch,
588
+ routerVersion: version,
589
+ routerId: router.id,
590
+ });
591
+ } catch (error) {
592
+ if (
593
+ error instanceof RouteNotFoundError ||
594
+ (error instanceof Error && error.name === "RouteNotFoundError")
595
+ ) {
596
+ // Let the render path handle 404 — match()/matchPartial() will
597
+ // re-throw RouteNotFoundError and the catch block in
598
+ // executeRenderWithMiddleware renders the not-found page.
599
+ plan = {
600
+ mode: "full-render",
601
+ route: {
602
+ matched: null as any,
603
+ manifestEntry: null as any,
604
+ entries: [],
605
+ routeKey: "",
606
+ localRouteName: "",
607
+ params: {},
608
+ routeMiddleware: [],
609
+ cacheScope: null,
610
+ isPassthrough: false,
611
+ },
612
+ negotiated: false,
613
+ };
614
+ } else {
615
+ throw error;
616
+ }
617
+ }
618
+ const classifyDur = performance.now() - classifyStart;
619
+ handlerTiming.push(`handler-classify;dur=${classifyDur.toFixed(2)}`);
620
+
621
+ // ---- 2. Terminal plans (no execution needed) ----
622
+ if (plan.mode === "redirect") {
623
+ // Redirects are handled by the pipeline (match/matchPartial),
624
+ // but for partial requests we short-circuit with a Flight redirect.
625
+ if (url.searchParams.has("_rsc_partial")) {
626
+ return createRedirectFlightResponse(plan.redirectUrl);
575
627
  }
576
- return responseOutcome.result;
628
+ // Full requests: let the pipeline handle the redirect via match()
629
+ // which returns { redirect: url }. Fall through to full-render.
577
630
  }
578
631
 
579
- // Kick off SSR module loading + stream mode resolution in parallel with
580
- // segment resolution. Placed after the response-route short-circuit so
581
- // response/mime routes never pay for SSR work.
582
- if (mayNeedSSR(request, url)) {
583
- variables[SSR_SETUP_VAR] = startSSRSetup(
584
- handlerCtx,
585
- request,
586
- env,
587
- url,
588
- router.debugPerformance
589
- ? () => requireRequestContext()._metricsStore
590
- : undefined,
632
+ if (plan.mode === "version-mismatch") {
633
+ console.log(
634
+ `[RSC] Version mismatch: client=${url.searchParams.get("_rsc_v")}, server=${version}. Forcing reload.`,
591
635
  );
636
+ return createResponseWithMergedHeaders(null, {
637
+ status: 200,
638
+ headers: {
639
+ "X-RSC-Reload": plan.reloadUrl,
640
+ "content-type": "text/x-component;charset=utf-8",
641
+ },
642
+ });
592
643
  }
593
644
 
594
- const routeReverse = createReverseFunction(getRequiredRouteMap());
595
-
596
- const isAction =
597
- request.headers.has("rsc-action") || url.searchParams.has("_rsc_action");
598
- const isLoaderFetch = url.searchParams.has("_rsc_loader");
599
- const actionId =
600
- request.headers.get("rsc-action") || url.searchParams.get("_rsc_action");
601
-
602
- // Origin guard: reject cross-origin actions, loader fetches, and
603
- // PE form submissions before any execution. Regular page navigations
604
- // (GET without _rsc_loader/_rsc_action) are not affected.
605
- const originPhase: OriginCheckPhase | null = isAction
606
- ? "action"
607
- : isLoaderFetch
608
- ? "loader"
609
- : request.method === "POST"
610
- ? "pe-form"
611
- : null;
645
+ // ---- 3. Origin guard (gate for action/loader/PE modes) ----
646
+ const originPhase: OriginCheckPhase | null =
647
+ plan.mode === "action"
648
+ ? "action"
649
+ : plan.mode === "loader"
650
+ ? "loader"
651
+ : plan.mode === "pe-render"
652
+ ? "pe-form"
653
+ : null;
612
654
  if (originPhase) {
613
655
  const originResult = await checkRequestOrigin(
614
656
  request,
@@ -658,13 +700,33 @@ export function createRSCHandler<
658
700
  }
659
701
  }
660
702
 
661
- // Get handle store from request context
703
+ // ---- 4. Execute ----
704
+ return executeRequest(
705
+ plan as ExecutableRequestPlan<TEnv>,
706
+ request,
707
+ env,
708
+ url,
709
+ variables,
710
+ nonce,
711
+ );
712
+ }
713
+
714
+ // Execute a classified request plan. Dispatches to the appropriate handler
715
+ // based on plan.mode. Lives in the createRSCHandler closure for access to
716
+ // handlerCtx, router, callOnError, etc.
717
+ // Only receives executable plans (version-mismatch is handled above).
718
+ async function executeRequest(
719
+ plan: ExecutableRequestPlan<TEnv>,
720
+ request: Request,
721
+ env: TEnv,
722
+ url: URL,
723
+ variables: Record<string, any>,
724
+ nonce: string | undefined,
725
+ ): Promise<Response> {
726
+ // Common setup
662
727
  const handleStore = requireRequestContext()._handleStore;
663
728
 
664
729
  // Wire up error reporting for late streaming-handle failures
665
- // (LateHandlePushError: handle pushed after stream completion).
666
- // Without this, these errors are only caught by React's error boundary
667
- // and never reach the router's onError callback or telemetry.
668
730
  handleStore.onError = (error: Error) => {
669
731
  const reqCtx = requireRequestContext();
670
732
  callOnError(error, "handler", {
@@ -694,37 +756,106 @@ export function createRSCHandler<
694
756
  };
695
757
 
696
758
  // Set route params early so all execution paths can access ctx.params.
697
- if (preview?.params) {
698
- setRequestContextParams(preview.params, preview.routeKey);
759
+ // Also store the classified snapshot so match/matchPartial can reuse it
760
+ // instead of calling resolveRoute again.
761
+ if (plan.mode !== "redirect") {
762
+ setRequestContextParams(plan.route.params, plan.route.routeKey);
763
+ requireRequestContext()._classifiedRoute = plan.route;
699
764
  }
700
765
 
701
- // Progressive enhancement runs before the normal action/render paths.
702
- // Route middleware wraps the PE re-render so handlers see the same
703
- // context variables regardless of JS/no-JS transport.
704
- const progressiveResult = await handleProgressiveEnhancement(
705
- handlerCtx,
706
- request,
707
- env,
708
- url,
709
- isAction,
710
- handleStore,
711
- nonce,
712
- {
713
- routeMiddleware: preview?.routeMiddleware,
766
+ const routeReverse = createReverseFunction(getRequiredRouteMap());
767
+
768
+ // ---- Response route: skip entire RSC pipeline ----
769
+ if (plan.mode === "response") {
770
+ // Build ResponseRouteMatch from plan fields. handleResponseRoute
771
+ // expects a flat object with params at the top level.
772
+ const responseMatch: ResponseRouteMatch = {
773
+ responseType: plan.responseType,
774
+ handler: plan.handler,
775
+ params: plan.route.params,
776
+ negotiated: plan.negotiated,
777
+ manifestEntry: plan.manifestEntry,
778
+ routeMiddleware: plan.routeMiddleware,
779
+ };
780
+ const responseOutcome = await withTimeout(
781
+ handleResponseRoute(
782
+ handlerCtx,
783
+ responseMatch,
784
+ request,
785
+ env,
786
+ url,
787
+ variables,
788
+ ),
789
+ router.timeouts.renderStartMs,
790
+ "render-start",
791
+ );
792
+ if (responseOutcome.timedOut) {
793
+ return handleTimeoutResponse(
794
+ request,
795
+ env,
796
+ url,
797
+ "render-start",
798
+ responseOutcome.durationMs,
799
+ plan.route.routeKey,
800
+ );
801
+ }
802
+ const response = responseOutcome.result;
803
+ if (plan.negotiated) {
804
+ response.headers.append("Vary", "Accept");
805
+ }
806
+ return response;
807
+ }
808
+
809
+ // SSR setup: kick off in parallel for modes that need HTML rendering.
810
+ // Placed after response-route short-circuit so response/mime routes
811
+ // never pay for SSR work.
812
+ if (plan.mode !== "loader" && mayNeedSSR(request, url)) {
813
+ variables[SSR_SETUP_VAR] = startSSRSetup(
814
+ handlerCtx,
815
+ request,
816
+ env,
817
+ url,
818
+ router.debugPerformance
819
+ ? () => requireRequestContext()._metricsStore
820
+ : undefined,
821
+ );
822
+ }
823
+
824
+ // ---- Loader fetch ----
825
+ if (plan.mode === "loader") {
826
+ return handleLoaderFetch(
827
+ handlerCtx,
828
+ request,
829
+ env,
830
+ url,
714
831
  variables,
715
- routeReverse,
716
- },
717
- );
718
- if (progressiveResult) {
719
- return progressiveResult;
832
+ plan.route.params,
833
+ );
834
+ }
835
+
836
+ // ---- Progressive enhancement ----
837
+ if (plan.mode === "pe-render") {
838
+ const peResult = await handleProgressiveEnhancement(
839
+ handlerCtx,
840
+ request,
841
+ env,
842
+ url,
843
+ false, // isAction = false for PE
844
+ handleStore,
845
+ nonce,
846
+ {
847
+ routeMiddleware: plan.route.routeMiddleware,
848
+ variables,
849
+ routeReverse,
850
+ },
851
+ );
852
+ if (peResult) return peResult;
853
+ // PE handler returned null (not a PE form) — fall through to render
720
854
  }
721
855
 
722
- // --- Action execution: runs BEFORE route middleware ---
723
- // Route middleware wraps rendering only. For actions, the action runs
724
- // first in the global middleware context, then route middleware wraps
725
- // the revalidation pass (identical to a normal render).
726
- let actionContinuation: ActionContinuation | undefined;
727
- if (isAction && actionId) {
856
+ // ---- Action: execute action, then revalidate wrapped in route middleware ----
857
+ if (plan.mode === "action") {
858
+ let actionContinuation: ActionContinuation | undefined;
728
859
  try {
729
860
  const actionOutcome = await withTimeout(
730
861
  executeServerAction(
@@ -732,7 +863,7 @@ export function createRSCHandler<
732
863
  request,
733
864
  env,
734
865
  url,
735
- actionId,
866
+ plan.actionId,
736
867
  handleStore,
737
868
  ),
738
869
  router.timeouts.actionMs,
@@ -745,8 +876,8 @@ export function createRSCHandler<
745
876
  url,
746
877
  "action",
747
878
  actionOutcome.durationMs,
748
- preview?.routeKey,
749
- actionId,
879
+ plan.route.routeKey,
880
+ plan.actionId,
750
881
  );
751
882
  }
752
883
  const result = actionOutcome.result;
@@ -758,341 +889,293 @@ export function createRSCHandler<
758
889
  request,
759
890
  url,
760
891
  env,
761
- actionId,
892
+ actionId: plan.actionId,
762
893
  handledByBoundary: false,
763
894
  });
764
895
  console.error(`[RSC] Action error:`, error);
765
896
  throw error;
766
897
  }
767
- }
768
898
 
769
- // --- Rendering (action revalidation or navigation) ---
770
- // Route middleware wraps this same code path for both cases.
771
- const renderHandler = async () => {
772
- const response = await coreRequestHandlerInner(
899
+ // Revalidation render wrapped in route middleware.
900
+ // Actions from client-side navigation include _rsc_partial preserve
901
+ // the partial flag so the revalidation returns a Flight stream, not HTML.
902
+ // App-switch is already excluded by classifyRequest (would be full-render).
903
+ const isPartialAction = url.searchParams.has("_rsc_partial");
904
+ return executeRenderWithMiddleware(
905
+ plan.route.routeMiddleware,
906
+ plan.negotiated,
907
+ plan.route.routeKey,
908
+ routeReverse,
773
909
  request,
774
910
  env,
775
911
  url,
776
912
  variables,
777
913
  nonce,
778
- preview?.params,
779
- preview?.routeKey,
780
914
  handleStore,
915
+ isPartialAction,
781
916
  actionContinuation,
782
917
  );
783
- if (preview?.negotiated) {
784
- response.headers.append("Vary", "Accept");
785
- }
786
- return response;
787
- };
788
-
789
- // Wrap the render path (with or without route middleware) in a
790
- // renderStartMs timeout so slow renders are caught before output.
791
- const executeRender = async (): Promise<Response> => {
792
- if (preview?.routeMiddleware && preview.routeMiddleware.length > 0) {
793
- const mwResponse = await executeMiddleware(
794
- buildRouteMiddlewareEntries<TEnv>(preview.routeMiddleware),
795
- request,
796
- env,
797
- variables,
798
- renderHandler,
799
- routeReverse,
800
- );
801
-
802
- if (
803
- url.searchParams.has("_rsc_partial") ||
804
- url.searchParams.has("_rsc_action")
805
- ) {
806
- const intercepted = interceptRedirectForPartial(
807
- mwResponse,
808
- createRedirectFlightResponse,
809
- );
810
- if (intercepted) return intercepted;
811
- }
812
-
813
- return finalizeResponse(mwResponse);
814
- }
918
+ }
815
919
 
816
- // No route middleware, proceed directly
817
- return renderHandler();
818
- };
920
+ // ---- Full render / Partial render (or PE that fell through) ----
921
+ if (plan.mode === "full-render" || plan.mode === "partial-render") {
922
+ const isPartial = plan.mode === "partial-render";
923
+ return executeRenderWithMiddleware(
924
+ plan.route.routeMiddleware,
925
+ plan.negotiated,
926
+ plan.route.routeKey,
927
+ routeReverse,
928
+ request,
929
+ env,
930
+ url,
931
+ variables,
932
+ nonce,
933
+ handleStore,
934
+ isPartial,
935
+ );
936
+ }
819
937
 
820
- const renderOutcome = await withTimeout(
821
- executeRender(),
822
- router.timeouts.renderStartMs,
823
- "render-start",
824
- );
825
- if (renderOutcome.timedOut) {
826
- return handleTimeoutResponse(
938
+ // PE that fell through (handleProgressiveEnhancement returned null)
939
+ // falls back to full render
940
+ if (plan.mode === "pe-render") {
941
+ return executeRenderWithMiddleware(
942
+ plan.route.routeMiddleware,
943
+ false,
944
+ plan.route.routeKey,
945
+ routeReverse,
827
946
  request,
828
947
  env,
829
948
  url,
830
- "render-start",
831
- renderOutcome.durationMs,
832
- preview?.routeKey,
949
+ variables,
950
+ nonce,
951
+ handleStore,
952
+ false,
833
953
  );
834
954
  }
835
- return renderOutcome.result;
955
+
956
+ // Redirect plan that wasn't handled above (full-page redirect — let
957
+ // the pipeline handle it via match() which returns { redirect: url })
958
+ return executeRenderWithMiddleware(
959
+ plan.route.routeMiddleware,
960
+ false,
961
+ plan.route.routeKey,
962
+ routeReverse,
963
+ request,
964
+ env,
965
+ url,
966
+ variables,
967
+ nonce,
968
+ handleStore,
969
+ false,
970
+ );
836
971
  }
837
972
 
838
- // Inner request handler: rendering logic wrapped by route middleware.
839
- // Handles action revalidation (when actionContinuation is present),
840
- // loader fetches, and regular RSC rendering.
841
- async function coreRequestHandlerInner(
973
+ // Shared render execution: wraps handleRscRendering (or revalidateAfterAction)
974
+ // in route middleware and timeout handling. Consolidates the pattern used by
975
+ // action-revalidate, full-render, and partial-render modes.
976
+ async function executeRenderWithMiddleware(
977
+ routeMiddleware: import("../router/middleware-types.js").CollectedMiddleware[],
978
+ negotiated: boolean,
979
+ routeKey: string,
980
+ routeReverse: ReturnType<typeof createReverseFunction>,
842
981
  request: Request,
843
982
  env: TEnv,
844
983
  url: URL,
845
984
  variables: Record<string, any>,
846
985
  nonce: string | undefined,
847
- routeParams?: Record<string, string>,
848
- routeKey?: string,
849
- handleStore?: ReturnType<typeof requireRequestContext>["_handleStore"],
986
+ handleStore: ReturnType<typeof requireRequestContext>["_handleStore"],
987
+ isPartial: boolean,
850
988
  actionContinuation?: ActionContinuation,
851
989
  ): Promise<Response> {
852
- const isPartial = url.searchParams.has("_rsc_partial");
853
- const isAction =
854
- request.headers.has("rsc-action") || url.searchParams.has("_rsc_action");
855
-
856
- // Version mismatch detection - client may have stale code after HMR/deployment
857
- // If versions don't match, tell the client to reload
858
- const clientVersion = url.searchParams.get("_rsc_v");
859
- if (version && clientVersion && clientVersion !== version) {
860
- console.log(
861
- `[RSC] Version mismatch: client=${clientVersion}, server=${version}. Forcing reload.`,
862
- );
990
+ const renderHandler = async (): Promise<Response> => {
991
+ try {
992
+ let response: Response;
993
+ if (actionContinuation) {
994
+ response = await revalidateAfterAction(
995
+ handlerCtx,
996
+ request,
997
+ env,
998
+ url,
999
+ handleStore,
1000
+ actionContinuation,
1001
+ );
1002
+ } else {
1003
+ response = await handleRscRendering(
1004
+ handlerCtx,
1005
+ request,
1006
+ env,
1007
+ url,
1008
+ isPartial,
1009
+ handleStore,
1010
+ nonce,
1011
+ );
1012
+ }
1013
+ if (negotiated) {
1014
+ response.headers.append("Vary", "Accept");
1015
+ }
1016
+ return response;
1017
+ } catch (error) {
1018
+ // Check if middleware/handler returned Response
1019
+ if (error instanceof Response) {
1020
+ // During partial (client-side navigation), a 200 Response from a handler
1021
+ // means the route serves raw content (JSON, text, etc.), not JSX.
1022
+ // Signal the browser to hard-navigate so it renders the raw response.
1023
+ if (isPartial && error.status === 200) {
1024
+ console.warn(
1025
+ `[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
1026
+ `Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
1027
+ );
1028
+ return createResponseWithMergedHeaders(null, {
1029
+ status: 200,
1030
+ headers: {
1031
+ "X-RSC-Reload": stripInternalParams(url).toString(),
1032
+ "content-type": "text/x-component;charset=utf-8",
1033
+ },
1034
+ });
1035
+ }
863
1036
 
864
- // For actions, reload current page (referer) if same origin.
865
- // For navigation, load the target URL.
866
- // Validate referer origin to prevent open redirect via crafted header.
867
- let reloadUrl = stripInternalParams(url).toString();
868
- if (isAction) {
869
- const referer = request.headers.get("referer");
870
- if (referer) {
871
- try {
872
- const refererUrl = new URL(referer);
873
- if (refererUrl.origin === url.origin) {
874
- reloadUrl = referer;
875
- }
876
- } catch {
877
- // Malformed referer, fall back to cleanUrl
1037
+ if (isPartial) {
1038
+ const intercepted = interceptRedirectForPartial(
1039
+ error,
1040
+ createRedirectFlightResponse,
1041
+ );
1042
+ if (intercepted) return intercepted;
878
1043
  }
1044
+
1045
+ return error;
879
1046
  }
880
- }
881
1047
 
882
- // Return special response that tells client to reload
883
- return createResponseWithMergedHeaders(null, {
884
- status: 200,
885
- headers: {
886
- "X-RSC-Reload": reloadUrl,
887
- "content-type": "text/x-component;charset=utf-8",
888
- },
889
- });
890
- }
891
- // Debug manifest endpoint: ?__debug_manifest on any route.
892
- // Always available in dev, requires allowDebugManifest option in production.
893
- const isDev = process.env.NODE_ENV !== "production";
894
- if (
895
- url.searchParams.has("__debug_manifest") &&
896
- (isDev || router.allowDebugManifest)
897
- ) {
898
- const trie = getRouterTrie(router.id) ?? getRouteTrie();
899
- const routeManifest = getRequiredRouteMap();
900
- const { extractAncestryFromTrie } =
901
- await import("../build/route-trie.js");
902
- return new Response(
903
- JSON.stringify(
904
- {
905
- routerId: router.id,
906
- routeManifest,
907
- routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
908
- routeTrie: trie,
909
- precomputedEntries: getPrecomputedEntries(),
910
- },
911
- null,
912
- 2,
913
- ),
914
- {
915
- headers: { "Content-Type": "application/json" },
916
- },
917
- );
918
- }
1048
+ // Render 404 page for unmatched routes
1049
+ const isRouteNotFound =
1050
+ error instanceof RouteNotFoundError ||
1051
+ (error instanceof Error && error.name === "RouteNotFoundError");
1052
+ if (isRouteNotFound) {
1053
+ callOnError(error, "routing", {
1054
+ request,
1055
+ url,
1056
+ env,
1057
+ handledByBoundary: true,
1058
+ });
919
1059
 
920
- const store = handleStore ?? requireRequestContext()._handleStore;
1060
+ const notFoundOption = router.notFound;
1061
+ const notFoundComponent =
1062
+ typeof notFoundOption === "function"
1063
+ ? notFoundOption({ pathname: url.pathname })
1064
+ : (notFoundOption ?? createElement("h1", null, "Not Found"));
1065
+
1066
+ const notFoundSegment = {
1067
+ id: "notFound",
1068
+ namespace: "notFound",
1069
+ type: "route" as const,
1070
+ index: 0,
1071
+ component: notFoundComponent,
1072
+ params: {},
1073
+ };
1074
+
1075
+ const payload: RscPayload = {
1076
+ metadata: {
1077
+ pathname: url.pathname,
1078
+ routerId: router.id,
1079
+ basename: router.basename,
1080
+ segments: [notFoundSegment],
1081
+ matched: [],
1082
+ diff: [],
1083
+ isPartial: false,
1084
+ rootLayout: router.rootLayout,
1085
+ handles: handleStore.stream(),
1086
+ version,
1087
+ themeConfig: router.themeConfig,
1088
+ warmupEnabled: router.warmupEnabled,
1089
+ initialTheme: requireRequestContext().theme,
1090
+ },
1091
+ };
921
1092
 
922
- try {
923
- // Route params were already set in coreRequestHandler, but set again
924
- // for callers that enter coreRequestHandlerInner directly.
925
- if (routeParams) {
926
- setRequestContextParams(routeParams, routeKey);
927
- }
1093
+ const rscStream = renderToReadableStream(payload);
928
1094
 
929
- // ============================================================================
930
- // ACTION REVALIDATION (action already executed, revalidate segments)
931
- // ============================================================================
932
- if (actionContinuation) {
933
- return await revalidateAfterAction(
934
- handlerCtx,
935
- request,
936
- env,
937
- url,
938
- store,
939
- actionContinuation,
940
- );
941
- }
1095
+ const isRscRequest =
1096
+ isPartial ||
1097
+ (!request.headers.get("accept")?.includes("text/html") &&
1098
+ !url.searchParams.has("__html")) ||
1099
+ url.searchParams.has("__rsc");
942
1100
 
943
- // ============================================================================
944
- // LOADER FETCH EXECUTION (data fetching with RSC serialization)
945
- // ============================================================================
946
- const isLoaderRequest = url.searchParams.has("_rsc_loader");
947
- if (isLoaderRequest) {
948
- return handleLoaderFetch(
949
- handlerCtx,
950
- request,
951
- env,
952
- url,
953
- variables,
954
- routeParams,
955
- );
956
- }
1101
+ if (isRscRequest) {
1102
+ return createResponseWithMergedHeaders(rscStream, {
1103
+ status: 404,
1104
+ headers: { "content-type": "text/x-component;charset=utf-8" },
1105
+ });
1106
+ }
957
1107
 
958
- // ============================================================================
959
- // REGULAR RSC RENDERING (Navigation)
960
- // ============================================================================
961
- // Note: Must use "return await" for try/catch to catch async rejections
962
- return await handleRscRendering(
963
- handlerCtx,
964
- request,
965
- env,
966
- url,
967
- isPartial,
968
- store,
969
- nonce,
970
- );
971
- } catch (error) {
972
- // Check if middleware/handler returned Response
973
- if (error instanceof Response) {
974
- // During partial (client-side navigation), a 200 Response from a handler
975
- // means the route serves raw content (JSON, text, etc.), not JSX.
976
- // Signal the browser to hard-navigate so it renders the raw response.
977
- // Only for 200 — redirects (3xx) work already because the browser follows
978
- // them automatically to a URL that serves Flight data.
979
- if (isPartial && error.status === 200) {
980
- console.warn(
981
- `[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
982
- `Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
1108
+ const [ssrModule, streamMode] = await getSSRSetup(
1109
+ handlerCtx,
1110
+ request,
1111
+ env,
1112
+ url,
1113
+ requireRequestContext()._metricsStore,
983
1114
  );
984
- return createResponseWithMergedHeaders(null, {
985
- status: 200,
986
- headers: {
987
- "X-RSC-Reload": stripInternalParams(url).toString(),
988
- "content-type": "text/x-component;charset=utf-8",
989
- },
1115
+ const htmlStream = await ssrModule.renderHTML(rscStream, {
1116
+ nonce,
1117
+ streamMode,
990
1118
  });
991
- }
992
1119
 
993
- if (isPartial) {
994
- const intercepted = interceptRedirectForPartial(
995
- error,
996
- createRedirectFlightResponse,
997
- );
998
- if (intercepted) return intercepted;
1120
+ return createResponseWithMergedHeaders(htmlStream, {
1121
+ status: 404,
1122
+ headers: { "content-type": "text/html;charset=utf-8" },
1123
+ });
999
1124
  }
1000
1125
 
1001
- return error;
1002
- }
1003
-
1004
- // Render 404 page for unmatched routes
1005
- // Check both instanceof and error.name for cross-bundle compatibility
1006
- const isRouteNotFound =
1007
- error instanceof RouteNotFoundError ||
1008
- (error instanceof Error && error.name === "RouteNotFoundError");
1009
- if (isRouteNotFound) {
1126
+ // Report unhandled errors
1010
1127
  callOnError(error, "routing", {
1011
1128
  request,
1012
1129
  url,
1013
1130
  env,
1014
- handledByBoundary: true, // Handled by notFound component
1131
+ handledByBoundary: false,
1015
1132
  });
1133
+ console.error(`[RSC] Error:`, error);
1134
+ throw error;
1135
+ }
1136
+ };
1016
1137
 
1017
- // Get notFound component from router options or use default
1018
- const notFoundOption = router.notFound;
1019
- const notFoundComponent =
1020
- typeof notFoundOption === "function"
1021
- ? notFoundOption({ pathname: url.pathname })
1022
- : (notFoundOption ?? createElement("h1", null, "Not Found"));
1023
-
1024
- // Create a simple segment for the 404 page
1025
- const notFoundSegment = {
1026
- id: "notFound",
1027
- namespace: "notFound",
1028
- type: "route" as const,
1029
- index: 0,
1030
- component: notFoundComponent,
1031
- params: {},
1032
- };
1033
-
1034
- const payload: RscPayload = {
1035
- metadata: {
1036
- pathname: url.pathname,
1037
- segments: [notFoundSegment],
1038
- matched: [],
1039
- diff: [],
1040
- isPartial: false,
1041
- rootLayout: router.rootLayout,
1042
- handles: store.stream(),
1043
- version,
1044
- themeConfig: router.themeConfig,
1045
- warmupEnabled: router.warmupEnabled,
1046
- initialTheme: requireRequestContext().theme,
1047
- // No routeName for not-found routes
1048
- },
1049
- };
1050
-
1051
- const rscStream = renderToReadableStream(payload);
1052
-
1053
- // Determine if this is an RSC request or HTML request.
1054
- // Partial requests are always RSC (see main isRscRequest comment).
1055
- const isRscRequest =
1056
- isPartial ||
1057
- (!request.headers.get("accept")?.includes("text/html") &&
1058
- !url.searchParams.has("__html")) ||
1059
- url.searchParams.has("__rsc");
1060
-
1061
- if (isRscRequest) {
1062
- return createResponseWithMergedHeaders(rscStream, {
1063
- status: 404,
1064
- headers: { "content-type": "text/x-component;charset=utf-8" },
1065
- });
1066
- }
1067
-
1068
- // Delegate to SSR for HTML response (reuse early setup if available)
1069
- const [ssrModule, streamMode] = await getSSRSetup(
1070
- handlerCtx,
1138
+ // Wrap the render path in a renderStartMs timeout
1139
+ const executeRender = async (): Promise<Response> => {
1140
+ if (routeMiddleware.length > 0) {
1141
+ const mwResponse = await executeMiddleware(
1142
+ buildRouteMiddlewareEntries<TEnv>(routeMiddleware),
1071
1143
  request,
1072
1144
  env,
1073
- url,
1074
- requireRequestContext()._metricsStore,
1145
+ variables,
1146
+ renderHandler,
1147
+ routeReverse,
1075
1148
  );
1076
- const htmlStream = await ssrModule.renderHTML(rscStream, {
1077
- nonce,
1078
- streamMode,
1079
- });
1080
1149
 
1081
- return createResponseWithMergedHeaders(htmlStream, {
1082
- status: 404,
1083
- headers: { "content-type": "text/html;charset=utf-8" },
1084
- });
1150
+ if (isPartial || actionContinuation) {
1151
+ const intercepted = interceptRedirectForPartial(
1152
+ mwResponse,
1153
+ createRedirectFlightResponse,
1154
+ );
1155
+ if (intercepted) return intercepted;
1156
+ }
1157
+
1158
+ return finalizeResponse(mwResponse);
1085
1159
  }
1086
1160
 
1087
- // Report unhandled errors
1088
- callOnError(error, "routing", {
1161
+ return renderHandler();
1162
+ };
1163
+
1164
+ const renderOutcome = await withTimeout(
1165
+ executeRender(),
1166
+ router.timeouts.renderStartMs,
1167
+ "render-start",
1168
+ );
1169
+ if (renderOutcome.timedOut) {
1170
+ return handleTimeoutResponse(
1089
1171
  request,
1090
- url,
1091
1172
  env,
1092
- handledByBoundary: false,
1093
- });
1094
- console.error(`[RSC] Error:`, error);
1095
- throw error;
1173
+ url,
1174
+ "render-start",
1175
+ renderOutcome.durationMs,
1176
+ routeKey,
1177
+ );
1096
1178
  }
1179
+ return renderOutcome.result;
1097
1180
  }
1098
1181
  }