@rangojs/router 0.0.0-experimental.49 → 0.0.0-experimental.4ffa0f9b

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 (910) 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/prerender/SKILL.md +110 -68
  11. package/skills/route/SKILL.md +31 -0
  12. package/skills/router-setup/SKILL.md +87 -2
  13. package/skills/typesafety/SKILL.md +10 -0
  14. package/src/__internal.ts +1 -1
  15. package/src/browser/app-version.ts +14 -0
  16. package/src/browser/navigation-bridge.ts +16 -3
  17. package/src/browser/navigation-client.ts +64 -40
  18. package/src/browser/navigation-store.ts +43 -8
  19. package/src/browser/partial-update.ts +27 -5
  20. package/src/browser/prefetch/fetch.ts +8 -2
  21. package/src/browser/prefetch/queue.ts +61 -29
  22. package/src/browser/prefetch/resource-ready.ts +77 -0
  23. package/src/browser/react/Link.tsx +44 -8
  24. package/src/browser/react/NavigationProvider.tsx +13 -4
  25. package/src/browser/react/context.ts +7 -2
  26. package/src/browser/react/use-handle.ts +9 -58
  27. package/src/browser/react/use-router.ts +21 -8
  28. package/src/browser/rsc-router.tsx +26 -3
  29. package/src/browser/scroll-restoration.ts +10 -8
  30. package/src/browser/server-action-bridge.ts +8 -6
  31. package/src/browser/types.ts +27 -5
  32. package/src/build/generate-manifest.ts +6 -6
  33. package/src/build/generate-route-types.ts +3 -0
  34. package/src/build/route-types/include-resolution.ts +8 -1
  35. package/src/build/route-types/router-processing.ts +211 -72
  36. package/src/build/route-types/scan-filter.ts +8 -1
  37. package/src/cache/cache-scope.ts +46 -5
  38. package/src/cache/taint.ts +55 -0
  39. package/src/client.tsx +2 -56
  40. package/src/context-var.ts +72 -2
  41. package/src/handle.ts +40 -0
  42. package/src/index.rsc.ts +3 -1
  43. package/src/index.ts +8 -0
  44. package/src/prerender/store.ts +5 -4
  45. package/src/prerender.ts +138 -77
  46. package/src/reverse.ts +22 -1
  47. package/src/route-definition/dsl-helpers.ts +42 -19
  48. package/src/route-definition/helpers-types.ts +10 -6
  49. package/src/route-definition/index.ts +3 -0
  50. package/src/route-definition/redirect.ts +9 -1
  51. package/src/route-definition/resolve-handler-use.ts +149 -0
  52. package/src/route-types.ts +11 -0
  53. package/src/router/content-negotiation.ts +100 -1
  54. package/src/router/handler-context.ts +79 -23
  55. package/src/router/intercept-resolution.ts +9 -4
  56. package/src/router/loader-resolution.ts +121 -10
  57. package/src/router/match-api.ts +124 -189
  58. package/src/router/match-middleware/cache-lookup.ts +22 -7
  59. package/src/router/match-middleware/cache-store.ts +5 -0
  60. package/src/router/match-middleware/segment-resolution.ts +53 -0
  61. package/src/router/middleware-types.ts +6 -8
  62. package/src/router/middleware.ts +2 -5
  63. package/src/router/navigation-snapshot.ts +182 -0
  64. package/src/router/prerender-match.ts +110 -10
  65. package/src/router/preview-match.ts +30 -102
  66. package/src/router/request-classification.ts +310 -0
  67. package/src/router/route-snapshot.ts +245 -0
  68. package/src/router/router-interfaces.ts +36 -4
  69. package/src/router/router-options.ts +37 -11
  70. package/src/router/segment-resolution/fresh.ts +65 -9
  71. package/src/router/segment-resolution/helpers.ts +29 -24
  72. package/src/router/segment-resolution/revalidation.ts +65 -7
  73. package/src/router/types.ts +1 -0
  74. package/src/router.ts +54 -5
  75. package/src/rsc/handler.ts +460 -368
  76. package/src/rsc/manifest-init.ts +5 -1
  77. package/src/rsc/progressive-enhancement.ts +4 -0
  78. package/src/rsc/rsc-rendering.ts +5 -0
  79. package/src/rsc/server-action.ts +2 -0
  80. package/src/rsc/ssr-setup.ts +2 -2
  81. package/src/rsc/types.ts +8 -1
  82. package/src/server/context.ts +50 -1
  83. package/src/server/loader-registry.ts +9 -8
  84. package/src/server/request-context.ts +134 -14
  85. package/src/ssr/index.tsx +3 -0
  86. package/src/static-handler.ts +18 -6
  87. package/src/types/cache-types.ts +4 -4
  88. package/src/types/handler-context.ts +37 -19
  89. package/src/types/loader-types.ts +36 -9
  90. package/src/types/route-entry.ts +1 -1
  91. package/src/urls/path-helper-types.ts +9 -2
  92. package/src/urls/path-helper.ts +47 -12
  93. package/src/urls/pattern-types.ts +12 -0
  94. package/src/urls/response-types.ts +16 -6
  95. package/src/use-loader.tsx +73 -4
  96. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  97. package/src/vite/discovery/discover-routers.ts +5 -1
  98. package/src/vite/discovery/prerender-collection.ts +14 -1
  99. package/src/vite/discovery/state.ts +13 -4
  100. package/src/vite/index.ts +4 -0
  101. package/src/vite/plugin-types.ts +60 -5
  102. package/src/vite/plugins/performance-tracks.ts +88 -0
  103. package/src/vite/plugins/refresh-cmd.ts +88 -26
  104. package/src/vite/rango.ts +19 -2
  105. package/src/vite/router-discovery.ts +153 -34
  106. package/src/vite/utils/prerender-utils.ts +18 -0
  107. package/src/vite/utils/shared-utils.ts +3 -2
  108. package/dist/__internal.d.ts +0 -83
  109. package/dist/__internal.d.ts.map +0 -1
  110. package/dist/__internal.js +0 -19
  111. package/dist/__internal.js.map +0 -1
  112. package/dist/__mocks__/version.d.ts +0 -7
  113. package/dist/__mocks__/version.d.ts.map +0 -1
  114. package/dist/__mocks__/version.js +0 -7
  115. package/dist/__mocks__/version.js.map +0 -1
  116. package/dist/__tests__/client-href.test.d.ts +0 -2
  117. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  118. package/dist/__tests__/client-href.test.js +0 -74
  119. package/dist/__tests__/client-href.test.js.map +0 -1
  120. package/dist/__tests__/component-utils.test.d.ts +0 -2
  121. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  122. package/dist/__tests__/component-utils.test.js +0 -51
  123. package/dist/__tests__/component-utils.test.js.map +0 -1
  124. package/dist/__tests__/event-controller.test.d.ts +0 -2
  125. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  126. package/dist/__tests__/event-controller.test.js +0 -538
  127. package/dist/__tests__/event-controller.test.js.map +0 -1
  128. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  129. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  130. package/dist/__tests__/helpers/route-tree.js +0 -374
  131. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  132. package/dist/__tests__/match-result.test.d.ts +0 -2
  133. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  134. package/dist/__tests__/match-result.test.js +0 -154
  135. package/dist/__tests__/match-result.test.js.map +0 -1
  136. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  137. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  138. package/dist/__tests__/navigation-store.test.js +0 -440
  139. package/dist/__tests__/navigation-store.test.js.map +0 -1
  140. package/dist/__tests__/partial-update.test.d.ts +0 -2
  141. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  142. package/dist/__tests__/partial-update.test.js +0 -1009
  143. package/dist/__tests__/partial-update.test.js.map +0 -1
  144. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  145. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  146. package/dist/__tests__/reverse-types.test.js +0 -656
  147. package/dist/__tests__/reverse-types.test.js.map +0 -1
  148. package/dist/__tests__/route-definition.test.d.ts +0 -2
  149. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  150. package/dist/__tests__/route-definition.test.js +0 -55
  151. package/dist/__tests__/route-definition.test.js.map +0 -1
  152. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  153. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  154. package/dist/__tests__/router-helpers.test.js +0 -377
  155. package/dist/__tests__/router-helpers.test.js.map +0 -1
  156. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  157. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  158. package/dist/__tests__/router-integration-2.test.js +0 -426
  159. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  160. package/dist/__tests__/router-integration.test.d.ts +0 -2
  161. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  162. package/dist/__tests__/router-integration.test.js +0 -1051
  163. package/dist/__tests__/router-integration.test.js.map +0 -1
  164. package/dist/__tests__/search-params.test.d.ts +0 -5
  165. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  166. package/dist/__tests__/search-params.test.js +0 -306
  167. package/dist/__tests__/search-params.test.js.map +0 -1
  168. package/dist/__tests__/segment-system.test.d.ts +0 -2
  169. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  170. package/dist/__tests__/segment-system.test.js +0 -627
  171. package/dist/__tests__/segment-system.test.js.map +0 -1
  172. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  173. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  174. package/dist/__tests__/static-handler-types.test.js +0 -63
  175. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  176. package/dist/__tests__/urls.test.d.ts +0 -2
  177. package/dist/__tests__/urls.test.d.ts.map +0 -1
  178. package/dist/__tests__/urls.test.js +0 -421
  179. package/dist/__tests__/urls.test.js.map +0 -1
  180. package/dist/__tests__/use-mount.test.d.ts +0 -2
  181. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  182. package/dist/__tests__/use-mount.test.js +0 -35
  183. package/dist/__tests__/use-mount.test.js.map +0 -1
  184. package/dist/bin/rango.d.ts +0 -2
  185. package/dist/bin/rango.d.ts.map +0 -1
  186. package/dist/bin/rango.js.map +0 -1
  187. package/dist/browser/event-controller.d.ts +0 -191
  188. package/dist/browser/event-controller.d.ts.map +0 -1
  189. package/dist/browser/event-controller.js +0 -559
  190. package/dist/browser/event-controller.js.map +0 -1
  191. package/dist/browser/index.d.ts +0 -2
  192. package/dist/browser/index.d.ts.map +0 -1
  193. package/dist/browser/index.js +0 -14
  194. package/dist/browser/index.js.map +0 -1
  195. package/dist/browser/link-interceptor.d.ts +0 -38
  196. package/dist/browser/link-interceptor.d.ts.map +0 -1
  197. package/dist/browser/link-interceptor.js +0 -99
  198. package/dist/browser/link-interceptor.js.map +0 -1
  199. package/dist/browser/logging.d.ts +0 -10
  200. package/dist/browser/logging.d.ts.map +0 -1
  201. package/dist/browser/logging.js +0 -29
  202. package/dist/browser/logging.js.map +0 -1
  203. package/dist/browser/lru-cache.d.ts +0 -17
  204. package/dist/browser/lru-cache.d.ts.map +0 -1
  205. package/dist/browser/lru-cache.js +0 -50
  206. package/dist/browser/lru-cache.js.map +0 -1
  207. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  208. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  209. package/dist/browser/merge-segment-loaders.js +0 -102
  210. package/dist/browser/merge-segment-loaders.js.map +0 -1
  211. package/dist/browser/navigation-bridge.d.ts +0 -102
  212. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  213. package/dist/browser/navigation-bridge.js +0 -708
  214. package/dist/browser/navigation-bridge.js.map +0 -1
  215. package/dist/browser/navigation-client.d.ts +0 -25
  216. package/dist/browser/navigation-client.d.ts.map +0 -1
  217. package/dist/browser/navigation-client.js +0 -157
  218. package/dist/browser/navigation-client.js.map +0 -1
  219. package/dist/browser/navigation-store.d.ts +0 -101
  220. package/dist/browser/navigation-store.d.ts.map +0 -1
  221. package/dist/browser/navigation-store.js +0 -625
  222. package/dist/browser/navigation-store.js.map +0 -1
  223. package/dist/browser/partial-update.d.ts +0 -75
  224. package/dist/browser/partial-update.d.ts.map +0 -1
  225. package/dist/browser/partial-update.js +0 -426
  226. package/dist/browser/partial-update.js.map +0 -1
  227. package/dist/browser/react/Link.d.ts +0 -86
  228. package/dist/browser/react/Link.d.ts.map +0 -1
  229. package/dist/browser/react/Link.js +0 -128
  230. package/dist/browser/react/Link.js.map +0 -1
  231. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  232. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  233. package/dist/browser/react/NavigationProvider.js +0 -216
  234. package/dist/browser/react/NavigationProvider.js.map +0 -1
  235. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  236. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  237. package/dist/browser/react/ScrollRestoration.js +0 -57
  238. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  239. package/dist/browser/react/context.d.ts +0 -46
  240. package/dist/browser/react/context.d.ts.map +0 -1
  241. package/dist/browser/react/context.js +0 -10
  242. package/dist/browser/react/context.js.map +0 -1
  243. package/dist/browser/react/index.d.ts +0 -11
  244. package/dist/browser/react/index.d.ts.map +0 -1
  245. package/dist/browser/react/index.js +0 -22
  246. package/dist/browser/react/index.js.map +0 -1
  247. package/dist/browser/react/location-state-shared.d.ts +0 -63
  248. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  249. package/dist/browser/react/location-state-shared.js +0 -81
  250. package/dist/browser/react/location-state-shared.js.map +0 -1
  251. package/dist/browser/react/location-state.d.ts +0 -23
  252. package/dist/browser/react/location-state.d.ts.map +0 -1
  253. package/dist/browser/react/location-state.js +0 -29
  254. package/dist/browser/react/location-state.js.map +0 -1
  255. package/dist/browser/react/mount-context.d.ts +0 -24
  256. package/dist/browser/react/mount-context.d.ts.map +0 -1
  257. package/dist/browser/react/mount-context.js +0 -24
  258. package/dist/browser/react/mount-context.js.map +0 -1
  259. package/dist/browser/react/use-action.d.ts +0 -64
  260. package/dist/browser/react/use-action.d.ts.map +0 -1
  261. package/dist/browser/react/use-action.js +0 -134
  262. package/dist/browser/react/use-action.js.map +0 -1
  263. package/dist/browser/react/use-client-cache.d.ts +0 -41
  264. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  265. package/dist/browser/react/use-client-cache.js +0 -39
  266. package/dist/browser/react/use-client-cache.js.map +0 -1
  267. package/dist/browser/react/use-handle.d.ts +0 -31
  268. package/dist/browser/react/use-handle.d.ts.map +0 -1
  269. package/dist/browser/react/use-handle.js +0 -144
  270. package/dist/browser/react/use-handle.js.map +0 -1
  271. package/dist/browser/react/use-href.d.ts +0 -33
  272. package/dist/browser/react/use-href.d.ts.map +0 -1
  273. package/dist/browser/react/use-href.js +0 -39
  274. package/dist/browser/react/use-href.js.map +0 -1
  275. package/dist/browser/react/use-link-status.d.ts +0 -37
  276. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  277. package/dist/browser/react/use-link-status.js +0 -99
  278. package/dist/browser/react/use-link-status.js.map +0 -1
  279. package/dist/browser/react/use-mount.d.ts +0 -25
  280. package/dist/browser/react/use-mount.d.ts.map +0 -1
  281. package/dist/browser/react/use-mount.js +0 -30
  282. package/dist/browser/react/use-mount.js.map +0 -1
  283. package/dist/browser/react/use-navigation.d.ts +0 -27
  284. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  285. package/dist/browser/react/use-navigation.js +0 -87
  286. package/dist/browser/react/use-navigation.js.map +0 -1
  287. package/dist/browser/react/use-segments.d.ts +0 -38
  288. package/dist/browser/react/use-segments.d.ts.map +0 -1
  289. package/dist/browser/react/use-segments.js +0 -130
  290. package/dist/browser/react/use-segments.js.map +0 -1
  291. package/dist/browser/request-controller.d.ts +0 -26
  292. package/dist/browser/request-controller.d.ts.map +0 -1
  293. package/dist/browser/request-controller.js +0 -147
  294. package/dist/browser/request-controller.js.map +0 -1
  295. package/dist/browser/rsc-router.d.ts +0 -129
  296. package/dist/browser/rsc-router.d.ts.map +0 -1
  297. package/dist/browser/rsc-router.js +0 -195
  298. package/dist/browser/rsc-router.js.map +0 -1
  299. package/dist/browser/scroll-restoration.d.ts +0 -93
  300. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  301. package/dist/browser/scroll-restoration.js +0 -321
  302. package/dist/browser/scroll-restoration.js.map +0 -1
  303. package/dist/browser/segment-structure-assert.d.ts +0 -17
  304. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  305. package/dist/browser/segment-structure-assert.js +0 -59
  306. package/dist/browser/segment-structure-assert.js.map +0 -1
  307. package/dist/browser/server-action-bridge.d.ts +0 -26
  308. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  309. package/dist/browser/server-action-bridge.js +0 -668
  310. package/dist/browser/server-action-bridge.js.map +0 -1
  311. package/dist/browser/shallow.d.ts +0 -12
  312. package/dist/browser/shallow.d.ts.map +0 -1
  313. package/dist/browser/shallow.js +0 -34
  314. package/dist/browser/shallow.js.map +0 -1
  315. package/dist/browser/types.d.ts +0 -369
  316. package/dist/browser/types.d.ts.map +0 -1
  317. package/dist/browser/types.js +0 -2
  318. package/dist/browser/types.js.map +0 -1
  319. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  320. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  321. package/dist/build/__tests__/generate-cli.test.js +0 -237
  322. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  323. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  324. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  325. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  326. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  327. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  328. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  329. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  330. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  331. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  332. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  333. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  334. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  335. package/dist/build/generate-manifest.d.ts +0 -81
  336. package/dist/build/generate-manifest.d.ts.map +0 -1
  337. package/dist/build/generate-manifest.js +0 -276
  338. package/dist/build/generate-manifest.js.map +0 -1
  339. package/dist/build/generate-route-types.d.ts +0 -115
  340. package/dist/build/generate-route-types.d.ts.map +0 -1
  341. package/dist/build/generate-route-types.js +0 -740
  342. package/dist/build/generate-route-types.js.map +0 -1
  343. package/dist/build/index.d.ts +0 -21
  344. package/dist/build/index.d.ts.map +0 -1
  345. package/dist/build/index.js +0 -21
  346. package/dist/build/index.js.map +0 -1
  347. package/dist/build/route-trie.d.ts +0 -71
  348. package/dist/build/route-trie.d.ts.map +0 -1
  349. package/dist/build/route-trie.js +0 -175
  350. package/dist/build/route-trie.js.map +0 -1
  351. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  352. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  353. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  354. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  355. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  356. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  357. package/dist/cache/__tests__/document-cache.test.js +0 -345
  358. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  359. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  360. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  361. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  362. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  363. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  364. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  365. package/dist/cache/__tests__/memory-store.test.js +0 -367
  366. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  367. package/dist/cache/cache-scope.d.ts +0 -102
  368. package/dist/cache/cache-scope.d.ts.map +0 -1
  369. package/dist/cache/cache-scope.js +0 -440
  370. package/dist/cache/cache-scope.js.map +0 -1
  371. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  372. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  373. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  374. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  375. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  376. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  377. package/dist/cache/cf/cf-cache-store.js +0 -242
  378. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  379. package/dist/cache/cf/index.d.ts +0 -14
  380. package/dist/cache/cf/index.d.ts.map +0 -1
  381. package/dist/cache/cf/index.js +0 -17
  382. package/dist/cache/cf/index.js.map +0 -1
  383. package/dist/cache/document-cache.d.ts +0 -64
  384. package/dist/cache/document-cache.d.ts.map +0 -1
  385. package/dist/cache/document-cache.js +0 -228
  386. package/dist/cache/document-cache.js.map +0 -1
  387. package/dist/cache/index.d.ts +0 -19
  388. package/dist/cache/index.d.ts.map +0 -1
  389. package/dist/cache/index.js +0 -21
  390. package/dist/cache/index.js.map +0 -1
  391. package/dist/cache/memory-segment-store.d.ts +0 -110
  392. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  393. package/dist/cache/memory-segment-store.js +0 -117
  394. package/dist/cache/memory-segment-store.js.map +0 -1
  395. package/dist/cache/memory-store.d.ts +0 -41
  396. package/dist/cache/memory-store.d.ts.map +0 -1
  397. package/dist/cache/memory-store.js +0 -191
  398. package/dist/cache/memory-store.js.map +0 -1
  399. package/dist/cache/types.d.ts +0 -317
  400. package/dist/cache/types.d.ts.map +0 -1
  401. package/dist/cache/types.js +0 -12
  402. package/dist/cache/types.js.map +0 -1
  403. package/dist/client.d.ts +0 -248
  404. package/dist/client.d.ts.map +0 -1
  405. package/dist/client.js +0 -367
  406. package/dist/client.js.map +0 -1
  407. package/dist/client.rsc.d.ts +0 -26
  408. package/dist/client.rsc.d.ts.map +0 -1
  409. package/dist/client.rsc.js +0 -46
  410. package/dist/client.rsc.js.map +0 -1
  411. package/dist/component-utils.d.ts +0 -36
  412. package/dist/component-utils.d.ts.map +0 -1
  413. package/dist/component-utils.js +0 -61
  414. package/dist/component-utils.js.map +0 -1
  415. package/dist/components/DefaultDocument.d.ts +0 -13
  416. package/dist/components/DefaultDocument.d.ts.map +0 -1
  417. package/dist/components/DefaultDocument.js +0 -15
  418. package/dist/components/DefaultDocument.js.map +0 -1
  419. package/dist/debug.d.ts +0 -58
  420. package/dist/debug.d.ts.map +0 -1
  421. package/dist/debug.js +0 -157
  422. package/dist/debug.js.map +0 -1
  423. package/dist/default-error-boundary.d.ts +0 -11
  424. package/dist/default-error-boundary.d.ts.map +0 -1
  425. package/dist/default-error-boundary.js +0 -45
  426. package/dist/default-error-boundary.js.map +0 -1
  427. package/dist/deps/browser.d.ts +0 -2
  428. package/dist/deps/browser.d.ts.map +0 -1
  429. package/dist/deps/browser.js +0 -3
  430. package/dist/deps/browser.js.map +0 -1
  431. package/dist/deps/html-stream-client.d.ts +0 -2
  432. package/dist/deps/html-stream-client.d.ts.map +0 -1
  433. package/dist/deps/html-stream-client.js +0 -3
  434. package/dist/deps/html-stream-client.js.map +0 -1
  435. package/dist/deps/html-stream-server.d.ts +0 -2
  436. package/dist/deps/html-stream-server.d.ts.map +0 -1
  437. package/dist/deps/html-stream-server.js +0 -3
  438. package/dist/deps/html-stream-server.js.map +0 -1
  439. package/dist/deps/rsc.d.ts +0 -2
  440. package/dist/deps/rsc.d.ts.map +0 -1
  441. package/dist/deps/rsc.js +0 -4
  442. package/dist/deps/rsc.js.map +0 -1
  443. package/dist/deps/ssr.d.ts +0 -2
  444. package/dist/deps/ssr.d.ts.map +0 -1
  445. package/dist/deps/ssr.js +0 -3
  446. package/dist/deps/ssr.js.map +0 -1
  447. package/dist/errors.d.ts +0 -174
  448. package/dist/errors.d.ts.map +0 -1
  449. package/dist/errors.js +0 -241
  450. package/dist/errors.js.map +0 -1
  451. package/dist/handle.d.ts +0 -78
  452. package/dist/handle.d.ts.map +0 -1
  453. package/dist/handle.js +0 -82
  454. package/dist/handle.js.map +0 -1
  455. package/dist/handles/MetaTags.d.ts +0 -14
  456. package/dist/handles/MetaTags.d.ts.map +0 -1
  457. package/dist/handles/MetaTags.js +0 -136
  458. package/dist/handles/MetaTags.js.map +0 -1
  459. package/dist/handles/index.d.ts +0 -6
  460. package/dist/handles/index.d.ts.map +0 -1
  461. package/dist/handles/index.js +0 -6
  462. package/dist/handles/index.js.map +0 -1
  463. package/dist/handles/meta.d.ts +0 -39
  464. package/dist/handles/meta.d.ts.map +0 -1
  465. package/dist/handles/meta.js +0 -202
  466. package/dist/handles/meta.js.map +0 -1
  467. package/dist/host/__tests__/errors.test.d.ts +0 -2
  468. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  469. package/dist/host/__tests__/errors.test.js +0 -76
  470. package/dist/host/__tests__/errors.test.js.map +0 -1
  471. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  472. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  473. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  474. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  475. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  476. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  477. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  478. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  479. package/dist/host/__tests__/router.test.d.ts +0 -2
  480. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  481. package/dist/host/__tests__/router.test.js +0 -241
  482. package/dist/host/__tests__/router.test.js.map +0 -1
  483. package/dist/host/__tests__/testing.test.d.ts +0 -2
  484. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  485. package/dist/host/__tests__/testing.test.js +0 -64
  486. package/dist/host/__tests__/testing.test.js.map +0 -1
  487. package/dist/host/__tests__/utils.test.d.ts +0 -2
  488. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  489. package/dist/host/__tests__/utils.test.js +0 -29
  490. package/dist/host/__tests__/utils.test.js.map +0 -1
  491. package/dist/host/cookie-handler.d.ts +0 -34
  492. package/dist/host/cookie-handler.d.ts.map +0 -1
  493. package/dist/host/cookie-handler.js +0 -124
  494. package/dist/host/cookie-handler.js.map +0 -1
  495. package/dist/host/errors.d.ts +0 -56
  496. package/dist/host/errors.d.ts.map +0 -1
  497. package/dist/host/errors.js +0 -79
  498. package/dist/host/errors.js.map +0 -1
  499. package/dist/host/index.d.ts +0 -29
  500. package/dist/host/index.d.ts.map +0 -1
  501. package/dist/host/index.js +0 -32
  502. package/dist/host/index.js.map +0 -1
  503. package/dist/host/pattern-matcher.d.ts +0 -36
  504. package/dist/host/pattern-matcher.d.ts.map +0 -1
  505. package/dist/host/pattern-matcher.js +0 -172
  506. package/dist/host/pattern-matcher.js.map +0 -1
  507. package/dist/host/router.d.ts +0 -26
  508. package/dist/host/router.d.ts.map +0 -1
  509. package/dist/host/router.js +0 -218
  510. package/dist/host/router.js.map +0 -1
  511. package/dist/host/testing.d.ts +0 -36
  512. package/dist/host/testing.d.ts.map +0 -1
  513. package/dist/host/testing.js +0 -55
  514. package/dist/host/testing.js.map +0 -1
  515. package/dist/host/types.d.ts +0 -115
  516. package/dist/host/types.d.ts.map +0 -1
  517. package/dist/host/types.js +0 -7
  518. package/dist/host/types.js.map +0 -1
  519. package/dist/host/utils.d.ts +0 -21
  520. package/dist/host/utils.d.ts.map +0 -1
  521. package/dist/host/utils.js +0 -23
  522. package/dist/host/utils.js.map +0 -1
  523. package/dist/href-client.d.ts +0 -131
  524. package/dist/href-client.d.ts.map +0 -1
  525. package/dist/href-client.js +0 -64
  526. package/dist/href-client.js.map +0 -1
  527. package/dist/href-context.d.ts +0 -29
  528. package/dist/href-context.d.ts.map +0 -1
  529. package/dist/href-context.js +0 -21
  530. package/dist/href-context.js.map +0 -1
  531. package/dist/index.d.ts +0 -73
  532. package/dist/index.d.ts.map +0 -1
  533. package/dist/index.js +0 -91
  534. package/dist/index.js.map +0 -1
  535. package/dist/index.rsc.d.ts +0 -32
  536. package/dist/index.rsc.d.ts.map +0 -1
  537. package/dist/index.rsc.js +0 -40
  538. package/dist/index.rsc.js.map +0 -1
  539. package/dist/internal-debug.d.ts +0 -2
  540. package/dist/internal-debug.d.ts.map +0 -1
  541. package/dist/internal-debug.js +0 -5
  542. package/dist/internal-debug.js.map +0 -1
  543. package/dist/loader.d.ts +0 -14
  544. package/dist/loader.d.ts.map +0 -1
  545. package/dist/loader.js +0 -20
  546. package/dist/loader.js.map +0 -1
  547. package/dist/loader.rsc.d.ts +0 -19
  548. package/dist/loader.rsc.d.ts.map +0 -1
  549. package/dist/loader.rsc.js +0 -99
  550. package/dist/loader.rsc.js.map +0 -1
  551. package/dist/network-error-thrower.d.ts +0 -17
  552. package/dist/network-error-thrower.d.ts.map +0 -1
  553. package/dist/network-error-thrower.js +0 -14
  554. package/dist/network-error-thrower.js.map +0 -1
  555. package/dist/outlet-context.d.ts +0 -13
  556. package/dist/outlet-context.d.ts.map +0 -1
  557. package/dist/outlet-context.js +0 -3
  558. package/dist/outlet-context.js.map +0 -1
  559. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  560. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  561. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  562. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  563. package/dist/prerender/param-hash.d.ts +0 -16
  564. package/dist/prerender/param-hash.d.ts.map +0 -1
  565. package/dist/prerender/param-hash.js +0 -36
  566. package/dist/prerender/param-hash.js.map +0 -1
  567. package/dist/prerender/store.d.ts +0 -38
  568. package/dist/prerender/store.d.ts.map +0 -1
  569. package/dist/prerender/store.js +0 -61
  570. package/dist/prerender/store.js.map +0 -1
  571. package/dist/prerender.d.ts +0 -66
  572. package/dist/prerender.d.ts.map +0 -1
  573. package/dist/prerender.js +0 -57
  574. package/dist/prerender.js.map +0 -1
  575. package/dist/reverse.d.ts +0 -196
  576. package/dist/reverse.d.ts.map +0 -1
  577. package/dist/reverse.js +0 -78
  578. package/dist/reverse.js.map +0 -1
  579. package/dist/root-error-boundary.d.ts +0 -33
  580. package/dist/root-error-boundary.d.ts.map +0 -1
  581. package/dist/root-error-boundary.js +0 -165
  582. package/dist/root-error-boundary.js.map +0 -1
  583. package/dist/route-content-wrapper.d.ts +0 -46
  584. package/dist/route-content-wrapper.d.ts.map +0 -1
  585. package/dist/route-content-wrapper.js +0 -77
  586. package/dist/route-content-wrapper.js.map +0 -1
  587. package/dist/route-definition.d.ts +0 -421
  588. package/dist/route-definition.d.ts.map +0 -1
  589. package/dist/route-definition.js +0 -868
  590. package/dist/route-definition.js.map +0 -1
  591. package/dist/route-map-builder.d.ts +0 -155
  592. package/dist/route-map-builder.d.ts.map +0 -1
  593. package/dist/route-map-builder.js +0 -237
  594. package/dist/route-map-builder.js.map +0 -1
  595. package/dist/route-types.d.ts +0 -165
  596. package/dist/route-types.d.ts.map +0 -1
  597. package/dist/route-types.js +0 -7
  598. package/dist/route-types.js.map +0 -1
  599. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  600. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  601. package/dist/router/__tests__/handler-context.test.js +0 -65
  602. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  603. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  604. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  605. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  606. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  607. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  608. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  609. package/dist/router/__tests__/match-context.test.js +0 -92
  610. package/dist/router/__tests__/match-context.test.js.map +0 -1
  611. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  612. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  613. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  614. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  615. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  616. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  617. package/dist/router/__tests__/match-result.test.js +0 -457
  618. package/dist/router/__tests__/match-result.test.js.map +0 -1
  619. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  620. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  621. package/dist/router/__tests__/on-error.test.js +0 -678
  622. package/dist/router/__tests__/on-error.test.js.map +0 -1
  623. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  624. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  625. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  626. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  627. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  628. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  629. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  630. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  631. package/dist/router/error-handling.d.ts +0 -77
  632. package/dist/router/error-handling.d.ts.map +0 -1
  633. package/dist/router/error-handling.js +0 -202
  634. package/dist/router/error-handling.js.map +0 -1
  635. package/dist/router/handler-context.d.ts +0 -20
  636. package/dist/router/handler-context.d.ts.map +0 -1
  637. package/dist/router/handler-context.js +0 -198
  638. package/dist/router/handler-context.js.map +0 -1
  639. package/dist/router/intercept-resolution.d.ts +0 -66
  640. package/dist/router/intercept-resolution.d.ts.map +0 -1
  641. package/dist/router/intercept-resolution.js +0 -246
  642. package/dist/router/intercept-resolution.js.map +0 -1
  643. package/dist/router/loader-resolution.d.ts +0 -64
  644. package/dist/router/loader-resolution.d.ts.map +0 -1
  645. package/dist/router/loader-resolution.js +0 -284
  646. package/dist/router/loader-resolution.js.map +0 -1
  647. package/dist/router/logging.d.ts +0 -15
  648. package/dist/router/logging.d.ts.map +0 -1
  649. package/dist/router/logging.js +0 -99
  650. package/dist/router/logging.js.map +0 -1
  651. package/dist/router/manifest.d.ts +0 -22
  652. package/dist/router/manifest.d.ts.map +0 -1
  653. package/dist/router/manifest.js +0 -181
  654. package/dist/router/manifest.js.map +0 -1
  655. package/dist/router/match-api.d.ts +0 -35
  656. package/dist/router/match-api.d.ts.map +0 -1
  657. package/dist/router/match-api.js +0 -406
  658. package/dist/router/match-api.js.map +0 -1
  659. package/dist/router/match-context.d.ts +0 -206
  660. package/dist/router/match-context.d.ts.map +0 -1
  661. package/dist/router/match-context.js +0 -17
  662. package/dist/router/match-context.js.map +0 -1
  663. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  664. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  665. package/dist/router/match-middleware/background-revalidation.js +0 -75
  666. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  667. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  668. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  669. package/dist/router/match-middleware/cache-lookup.js +0 -257
  670. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  671. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  672. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  673. package/dist/router/match-middleware/cache-store.js +0 -108
  674. package/dist/router/match-middleware/cache-store.js.map +0 -1
  675. package/dist/router/match-middleware/index.d.ts +0 -81
  676. package/dist/router/match-middleware/index.d.ts.map +0 -1
  677. package/dist/router/match-middleware/index.js +0 -80
  678. package/dist/router/match-middleware/index.js.map +0 -1
  679. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  680. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  681. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  682. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  683. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  684. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  685. package/dist/router/match-middleware/segment-resolution.js +0 -53
  686. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  687. package/dist/router/match-pipelines.d.ts +0 -147
  688. package/dist/router/match-pipelines.d.ts.map +0 -1
  689. package/dist/router/match-pipelines.js +0 -82
  690. package/dist/router/match-pipelines.js.map +0 -1
  691. package/dist/router/match-result.d.ts +0 -126
  692. package/dist/router/match-result.d.ts.map +0 -1
  693. package/dist/router/match-result.js +0 -93
  694. package/dist/router/match-result.js.map +0 -1
  695. package/dist/router/metrics.d.ts +0 -20
  696. package/dist/router/metrics.d.ts.map +0 -1
  697. package/dist/router/metrics.js +0 -47
  698. package/dist/router/metrics.js.map +0 -1
  699. package/dist/router/middleware.d.ts +0 -249
  700. package/dist/router/middleware.d.ts.map +0 -1
  701. package/dist/router/middleware.js +0 -434
  702. package/dist/router/middleware.js.map +0 -1
  703. package/dist/router/middleware.test.d.ts +0 -2
  704. package/dist/router/middleware.test.d.ts.map +0 -1
  705. package/dist/router/middleware.test.js +0 -816
  706. package/dist/router/middleware.test.js.map +0 -1
  707. package/dist/router/pattern-matching.d.ts +0 -149
  708. package/dist/router/pattern-matching.d.ts.map +0 -1
  709. package/dist/router/pattern-matching.js +0 -349
  710. package/dist/router/pattern-matching.js.map +0 -1
  711. package/dist/router/revalidation.d.ts +0 -44
  712. package/dist/router/revalidation.d.ts.map +0 -1
  713. package/dist/router/revalidation.js +0 -147
  714. package/dist/router/revalidation.js.map +0 -1
  715. package/dist/router/router-context.d.ts +0 -135
  716. package/dist/router/router-context.d.ts.map +0 -1
  717. package/dist/router/router-context.js +0 -36
  718. package/dist/router/router-context.js.map +0 -1
  719. package/dist/router/segment-resolution.d.ts +0 -127
  720. package/dist/router/segment-resolution.d.ts.map +0 -1
  721. package/dist/router/segment-resolution.js +0 -919
  722. package/dist/router/segment-resolution.js.map +0 -1
  723. package/dist/router/trie-matching.d.ts +0 -40
  724. package/dist/router/trie-matching.d.ts.map +0 -1
  725. package/dist/router/trie-matching.js +0 -127
  726. package/dist/router/trie-matching.js.map +0 -1
  727. package/dist/router/types.d.ts +0 -136
  728. package/dist/router/types.d.ts.map +0 -1
  729. package/dist/router/types.js +0 -7
  730. package/dist/router/types.js.map +0 -1
  731. package/dist/router.d.ts +0 -753
  732. package/dist/router.d.ts.map +0 -1
  733. package/dist/router.gen.d.ts +0 -6
  734. package/dist/router.gen.d.ts.map +0 -1
  735. package/dist/router.gen.js +0 -6
  736. package/dist/router.gen.js.map +0 -1
  737. package/dist/router.js +0 -1304
  738. package/dist/router.js.map +0 -1
  739. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  740. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  741. package/dist/rsc/__tests__/helpers.test.js +0 -140
  742. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  743. package/dist/rsc/handler.d.ts +0 -45
  744. package/dist/rsc/handler.d.ts.map +0 -1
  745. package/dist/rsc/handler.js +0 -1172
  746. package/dist/rsc/handler.js.map +0 -1
  747. package/dist/rsc/helpers.d.ts +0 -16
  748. package/dist/rsc/helpers.d.ts.map +0 -1
  749. package/dist/rsc/helpers.js +0 -55
  750. package/dist/rsc/helpers.js.map +0 -1
  751. package/dist/rsc/index.d.ts +0 -22
  752. package/dist/rsc/index.d.ts.map +0 -1
  753. package/dist/rsc/index.js +0 -23
  754. package/dist/rsc/index.js.map +0 -1
  755. package/dist/rsc/nonce.d.ts +0 -9
  756. package/dist/rsc/nonce.d.ts.map +0 -1
  757. package/dist/rsc/nonce.js +0 -18
  758. package/dist/rsc/nonce.js.map +0 -1
  759. package/dist/rsc/types.d.ts +0 -206
  760. package/dist/rsc/types.d.ts.map +0 -1
  761. package/dist/rsc/types.js +0 -8
  762. package/dist/rsc/types.js.map +0 -1
  763. package/dist/search-params.d.ts +0 -103
  764. package/dist/search-params.d.ts.map +0 -1
  765. package/dist/search-params.js +0 -74
  766. package/dist/search-params.js.map +0 -1
  767. package/dist/segment-system.d.ts +0 -75
  768. package/dist/segment-system.d.ts.map +0 -1
  769. package/dist/segment-system.js +0 -336
  770. package/dist/segment-system.js.map +0 -1
  771. package/dist/server/context.d.ts +0 -245
  772. package/dist/server/context.d.ts.map +0 -1
  773. package/dist/server/context.js +0 -197
  774. package/dist/server/context.js.map +0 -1
  775. package/dist/server/fetchable-loader-store.d.ts +0 -18
  776. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  777. package/dist/server/fetchable-loader-store.js +0 -18
  778. package/dist/server/fetchable-loader-store.js.map +0 -1
  779. package/dist/server/handle-store.d.ts +0 -85
  780. package/dist/server/handle-store.d.ts.map +0 -1
  781. package/dist/server/handle-store.js +0 -142
  782. package/dist/server/handle-store.js.map +0 -1
  783. package/dist/server/loader-registry.d.ts +0 -55
  784. package/dist/server/loader-registry.d.ts.map +0 -1
  785. package/dist/server/loader-registry.js +0 -132
  786. package/dist/server/loader-registry.js.map +0 -1
  787. package/dist/server/request-context.d.ts +0 -226
  788. package/dist/server/request-context.d.ts.map +0 -1
  789. package/dist/server/request-context.js +0 -290
  790. package/dist/server/request-context.js.map +0 -1
  791. package/dist/server/root-layout.d.ts +0 -4
  792. package/dist/server/root-layout.d.ts.map +0 -1
  793. package/dist/server/root-layout.js +0 -5
  794. package/dist/server/root-layout.js.map +0 -1
  795. package/dist/server.d.ts +0 -15
  796. package/dist/server.d.ts.map +0 -1
  797. package/dist/server.js +0 -20
  798. package/dist/server.js.map +0 -1
  799. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  800. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  801. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  802. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  803. package/dist/ssr/index.d.ts +0 -98
  804. package/dist/ssr/index.d.ts.map +0 -1
  805. package/dist/ssr/index.js +0 -158
  806. package/dist/ssr/index.js.map +0 -1
  807. package/dist/static-handler.d.ts +0 -50
  808. package/dist/static-handler.d.ts.map +0 -1
  809. package/dist/static-handler.gen.d.ts +0 -5
  810. package/dist/static-handler.gen.d.ts.map +0 -1
  811. package/dist/static-handler.gen.js +0 -5
  812. package/dist/static-handler.gen.js.map +0 -1
  813. package/dist/static-handler.js +0 -29
  814. package/dist/static-handler.js.map +0 -1
  815. package/dist/theme/ThemeProvider.d.ts +0 -20
  816. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  817. package/dist/theme/ThemeProvider.js +0 -240
  818. package/dist/theme/ThemeProvider.js.map +0 -1
  819. package/dist/theme/ThemeScript.d.ts +0 -48
  820. package/dist/theme/ThemeScript.d.ts.map +0 -1
  821. package/dist/theme/ThemeScript.js +0 -13
  822. package/dist/theme/ThemeScript.js.map +0 -1
  823. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  824. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  825. package/dist/theme/__tests__/theme.test.js +0 -103
  826. package/dist/theme/__tests__/theme.test.js.map +0 -1
  827. package/dist/theme/constants.d.ts +0 -29
  828. package/dist/theme/constants.d.ts.map +0 -1
  829. package/dist/theme/constants.js +0 -48
  830. package/dist/theme/constants.js.map +0 -1
  831. package/dist/theme/index.d.ts +0 -31
  832. package/dist/theme/index.d.ts.map +0 -1
  833. package/dist/theme/index.js +0 -36
  834. package/dist/theme/index.js.map +0 -1
  835. package/dist/theme/theme-context.d.ts +0 -40
  836. package/dist/theme/theme-context.d.ts.map +0 -1
  837. package/dist/theme/theme-context.js +0 -60
  838. package/dist/theme/theme-context.js.map +0 -1
  839. package/dist/theme/theme-script.d.ts +0 -27
  840. package/dist/theme/theme-script.d.ts.map +0 -1
  841. package/dist/theme/theme-script.js +0 -147
  842. package/dist/theme/theme-script.js.map +0 -1
  843. package/dist/theme/types.d.ts +0 -163
  844. package/dist/theme/types.d.ts.map +0 -1
  845. package/dist/theme/types.js +0 -11
  846. package/dist/theme/types.js.map +0 -1
  847. package/dist/theme/use-theme.d.ts +0 -12
  848. package/dist/theme/use-theme.d.ts.map +0 -1
  849. package/dist/theme/use-theme.js +0 -40
  850. package/dist/theme/use-theme.js.map +0 -1
  851. package/dist/types.d.ts +0 -1479
  852. package/dist/types.d.ts.map +0 -1
  853. package/dist/types.js +0 -10
  854. package/dist/types.js.map +0 -1
  855. package/dist/urls.d.ts +0 -441
  856. package/dist/urls.d.ts.map +0 -1
  857. package/dist/urls.gen.d.ts +0 -8
  858. package/dist/urls.gen.d.ts.map +0 -1
  859. package/dist/urls.gen.js +0 -8
  860. package/dist/urls.gen.js.map +0 -1
  861. package/dist/urls.js +0 -443
  862. package/dist/urls.js.map +0 -1
  863. package/dist/use-loader.d.ts +0 -127
  864. package/dist/use-loader.d.ts.map +0 -1
  865. package/dist/use-loader.js +0 -237
  866. package/dist/use-loader.js.map +0 -1
  867. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  868. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  869. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  870. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  871. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  872. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  873. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  874. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  875. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  876. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  877. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  878. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  879. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  880. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  881. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  882. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  883. package/dist/vite/ast-handler-extract.d.ts +0 -49
  884. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  885. package/dist/vite/ast-handler-extract.js +0 -249
  886. package/dist/vite/ast-handler-extract.js.map +0 -1
  887. package/dist/vite/expose-action-id.d.ts +0 -19
  888. package/dist/vite/expose-action-id.d.ts.map +0 -1
  889. package/dist/vite/expose-action-id.js +0 -250
  890. package/dist/vite/expose-action-id.js.map +0 -1
  891. package/dist/vite/expose-id-utils.d.ts +0 -69
  892. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  893. package/dist/vite/expose-id-utils.js +0 -289
  894. package/dist/vite/expose-id-utils.js.map +0 -1
  895. package/dist/vite/expose-internal-ids.d.ts +0 -22
  896. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  897. package/dist/vite/expose-internal-ids.js +0 -886
  898. package/dist/vite/expose-internal-ids.js.map +0 -1
  899. package/dist/vite/index.d.ts +0 -149
  900. package/dist/vite/index.d.ts.map +0 -1
  901. package/dist/vite/index.js.map +0 -1
  902. package/dist/vite/index.named-routes.gen.ts +0 -103
  903. package/dist/vite/package-resolution.d.ts +0 -43
  904. package/dist/vite/package-resolution.d.ts.map +0 -1
  905. package/dist/vite/package-resolution.js +0 -112
  906. package/dist/vite/package-resolution.js.map +0 -1
  907. package/dist/vite/virtual-entries.d.ts +0 -25
  908. package/dist/vite/virtual-entries.d.ts.map +0 -1
  909. package/dist/vite/virtual-entries.js +0 -110
  910. 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> => {
@@ -527,7 +535,9 @@ export function createRSCHandler<
527
535
  });
