@rangojs/router 0.0.0-experimental.60 → 0.0.0-experimental.60c5dbde

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 (889) hide show
  1. package/README.md +61 -8
  2. package/dist/bin/rango.js +2 -1
  3. package/dist/vite/index.js +448 -179
  4. package/package.json +3 -3
  5. package/skills/handler-use/SKILL.md +362 -0
  6. package/skills/intercept/SKILL.md +20 -0
  7. package/skills/layout/SKILL.md +22 -0
  8. package/skills/middleware/SKILL.md +32 -3
  9. package/skills/migrate-nextjs/SKILL.md +560 -0
  10. package/skills/migrate-react-router/SKILL.md +764 -0
  11. package/skills/parallel/SKILL.md +59 -0
  12. package/skills/prerender/SKILL.md +110 -68
  13. package/skills/rango/SKILL.md +24 -22
  14. package/skills/route/SKILL.md +24 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/navigation-bridge.ts +7 -1
  17. package/src/browser/navigation-client.ts +34 -6
  18. package/src/browser/partial-update.ts +5 -0
  19. package/src/browser/prefetch/cache.ts +16 -6
  20. package/src/browser/prefetch/fetch.ts +60 -4
  21. package/src/browser/react/Link.tsx +25 -2
  22. package/src/browser/react/use-handle.ts +9 -58
  23. package/src/browser/segment-reconciler.ts +72 -2
  24. package/src/build/generate-manifest.ts +3 -6
  25. package/src/build/route-trie.ts +50 -24
  26. package/src/build/route-types/scan-filter.ts +8 -1
  27. package/src/client.tsx +5 -66
  28. package/src/handle.ts +40 -0
  29. package/src/index.rsc.ts +3 -1
  30. package/src/index.ts +46 -6
  31. package/src/prerender/store.ts +5 -4
  32. package/src/prerender.ts +138 -77
  33. package/src/reverse.ts +6 -1
  34. package/src/route-definition/dsl-helpers.ts +194 -32
  35. package/src/route-definition/helpers-types.ts +61 -14
  36. package/src/route-definition/index.ts +3 -0
  37. package/src/route-definition/resolve-handler-use.ts +149 -0
  38. package/src/route-types.ts +11 -0
  39. package/src/router/content-negotiation.ts +100 -1
  40. package/src/router/handler-context.ts +26 -6
  41. package/src/router/loader-resolution.ts +147 -19
  42. package/src/router/match-api.ts +124 -189
  43. package/src/router/match-middleware/cache-lookup.ts +24 -7
  44. package/src/router/match-middleware/segment-resolution.ts +53 -0
  45. package/src/router/match-result.ts +82 -4
  46. package/src/router/navigation-snapshot.ts +182 -0
  47. package/src/router/prerender-match.ts +108 -8
  48. package/src/router/preview-match.ts +30 -102
  49. package/src/router/request-classification.ts +310 -0
  50. package/src/router/route-snapshot.ts +245 -0
  51. package/src/router/router-interfaces.ts +11 -0
  52. package/src/router/segment-resolution/fresh.ts +59 -2
  53. package/src/router/segment-resolution/revalidation.ts +79 -6
  54. package/src/router.ts +13 -1
  55. package/src/rsc/handler.ts +468 -377
  56. package/src/rsc/loader-fetch.ts +23 -3
  57. package/src/rsc/progressive-enhancement.ts +10 -2
  58. package/src/rsc/rsc-rendering.ts +5 -1
  59. package/src/rsc/server-action.ts +6 -0
  60. package/src/rsc/ssr-setup.ts +1 -1
  61. package/src/rsc/types.ts +1 -0
  62. package/src/segment-content-promise.ts +38 -0
  63. package/src/segment-system.tsx +25 -11
  64. package/src/server/context.ts +14 -1
  65. package/src/server/handle-store.ts +19 -0
  66. package/src/server/request-context.ts +125 -3
  67. package/src/static-handler.ts +18 -6
  68. package/src/types/handler-context.ts +12 -2
  69. package/src/types/loader-types.ts +32 -4
  70. package/src/types/route-entry.ts +1 -1
  71. package/src/types/segments.ts +4 -0
  72. package/src/urls/path-helper-types.ts +39 -6
  73. package/src/urls/path-helper.ts +47 -12
  74. package/src/urls/response-types.ts +16 -6
  75. package/src/use-loader.tsx +77 -5
  76. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  77. package/src/vite/discovery/prerender-collection.ts +128 -74
  78. package/src/vite/discovery/state.ts +13 -4
  79. package/src/vite/index.ts +4 -0
  80. package/src/vite/plugin-types.ts +60 -5
  81. package/src/vite/plugins/expose-id-utils.ts +12 -0
  82. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  83. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  84. package/src/vite/rango.ts +2 -1
  85. package/src/vite/router-discovery.ts +178 -37
  86. package/src/vite/utils/prerender-utils.ts +37 -5
  87. package/dist/__internal.d.ts +0 -83
  88. package/dist/__internal.d.ts.map +0 -1
  89. package/dist/__internal.js +0 -19
  90. package/dist/__internal.js.map +0 -1
  91. package/dist/__mocks__/version.d.ts +0 -7
  92. package/dist/__mocks__/version.d.ts.map +0 -1
  93. package/dist/__mocks__/version.js +0 -7
  94. package/dist/__mocks__/version.js.map +0 -1
  95. package/dist/__tests__/client-href.test.d.ts +0 -2
  96. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  97. package/dist/__tests__/client-href.test.js +0 -74
  98. package/dist/__tests__/client-href.test.js.map +0 -1
  99. package/dist/__tests__/component-utils.test.d.ts +0 -2
  100. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  101. package/dist/__tests__/component-utils.test.js +0 -51
  102. package/dist/__tests__/component-utils.test.js.map +0 -1
  103. package/dist/__tests__/event-controller.test.d.ts +0 -2
  104. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  105. package/dist/__tests__/event-controller.test.js +0 -538
  106. package/dist/__tests__/event-controller.test.js.map +0 -1
  107. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  108. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  109. package/dist/__tests__/helpers/route-tree.js +0 -374
  110. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  111. package/dist/__tests__/match-result.test.d.ts +0 -2
  112. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  113. package/dist/__tests__/match-result.test.js +0 -154
  114. package/dist/__tests__/match-result.test.js.map +0 -1
  115. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  116. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  117. package/dist/__tests__/navigation-store.test.js +0 -440
  118. package/dist/__tests__/navigation-store.test.js.map +0 -1
  119. package/dist/__tests__/partial-update.test.d.ts +0 -2
  120. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  121. package/dist/__tests__/partial-update.test.js +0 -1009
  122. package/dist/__tests__/partial-update.test.js.map +0 -1
  123. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  124. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  125. package/dist/__tests__/reverse-types.test.js +0 -656
  126. package/dist/__tests__/reverse-types.test.js.map +0 -1
  127. package/dist/__tests__/route-definition.test.d.ts +0 -2
  128. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  129. package/dist/__tests__/route-definition.test.js +0 -55
  130. package/dist/__tests__/route-definition.test.js.map +0 -1
  131. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  132. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  133. package/dist/__tests__/router-helpers.test.js +0 -377
  134. package/dist/__tests__/router-helpers.test.js.map +0 -1
  135. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  136. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  137. package/dist/__tests__/router-integration-2.test.js +0 -426
  138. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  139. package/dist/__tests__/router-integration.test.d.ts +0 -2
  140. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  141. package/dist/__tests__/router-integration.test.js +0 -1051
  142. package/dist/__tests__/router-integration.test.js.map +0 -1
  143. package/dist/__tests__/search-params.test.d.ts +0 -5
  144. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  145. package/dist/__tests__/search-params.test.js +0 -306
  146. package/dist/__tests__/search-params.test.js.map +0 -1
  147. package/dist/__tests__/segment-system.test.d.ts +0 -2
  148. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  149. package/dist/__tests__/segment-system.test.js +0 -627
  150. package/dist/__tests__/segment-system.test.js.map +0 -1
  151. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  152. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  153. package/dist/__tests__/static-handler-types.test.js +0 -63
  154. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  155. package/dist/__tests__/urls.test.d.ts +0 -2
  156. package/dist/__tests__/urls.test.d.ts.map +0 -1
  157. package/dist/__tests__/urls.test.js +0 -421
  158. package/dist/__tests__/urls.test.js.map +0 -1
  159. package/dist/__tests__/use-mount.test.d.ts +0 -2
  160. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  161. package/dist/__tests__/use-mount.test.js +0 -35
  162. package/dist/__tests__/use-mount.test.js.map +0 -1
  163. package/dist/bin/rango.d.ts +0 -2
  164. package/dist/bin/rango.d.ts.map +0 -1
  165. package/dist/bin/rango.js.map +0 -1
  166. package/dist/browser/event-controller.d.ts +0 -191
  167. package/dist/browser/event-controller.d.ts.map +0 -1
  168. package/dist/browser/event-controller.js +0 -559
  169. package/dist/browser/event-controller.js.map +0 -1
  170. package/dist/browser/index.d.ts +0 -2
  171. package/dist/browser/index.d.ts.map +0 -1
  172. package/dist/browser/index.js +0 -14
  173. package/dist/browser/index.js.map +0 -1
  174. package/dist/browser/link-interceptor.d.ts +0 -38
  175. package/dist/browser/link-interceptor.d.ts.map +0 -1
  176. package/dist/browser/link-interceptor.js +0 -99
  177. package/dist/browser/link-interceptor.js.map +0 -1
  178. package/dist/browser/logging.d.ts +0 -10
  179. package/dist/browser/logging.d.ts.map +0 -1
  180. package/dist/browser/logging.js +0 -29
  181. package/dist/browser/logging.js.map +0 -1
  182. package/dist/browser/lru-cache.d.ts +0 -17
  183. package/dist/browser/lru-cache.d.ts.map +0 -1
  184. package/dist/browser/lru-cache.js +0 -50
  185. package/dist/browser/lru-cache.js.map +0 -1
  186. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  187. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  188. package/dist/browser/merge-segment-loaders.js +0 -102
  189. package/dist/browser/merge-segment-loaders.js.map +0 -1
  190. package/dist/browser/navigation-bridge.d.ts +0 -102
  191. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  192. package/dist/browser/navigation-bridge.js +0 -708
  193. package/dist/browser/navigation-bridge.js.map +0 -1
  194. package/dist/browser/navigation-client.d.ts +0 -25
  195. package/dist/browser/navigation-client.d.ts.map +0 -1
  196. package/dist/browser/navigation-client.js +0 -157
  197. package/dist/browser/navigation-client.js.map +0 -1
  198. package/dist/browser/navigation-store.d.ts +0 -101
  199. package/dist/browser/navigation-store.d.ts.map +0 -1
  200. package/dist/browser/navigation-store.js +0 -625
  201. package/dist/browser/navigation-store.js.map +0 -1
  202. package/dist/browser/partial-update.d.ts +0 -75
  203. package/dist/browser/partial-update.d.ts.map +0 -1
  204. package/dist/browser/partial-update.js +0 -426
  205. package/dist/browser/partial-update.js.map +0 -1
  206. package/dist/browser/react/Link.d.ts +0 -86
  207. package/dist/browser/react/Link.d.ts.map +0 -1
  208. package/dist/browser/react/Link.js +0 -128
  209. package/dist/browser/react/Link.js.map +0 -1
  210. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  211. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  212. package/dist/browser/react/NavigationProvider.js +0 -216
  213. package/dist/browser/react/NavigationProvider.js.map +0 -1
  214. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  215. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  216. package/dist/browser/react/ScrollRestoration.js +0 -57
  217. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  218. package/dist/browser/react/context.d.ts +0 -46
  219. package/dist/browser/react/context.d.ts.map +0 -1
  220. package/dist/browser/react/context.js +0 -10
  221. package/dist/browser/react/context.js.map +0 -1
  222. package/dist/browser/react/index.d.ts +0 -11
  223. package/dist/browser/react/index.d.ts.map +0 -1
  224. package/dist/browser/react/index.js +0 -22
  225. package/dist/browser/react/index.js.map +0 -1
  226. package/dist/browser/react/location-state-shared.d.ts +0 -63
  227. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  228. package/dist/browser/react/location-state-shared.js +0 -81
  229. package/dist/browser/react/location-state-shared.js.map +0 -1
  230. package/dist/browser/react/location-state.d.ts +0 -23
  231. package/dist/browser/react/location-state.d.ts.map +0 -1
  232. package/dist/browser/react/location-state.js +0 -29
  233. package/dist/browser/react/location-state.js.map +0 -1
  234. package/dist/browser/react/mount-context.d.ts +0 -24
  235. package/dist/browser/react/mount-context.d.ts.map +0 -1
  236. package/dist/browser/react/mount-context.js +0 -24
  237. package/dist/browser/react/mount-context.js.map +0 -1
  238. package/dist/browser/react/use-action.d.ts +0 -64
  239. package/dist/browser/react/use-action.d.ts.map +0 -1
  240. package/dist/browser/react/use-action.js +0 -134
  241. package/dist/browser/react/use-action.js.map +0 -1
  242. package/dist/browser/react/use-client-cache.d.ts +0 -41
  243. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  244. package/dist/browser/react/use-client-cache.js +0 -39
  245. package/dist/browser/react/use-client-cache.js.map +0 -1
  246. package/dist/browser/react/use-handle.d.ts +0 -31
  247. package/dist/browser/react/use-handle.d.ts.map +0 -1
  248. package/dist/browser/react/use-handle.js +0 -144
  249. package/dist/browser/react/use-handle.js.map +0 -1
  250. package/dist/browser/react/use-href.d.ts +0 -33
  251. package/dist/browser/react/use-href.d.ts.map +0 -1
  252. package/dist/browser/react/use-href.js +0 -39
  253. package/dist/browser/react/use-href.js.map +0 -1
  254. package/dist/browser/react/use-link-status.d.ts +0 -37
  255. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  256. package/dist/browser/react/use-link-status.js +0 -99
  257. package/dist/browser/react/use-link-status.js.map +0 -1
  258. package/dist/browser/react/use-mount.d.ts +0 -25
  259. package/dist/browser/react/use-mount.d.ts.map +0 -1
  260. package/dist/browser/react/use-mount.js +0 -30
  261. package/dist/browser/react/use-mount.js.map +0 -1
  262. package/dist/browser/react/use-navigation.d.ts +0 -27
  263. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  264. package/dist/browser/react/use-navigation.js +0 -87
  265. package/dist/browser/react/use-navigation.js.map +0 -1
  266. package/dist/browser/react/use-segments.d.ts +0 -38
  267. package/dist/browser/react/use-segments.d.ts.map +0 -1
  268. package/dist/browser/react/use-segments.js +0 -130
  269. package/dist/browser/react/use-segments.js.map +0 -1
  270. package/dist/browser/request-controller.d.ts +0 -26
  271. package/dist/browser/request-controller.d.ts.map +0 -1
  272. package/dist/browser/request-controller.js +0 -147
  273. package/dist/browser/request-controller.js.map +0 -1
  274. package/dist/browser/rsc-router.d.ts +0 -129
  275. package/dist/browser/rsc-router.d.ts.map +0 -1
  276. package/dist/browser/rsc-router.js +0 -195
  277. package/dist/browser/rsc-router.js.map +0 -1
  278. package/dist/browser/scroll-restoration.d.ts +0 -93
  279. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  280. package/dist/browser/scroll-restoration.js +0 -321
  281. package/dist/browser/scroll-restoration.js.map +0 -1
  282. package/dist/browser/segment-structure-assert.d.ts +0 -17
  283. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  284. package/dist/browser/segment-structure-assert.js +0 -59
  285. package/dist/browser/segment-structure-assert.js.map +0 -1
  286. package/dist/browser/server-action-bridge.d.ts +0 -26
  287. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  288. package/dist/browser/server-action-bridge.js +0 -668
  289. package/dist/browser/server-action-bridge.js.map +0 -1
  290. package/dist/browser/shallow.d.ts +0 -12
  291. package/dist/browser/shallow.d.ts.map +0 -1
  292. package/dist/browser/shallow.js +0 -34
  293. package/dist/browser/shallow.js.map +0 -1
  294. package/dist/browser/types.d.ts +0 -369
  295. package/dist/browser/types.d.ts.map +0 -1
  296. package/dist/browser/types.js +0 -2
  297. package/dist/browser/types.js.map +0 -1
  298. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  299. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  300. package/dist/build/__tests__/generate-cli.test.js +0 -237
  301. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  302. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  303. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  304. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  305. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  306. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  307. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  308. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  309. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  310. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  311. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  312. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  313. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  314. package/dist/build/generate-manifest.d.ts +0 -81
  315. package/dist/build/generate-manifest.d.ts.map +0 -1
  316. package/dist/build/generate-manifest.js +0 -276
  317. package/dist/build/generate-manifest.js.map +0 -1
  318. package/dist/build/generate-route-types.d.ts +0 -115
  319. package/dist/build/generate-route-types.d.ts.map +0 -1
  320. package/dist/build/generate-route-types.js +0 -740
  321. package/dist/build/generate-route-types.js.map +0 -1
  322. package/dist/build/index.d.ts +0 -21
  323. package/dist/build/index.d.ts.map +0 -1
  324. package/dist/build/index.js +0 -21
  325. package/dist/build/index.js.map +0 -1
  326. package/dist/build/route-trie.d.ts +0 -71
  327. package/dist/build/route-trie.d.ts.map +0 -1
  328. package/dist/build/route-trie.js +0 -175
  329. package/dist/build/route-trie.js.map +0 -1
  330. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  331. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  332. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  333. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  334. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  335. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  336. package/dist/cache/__tests__/document-cache.test.js +0 -345
  337. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  338. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  339. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  340. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  341. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  342. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  343. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  344. package/dist/cache/__tests__/memory-store.test.js +0 -367
  345. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  346. package/dist/cache/cache-scope.d.ts +0 -102
  347. package/dist/cache/cache-scope.d.ts.map +0 -1
  348. package/dist/cache/cache-scope.js +0 -440
  349. package/dist/cache/cache-scope.js.map +0 -1
  350. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  351. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  352. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  353. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  354. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  355. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  356. package/dist/cache/cf/cf-cache-store.js +0 -242
  357. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  358. package/dist/cache/cf/index.d.ts +0 -14
  359. package/dist/cache/cf/index.d.ts.map +0 -1
  360. package/dist/cache/cf/index.js +0 -17
  361. package/dist/cache/cf/index.js.map +0 -1
  362. package/dist/cache/document-cache.d.ts +0 -64
  363. package/dist/cache/document-cache.d.ts.map +0 -1
  364. package/dist/cache/document-cache.js +0 -228
  365. package/dist/cache/document-cache.js.map +0 -1
  366. package/dist/cache/index.d.ts +0 -19
  367. package/dist/cache/index.d.ts.map +0 -1
  368. package/dist/cache/index.js +0 -21
  369. package/dist/cache/index.js.map +0 -1
  370. package/dist/cache/memory-segment-store.d.ts +0 -110
  371. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  372. package/dist/cache/memory-segment-store.js +0 -117
  373. package/dist/cache/memory-segment-store.js.map +0 -1
  374. package/dist/cache/memory-store.d.ts +0 -41
  375. package/dist/cache/memory-store.d.ts.map +0 -1
  376. package/dist/cache/memory-store.js +0 -191
  377. package/dist/cache/memory-store.js.map +0 -1
  378. package/dist/cache/types.d.ts +0 -317
  379. package/dist/cache/types.d.ts.map +0 -1
  380. package/dist/cache/types.js +0 -12
  381. package/dist/cache/types.js.map +0 -1
  382. package/dist/client.d.ts +0 -248
  383. package/dist/client.d.ts.map +0 -1
  384. package/dist/client.js +0 -367
  385. package/dist/client.js.map +0 -1
  386. package/dist/client.rsc.d.ts +0 -26
  387. package/dist/client.rsc.d.ts.map +0 -1
  388. package/dist/client.rsc.js +0 -46
  389. package/dist/client.rsc.js.map +0 -1
  390. package/dist/component-utils.d.ts +0 -36
  391. package/dist/component-utils.d.ts.map +0 -1
  392. package/dist/component-utils.js +0 -61
  393. package/dist/component-utils.js.map +0 -1
  394. package/dist/components/DefaultDocument.d.ts +0 -13
  395. package/dist/components/DefaultDocument.d.ts.map +0 -1
  396. package/dist/components/DefaultDocument.js +0 -15
  397. package/dist/components/DefaultDocument.js.map +0 -1
  398. package/dist/debug.d.ts +0 -58
  399. package/dist/debug.d.ts.map +0 -1
  400. package/dist/debug.js +0 -157
  401. package/dist/debug.js.map +0 -1
  402. package/dist/default-error-boundary.d.ts +0 -11
  403. package/dist/default-error-boundary.d.ts.map +0 -1
  404. package/dist/default-error-boundary.js +0 -45
  405. package/dist/default-error-boundary.js.map +0 -1
  406. package/dist/deps/browser.d.ts +0 -2
  407. package/dist/deps/browser.d.ts.map +0 -1
  408. package/dist/deps/browser.js +0 -3
  409. package/dist/deps/browser.js.map +0 -1
  410. package/dist/deps/html-stream-client.d.ts +0 -2
  411. package/dist/deps/html-stream-client.d.ts.map +0 -1
  412. package/dist/deps/html-stream-client.js +0 -3
  413. package/dist/deps/html-stream-client.js.map +0 -1
  414. package/dist/deps/html-stream-server.d.ts +0 -2
  415. package/dist/deps/html-stream-server.d.ts.map +0 -1
  416. package/dist/deps/html-stream-server.js +0 -3
  417. package/dist/deps/html-stream-server.js.map +0 -1
  418. package/dist/deps/rsc.d.ts +0 -2
  419. package/dist/deps/rsc.d.ts.map +0 -1
  420. package/dist/deps/rsc.js +0 -4
  421. package/dist/deps/rsc.js.map +0 -1
  422. package/dist/deps/ssr.d.ts +0 -2
  423. package/dist/deps/ssr.d.ts.map +0 -1
  424. package/dist/deps/ssr.js +0 -3
  425. package/dist/deps/ssr.js.map +0 -1
  426. package/dist/errors.d.ts +0 -174
  427. package/dist/errors.d.ts.map +0 -1
  428. package/dist/errors.js +0 -241
  429. package/dist/errors.js.map +0 -1
  430. package/dist/handle.d.ts +0 -78
  431. package/dist/handle.d.ts.map +0 -1
  432. package/dist/handle.js +0 -82
  433. package/dist/handle.js.map +0 -1
  434. package/dist/handles/MetaTags.d.ts +0 -14
  435. package/dist/handles/MetaTags.d.ts.map +0 -1
  436. package/dist/handles/MetaTags.js +0 -136
  437. package/dist/handles/MetaTags.js.map +0 -1
  438. package/dist/handles/index.d.ts +0 -6
  439. package/dist/handles/index.d.ts.map +0 -1
  440. package/dist/handles/index.js +0 -6
  441. package/dist/handles/index.js.map +0 -1
  442. package/dist/handles/meta.d.ts +0 -39
  443. package/dist/handles/meta.d.ts.map +0 -1
  444. package/dist/handles/meta.js +0 -202
  445. package/dist/handles/meta.js.map +0 -1
  446. package/dist/host/__tests__/errors.test.d.ts +0 -2
  447. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  448. package/dist/host/__tests__/errors.test.js +0 -76
  449. package/dist/host/__tests__/errors.test.js.map +0 -1
  450. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  451. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  452. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  453. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  454. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  455. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  456. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  457. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  458. package/dist/host/__tests__/router.test.d.ts +0 -2
  459. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  460. package/dist/host/__tests__/router.test.js +0 -241
  461. package/dist/host/__tests__/router.test.js.map +0 -1
  462. package/dist/host/__tests__/testing.test.d.ts +0 -2
  463. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  464. package/dist/host/__tests__/testing.test.js +0 -64
  465. package/dist/host/__tests__/testing.test.js.map +0 -1
  466. package/dist/host/__tests__/utils.test.d.ts +0 -2
  467. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  468. package/dist/host/__tests__/utils.test.js +0 -29
  469. package/dist/host/__tests__/utils.test.js.map +0 -1
  470. package/dist/host/cookie-handler.d.ts +0 -34
  471. package/dist/host/cookie-handler.d.ts.map +0 -1
  472. package/dist/host/cookie-handler.js +0 -124
  473. package/dist/host/cookie-handler.js.map +0 -1
  474. package/dist/host/errors.d.ts +0 -56
  475. package/dist/host/errors.d.ts.map +0 -1
  476. package/dist/host/errors.js +0 -79
  477. package/dist/host/errors.js.map +0 -1
  478. package/dist/host/index.d.ts +0 -29
  479. package/dist/host/index.d.ts.map +0 -1
  480. package/dist/host/index.js +0 -32
  481. package/dist/host/index.js.map +0 -1
  482. package/dist/host/pattern-matcher.d.ts +0 -36
  483. package/dist/host/pattern-matcher.d.ts.map +0 -1
  484. package/dist/host/pattern-matcher.js +0 -172
  485. package/dist/host/pattern-matcher.js.map +0 -1
  486. package/dist/host/router.d.ts +0 -26
  487. package/dist/host/router.d.ts.map +0 -1
  488. package/dist/host/router.js +0 -218
  489. package/dist/host/router.js.map +0 -1
  490. package/dist/host/testing.d.ts +0 -36
  491. package/dist/host/testing.d.ts.map +0 -1
  492. package/dist/host/testing.js +0 -55
  493. package/dist/host/testing.js.map +0 -1
  494. package/dist/host/types.d.ts +0 -115
  495. package/dist/host/types.d.ts.map +0 -1
  496. package/dist/host/types.js +0 -7
  497. package/dist/host/types.js.map +0 -1
  498. package/dist/host/utils.d.ts +0 -21
  499. package/dist/host/utils.d.ts.map +0 -1
  500. package/dist/host/utils.js +0 -23
  501. package/dist/host/utils.js.map +0 -1
  502. package/dist/href-client.d.ts +0 -131
  503. package/dist/href-client.d.ts.map +0 -1
  504. package/dist/href-client.js +0 -64
  505. package/dist/href-client.js.map +0 -1
  506. package/dist/href-context.d.ts +0 -29
  507. package/dist/href-context.d.ts.map +0 -1
  508. package/dist/href-context.js +0 -21
  509. package/dist/href-context.js.map +0 -1
  510. package/dist/index.d.ts +0 -73
  511. package/dist/index.d.ts.map +0 -1
  512. package/dist/index.js +0 -91
  513. package/dist/index.js.map +0 -1
  514. package/dist/index.rsc.d.ts +0 -32
  515. package/dist/index.rsc.d.ts.map +0 -1
  516. package/dist/index.rsc.js +0 -40
  517. package/dist/index.rsc.js.map +0 -1
  518. package/dist/internal-debug.d.ts +0 -2
  519. package/dist/internal-debug.d.ts.map +0 -1
  520. package/dist/internal-debug.js +0 -5
  521. package/dist/internal-debug.js.map +0 -1
  522. package/dist/loader.d.ts +0 -14
  523. package/dist/loader.d.ts.map +0 -1
  524. package/dist/loader.js +0 -20
  525. package/dist/loader.js.map +0 -1
  526. package/dist/loader.rsc.d.ts +0 -19
  527. package/dist/loader.rsc.d.ts.map +0 -1
  528. package/dist/loader.rsc.js +0 -99
  529. package/dist/loader.rsc.js.map +0 -1
  530. package/dist/network-error-thrower.d.ts +0 -17
  531. package/dist/network-error-thrower.d.ts.map +0 -1
  532. package/dist/network-error-thrower.js +0 -14
  533. package/dist/network-error-thrower.js.map +0 -1
  534. package/dist/outlet-context.d.ts +0 -13
  535. package/dist/outlet-context.d.ts.map +0 -1
  536. package/dist/outlet-context.js +0 -3
  537. package/dist/outlet-context.js.map +0 -1
  538. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  539. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  540. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  541. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  542. package/dist/prerender/param-hash.d.ts +0 -16
  543. package/dist/prerender/param-hash.d.ts.map +0 -1
  544. package/dist/prerender/param-hash.js +0 -36
  545. package/dist/prerender/param-hash.js.map +0 -1
  546. package/dist/prerender/store.d.ts +0 -38
  547. package/dist/prerender/store.d.ts.map +0 -1
  548. package/dist/prerender/store.js +0 -61
  549. package/dist/prerender/store.js.map +0 -1
  550. package/dist/prerender.d.ts +0 -66
  551. package/dist/prerender.d.ts.map +0 -1
  552. package/dist/prerender.js +0 -57
  553. package/dist/prerender.js.map +0 -1
  554. package/dist/reverse.d.ts +0 -196
  555. package/dist/reverse.d.ts.map +0 -1
  556. package/dist/reverse.js +0 -78
  557. package/dist/reverse.js.map +0 -1
  558. package/dist/root-error-boundary.d.ts +0 -33
  559. package/dist/root-error-boundary.d.ts.map +0 -1
  560. package/dist/root-error-boundary.js +0 -165
  561. package/dist/root-error-boundary.js.map +0 -1
  562. package/dist/route-content-wrapper.d.ts +0 -46
  563. package/dist/route-content-wrapper.d.ts.map +0 -1
  564. package/dist/route-content-wrapper.js +0 -77
  565. package/dist/route-content-wrapper.js.map +0 -1
  566. package/dist/route-definition.d.ts +0 -421
  567. package/dist/route-definition.d.ts.map +0 -1
  568. package/dist/route-definition.js +0 -868
  569. package/dist/route-definition.js.map +0 -1
  570. package/dist/route-map-builder.d.ts +0 -155
  571. package/dist/route-map-builder.d.ts.map +0 -1
  572. package/dist/route-map-builder.js +0 -237
  573. package/dist/route-map-builder.js.map +0 -1
  574. package/dist/route-types.d.ts +0 -165
  575. package/dist/route-types.d.ts.map +0 -1
  576. package/dist/route-types.js +0 -7
  577. package/dist/route-types.js.map +0 -1
  578. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  579. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  580. package/dist/router/__tests__/handler-context.test.js +0 -65
  581. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  582. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  583. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  584. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  585. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  586. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  587. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  588. package/dist/router/__tests__/match-context.test.js +0 -92
  589. package/dist/router/__tests__/match-context.test.js.map +0 -1
  590. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  591. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  592. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  593. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  594. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  595. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  596. package/dist/router/__tests__/match-result.test.js +0 -457
  597. package/dist/router/__tests__/match-result.test.js.map +0 -1
  598. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  599. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  600. package/dist/router/__tests__/on-error.test.js +0 -678
  601. package/dist/router/__tests__/on-error.test.js.map +0 -1
  602. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  603. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  604. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  605. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  606. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  607. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  608. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  609. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  610. package/dist/router/error-handling.d.ts +0 -77
  611. package/dist/router/error-handling.d.ts.map +0 -1
  612. package/dist/router/error-handling.js +0 -202
  613. package/dist/router/error-handling.js.map +0 -1
  614. package/dist/router/handler-context.d.ts +0 -20
  615. package/dist/router/handler-context.d.ts.map +0 -1
  616. package/dist/router/handler-context.js +0 -198
  617. package/dist/router/handler-context.js.map +0 -1
  618. package/dist/router/intercept-resolution.d.ts +0 -66
  619. package/dist/router/intercept-resolution.d.ts.map +0 -1
  620. package/dist/router/intercept-resolution.js +0 -246
  621. package/dist/router/intercept-resolution.js.map +0 -1
  622. package/dist/router/loader-resolution.d.ts +0 -64
  623. package/dist/router/loader-resolution.d.ts.map +0 -1
  624. package/dist/router/loader-resolution.js +0 -284
  625. package/dist/router/loader-resolution.js.map +0 -1
  626. package/dist/router/logging.d.ts +0 -15
  627. package/dist/router/logging.d.ts.map +0 -1
  628. package/dist/router/logging.js +0 -99
  629. package/dist/router/logging.js.map +0 -1
  630. package/dist/router/manifest.d.ts +0 -22
  631. package/dist/router/manifest.d.ts.map +0 -1
  632. package/dist/router/manifest.js +0 -181
  633. package/dist/router/manifest.js.map +0 -1
  634. package/dist/router/match-api.d.ts +0 -35
  635. package/dist/router/match-api.d.ts.map +0 -1
  636. package/dist/router/match-api.js +0 -406
  637. package/dist/router/match-api.js.map +0 -1
  638. package/dist/router/match-context.d.ts +0 -206
  639. package/dist/router/match-context.d.ts.map +0 -1
  640. package/dist/router/match-context.js +0 -17
  641. package/dist/router/match-context.js.map +0 -1
  642. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  643. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  644. package/dist/router/match-middleware/background-revalidation.js +0 -75
  645. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  646. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  647. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  648. package/dist/router/match-middleware/cache-lookup.js +0 -257
  649. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  650. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  651. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  652. package/dist/router/match-middleware/cache-store.js +0 -108
  653. package/dist/router/match-middleware/cache-store.js.map +0 -1
  654. package/dist/router/match-middleware/index.d.ts +0 -81
  655. package/dist/router/match-middleware/index.d.ts.map +0 -1
  656. package/dist/router/match-middleware/index.js +0 -80
  657. package/dist/router/match-middleware/index.js.map +0 -1
  658. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  659. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  660. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  661. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  662. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  663. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  664. package/dist/router/match-middleware/segment-resolution.js +0 -53
  665. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  666. package/dist/router/match-pipelines.d.ts +0 -147
  667. package/dist/router/match-pipelines.d.ts.map +0 -1
  668. package/dist/router/match-pipelines.js +0 -82
  669. package/dist/router/match-pipelines.js.map +0 -1
  670. package/dist/router/match-result.d.ts +0 -126
  671. package/dist/router/match-result.d.ts.map +0 -1
  672. package/dist/router/match-result.js +0 -93
  673. package/dist/router/match-result.js.map +0 -1
  674. package/dist/router/metrics.d.ts +0 -20
  675. package/dist/router/metrics.d.ts.map +0 -1
  676. package/dist/router/metrics.js +0 -47
  677. package/dist/router/metrics.js.map +0 -1
  678. package/dist/router/middleware.d.ts +0 -249
  679. package/dist/router/middleware.d.ts.map +0 -1
  680. package/dist/router/middleware.js +0 -434
  681. package/dist/router/middleware.js.map +0 -1
  682. package/dist/router/middleware.test.d.ts +0 -2
  683. package/dist/router/middleware.test.d.ts.map +0 -1
  684. package/dist/router/middleware.test.js +0 -816
  685. package/dist/router/middleware.test.js.map +0 -1
  686. package/dist/router/pattern-matching.d.ts +0 -149
  687. package/dist/router/pattern-matching.d.ts.map +0 -1
  688. package/dist/router/pattern-matching.js +0 -349
  689. package/dist/router/pattern-matching.js.map +0 -1
  690. package/dist/router/revalidation.d.ts +0 -44
  691. package/dist/router/revalidation.d.ts.map +0 -1
  692. package/dist/router/revalidation.js +0 -147
  693. package/dist/router/revalidation.js.map +0 -1
  694. package/dist/router/router-context.d.ts +0 -135
  695. package/dist/router/router-context.d.ts.map +0 -1
  696. package/dist/router/router-context.js +0 -36
  697. package/dist/router/router-context.js.map +0 -1
  698. package/dist/router/segment-resolution.d.ts +0 -127
  699. package/dist/router/segment-resolution.d.ts.map +0 -1
  700. package/dist/router/segment-resolution.js +0 -919
  701. package/dist/router/segment-resolution.js.map +0 -1
  702. package/dist/router/trie-matching.d.ts +0 -40
  703. package/dist/router/trie-matching.d.ts.map +0 -1
  704. package/dist/router/trie-matching.js +0 -127
  705. package/dist/router/trie-matching.js.map +0 -1
  706. package/dist/router/types.d.ts +0 -136
  707. package/dist/router/types.d.ts.map +0 -1
  708. package/dist/router/types.js +0 -7
  709. package/dist/router/types.js.map +0 -1
  710. package/dist/router.d.ts +0 -753
  711. package/dist/router.d.ts.map +0 -1
  712. package/dist/router.gen.d.ts +0 -6
  713. package/dist/router.gen.d.ts.map +0 -1
  714. package/dist/router.gen.js +0 -6
  715. package/dist/router.gen.js.map +0 -1
  716. package/dist/router.js +0 -1304
  717. package/dist/router.js.map +0 -1
  718. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  719. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  720. package/dist/rsc/__tests__/helpers.test.js +0 -140
  721. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  722. package/dist/rsc/handler.d.ts +0 -45
  723. package/dist/rsc/handler.d.ts.map +0 -1
  724. package/dist/rsc/handler.js +0 -1172
  725. package/dist/rsc/handler.js.map +0 -1
  726. package/dist/rsc/helpers.d.ts +0 -16
  727. package/dist/rsc/helpers.d.ts.map +0 -1
  728. package/dist/rsc/helpers.js +0 -55
  729. package/dist/rsc/helpers.js.map +0 -1
  730. package/dist/rsc/index.d.ts +0 -22
  731. package/dist/rsc/index.d.ts.map +0 -1
  732. package/dist/rsc/index.js +0 -23
  733. package/dist/rsc/index.js.map +0 -1
  734. package/dist/rsc/nonce.d.ts +0 -9
  735. package/dist/rsc/nonce.d.ts.map +0 -1
  736. package/dist/rsc/nonce.js +0 -18
  737. package/dist/rsc/nonce.js.map +0 -1
  738. package/dist/rsc/types.d.ts +0 -206
  739. package/dist/rsc/types.d.ts.map +0 -1
  740. package/dist/rsc/types.js +0 -8
  741. package/dist/rsc/types.js.map +0 -1
  742. package/dist/search-params.d.ts +0 -103
  743. package/dist/search-params.d.ts.map +0 -1
  744. package/dist/search-params.js +0 -74
  745. package/dist/search-params.js.map +0 -1
  746. package/dist/segment-system.d.ts +0 -75
  747. package/dist/segment-system.d.ts.map +0 -1
  748. package/dist/segment-system.js +0 -336
  749. package/dist/segment-system.js.map +0 -1
  750. package/dist/server/context.d.ts +0 -245
  751. package/dist/server/context.d.ts.map +0 -1
  752. package/dist/server/context.js +0 -197
  753. package/dist/server/context.js.map +0 -1
  754. package/dist/server/fetchable-loader-store.d.ts +0 -18
  755. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  756. package/dist/server/fetchable-loader-store.js +0 -18
  757. package/dist/server/fetchable-loader-store.js.map +0 -1
  758. package/dist/server/handle-store.d.ts +0 -85
  759. package/dist/server/handle-store.d.ts.map +0 -1
  760. package/dist/server/handle-store.js +0 -142
  761. package/dist/server/handle-store.js.map +0 -1
  762. package/dist/server/loader-registry.d.ts +0 -55
  763. package/dist/server/loader-registry.d.ts.map +0 -1
  764. package/dist/server/loader-registry.js +0 -132
  765. package/dist/server/loader-registry.js.map +0 -1
  766. package/dist/server/request-context.d.ts +0 -226
  767. package/dist/server/request-context.d.ts.map +0 -1
  768. package/dist/server/request-context.js +0 -290
  769. package/dist/server/request-context.js.map +0 -1
  770. package/dist/server/root-layout.d.ts +0 -4
  771. package/dist/server/root-layout.d.ts.map +0 -1
  772. package/dist/server/root-layout.js +0 -5
  773. package/dist/server/root-layout.js.map +0 -1
  774. package/dist/server.d.ts +0 -15
  775. package/dist/server.d.ts.map +0 -1
  776. package/dist/server.js +0 -20
  777. package/dist/server.js.map +0 -1
  778. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  779. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  780. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  781. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  782. package/dist/ssr/index.d.ts +0 -98
  783. package/dist/ssr/index.d.ts.map +0 -1
  784. package/dist/ssr/index.js +0 -158
  785. package/dist/ssr/index.js.map +0 -1
  786. package/dist/static-handler.d.ts +0 -50
  787. package/dist/static-handler.d.ts.map +0 -1
  788. package/dist/static-handler.gen.d.ts +0 -5
  789. package/dist/static-handler.gen.d.ts.map +0 -1
  790. package/dist/static-handler.gen.js +0 -5
  791. package/dist/static-handler.gen.js.map +0 -1
  792. package/dist/static-handler.js +0 -29
  793. package/dist/static-handler.js.map +0 -1
  794. package/dist/theme/ThemeProvider.d.ts +0 -20
  795. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  796. package/dist/theme/ThemeProvider.js +0 -240
  797. package/dist/theme/ThemeProvider.js.map +0 -1
  798. package/dist/theme/ThemeScript.d.ts +0 -48
  799. package/dist/theme/ThemeScript.d.ts.map +0 -1
  800. package/dist/theme/ThemeScript.js +0 -13
  801. package/dist/theme/ThemeScript.js.map +0 -1
  802. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  803. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  804. package/dist/theme/__tests__/theme.test.js +0 -103
  805. package/dist/theme/__tests__/theme.test.js.map +0 -1
  806. package/dist/theme/constants.d.ts +0 -29
  807. package/dist/theme/constants.d.ts.map +0 -1
  808. package/dist/theme/constants.js +0 -48
  809. package/dist/theme/constants.js.map +0 -1
  810. package/dist/theme/index.d.ts +0 -31
  811. package/dist/theme/index.d.ts.map +0 -1
  812. package/dist/theme/index.js +0 -36
  813. package/dist/theme/index.js.map +0 -1
  814. package/dist/theme/theme-context.d.ts +0 -40
  815. package/dist/theme/theme-context.d.ts.map +0 -1
  816. package/dist/theme/theme-context.js +0 -60
  817. package/dist/theme/theme-context.js.map +0 -1
  818. package/dist/theme/theme-script.d.ts +0 -27
  819. package/dist/theme/theme-script.d.ts.map +0 -1
  820. package/dist/theme/theme-script.js +0 -147
  821. package/dist/theme/theme-script.js.map +0 -1
  822. package/dist/theme/types.d.ts +0 -163
  823. package/dist/theme/types.d.ts.map +0 -1
  824. package/dist/theme/types.js +0 -11
  825. package/dist/theme/types.js.map +0 -1
  826. package/dist/theme/use-theme.d.ts +0 -12
  827. package/dist/theme/use-theme.d.ts.map +0 -1
  828. package/dist/theme/use-theme.js +0 -40
  829. package/dist/theme/use-theme.js.map +0 -1
  830. package/dist/types.d.ts +0 -1479
  831. package/dist/types.d.ts.map +0 -1
  832. package/dist/types.js +0 -10
  833. package/dist/types.js.map +0 -1
  834. package/dist/urls.d.ts +0 -441
  835. package/dist/urls.d.ts.map +0 -1
  836. package/dist/urls.gen.d.ts +0 -8
  837. package/dist/urls.gen.d.ts.map +0 -1
  838. package/dist/urls.gen.js +0 -8
  839. package/dist/urls.gen.js.map +0 -1
  840. package/dist/urls.js +0 -443
  841. package/dist/urls.js.map +0 -1
  842. package/dist/use-loader.d.ts +0 -127
  843. package/dist/use-loader.d.ts.map +0 -1
  844. package/dist/use-loader.js +0 -237
  845. package/dist/use-loader.js.map +0 -1
  846. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  847. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  848. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  849. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  850. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  851. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  852. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  853. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  854. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  855. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  856. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  857. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  858. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  859. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  860. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  861. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  862. package/dist/vite/ast-handler-extract.d.ts +0 -49
  863. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  864. package/dist/vite/ast-handler-extract.js +0 -249
  865. package/dist/vite/ast-handler-extract.js.map +0 -1
  866. package/dist/vite/expose-action-id.d.ts +0 -19
  867. package/dist/vite/expose-action-id.d.ts.map +0 -1
  868. package/dist/vite/expose-action-id.js +0 -250
  869. package/dist/vite/expose-action-id.js.map +0 -1
  870. package/dist/vite/expose-id-utils.d.ts +0 -69
  871. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  872. package/dist/vite/expose-id-utils.js +0 -289
  873. package/dist/vite/expose-id-utils.js.map +0 -1
  874. package/dist/vite/expose-internal-ids.d.ts +0 -22
  875. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  876. package/dist/vite/expose-internal-ids.js +0 -886
  877. package/dist/vite/expose-internal-ids.js.map +0 -1
  878. package/dist/vite/index.d.ts +0 -149
  879. package/dist/vite/index.d.ts.map +0 -1
  880. package/dist/vite/index.js.map +0 -1
  881. package/dist/vite/index.named-routes.gen.ts +0 -103
  882. package/dist/vite/package-resolution.d.ts +0 -43
  883. package/dist/vite/package-resolution.d.ts.map +0 -1
  884. package/dist/vite/package-resolution.js +0 -112
  885. package/dist/vite/package-resolution.js.map +0 -1
  886. package/dist/vite/virtual-entries.d.ts +0 -25
  887. package/dist/vite/virtual-entries.d.ts.map +0 -1
  888. package/dist/vite/virtual-entries.js +0 -110
  889. package/dist/vite/virtual-entries.js.map +0 -1
