@rangojs/router 0.0.0-experimental.0da83ed6 → 0.0.0-experimental.0e02cd4e

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