528
536
  };
529
537
 
530
- // 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.
531
541
  async function coreRequestHandler(
532
542
  request: Request,
533
543
  env: TEnv,
@@ -535,71 +545,112 @@ export function createRSCHandler<
535
545
  variables: Record<string, any>,
536
546
  nonce: string | undefined,
537
547
  ): Promise<Response> {
538
- const previewStart = performance.now();
539
- const preview = await router.previewMatch(request, { env });
540
- const previewDur = performance.now() - previewStart;
541
548
  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,
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,
553
572
  ),
554
- router.timeouts.renderStartMs,
555
- "render-start",
573
+ {
574
+ headers: { "Content-Type": "application/json" },
575
+ },
556
576
  );
557
- if (responseOutcome.timedOut) {
558
- return handleTimeoutResponse(
559
- request,
560
- env,
561
- url,
562
- "render-start",
563
- responseOutcome.durationMs,
564
- preview?.routeKey,
565
- );
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);
566
627
  }
567
- return responseOutcome.result;
628
+ // Full requests: let the pipeline handle the redirect via match()
629
+ // which returns { redirect: url }. Fall through to full-render.
568
630
  }
569
631
 
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,
632
+ if (plan.mode === "version-mismatch") {
633
+ console.log(
634
+ `[RSC] Version mismatch: client=${url.searchParams.get("_rsc_v")}, server=${version}. Forcing reload.`,
582
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
+ });
583
643
  }