@@ -36,7 +36,14 @@ import {
36
36
  setRequestContextPrevRouteKey,
37
37
  } from "../server/request-context.js";
38
38
  import { isAutoGeneratedRouteName } from "../route-name.js";
39
+ import type { DefaultRouteName } from "../types/global-namespace.js";
39
40
  import { debugLog, debugWarn } from "./logging.js";
41
+ import {
42
+ resolveRoute,
43
+ ensureFullRouteSnapshot,
44
+ type RouteSnapshot,
45
+ } from "./route-snapshot.js";
46
+ import { resolveNavigation } from "./navigation-snapshot.js";
40
47
 
41
48
  /**
42
49
  * Create match context for full requests (document/SSR).
@@ -52,57 +59,36 @@ export async function createMatchContextForFull<TEnv>(
52
59
 
53
60
  const metricsStore = deps.getMetricsStore();
54
61
 
55
- const routeMatchStart = metricsStore ? performance.now() : 0;
56
- const matched = deps.findMatch(pathname, metricsStore);
57
- if (metricsStore) {
58
- metricsStore.metrics.push({
59
- label: "route-matching",
60
- duration: performance.now() - routeMatchStart,
61
- startTime: routeMatchStart - metricsStore.requestStart,
62
- });
63
- }
62
+ // Full renders always resolve fresh with isSSR: true because loadManifest
63
+ // keys its cache on isSSR and stamps Store.isSSR for downstream behavior.
64
+ const result = await resolveRoute<TEnv>(pathname, {
65
+ findMatch: (p) => deps.findMatch(p, metricsStore),
66
+ metricsStore,
67
+ isSSR: true,
68
+ });
64
69
 
65
- if (!matched) {
70
+ if (!result) {
66
71
  throw new RouteNotFoundError(`No route matched for ${pathname}`, {
67
72
  cause: { pathname, method: request.method },
68
73
  });
69
74
  }
70
75
 
71
- if (matched.redirectTo) {
76
+ if (result.type === "redirect") {
72
77
  return {
73
78
  type: "redirect",
74
- redirectUrl: matched.redirectTo + url.search,
79
+ redirectUrl: result.redirectTo + url.search,
75
80
  };
76
81
  }
77
82
 
78
- const manifestStart = metricsStore ? performance.now() : 0;
79
- const manifestEntry = await loadManifest(
80
- matched.entry,
81
- matched.routeKey,
82
- pathname,
83
- metricsStore,
84
- true,
85
- );
86
- if (metricsStore) {
87
- metricsStore.metrics.push({
88
- label: "manifest-loading",
89
- duration: performance.now() - manifestStart,
90
- startTime: manifestStart - metricsStore.requestStart,
91
- });
92
- }
83
+ const snapshot = result.snapshot;
93
84
 
94
- if (
95
- manifestEntry.type === "route" &&
96
- manifestEntry.prerenderDef?.options?.passthrough === true
97
- ) {
85
+ const { matched } = snapshot;
86
+
87
+ // Backward compat: downstream middleware reads matched.pt
88
+ if (snapshot.isPassthrough) {
98
89
  matched.pt = true;
99
90
  }
100
91
 
101
- const routeMiddleware = collectRouteMiddleware(
102
- traverseBack(manifestEntry),
103
- matched.params,
104
- );
105
-
106
92
  // Clean URL without internal _rsc* params for userland access
107
93
  const cleanUrl = stripInternalParams(url);
108
94
 
@@ -134,14 +120,6 @@ export async function createMatchContextForFull<TEnv>(
134
120
  Store.metrics = metricsStore;
135
121
  }
136
122
 
137
- const entries = [...traverseBack(manifestEntry)];
138
- let cacheScope: CacheScope | null = null;
139
- for (const entry of entries) {
140
- if (entry.cache) {
141
- cacheScope = createCacheScope(entry.cache, cacheScope);
142
- }
143
- }
144
-
145
123
  return {
146
124
  request,
147
125
  url: cleanUrl,
@@ -154,12 +132,10 @@ export async function createMatchContextForFull<TEnv>(
154
132
  prevParams: {},
155
133
  prevMatch: null,
156
134
  matched,
157
- manifestEntry,
158
- entries,
135
+ manifestEntry: snapshot.manifestEntry,
136
+ entries: snapshot.entries,
159
137
  routeKey: matched.routeKey,
160
- localRouteName: matched.routeKey.includes(".")
161
- ? matched.routeKey.split(".").pop()!
162
- : matched.routeKey,
138
+ localRouteName: snapshot.localRouteName,
163
139
  handlerContext,
164
140
  loaderPromises,
165
141
  routeMap: deps.getRouteMap(),
@@ -175,16 +151,16 @@ export async function createMatchContextForFull<TEnv>(
175
151
  segments: { path: [], ids: [] },
176
152
  toRouteName:
177
153
  matched.routeKey && !isAutoGeneratedRouteName(matched.routeKey)
178
- ? matched.routeKey
154
+ ? (matched.routeKey as DefaultRouteName)
179
155
  : undefined,
180
156
  },
181
157
  isSameRouteNavigation: false,
182
158
  interceptResult: null,
183
- cacheScope,
159
+ cacheScope: snapshot.cacheScope,
184
160
  isIntercept: false,
185
161
  actionContext: undefined,
186
162
  isAction: false,
187
- routeMiddleware,
163
+ routeMiddleware: snapshot.routeMiddleware,
188
164
  isFullMatch: true,
189
165
  };
190
166
  }
@@ -204,103 +180,85 @@ export async function createMatchContextForPartial<TEnv>(
204
180
 
205
181
  const metricsStore = deps.getMetricsStore();
206
182
 
207
- const clientSegmentIds =
208
- url.searchParams.get("_rsc_segments")?.split(",").filter(Boolean) || [];
209
- const stale = url.searchParams.get("_rsc_stale") === "true";
210
- const previousUrl =
211
- request.headers.get("X-RSC-Router-Client-Path") ||
212
- request.headers.get("Referer");
213
- const interceptSourceUrl = request.headers.get(
214
- "X-RSC-Router-Intercept-Source",
215
- );
183
+ const isHmr = !!request.headers.get("X-RSC-HMR");
216
184
 
217
185
  // HMR: clear manifest cache so stale handler references are discarded
218
- if (request.headers.get("X-RSC-HMR")) {
186
+ if (isHmr) {
219
187
  clearManifestCache();
220
188
  }
221
189
 
222
- if (!previousUrl) {
223
- return null;
224
- }
225
-
226
- let prevUrl: URL;
227
- try {
228
- prevUrl = new URL(previousUrl, url.origin);
229
- } catch {
230
- return null;
231
- }
190
+ // Reuse the classified snapshot when available and not invalidated by HMR.
191
+ // classifyRequest already called resolveRoute(lite) with isSSR=false, which
192
+ // matches the partial path. On HMR, discard to pick up manifest changes.
193
+ const classifiedRoute = isHmr
194
+ ? undefined
195
+ : getRequestContext()?._classifiedRoute;
196
+
197
+ // Time route matching. On the reuse path, only nav findMatch calls are new
198
+ // (current-route findMatch and manifest-loading were already timed during
199
+ // classifyRequest via its metricsStore). On the fresh path, all findMatch
200
+ // calls are measured together.
201
+ const routeMatchStart = metricsStore ? performance.now() : 0;
232
202
 
233
- let interceptContextUrl: URL;
234
- try {
235
- interceptContextUrl = interceptSourceUrl
236
- ? new URL(interceptSourceUrl, url.origin)
237
- : prevUrl;
238
- } catch {
239
- interceptContextUrl = prevUrl;
240
- }
203
+ let snapshot: RouteSnapshot<TEnv>;
204
+ if (classifiedRoute && classifiedRoute.manifestEntry) {
205
+ snapshot = ensureFullRouteSnapshot(classifiedRoute);
206
+ } else {
207
+ const result = await resolveRoute<TEnv>(pathname, {
208
+ findMatch: (p) => deps.findMatch(p, metricsStore),
209
+ metricsStore,
210
+ isSSR: false,
211
+ skipRouteMatchMetric: true,
212
+ });
241
213
 
242
- const routeMatchStart = metricsStore ? performance.now() : 0;
243
- const prevMatch = deps.findMatch(prevUrl.pathname);
244
- const prevParams = prevMatch?.params || {};
245
- const interceptContextMatch = interceptSourceUrl
246
- ? deps.findMatch(interceptContextUrl.pathname)
247
- : prevMatch;
214
+ if (!result) {
215
+ throw new RouteNotFoundError(`No route matched for ${pathname}`, {
216
+ cause: { pathname, method: request.method },
217
+ });
218
+ }
248
219
 
249
- const matched = deps.findMatch(pathname, metricsStore);
220
+ if (result.type === "redirect") {
221
+ return null;
222
+ }
250
223
 
251
- if (metricsStore) {
252
- metricsStore.metrics.push({
253
- label: "route-matching",
254
- duration: performance.now() - routeMatchStart,
255
- startTime: routeMatchStart - metricsStore.requestStart,
256
- });
224
+ snapshot = result.snapshot;
257
225
  }
258
226
 
259
- if (!matched) {
260
- throw new RouteNotFoundError(`No route matched for ${pathname}`, {
261
- cause: { pathname, method: request.method, previousUrl },
262
- });
263
- }
227
+ const { matched } = snapshot;
264
228
 
265
- if (matched.redirectTo) {
266
- return null;
229
+ // Backward compat: downstream middleware reads matched.pt
230
+ if (snapshot.isPassthrough) {
231
+ matched.pt = true;
267
232
  }
268
233
 
269
- if (prevMatch && prevMatch.entry !== matched.entry && !matched.pr) {
270
- debugLog("matchPartial", "route group changed", {
271
- from: prevMatch.routeKey,
272
- to: matched.routeKey,
273
- });
234
+ // Navigation state (prev + intercept-source findMatch calls)
235
+ const nav = resolveNavigation(request, url, matched.routeKey, {
236
+ findMatch: deps.findMatch,
237
+ });
238
+ if (!nav) {
239
+ return null;
274
240
  }
275
241
 
276
- const manifestStart = metricsStore ? performance.now() : 0;
277
- const manifestEntry = await loadManifest(
278
- matched.entry,
279
- matched.routeKey,
280
- pathname,
281
- metricsStore,
282
- false,
283
- );
242
+ // Push route-matching metric. On the fresh path this covers all findMatch
243
+ // calls (current + prev + intercept-source). On the reuse path, current-route
244
+ // findMatch was already timed during classification, so this only covers
245
+ // the nav lookups (prev + intercept-source).
284
246
  if (metricsStore) {
247
+ const isReuse = !!classifiedRoute;
285
248
  metricsStore.metrics.push({
286
- label: "manifest-loading",
287
- duration: performance.now() - manifestStart,
288
- startTime: manifestStart - metricsStore.requestStart,
249
+ label: isReuse ? "route-matching:nav" : "route-matching",
250
+ duration: performance.now() - routeMatchStart,
251
+ startTime: routeMatchStart - metricsStore.requestStart,
289
252
  });
290
253
  }
291
254
 
292
- if (
293
- manifestEntry.type === "route" &&
294
- manifestEntry.prerenderDef?.options?.passthrough === true
295
- ) {
296
- matched.pt = true;
255
+ if (nav.prevMatch && nav.prevMatch.entry !== matched.entry && !matched.pr) {
256
+ debugLog("matchPartial", "route group changed", {
257
+ from: nav.prevMatch.routeKey,
258
+ to: matched.routeKey,
259
+ });
297
260
  }
298
261
 
299
- const routeMiddleware = collectRouteMiddleware(
300
- traverseBack(manifestEntry),
301
- matched.params,
302
- );
303
-
304
262
  // Clean URL without internal _rsc* params for userland access
305
263
  const cleanUrl = stripInternalParams(url);
306
264
 
@@ -317,9 +275,8 @@ export async function createMatchContextForPartial<TEnv>(
317
275
  matched.pt === true,
318
276
  );
319
277
 
320
- const clientSegmentSet = new Set(clientSegmentIds);
321
278
  debugLog("matchPartial", "client segments", {
322
- segments: Array.from(clientSegmentSet),
279
+ segments: Array.from(nav.clientSegmentSet),
323
280
  });
324
281
 
325
282
  const loaderPromises = new Map<string, Promise<any>>();
@@ -337,100 +294,78 @@ export async function createMatchContextForPartial<TEnv>(
337
294
  Store.metrics = metricsStore;
338
295
  }
339
296
 
340
- const isSameRouteNavigation = !!(
341
- interceptContextMatch && interceptContextMatch.routeKey === matched.routeKey
342
- );
343
-
344
- if (interceptSourceUrl) {
297
+ if (nav.hasInterceptSource) {
345
298
  debugLog("matchPartial.intercept", "intercept context detected", {
346
299
  currentUrl: pathname,
347
- interceptSource: interceptSourceUrl,
348
- contextRoute: interceptContextMatch?.routeKey,
300
+ interceptSource: nav.interceptContextUrl.href,
301
+ contextRoute: nav.interceptContextMatch?.routeKey,
349
302
  currentRoute: matched.routeKey,
350
- sameRouteNavigation: isSameRouteNavigation,
303
+ sameRouteNavigation: nav.isSameRouteNavigation,
351
304
  });
352
305
  }
353
306
 
354
- const localRouteName = matched.routeKey.includes(".")
355
- ? matched.routeKey.split(".").pop()!
356
- : matched.routeKey;
357
-
358
- const filteredSegmentIds = clientSegmentIds.filter((id) => {
359
- if (id.includes(".@")) return false;
360
- if (/D\d+\./.test(id)) return false;
361
- return true;
362
- });
363
- const effectiveFromUrl = interceptSourceUrl ? interceptContextUrl : prevUrl;
364
- const effectiveFromMatch = interceptSourceUrl
365
- ? interceptContextMatch
366
- : prevMatch;
367
-
368
307
  // Store previous route key on the request context for revalidation
369
308
  // fromRouteName. Uses effectiveFromMatch so intercept-source navigations
370
309
  // see the intercept origin route, not the plain previous URL route.
371
- setRequestContextPrevRouteKey(effectiveFromMatch?.routeKey);
310
+ setRequestContextPrevRouteKey(nav.effectiveFromMatch?.routeKey);
372
311
 
373
312
  const interceptSelectorContext: InterceptSelectorContext = {
374
- from: effectiveFromUrl,
313
+ from: nav.effectiveFromUrl,
375
314
  to: cleanUrl,
376
315
  params: matched.params,
377
316
  request,
378
317
  env,
379
318
  segments: {
380
- path: effectiveFromUrl.pathname.split("/").filter(Boolean),
381
- ids: filteredSegmentIds,
319
+ path: nav.effectiveFromUrl.pathname.split("/").filter(Boolean),
320
+ ids: nav.filteredSegmentIds,
382
321
  },
383
322
  fromRouteName:
384
- effectiveFromMatch?.routeKey &&
385
- !isAutoGeneratedRouteName(effectiveFromMatch.routeKey)
386
- ? effectiveFromMatch.routeKey
323
+ nav.effectiveFromMatch?.routeKey &&
324
+ !isAutoGeneratedRouteName(nav.effectiveFromMatch.routeKey)
325
+ ? (nav.effectiveFromMatch.routeKey as DefaultRouteName)
387
326
  : undefined,
388
327
  toRouteName:
389
328
  matched.routeKey && !isAutoGeneratedRouteName(matched.routeKey)
390
- ? matched.routeKey
329
+ ? (matched.routeKey as DefaultRouteName)
391
330
  : undefined,
392
331
  };
393
332
  const isAction = !!actionContext;
394
333
 
395
- const clientHasInterceptSegments = [...clientSegmentSet].some((id) =>
334
+ const clientHasInterceptSegments = [...nav.clientSegmentSet].some((id) =>
396
335
  id.includes(".@"),
397
336
  );
398
337
  const skipInterceptForAction = isAction && !clientHasInterceptSegments;
399
338
  const interceptResult =
400
- isSameRouteNavigation || skipInterceptForAction
339
+ nav.isSameRouteNavigation || skipInterceptForAction
401
340
  ? null
402
341
  : findInterceptForRoute(
403
342
  matched.routeKey,
404
- manifestEntry.parent,
343
+ snapshot.manifestEntry.parent,
405
344
  interceptSelectorContext,
406
345
  isAction,
407
346
  ) ||
408
- (localRouteName !== matched.routeKey
347
+ (snapshot.localRouteName !== matched.routeKey
409
348
  ? findInterceptForRoute(
410
- localRouteName,
411
- manifestEntry.parent,
349
+ snapshot.localRouteName,
350
+ snapshot.manifestEntry.parent,
412
351
  interceptSelectorContext,
413
352
  isAction,
414
353
  )
415
354
  : null);
416
355
 
356
+ // Make a mutable copy of clientSegmentSet so we can delete entries
357
+ // for same-route navigation forcing
358
+ const clientSegmentSet = new Set(nav.clientSegmentSet);
359
+
417
360
  if (
418
- isSameRouteNavigation &&
419
- manifestEntry.type === "route" &&
420
- interceptSourceUrl
361
+ nav.isSameRouteNavigation &&
362
+ snapshot.manifestEntry.type === "route" &&
363
+ nav.hasInterceptSource
421
364
  ) {
422
365
  debugLog("matchPartial.intercept", "forcing route segment render", {
423
- segmentId: manifestEntry.shortCode,
366
+ segmentId: snapshot.manifestEntry.shortCode,
424
367
  });
425
- clientSegmentSet.delete(manifestEntry.shortCode);
426
- }
427
-
428
- const entries = [...traverseBack(manifestEntry)];
429
- let cacheScope: CacheScope | null = null;
430
- for (const entry of entries) {
431
- if (entry.cache) {
432
- cacheScope = createCacheScope(entry.cache, cacheScope);
433
- }
368
+ clientSegmentSet.delete(snapshot.manifestEntry.shortCode);
434
369
  }
435
370
 
436
371
  const isIntercept = !!interceptResult;
@@ -440,31 +375,31 @@ export async function createMatchContextForPartial<TEnv>(
440
375
  url: cleanUrl,
441
376
  pathname,
442
377
  env,
443
- clientSegmentIds,
378
+ clientSegmentIds: nav.clientSegmentIds,
444
379
  clientSegmentSet,
445
- stale,
446
- prevUrl,
447
- prevParams,
448
- prevMatch,
380
+ stale: nav.stale,
381
+ prevUrl: nav.prevUrl,
382
+ prevParams: nav.prevParams,
383
+ prevMatch: nav.prevMatch,
449
384
  matched,
450
- manifestEntry,
451
- entries,
385
+ manifestEntry: snapshot.manifestEntry,
386
+ entries: snapshot.entries,
452
387
  routeKey: matched.routeKey,
453
- localRouteName,
388
+ localRouteName: snapshot.localRouteName,
454
389
  handlerContext,
455
390
  loaderPromises,
456
391
  routeMap: deps.getRouteMap(),
457
392
  metricsStore,
458
393
  Store,
459
- interceptContextMatch,
394
+ interceptContextMatch: nav.interceptContextMatch,
460
395
  interceptSelectorContext,
461
- isSameRouteNavigation,
396
+ isSameRouteNavigation: nav.isSameRouteNavigation,
462
397
  interceptResult,
463
- cacheScope,
398
+ cacheScope: snapshot.cacheScope,
464
399
  isIntercept,
465
400
  actionContext,
466
401
  isAction,
467
- routeMiddleware,
402
+ routeMiddleware: snapshot.routeMiddleware,
468
403
  isFullMatch: false,
469
404
  };
470
405
  }
@@ -96,6 +96,7 @@ import type { MatchContext, MatchPipelineState } from "../match-context.js";
96
96
  import { getRouterContext } from "../router-context.js";
97
97
  import { resolveSink, safeEmit } from "../telemetry.js";
98
98
  import { pushRevalidationTraceEntry, isTraceActive } from "../logging.js";
99
+ import { treeHasStreaming } from "./segment-resolution.js";
99
100
  import type { PrerenderStore, PrerenderEntry } from "../../prerender/store.js";
100
101
  import type { HandleStore } from "../../server/handle-store.js";
101
102
  import {
@@ -193,6 +194,16 @@ async function* yieldFromStore<TEnv>(
193
194
  state.cachedSegments = segments;
194
195
  state.cachedMatchedIds = segments.map((s) => s.id);
195
196
 
197
+ // Set streaming flag (once) and resolve render barrier.
198
+ const reqCtx = handleStoreRef ? undefined : _lazyGetRequestContext?.();
199
+ const barrierReqCtx = reqCtx ?? _getRequestContext();
200
+ if (barrierReqCtx) {
201
+ if (barrierReqCtx._treeHasStreaming === undefined) {
202
+ barrierReqCtx._treeHasStreaming = treeHasStreaming(ctx.entries);
203
+ }
204
+ barrierReqCtx._resolveRenderBarrier(segments);
205
+ }
206
+
196
207
  // For partial navigation, nullify components the client already has
197
208
  // so parent layouts stay live (client keeps its existing versions).
198
209
  // When params changed (e.g., different guide slug), the segments have
@@ -240,6 +251,7 @@ async function* yieldFromStore<TEnv>(
240
251
  ctx.url,
241
252
  ctx.routeKey,
242
253
  ctx.actionContext,
254
+ ctx.stale || undefined,
243
255
  ),
244
256
  );
245
257
  state.matchedIds = [
@@ -324,9 +336,7 @@ export function withCacheLookup<TEnv>(
324
336
  if (prerenderStoreInstance) {
325
337
  const paramHash = _hashParams!(ctx.matched.params);
326
338
  const isPassthroughPrerenderRoute = ctx.entries.some(
327
- (entry) =>
328
- entry.type === "route" &&
329
- entry.prerenderDef?.options?.passthrough === true,
339
+ (entry) => entry.type === "route" && entry.isPassthrough === true,
330
340
  );
331
341
 
332
342
  if (ctx.isIntercept) {
@@ -396,9 +406,7 @@ export function withCacheLookup<TEnv>(
396
406
  if (prerenderStoreInstance) {
397
407
  const paramHash = _hashParams!(ctx.matched.params);
398
408
  const isPassthroughPrerenderRoute = ctx.entries.some(
399
- (entry) =>
400
- entry.type === "route" &&
401
- entry.prerenderDef?.options?.passthrough === true,
409
+ (entry) => entry.type === "route" && entry.isPassthrough === true,
402
410
  );
403
411
 
404
412
  if (ctx.isIntercept) {
@@ -591,7 +599,7 @@ export function withCacheLookup<TEnv>(
591
599
  routeKey: ctx.routeKey,
592
600
  context: ctx.handlerContext,
593
601
  actionContext: ctx.actionContext,
594
- stale: cacheResult.shouldRevalidate || undefined,
602
+ stale: cacheResult.shouldRevalidate || ctx.stale || undefined,
595
603
  traceSource: "cache-hit",
596
604
  });
597
605
 
@@ -618,6 +626,15 @@ export function withCacheLookup<TEnv>(
618
626
  yield segment;
619
627
  }
620
628
 
629
+ // Set streaming flag (once) and resolve render barrier.
630
+ const barrierReqCtx = _getRequestContext();
631
+ if (barrierReqCtx) {
632
+ if (barrierReqCtx._treeHasStreaming === undefined) {
633
+ barrierReqCtx._treeHasStreaming = treeHasStreaming(ctx.entries);
634
+ }
635
+ barrierReqCtx._resolveRenderBarrier(cacheResult.segments);
636
+ }
637
+
621
638
  // Resolve loaders fresh (loaders are NOT cached by default)
622
639
  // This ensures fresh data even on cache hit
623
640
  const Store = ctx.Store;
@@ -87,10 +87,49 @@
87
87
  * if (state.cacheHit) return; // Now we can check
88
88
  */