584
644
 
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;
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;
603
654
  if (originPhase) {
604
655
  const originResult = await checkRequestOrigin(
605
656
  request,
@@ -649,13 +700,33 @@ export function createRSCHandler<
649
700
  }
650
701
  }
651
702
 
652
- // 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
653
727
  const handleStore = requireRequestContext()._handleStore;
654
728
 
655
729
  // 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
730
  handleStore.onError = (error: Error) => {
660
731
  const reqCtx = requireRequestContext();
661
732
  callOnError(error, "handler", {
@@ -685,37 +756,106 @@ export function createRSCHandler<
685
756
  };
686
757
 
687
758
  // Set route params early so all execution paths can access ctx.params.
688
- if (preview?.params) {
689
- 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;
690
764
  }
691
765
 
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,
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,
705
831
  variables,
706
- routeReverse,
707
- },
708
- );
709
- if (progressiveResult) {
710
- return progressiveResult;
832
+ plan.route.params,
833
+ );
711
834
  }
712
835
 
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) {
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
854
+ }
855
+
856
+ // ---- Action: execute action, then revalidate wrapped in route middleware ----
857
+ if (plan.mode === "action") {
858
+ let actionContinuation: ActionContinuation | undefined;
719
859
  try {
720
860
  const actionOutcome = await withTimeout(
721
861
  executeServerAction(
@@ -723,7 +863,7 @@ export function createRSCHandler<
723
863
  request,
724
864
  env,
725
865
  url,
726
- actionId,
866
+ plan.actionId,
727
867
  handleStore,
728
868
  ),
729
869
  router.timeouts.actionMs,
@@ -736,8 +876,8 @@ export function createRSCHandler<
736
876
  url,
737
877
  "action",
738
878
  actionOutcome.durationMs,
739
- preview?.routeKey,
740
- actionId,
879
+ plan.route.routeKey,
880
+ plan.actionId,
741
881
  );
742
882
  }
743
883
  const result = actionOutcome.result;
@@ -749,341 +889,293 @@ export function createRSCHandler<
749
889
  request,
750
890
  url,
751
891
  env,
752
- actionId,
892
+ actionId: plan.actionId,
753
893
  handledByBoundary: false,
754
894
  });
755
895
  console.error(`[RSC] Action error:`, error);
756
896
  throw error;
757
897
  }
758
- }
759
898
 
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(
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,
764
909
  request,
765
910
  env,
766
911
  url,
767
912
  variables,
768
913
  nonce,
769
- preview?.params,
770
- preview?.routeKey,
771
914
  handleStore,
915
+ isPartialAction,
772
916
  actionContinuation,
773
917
  );
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
- }
918
+ }
806
919
 
807
- // No route middleware, proceed directly
808
- return renderHandler();
809
- };
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
+ }
810
937
 
811
- const renderOutcome = await withTimeout(
812
- executeRender(),
813
- router.timeouts.renderStartMs,
814
- "render-start",
815
- );
816
- if (renderOutcome.timedOut) {
817
- 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,
818
946
  request,
819
947
  env,
820
948
  url,
821
- "render-start",
822
- renderOutcome.durationMs,
823
- preview?.routeKey,
949
+ variables,
950
+ nonce,
951
+ handleStore,
952
+ false,
824
953
  );
825
954
  }
826
- 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
+ );
827
971
  }
828
972
 
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(
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>,
833
981
  request: Request,
834
982
  env: TEnv,
835
983
  url: URL,
836
984
  variables: Record<string, any>,
837
985
  nonce: string | undefined,
838
- routeParams?: Record<string, string>,
839
- routeKey?: string,
840
- handleStore?: ReturnType<typeof requireRequestContext>["_handleStore"],
986
+ handleStore: ReturnType<typeof requireRequestContext>["_handleStore"],
987
+ isPartial: boolean,
841
988
  actionContinuation?: ActionContinuation,
842
989
  ): 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