89
89
  import type { ResolvedSegment } from "../../types.js";
90
+ import type { EntryData } from "../../server/context.js";
91
+ import { _getRequestContext } from "../../server/request-context.js";
90
92
  import type { MatchContext, MatchPipelineState } from "../match-context.js";
91
93
  import { getRouterContext } from "../router-context.js";
92
94
  import type { GeneratorMiddleware } from "./cache-lookup.js";
93
95
 
96
+ /**
97
+ * Check whether any entry in the tree uses loading() (streaming).
98
+ * Matches the router's streaming semantics in fresh.ts: streaming is
99
+ * enabled when `loading` is defined AND not `false`. `loading: false`
100
+ * explicitly disables streaming; `undefined` means no loading at all.
101
+ */
102
+ export function treeHasStreaming(entries: EntryData[]): boolean {
103
+ for (const entry of entries) {
104
+ if (
105
+ "loading" in entry &&
106
+ entry.loading !== undefined &&
107
+ entry.loading !== false
108
+ )
109
+ return true;
110
+ if (entry.layout) {
111
+ if (treeHasStreaming(entry.layout)) return true;
112
+ }
113
+ if (entry.parallel) {
114
+ for (const key in entry.parallel) {
115
+ const parallelEntry = entry.parallel[key as `@${string}`];
116
+ if (parallelEntry) {
117
+ if (
118
+ "loading" in parallelEntry &&
119
+ parallelEntry.loading !== undefined &&
120
+ parallelEntry.loading !== false
121
+ )
122
+ return true;
123
+ if (parallelEntry.layout) {
124
+ if (treeHasStreaming(parallelEntry.layout)) return true;
125
+ }
126
+ }
127
+ }
128
+ }
129
+ }
130
+ return false;
131
+ }
132
+
94
133
  /**
95
134
  * Creates segment resolution middleware
96
135
  *
@@ -116,6 +155,7 @@ export function withSegmentResolution<TEnv>(
116
155
  const ownStart = performance.now();
117
156
 
118
157
  // If cache hit, segments were already yielded by cache lookup
158
+ // (render barrier is resolved on the cache-hit path)
119
159
  if (state.cacheHit) {
120
160
  if (ms) {
121
161
  ms.metrics.push({
@@ -127,6 +167,11 @@ export function withSegmentResolution<TEnv>(
127
167
  return;
128
168
  }
129
169
 
170
+ const reqCtx = _getRequestContext();
171
+ if (reqCtx && reqCtx._treeHasStreaming === undefined) {
172
+ reqCtx._treeHasStreaming = treeHasStreaming(ctx.entries);
173
+ }
174
+
130
175
  const { resolveAllSegmentsWithRevalidation, resolveAllSegments } =
131
176
  getRouterContext<TEnv>();
132
177
 
@@ -148,6 +193,10 @@ export function withSegmentResolution<TEnv>(
148
193
  state.segments = segments;
149
194
  state.matchedIds = segments.map((s: { id: string }) => s.id);
150
195
 
196
+ if (reqCtx) {
197
+ reqCtx._resolveRenderBarrier(segments);
198
+ }
199
+
151
200
  // Yield all resolved segments
152
201
  for (const segment of segments) {
153
202
  yield segment;
@@ -178,6 +227,10 @@ export function withSegmentResolution<TEnv>(
178
227
  state.segments = result.segments;
179
228
  state.matchedIds = result.matchedIds;
180
229
 
230
+ if (reqCtx) {
231
+ reqCtx._resolveRenderBarrier(result.segments);
232
+ }
233
+
181
234
  // Yield all resolved segments
182
235
  for (const segment of result.segments) {
183
236
  yield segment;