- );
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
+ }
854
1036
 
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
1037
+ if (isPartial) {
1038
+ const intercepted = interceptRedirectForPartial(
1039
+ error,
1040
+ createRedirectFlightResponse,
1041
+ );
1042
+ if (intercepted) return intercepted;
869
1043
  }
1044
+
1045
+ return error;
870
1046
  }
871
- }
872
1047
 
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
- }
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
+ });
910
1059
 
911
- 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
+ };
912
1092
 
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
- }
1093
+ const rscStream = renderToReadableStream(payload);
919
1094
 
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
- }
1095
+ const isRscRequest =
1096
+ isPartial ||
1097
+ (!request.headers.get("accept")?.includes("text/html") &&
1098
+ !url.searchParams.has("__html")) ||
1099
+ url.searchParams.has("__rsc");
933
1100
 
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
- }
1101
+ if (isRscRequest) {
1102
+ return createResponseWithMergedHeaders(rscStream, {
1103
+ status: 404,
1104
+ headers: { "content-type": "text/x-component;charset=utf-8" },
1105
+ });
1106
+ }
948
1107
 
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.`,
1108
+ const [ssrModule, streamMode] = await getSSRSetup(
1109
+ handlerCtx,
1110
+ request,
1111
+ env,
1112
+ url,
1113
+ requireRequestContext()._metricsStore,
974
1114
  );
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
- },
1115
+ const htmlStream = await ssrModule.renderHTML(rscStream, {
1116
+ nonce,
1117
+ streamMode,
981
1118
  });
982
- }
983
1119
 
984
- if (isPartial) {
985
- const intercepted = interceptRedirectForPartial(
986
- error,
987
- createRedirectFlightResponse,
988
- );
989
- if (intercepted) return intercepted;
1120
+ return createResponseWithMergedHeaders(htmlStream, {
1121
+ status: 404,
1122
+ headers: { "content-type": "text/html;charset=utf-8" },
1123
+ });
990
1124
  }
991
1125
 
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) {
1126
+ // Report unhandled errors
1001
1127
  callOnError(error, "routing", {
1002
1128
  request,
1003
1129
  url,
1004
1130
  env,
1005
- handledByBoundary: true, // Handled by notFound component
1131
+ handledByBoundary: false,
1006
1132
  });
1133
+ console.error(`[RSC] Error:`, error);
1134
+ throw error;
1135
+ }
1136
+ };
1007
1137
 
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,
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),
1062
1143
  request,
1063
1144
  env,
1064
- url,
1065
- requireRequestContext()._metricsStore,
1145
+ variables,
1146
+ renderHandler,
1147
+ routeReverse,
1066
1148
  );
1067
- const htmlStream = await ssrModule.renderHTML(rscStream, {
1068
- nonce,
1069
- streamMode,
1070
- });
1071
1149
 
1072
- return createResponseWithMergedHeaders(htmlStream, {
1073
- status: 404,
1074
- headers: { "content-type": "text/html;charset=utf-8" },
1075
- });
1150
+ if (isPartial || actionContinuation) {
1151
+ const intercepted = interceptRedirectForPartial(
1152
+ mwResponse,
1153
+ createRedirectFlightResponse,
1154
+ );
1155
+ if (intercepted) return intercepted;
1156
+ }
1157
+
1158
+ return finalizeResponse(mwResponse);
1076
1159
  }
1077
1160
 
1078
- // Report unhandled errors
1079
- 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(
1080
1171
  request,
1081
- url,
1082
1172
  env,
1083
- handledByBoundary: false,
1084
- });
1085
- console.error(`[RSC] Error:`, error);
1086
- throw error;
1173
+ url,
1174
+ "render-start",
1175
+ renderOutcome.durationMs,
1176
+ routeKey,
1177
+ );
1087
1178
  }
1179
+ return renderOutcome.result;
1088
1180
  }
1089
1181
  }