@rangojs/router 0.0.0-experimental.112 → 0.0.0-experimental.113

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 (830) hide show
  1. package/dist/bin/rango.js +1 -1
  2. package/dist/vite/index.js +4 -4
  3. package/package.json +17 -18
  4. package/skills/cache-guide/SKILL.md +35 -24
  5. package/skills/caching/SKILL.md +115 -7
  6. package/skills/document-cache/SKILL.md +78 -55
  7. package/skills/hooks/SKILL.md +37 -19
  8. package/skills/loader/SKILL.md +3 -3
  9. package/skills/rango/SKILL.md +15 -10
  10. package/skills/use-cache/SKILL.md +34 -5
  11. package/src/browser/react/location-state-shared.ts +93 -3
  12. package/src/build/route-types/per-module-writer.ts +4 -1
  13. package/src/cache/cache-scope.ts +28 -42
  14. package/src/cache/cf/cf-cache-store.ts +49 -6
  15. package/src/loader-store.ts +62 -25
  16. package/src/loader.ts +1 -5
  17. package/src/route-definition/helpers-types.ts +13 -4
  18. package/src/router/loader-resolution.ts +16 -2
  19. package/src/router/match-middleware/cache-lookup.ts +44 -91
  20. package/src/router/match-middleware/cache-store.ts +3 -2
  21. package/src/segment-system.tsx +41 -8
  22. package/src/server/context.ts +26 -0
  23. package/src/server/cookie-store.ts +28 -4
  24. package/src/types/handler-context.ts +5 -2
  25. package/src/use-loader.tsx +89 -42
  26. package/src/vite/plugins/use-cache-transform.ts +12 -10
  27. package/dist/__internal.d.ts +0 -83
  28. package/dist/__internal.d.ts.map +0 -1
  29. package/dist/__internal.js +0 -19
  30. package/dist/__internal.js.map +0 -1
  31. package/dist/__mocks__/version.d.ts +0 -7
  32. package/dist/__mocks__/version.d.ts.map +0 -1
  33. package/dist/__mocks__/version.js +0 -7
  34. package/dist/__mocks__/version.js.map +0 -1
  35. package/dist/__tests__/client-href.test.d.ts +0 -2
  36. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  37. package/dist/__tests__/client-href.test.js +0 -74
  38. package/dist/__tests__/client-href.test.js.map +0 -1
  39. package/dist/__tests__/component-utils.test.d.ts +0 -2
  40. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  41. package/dist/__tests__/component-utils.test.js +0 -51
  42. package/dist/__tests__/component-utils.test.js.map +0 -1
  43. package/dist/__tests__/event-controller.test.d.ts +0 -2
  44. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  45. package/dist/__tests__/event-controller.test.js +0 -538
  46. package/dist/__tests__/event-controller.test.js.map +0 -1
  47. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  48. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  49. package/dist/__tests__/helpers/route-tree.js +0 -374
  50. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  51. package/dist/__tests__/match-result.test.d.ts +0 -2
  52. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  53. package/dist/__tests__/match-result.test.js +0 -154
  54. package/dist/__tests__/match-result.test.js.map +0 -1
  55. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  56. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  57. package/dist/__tests__/navigation-store.test.js +0 -440
  58. package/dist/__tests__/navigation-store.test.js.map +0 -1
  59. package/dist/__tests__/partial-update.test.d.ts +0 -2
  60. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  61. package/dist/__tests__/partial-update.test.js +0 -1009
  62. package/dist/__tests__/partial-update.test.js.map +0 -1
  63. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  64. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  65. package/dist/__tests__/reverse-types.test.js +0 -656
  66. package/dist/__tests__/reverse-types.test.js.map +0 -1
  67. package/dist/__tests__/route-definition.test.d.ts +0 -2
  68. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  69. package/dist/__tests__/route-definition.test.js +0 -55
  70. package/dist/__tests__/route-definition.test.js.map +0 -1
  71. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  72. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  73. package/dist/__tests__/router-helpers.test.js +0 -377
  74. package/dist/__tests__/router-helpers.test.js.map +0 -1
  75. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  76. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  77. package/dist/__tests__/router-integration-2.test.js +0 -426
  78. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  79. package/dist/__tests__/router-integration.test.d.ts +0 -2
  80. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  81. package/dist/__tests__/router-integration.test.js +0 -1051
  82. package/dist/__tests__/router-integration.test.js.map +0 -1
  83. package/dist/__tests__/search-params.test.d.ts +0 -5
  84. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  85. package/dist/__tests__/search-params.test.js +0 -306
  86. package/dist/__tests__/search-params.test.js.map +0 -1
  87. package/dist/__tests__/segment-system.test.d.ts +0 -2
  88. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  89. package/dist/__tests__/segment-system.test.js +0 -627
  90. package/dist/__tests__/segment-system.test.js.map +0 -1
  91. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  92. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  93. package/dist/__tests__/static-handler-types.test.js +0 -63
  94. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  95. package/dist/__tests__/urls.test.d.ts +0 -2
  96. package/dist/__tests__/urls.test.d.ts.map +0 -1
  97. package/dist/__tests__/urls.test.js +0 -421
  98. package/dist/__tests__/urls.test.js.map +0 -1
  99. package/dist/__tests__/use-mount.test.d.ts +0 -2
  100. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  101. package/dist/__tests__/use-mount.test.js +0 -35
  102. package/dist/__tests__/use-mount.test.js.map +0 -1
  103. package/dist/bin/rango.d.ts +0 -2
  104. package/dist/bin/rango.d.ts.map +0 -1
  105. package/dist/bin/rango.js.map +0 -1
  106. package/dist/browser/event-controller.d.ts +0 -191
  107. package/dist/browser/event-controller.d.ts.map +0 -1
  108. package/dist/browser/event-controller.js +0 -559
  109. package/dist/browser/event-controller.js.map +0 -1
  110. package/dist/browser/index.d.ts +0 -2
  111. package/dist/browser/index.d.ts.map +0 -1
  112. package/dist/browser/index.js +0 -14
  113. package/dist/browser/index.js.map +0 -1
  114. package/dist/browser/link-interceptor.d.ts +0 -38
  115. package/dist/browser/link-interceptor.d.ts.map +0 -1
  116. package/dist/browser/link-interceptor.js +0 -99
  117. package/dist/browser/link-interceptor.js.map +0 -1
  118. package/dist/browser/logging.d.ts +0 -10
  119. package/dist/browser/logging.d.ts.map +0 -1
  120. package/dist/browser/logging.js +0 -29
  121. package/dist/browser/logging.js.map +0 -1
  122. package/dist/browser/lru-cache.d.ts +0 -17
  123. package/dist/browser/lru-cache.d.ts.map +0 -1
  124. package/dist/browser/lru-cache.js +0 -50
  125. package/dist/browser/lru-cache.js.map +0 -1
  126. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  127. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  128. package/dist/browser/merge-segment-loaders.js +0 -102
  129. package/dist/browser/merge-segment-loaders.js.map +0 -1
  130. package/dist/browser/navigation-bridge.d.ts +0 -102
  131. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  132. package/dist/browser/navigation-bridge.js +0 -708
  133. package/dist/browser/navigation-bridge.js.map +0 -1
  134. package/dist/browser/navigation-client.d.ts +0 -25
  135. package/dist/browser/navigation-client.d.ts.map +0 -1
  136. package/dist/browser/navigation-client.js +0 -157
  137. package/dist/browser/navigation-client.js.map +0 -1
  138. package/dist/browser/navigation-store.d.ts +0 -101
  139. package/dist/browser/navigation-store.d.ts.map +0 -1
  140. package/dist/browser/navigation-store.js +0 -625
  141. package/dist/browser/navigation-store.js.map +0 -1
  142. package/dist/browser/partial-update.d.ts +0 -75
  143. package/dist/browser/partial-update.d.ts.map +0 -1
  144. package/dist/browser/partial-update.js +0 -426
  145. package/dist/browser/partial-update.js.map +0 -1
  146. package/dist/browser/react/Link.d.ts +0 -86
  147. package/dist/browser/react/Link.d.ts.map +0 -1
  148. package/dist/browser/react/Link.js +0 -128
  149. package/dist/browser/react/Link.js.map +0 -1
  150. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  151. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  152. package/dist/browser/react/NavigationProvider.js +0 -216
  153. package/dist/browser/react/NavigationProvider.js.map +0 -1
  154. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  155. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  156. package/dist/browser/react/ScrollRestoration.js +0 -57
  157. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  158. package/dist/browser/react/context.d.ts +0 -46
  159. package/dist/browser/react/context.d.ts.map +0 -1
  160. package/dist/browser/react/context.js +0 -10
  161. package/dist/browser/react/context.js.map +0 -1
  162. package/dist/browser/react/index.d.ts +0 -11
  163. package/dist/browser/react/index.d.ts.map +0 -1
  164. package/dist/browser/react/index.js +0 -22
  165. package/dist/browser/react/index.js.map +0 -1
  166. package/dist/browser/react/location-state-shared.d.ts +0 -63
  167. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  168. package/dist/browser/react/location-state-shared.js +0 -81
  169. package/dist/browser/react/location-state-shared.js.map +0 -1
  170. package/dist/browser/react/location-state.d.ts +0 -23
  171. package/dist/browser/react/location-state.d.ts.map +0 -1
  172. package/dist/browser/react/location-state.js +0 -29
  173. package/dist/browser/react/location-state.js.map +0 -1
  174. package/dist/browser/react/mount-context.d.ts +0 -24
  175. package/dist/browser/react/mount-context.d.ts.map +0 -1
  176. package/dist/browser/react/mount-context.js +0 -24
  177. package/dist/browser/react/mount-context.js.map +0 -1
  178. package/dist/browser/react/use-action.d.ts +0 -64
  179. package/dist/browser/react/use-action.d.ts.map +0 -1
  180. package/dist/browser/react/use-action.js +0 -134
  181. package/dist/browser/react/use-action.js.map +0 -1
  182. package/dist/browser/react/use-client-cache.d.ts +0 -41
  183. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  184. package/dist/browser/react/use-client-cache.js +0 -39
  185. package/dist/browser/react/use-client-cache.js.map +0 -1
  186. package/dist/browser/react/use-handle.d.ts +0 -31
  187. package/dist/browser/react/use-handle.d.ts.map +0 -1
  188. package/dist/browser/react/use-handle.js +0 -144
  189. package/dist/browser/react/use-handle.js.map +0 -1
  190. package/dist/browser/react/use-href.d.ts +0 -33
  191. package/dist/browser/react/use-href.d.ts.map +0 -1
  192. package/dist/browser/react/use-href.js +0 -39
  193. package/dist/browser/react/use-href.js.map +0 -1
  194. package/dist/browser/react/use-link-status.d.ts +0 -37
  195. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  196. package/dist/browser/react/use-link-status.js +0 -99
  197. package/dist/browser/react/use-link-status.js.map +0 -1
  198. package/dist/browser/react/use-mount.d.ts +0 -25
  199. package/dist/browser/react/use-mount.d.ts.map +0 -1
  200. package/dist/browser/react/use-mount.js +0 -30
  201. package/dist/browser/react/use-mount.js.map +0 -1
  202. package/dist/browser/react/use-navigation.d.ts +0 -27
  203. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  204. package/dist/browser/react/use-navigation.js +0 -87
  205. package/dist/browser/react/use-navigation.js.map +0 -1
  206. package/dist/browser/react/use-segments.d.ts +0 -38
  207. package/dist/browser/react/use-segments.d.ts.map +0 -1
  208. package/dist/browser/react/use-segments.js +0 -130
  209. package/dist/browser/react/use-segments.js.map +0 -1
  210. package/dist/browser/request-controller.d.ts +0 -26
  211. package/dist/browser/request-controller.d.ts.map +0 -1
  212. package/dist/browser/request-controller.js +0 -147
  213. package/dist/browser/request-controller.js.map +0 -1
  214. package/dist/browser/rsc-router.d.ts +0 -129
  215. package/dist/browser/rsc-router.d.ts.map +0 -1
  216. package/dist/browser/rsc-router.js +0 -195
  217. package/dist/browser/rsc-router.js.map +0 -1
  218. package/dist/browser/scroll-restoration.d.ts +0 -93
  219. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  220. package/dist/browser/scroll-restoration.js +0 -321
  221. package/dist/browser/scroll-restoration.js.map +0 -1
  222. package/dist/browser/segment-structure-assert.d.ts +0 -17
  223. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  224. package/dist/browser/segment-structure-assert.js +0 -59
  225. package/dist/browser/segment-structure-assert.js.map +0 -1
  226. package/dist/browser/server-action-bridge.d.ts +0 -26
  227. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  228. package/dist/browser/server-action-bridge.js +0 -668
  229. package/dist/browser/server-action-bridge.js.map +0 -1
  230. package/dist/browser/shallow.d.ts +0 -12
  231. package/dist/browser/shallow.d.ts.map +0 -1
  232. package/dist/browser/shallow.js +0 -34
  233. package/dist/browser/shallow.js.map +0 -1
  234. package/dist/browser/types.d.ts +0 -369
  235. package/dist/browser/types.d.ts.map +0 -1
  236. package/dist/browser/types.js +0 -2
  237. package/dist/browser/types.js.map +0 -1
  238. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  239. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  240. package/dist/build/__tests__/generate-cli.test.js +0 -237
  241. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  242. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  243. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  244. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  245. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  246. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  247. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  248. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  249. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  250. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  251. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  252. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  253. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  254. package/dist/build/generate-manifest.d.ts +0 -81
  255. package/dist/build/generate-manifest.d.ts.map +0 -1
  256. package/dist/build/generate-manifest.js +0 -276
  257. package/dist/build/generate-manifest.js.map +0 -1
  258. package/dist/build/generate-route-types.d.ts +0 -115
  259. package/dist/build/generate-route-types.d.ts.map +0 -1
  260. package/dist/build/generate-route-types.js +0 -740
  261. package/dist/build/generate-route-types.js.map +0 -1
  262. package/dist/build/index.d.ts +0 -21
  263. package/dist/build/index.d.ts.map +0 -1
  264. package/dist/build/index.js +0 -21
  265. package/dist/build/index.js.map +0 -1
  266. package/dist/build/route-trie.d.ts +0 -71
  267. package/dist/build/route-trie.d.ts.map +0 -1
  268. package/dist/build/route-trie.js +0 -175
  269. package/dist/build/route-trie.js.map +0 -1
  270. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  271. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  272. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  273. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  274. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  275. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  276. package/dist/cache/__tests__/document-cache.test.js +0 -345
  277. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  278. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  279. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  280. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  281. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  282. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  283. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  284. package/dist/cache/__tests__/memory-store.test.js +0 -367
  285. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  286. package/dist/cache/cache-scope.d.ts +0 -102
  287. package/dist/cache/cache-scope.d.ts.map +0 -1
  288. package/dist/cache/cache-scope.js +0 -440
  289. package/dist/cache/cache-scope.js.map +0 -1
  290. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  291. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  292. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  293. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  294. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  295. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  296. package/dist/cache/cf/cf-cache-store.js +0 -242
  297. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  298. package/dist/cache/cf/index.d.ts +0 -14
  299. package/dist/cache/cf/index.d.ts.map +0 -1
  300. package/dist/cache/cf/index.js +0 -17
  301. package/dist/cache/cf/index.js.map +0 -1
  302. package/dist/cache/document-cache.d.ts +0 -64
  303. package/dist/cache/document-cache.d.ts.map +0 -1
  304. package/dist/cache/document-cache.js +0 -228
  305. package/dist/cache/document-cache.js.map +0 -1
  306. package/dist/cache/index.d.ts +0 -19
  307. package/dist/cache/index.d.ts.map +0 -1
  308. package/dist/cache/index.js +0 -21
  309. package/dist/cache/index.js.map +0 -1
  310. package/dist/cache/memory-segment-store.d.ts +0 -110
  311. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  312. package/dist/cache/memory-segment-store.js +0 -117
  313. package/dist/cache/memory-segment-store.js.map +0 -1
  314. package/dist/cache/memory-store.d.ts +0 -41
  315. package/dist/cache/memory-store.d.ts.map +0 -1
  316. package/dist/cache/memory-store.js +0 -191
  317. package/dist/cache/memory-store.js.map +0 -1
  318. package/dist/cache/types.d.ts +0 -317
  319. package/dist/cache/types.d.ts.map +0 -1
  320. package/dist/cache/types.js +0 -12
  321. package/dist/cache/types.js.map +0 -1
  322. package/dist/client.d.ts +0 -248
  323. package/dist/client.d.ts.map +0 -1
  324. package/dist/client.js +0 -367
  325. package/dist/client.js.map +0 -1
  326. package/dist/client.rsc.d.ts +0 -26
  327. package/dist/client.rsc.d.ts.map +0 -1
  328. package/dist/client.rsc.js +0 -46
  329. package/dist/client.rsc.js.map +0 -1
  330. package/dist/component-utils.d.ts +0 -36
  331. package/dist/component-utils.d.ts.map +0 -1
  332. package/dist/component-utils.js +0 -61
  333. package/dist/component-utils.js.map +0 -1
  334. package/dist/components/DefaultDocument.d.ts +0 -13
  335. package/dist/components/DefaultDocument.d.ts.map +0 -1
  336. package/dist/components/DefaultDocument.js +0 -15
  337. package/dist/components/DefaultDocument.js.map +0 -1
  338. package/dist/debug.d.ts +0 -58
  339. package/dist/debug.d.ts.map +0 -1
  340. package/dist/debug.js +0 -157
  341. package/dist/debug.js.map +0 -1
  342. package/dist/default-error-boundary.d.ts +0 -11
  343. package/dist/default-error-boundary.d.ts.map +0 -1
  344. package/dist/default-error-boundary.js +0 -45
  345. package/dist/default-error-boundary.js.map +0 -1
  346. package/dist/deps/browser.d.ts +0 -2
  347. package/dist/deps/browser.d.ts.map +0 -1
  348. package/dist/deps/browser.js +0 -3
  349. package/dist/deps/browser.js.map +0 -1
  350. package/dist/deps/html-stream-client.d.ts +0 -2
  351. package/dist/deps/html-stream-client.d.ts.map +0 -1
  352. package/dist/deps/html-stream-client.js +0 -3
  353. package/dist/deps/html-stream-client.js.map +0 -1
  354. package/dist/deps/html-stream-server.d.ts +0 -2
  355. package/dist/deps/html-stream-server.d.ts.map +0 -1
  356. package/dist/deps/html-stream-server.js +0 -3
  357. package/dist/deps/html-stream-server.js.map +0 -1
  358. package/dist/deps/rsc.d.ts +0 -2
  359. package/dist/deps/rsc.d.ts.map +0 -1
  360. package/dist/deps/rsc.js +0 -4
  361. package/dist/deps/rsc.js.map +0 -1
  362. package/dist/deps/ssr.d.ts +0 -2
  363. package/dist/deps/ssr.d.ts.map +0 -1
  364. package/dist/deps/ssr.js +0 -3
  365. package/dist/deps/ssr.js.map +0 -1
  366. package/dist/errors.d.ts +0 -174
  367. package/dist/errors.d.ts.map +0 -1
  368. package/dist/errors.js +0 -241
  369. package/dist/errors.js.map +0 -1
  370. package/dist/handle.d.ts +0 -78
  371. package/dist/handle.d.ts.map +0 -1
  372. package/dist/handle.js +0 -82
  373. package/dist/handle.js.map +0 -1
  374. package/dist/handles/MetaTags.d.ts +0 -14
  375. package/dist/handles/MetaTags.d.ts.map +0 -1
  376. package/dist/handles/MetaTags.js +0 -136
  377. package/dist/handles/MetaTags.js.map +0 -1
  378. package/dist/handles/index.d.ts +0 -6
  379. package/dist/handles/index.d.ts.map +0 -1
  380. package/dist/handles/index.js +0 -6
  381. package/dist/handles/index.js.map +0 -1
  382. package/dist/handles/meta.d.ts +0 -39
  383. package/dist/handles/meta.d.ts.map +0 -1
  384. package/dist/handles/meta.js +0 -202
  385. package/dist/handles/meta.js.map +0 -1
  386. package/dist/host/__tests__/errors.test.d.ts +0 -2
  387. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  388. package/dist/host/__tests__/errors.test.js +0 -76
  389. package/dist/host/__tests__/errors.test.js.map +0 -1
  390. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  391. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  392. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  393. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  394. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  395. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  396. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  397. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  398. package/dist/host/__tests__/router.test.d.ts +0 -2
  399. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  400. package/dist/host/__tests__/router.test.js +0 -241
  401. package/dist/host/__tests__/router.test.js.map +0 -1
  402. package/dist/host/__tests__/testing.test.d.ts +0 -2
  403. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  404. package/dist/host/__tests__/testing.test.js +0 -64
  405. package/dist/host/__tests__/testing.test.js.map +0 -1
  406. package/dist/host/__tests__/utils.test.d.ts +0 -2
  407. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  408. package/dist/host/__tests__/utils.test.js +0 -29
  409. package/dist/host/__tests__/utils.test.js.map +0 -1
  410. package/dist/host/cookie-handler.d.ts +0 -34
  411. package/dist/host/cookie-handler.d.ts.map +0 -1
  412. package/dist/host/cookie-handler.js +0 -124
  413. package/dist/host/cookie-handler.js.map +0 -1
  414. package/dist/host/errors.d.ts +0 -56
  415. package/dist/host/errors.d.ts.map +0 -1
  416. package/dist/host/errors.js +0 -79
  417. package/dist/host/errors.js.map +0 -1
  418. package/dist/host/index.d.ts +0 -29
  419. package/dist/host/index.d.ts.map +0 -1
  420. package/dist/host/index.js +0 -32
  421. package/dist/host/index.js.map +0 -1
  422. package/dist/host/pattern-matcher.d.ts +0 -36
  423. package/dist/host/pattern-matcher.d.ts.map +0 -1
  424. package/dist/host/pattern-matcher.js +0 -172
  425. package/dist/host/pattern-matcher.js.map +0 -1
  426. package/dist/host/router.d.ts +0 -26
  427. package/dist/host/router.d.ts.map +0 -1
  428. package/dist/host/router.js +0 -218
  429. package/dist/host/router.js.map +0 -1
  430. package/dist/host/testing.d.ts +0 -36
  431. package/dist/host/testing.d.ts.map +0 -1
  432. package/dist/host/testing.js +0 -55
  433. package/dist/host/testing.js.map +0 -1
  434. package/dist/host/types.d.ts +0 -115
  435. package/dist/host/types.d.ts.map +0 -1
  436. package/dist/host/types.js +0 -7
  437. package/dist/host/types.js.map +0 -1
  438. package/dist/host/utils.d.ts +0 -21
  439. package/dist/host/utils.d.ts.map +0 -1
  440. package/dist/host/utils.js +0 -23
  441. package/dist/host/utils.js.map +0 -1
  442. package/dist/href-client.d.ts +0 -131
  443. package/dist/href-client.d.ts.map +0 -1
  444. package/dist/href-client.js +0 -64
  445. package/dist/href-client.js.map +0 -1
  446. package/dist/href-context.d.ts +0 -29
  447. package/dist/href-context.d.ts.map +0 -1
  448. package/dist/href-context.js +0 -21
  449. package/dist/href-context.js.map +0 -1
  450. package/dist/index.d.ts +0 -73
  451. package/dist/index.d.ts.map +0 -1
  452. package/dist/index.js +0 -91
  453. package/dist/index.js.map +0 -1
  454. package/dist/index.rsc.d.ts +0 -32
  455. package/dist/index.rsc.d.ts.map +0 -1
  456. package/dist/index.rsc.js +0 -40
  457. package/dist/index.rsc.js.map +0 -1
  458. package/dist/internal-debug.d.ts +0 -2
  459. package/dist/internal-debug.d.ts.map +0 -1
  460. package/dist/internal-debug.js +0 -5
  461. package/dist/internal-debug.js.map +0 -1
  462. package/dist/loader.d.ts +0 -14
  463. package/dist/loader.d.ts.map +0 -1
  464. package/dist/loader.js +0 -20
  465. package/dist/loader.js.map +0 -1
  466. package/dist/loader.rsc.d.ts +0 -19
  467. package/dist/loader.rsc.d.ts.map +0 -1
  468. package/dist/loader.rsc.js +0 -99
  469. package/dist/loader.rsc.js.map +0 -1
  470. package/dist/network-error-thrower.d.ts +0 -17
  471. package/dist/network-error-thrower.d.ts.map +0 -1
  472. package/dist/network-error-thrower.js +0 -14
  473. package/dist/network-error-thrower.js.map +0 -1
  474. package/dist/outlet-context.d.ts +0 -13
  475. package/dist/outlet-context.d.ts.map +0 -1
  476. package/dist/outlet-context.js +0 -3
  477. package/dist/outlet-context.js.map +0 -1
  478. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  479. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  480. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  481. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  482. package/dist/prerender/param-hash.d.ts +0 -16
  483. package/dist/prerender/param-hash.d.ts.map +0 -1
  484. package/dist/prerender/param-hash.js +0 -36
  485. package/dist/prerender/param-hash.js.map +0 -1
  486. package/dist/prerender/store.d.ts +0 -38
  487. package/dist/prerender/store.d.ts.map +0 -1
  488. package/dist/prerender/store.js +0 -61
  489. package/dist/prerender/store.js.map +0 -1
  490. package/dist/prerender.d.ts +0 -66
  491. package/dist/prerender.d.ts.map +0 -1
  492. package/dist/prerender.js +0 -57
  493. package/dist/prerender.js.map +0 -1
  494. package/dist/reverse.d.ts +0 -196
  495. package/dist/reverse.d.ts.map +0 -1
  496. package/dist/reverse.js +0 -78
  497. package/dist/reverse.js.map +0 -1
  498. package/dist/root-error-boundary.d.ts +0 -33
  499. package/dist/root-error-boundary.d.ts.map +0 -1
  500. package/dist/root-error-boundary.js +0 -165
  501. package/dist/root-error-boundary.js.map +0 -1
  502. package/dist/route-content-wrapper.d.ts +0 -46
  503. package/dist/route-content-wrapper.d.ts.map +0 -1
  504. package/dist/route-content-wrapper.js +0 -77
  505. package/dist/route-content-wrapper.js.map +0 -1
  506. package/dist/route-definition.d.ts +0 -421
  507. package/dist/route-definition.d.ts.map +0 -1
  508. package/dist/route-definition.js +0 -868
  509. package/dist/route-definition.js.map +0 -1
  510. package/dist/route-map-builder.d.ts +0 -155
  511. package/dist/route-map-builder.d.ts.map +0 -1
  512. package/dist/route-map-builder.js +0 -237
  513. package/dist/route-map-builder.js.map +0 -1
  514. package/dist/route-types.d.ts +0 -165
  515. package/dist/route-types.d.ts.map +0 -1
  516. package/dist/route-types.js +0 -7
  517. package/dist/route-types.js.map +0 -1
  518. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  519. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  520. package/dist/router/__tests__/handler-context.test.js +0 -65
  521. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  522. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  523. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  524. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  525. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  526. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  527. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  528. package/dist/router/__tests__/match-context.test.js +0 -92
  529. package/dist/router/__tests__/match-context.test.js.map +0 -1
  530. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  531. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  532. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  533. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  534. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  535. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  536. package/dist/router/__tests__/match-result.test.js +0 -457
  537. package/dist/router/__tests__/match-result.test.js.map +0 -1
  538. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  539. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  540. package/dist/router/__tests__/on-error.test.js +0 -678
  541. package/dist/router/__tests__/on-error.test.js.map +0 -1
  542. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  543. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  544. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  545. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  546. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  547. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  548. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  549. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  550. package/dist/router/error-handling.d.ts +0 -77
  551. package/dist/router/error-handling.d.ts.map +0 -1
  552. package/dist/router/error-handling.js +0 -202
  553. package/dist/router/error-handling.js.map +0 -1
  554. package/dist/router/handler-context.d.ts +0 -20
  555. package/dist/router/handler-context.d.ts.map +0 -1
  556. package/dist/router/handler-context.js +0 -198
  557. package/dist/router/handler-context.js.map +0 -1
  558. package/dist/router/intercept-resolution.d.ts +0 -66
  559. package/dist/router/intercept-resolution.d.ts.map +0 -1
  560. package/dist/router/intercept-resolution.js +0 -246
  561. package/dist/router/intercept-resolution.js.map +0 -1
  562. package/dist/router/loader-resolution.d.ts +0 -64
  563. package/dist/router/loader-resolution.d.ts.map +0 -1
  564. package/dist/router/loader-resolution.js +0 -284
  565. package/dist/router/loader-resolution.js.map +0 -1
  566. package/dist/router/logging.d.ts +0 -15
  567. package/dist/router/logging.d.ts.map +0 -1
  568. package/dist/router/logging.js +0 -99
  569. package/dist/router/logging.js.map +0 -1
  570. package/dist/router/manifest.d.ts +0 -22
  571. package/dist/router/manifest.d.ts.map +0 -1
  572. package/dist/router/manifest.js +0 -181
  573. package/dist/router/manifest.js.map +0 -1
  574. package/dist/router/match-api.d.ts +0 -35
  575. package/dist/router/match-api.d.ts.map +0 -1
  576. package/dist/router/match-api.js +0 -406
  577. package/dist/router/match-api.js.map +0 -1
  578. package/dist/router/match-context.d.ts +0 -206
  579. package/dist/router/match-context.d.ts.map +0 -1
  580. package/dist/router/match-context.js +0 -17
  581. package/dist/router/match-context.js.map +0 -1
  582. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  583. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  584. package/dist/router/match-middleware/background-revalidation.js +0 -75
  585. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  586. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  587. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  588. package/dist/router/match-middleware/cache-lookup.js +0 -257
  589. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  590. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  591. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  592. package/dist/router/match-middleware/cache-store.js +0 -108
  593. package/dist/router/match-middleware/cache-store.js.map +0 -1
  594. package/dist/router/match-middleware/index.d.ts +0 -81
  595. package/dist/router/match-middleware/index.d.ts.map +0 -1
  596. package/dist/router/match-middleware/index.js +0 -80
  597. package/dist/router/match-middleware/index.js.map +0 -1
  598. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  599. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  600. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  601. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  602. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  603. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  604. package/dist/router/match-middleware/segment-resolution.js +0 -53
  605. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  606. package/dist/router/match-pipelines.d.ts +0 -147
  607. package/dist/router/match-pipelines.d.ts.map +0 -1
  608. package/dist/router/match-pipelines.js +0 -82
  609. package/dist/router/match-pipelines.js.map +0 -1
  610. package/dist/router/match-result.d.ts +0 -126
  611. package/dist/router/match-result.d.ts.map +0 -1
  612. package/dist/router/match-result.js +0 -93
  613. package/dist/router/match-result.js.map +0 -1
  614. package/dist/router/metrics.d.ts +0 -20
  615. package/dist/router/metrics.d.ts.map +0 -1
  616. package/dist/router/metrics.js +0 -47
  617. package/dist/router/metrics.js.map +0 -1
  618. package/dist/router/middleware.d.ts +0 -249
  619. package/dist/router/middleware.d.ts.map +0 -1
  620. package/dist/router/middleware.js +0 -434
  621. package/dist/router/middleware.js.map +0 -1
  622. package/dist/router/middleware.test.d.ts +0 -2
  623. package/dist/router/middleware.test.d.ts.map +0 -1
  624. package/dist/router/middleware.test.js +0 -816
  625. package/dist/router/middleware.test.js.map +0 -1
  626. package/dist/router/pattern-matching.d.ts +0 -149
  627. package/dist/router/pattern-matching.d.ts.map +0 -1
  628. package/dist/router/pattern-matching.js +0 -349
  629. package/dist/router/pattern-matching.js.map +0 -1
  630. package/dist/router/revalidation.d.ts +0 -44
  631. package/dist/router/revalidation.d.ts.map +0 -1
  632. package/dist/router/revalidation.js +0 -147
  633. package/dist/router/revalidation.js.map +0 -1
  634. package/dist/router/router-context.d.ts +0 -135
  635. package/dist/router/router-context.d.ts.map +0 -1
  636. package/dist/router/router-context.js +0 -36
  637. package/dist/router/router-context.js.map +0 -1
  638. package/dist/router/segment-resolution.d.ts +0 -127
  639. package/dist/router/segment-resolution.d.ts.map +0 -1
  640. package/dist/router/segment-resolution.js +0 -919
  641. package/dist/router/segment-resolution.js.map +0 -1
  642. package/dist/router/trie-matching.d.ts +0 -40
  643. package/dist/router/trie-matching.d.ts.map +0 -1
  644. package/dist/router/trie-matching.js +0 -127
  645. package/dist/router/trie-matching.js.map +0 -1
  646. package/dist/router/types.d.ts +0 -136
  647. package/dist/router/types.d.ts.map +0 -1
  648. package/dist/router/types.js +0 -7
  649. package/dist/router/types.js.map +0 -1
  650. package/dist/router.d.ts +0 -753
  651. package/dist/router.d.ts.map +0 -1
  652. package/dist/router.gen.d.ts +0 -6
  653. package/dist/router.gen.d.ts.map +0 -1
  654. package/dist/router.gen.js +0 -6
  655. package/dist/router.gen.js.map +0 -1
  656. package/dist/router.js +0 -1304
  657. package/dist/router.js.map +0 -1
  658. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  659. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  660. package/dist/rsc/__tests__/helpers.test.js +0 -140
  661. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  662. package/dist/rsc/handler.d.ts +0 -45
  663. package/dist/rsc/handler.d.ts.map +0 -1
  664. package/dist/rsc/handler.js +0 -1172
  665. package/dist/rsc/handler.js.map +0 -1
  666. package/dist/rsc/helpers.d.ts +0 -16
  667. package/dist/rsc/helpers.d.ts.map +0 -1
  668. package/dist/rsc/helpers.js +0 -55
  669. package/dist/rsc/helpers.js.map +0 -1
  670. package/dist/rsc/index.d.ts +0 -22
  671. package/dist/rsc/index.d.ts.map +0 -1
  672. package/dist/rsc/index.js +0 -23
  673. package/dist/rsc/index.js.map +0 -1
  674. package/dist/rsc/nonce.d.ts +0 -9
  675. package/dist/rsc/nonce.d.ts.map +0 -1
  676. package/dist/rsc/nonce.js +0 -18
  677. package/dist/rsc/nonce.js.map +0 -1
  678. package/dist/rsc/types.d.ts +0 -206
  679. package/dist/rsc/types.d.ts.map +0 -1
  680. package/dist/rsc/types.js +0 -8
  681. package/dist/rsc/types.js.map +0 -1
  682. package/dist/search-params.d.ts +0 -103
  683. package/dist/search-params.d.ts.map +0 -1
  684. package/dist/search-params.js +0 -74
  685. package/dist/search-params.js.map +0 -1
  686. package/dist/segment-system.d.ts +0 -75
  687. package/dist/segment-system.d.ts.map +0 -1
  688. package/dist/segment-system.js +0 -336
  689. package/dist/segment-system.js.map +0 -1
  690. package/dist/server/context.d.ts +0 -245
  691. package/dist/server/context.d.ts.map +0 -1
  692. package/dist/server/context.js +0 -197
  693. package/dist/server/context.js.map +0 -1
  694. package/dist/server/fetchable-loader-store.d.ts +0 -18
  695. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  696. package/dist/server/fetchable-loader-store.js +0 -18
  697. package/dist/server/fetchable-loader-store.js.map +0 -1
  698. package/dist/server/handle-store.d.ts +0 -85
  699. package/dist/server/handle-store.d.ts.map +0 -1
  700. package/dist/server/handle-store.js +0 -142
  701. package/dist/server/handle-store.js.map +0 -1
  702. package/dist/server/loader-registry.d.ts +0 -55
  703. package/dist/server/loader-registry.d.ts.map +0 -1
  704. package/dist/server/loader-registry.js +0 -132
  705. package/dist/server/loader-registry.js.map +0 -1
  706. package/dist/server/request-context.d.ts +0 -226
  707. package/dist/server/request-context.d.ts.map +0 -1
  708. package/dist/server/request-context.js +0 -290
  709. package/dist/server/request-context.js.map +0 -1
  710. package/dist/server/root-layout.d.ts +0 -4
  711. package/dist/server/root-layout.d.ts.map +0 -1
  712. package/dist/server/root-layout.js +0 -5
  713. package/dist/server/root-layout.js.map +0 -1
  714. package/dist/server.d.ts +0 -15
  715. package/dist/server.d.ts.map +0 -1
  716. package/dist/server.js +0 -20
  717. package/dist/server.js.map +0 -1
  718. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  719. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  720. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  721. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  722. package/dist/ssr/index.d.ts +0 -98
  723. package/dist/ssr/index.d.ts.map +0 -1
  724. package/dist/ssr/index.js +0 -158
  725. package/dist/ssr/index.js.map +0 -1
  726. package/dist/static-handler.d.ts +0 -50
  727. package/dist/static-handler.d.ts.map +0 -1
  728. package/dist/static-handler.gen.d.ts +0 -5
  729. package/dist/static-handler.gen.d.ts.map +0 -1
  730. package/dist/static-handler.gen.js +0 -5
  731. package/dist/static-handler.gen.js.map +0 -1
  732. package/dist/static-handler.js +0 -29
  733. package/dist/static-handler.js.map +0 -1
  734. package/dist/theme/ThemeProvider.d.ts +0 -20
  735. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  736. package/dist/theme/ThemeProvider.js +0 -240
  737. package/dist/theme/ThemeProvider.js.map +0 -1
  738. package/dist/theme/ThemeScript.d.ts +0 -48
  739. package/dist/theme/ThemeScript.d.ts.map +0 -1
  740. package/dist/theme/ThemeScript.js +0 -13
  741. package/dist/theme/ThemeScript.js.map +0 -1
  742. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  743. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  744. package/dist/theme/__tests__/theme.test.js +0 -103
  745. package/dist/theme/__tests__/theme.test.js.map +0 -1
  746. package/dist/theme/constants.d.ts +0 -29
  747. package/dist/theme/constants.d.ts.map +0 -1
  748. package/dist/theme/constants.js +0 -48
  749. package/dist/theme/constants.js.map +0 -1
  750. package/dist/theme/index.d.ts +0 -31
  751. package/dist/theme/index.d.ts.map +0 -1
  752. package/dist/theme/index.js +0 -36
  753. package/dist/theme/index.js.map +0 -1
  754. package/dist/theme/theme-context.d.ts +0 -40
  755. package/dist/theme/theme-context.d.ts.map +0 -1
  756. package/dist/theme/theme-context.js +0 -60
  757. package/dist/theme/theme-context.js.map +0 -1
  758. package/dist/theme/theme-script.d.ts +0 -27
  759. package/dist/theme/theme-script.d.ts.map +0 -1
  760. package/dist/theme/theme-script.js +0 -147
  761. package/dist/theme/theme-script.js.map +0 -1
  762. package/dist/theme/types.d.ts +0 -163
  763. package/dist/theme/types.d.ts.map +0 -1
  764. package/dist/theme/types.js +0 -11
  765. package/dist/theme/types.js.map +0 -1
  766. package/dist/theme/use-theme.d.ts +0 -12
  767. package/dist/theme/use-theme.d.ts.map +0 -1
  768. package/dist/theme/use-theme.js +0 -40
  769. package/dist/theme/use-theme.js.map +0 -1
  770. package/dist/types.d.ts +0 -1479
  771. package/dist/types.d.ts.map +0 -1
  772. package/dist/types.js +0 -10
  773. package/dist/types.js.map +0 -1
  774. package/dist/urls.d.ts +0 -441
  775. package/dist/urls.d.ts.map +0 -1
  776. package/dist/urls.gen.d.ts +0 -8
  777. package/dist/urls.gen.d.ts.map +0 -1
  778. package/dist/urls.gen.js +0 -8
  779. package/dist/urls.gen.js.map +0 -1
  780. package/dist/urls.js +0 -443
  781. package/dist/urls.js.map +0 -1
  782. package/dist/use-loader.d.ts +0 -127
  783. package/dist/use-loader.d.ts.map +0 -1
  784. package/dist/use-loader.js +0 -237
  785. package/dist/use-loader.js.map +0 -1
  786. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  787. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  788. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  789. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  790. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  791. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  792. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  793. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  794. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  795. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  796. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  797. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  798. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  799. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  800. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  801. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  802. package/dist/vite/ast-handler-extract.d.ts +0 -49
  803. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  804. package/dist/vite/ast-handler-extract.js +0 -249
  805. package/dist/vite/ast-handler-extract.js.map +0 -1
  806. package/dist/vite/expose-action-id.d.ts +0 -19
  807. package/dist/vite/expose-action-id.d.ts.map +0 -1
  808. package/dist/vite/expose-action-id.js +0 -250
  809. package/dist/vite/expose-action-id.js.map +0 -1
  810. package/dist/vite/expose-id-utils.d.ts +0 -69
  811. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  812. package/dist/vite/expose-id-utils.js +0 -289
  813. package/dist/vite/expose-id-utils.js.map +0 -1
  814. package/dist/vite/expose-internal-ids.d.ts +0 -22
  815. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  816. package/dist/vite/expose-internal-ids.js +0 -886
  817. package/dist/vite/expose-internal-ids.js.map +0 -1
  818. package/dist/vite/index.d.ts +0 -149
  819. package/dist/vite/index.d.ts.map +0 -1
  820. package/dist/vite/index.js.bak +0 -5448
  821. package/dist/vite/index.js.map +0 -1
  822. package/dist/vite/index.named-routes.gen.ts +0 -103
  823. package/dist/vite/package-resolution.d.ts +0 -43
  824. package/dist/vite/package-resolution.d.ts.map +0 -1
  825. package/dist/vite/package-resolution.js +0 -112
  826. package/dist/vite/package-resolution.js.map +0 -1
  827. package/dist/vite/virtual-entries.d.ts +0 -25
  828. package/dist/vite/virtual-entries.d.ts.map +0 -1
  829. package/dist/vite/virtual-entries.js +0 -110
  830. package/dist/vite/virtual-entries.js.map +0 -1
@@ -36,6 +36,13 @@
36
36
 
37
37
  export interface LoaderEntry<T = unknown> {
38
38
  readonly value: T | undefined;
39
+ /**
40
+ * Whether a load has committed a value to this bucket. Distinguishes a
41
+ * committed `null`/`undefined` result from "never loaded", so a loader that
42
+ * resolves to a falsy value is not mistaken for an empty bucket and is not
43
+ * overridden by the server-seeded context value.
44
+ */
45
+ readonly hasValue: boolean;
39
46
  readonly error: Error | null;
40
47
  readonly isLoading: boolean;
41
48
  /** Identifies the request that produced this snapshot. 0 means "no request". */
@@ -44,6 +51,7 @@ export interface LoaderEntry<T = unknown> {
44
51
 
45
52
  const EMPTY_SNAPSHOT: LoaderEntry = Object.freeze({
46
53
  value: undefined,
54
+ hasValue: false,
47
55
  error: null,
48
56
  isLoading: false,
49
57
  requestId: 0,
@@ -67,14 +75,15 @@ export interface SubscribeOptions {
67
75
  */
68
76
  ephemeral?: boolean;
69
77
  /**
70
- * Cross-loader refresh group name. Tags this bucket so `refreshGroup(name)`
71
- * can refresh it alongside buckets of other loaders. Group membership follows
72
- * subscriber presence: a bucket leaves its group when its last subscriber
73
- * unsubscribes.
78
+ * Cross-loader refresh group name(s). Tags this bucket so `refreshGroups(name)`
79
+ * can refresh it alongside buckets of other loaders. A bucket may be tagged
80
+ * with several group names at once (pass an array); it is then refreshed when
81
+ * ANY of its groups is refreshed. Group membership follows subscriber presence:
82
+ * a bucket leaves a group when that group's last subscriber unsubscribes.
74
83
  */
75
- group?: string;
84
+ group?: string | string[];
76
85
  /**
77
- * Plain-GET refresh thunk used by `refreshGroup`. Provided alongside `group`.
86
+ * Plain-GET refresh thunk used by `refreshGroups`. Provided alongside `group`.
78
87
  * Refreshes this bucket in place (no params/body) and rejects on failure.
79
88
  */
80
89
  refetch?: () => Promise<void>;
@@ -102,20 +111,31 @@ interface InternalEntry {
102
111
  /**
103
112
  * Cross-loader refresh groups this bucket belongs to, mapped to the number of
104
113
  * current subscribers that requested each group. A bucket can be in several
105
- * groups at once (different subscribers may tag the same shared bucket with
106
- * different group names); refcounting keeps membership independent of
107
- * subscribe/unsubscribe order.
114
+ * groups at once (one read tagged with multiple names, or different subscribers
115
+ * tagging the same shared bucket with different names); refcounting keeps
116
+ * membership independent of subscribe/unsubscribe order.
108
117
  */
109
118
  groups: Map<string, number>;
110
- /** Plain-GET refresh thunk for `refreshGroup`, set while in any group. */
119
+ /** Plain-GET refresh thunk for `refreshGroups`, set while in any group. */
111
120
  refetch: (() => Promise<void>) | undefined;
112
121
  }
113
122
 
123
+ /**
124
+ * Normalize a group tag option (`undefined | string | string[]`) to a deduped
125
+ * list of names. Deduping keeps a single subscriber from being counted more than
126
+ * once in one group when the caller passes a repeated name.
127
+ */
128
+ function normalizeGroups(group: string | string[] | undefined): string[] {
129
+ if (group === undefined) return [];
130
+ if (typeof group === "string") return [group];
131
+ return [...new Set(group)];
132
+ }
133
+
114
134
  export class LoaderStore {
115
135
  private readonly entries = new Map<string, InternalEntry>();
116
136
  /** loader.$$id -> set of bucket keys, so clearFamily() can reach every bucket. */
117
137
  private readonly families = new Map<string, Set<string>>();
118
- /** refresh group name -> set of bucket keys, for refreshGroup(). */
138
+ /** refresh group name -> set of bucket keys, for refreshGroups(). */
119
139
  private readonly groups = new Map<string, Set<string>>();
120
140
 
121
141
  private getOrCreate(bucketKey: string): InternalEntry {
@@ -163,8 +183,11 @@ export class LoaderStore {
163
183
  e.loaderId = loaderId;
164
184
  this.registerFamily(loaderId, bucketKey);
165
185
  if (options?.ephemeral !== true) e.sticky = true;
166
- const group = options?.group;
167
- if (group !== undefined) {
186
+ // Normalize the group tag(s) to a deduped list so one subscriber is counted
187
+ // once per distinct group, and subscribe/unsubscribe stay symmetric (the
188
+ // same list drives both addToGroup and releaseGroup).
189
+ const groups = normalizeGroups(options?.group);
190
+ for (const group of groups) {
168
191
  this.addToGroup(group, bucketKey, e, options?.refetch);
169
192
  }
170
193
  // A fresh subscriber means the bucket is wanted again: cancel any pending
@@ -174,11 +197,11 @@ export class LoaderStore {
174
197
  e.listeners.add(cb);
175
198
  return () => {
176
199
  e.listeners.delete(cb);
177
- // Group membership is refcounted per subscriber so refreshGroup() never
200
+ // Group membership is refcounted per subscriber so refreshGroups() never
178
201
  // fetches for an unmounted reader, and a bucket shared by subscribers in
179
202
  // different groups stays in each group until ALL of that group's
180
203
  // subscribers have left (order-independent).
181
- if (group !== undefined) this.releaseGroup(group, bucketKey, e);
204
+ for (const group of groups) this.releaseGroup(group, bucketKey, e);
182
205
  this.maybeScheduleRefcountClear(bucketKey, e);
183
206
  };
184
207
  }
@@ -232,17 +255,27 @@ export class LoaderStore {
232
255
  }
233
256
 
234
257
  /**
235
- * Refresh every currently-mounted bucket in a cross-loader refresh group with
236
- * a plain GET (no params/body). Buckets are deduped by key, so multiple reads
237
- * of one bucket trigger a single fetch. Resolves when all refreshes settle;
238
- * rejects with an `AggregateError` of the failures if any member fails — each
239
- * failing member also records its error on its own snapshot.
258
+ * Refresh every currently-mounted bucket tagged with ANY of the given group
259
+ * names, with a plain GET (no params/body). Accepts a single name or an array
260
+ * of names. A bucket that belongs to more than one of the named groups is
261
+ * refreshed exactly once (members are unioned and deduped by bucket key), as
262
+ * are multiple reads of one bucket. Resolves when all refreshes settle; rejects
263
+ * with an `AggregateError` of the failures if any member fails — each failing
264
+ * member also records its error on its own snapshot.
240
265
  */
241
- async refreshGroup(group: string): Promise<void> {
242
- const members = this.groups.get(group);
243
- if (!members || members.size === 0) return;
266
+ async refreshGroups(groups: string | string[]): Promise<void> {
267
+ const names = typeof groups === "string" ? [groups] : groups;
268
+ // Union the member buckets across every named group, deduped by key, so a
269
+ // bucket tagged into two of the requested groups is fetched a single time.
270
+ const buckets = new Set<string>();
271
+ for (const name of names) {
272
+ const members = this.groups.get(name);
273
+ if (!members) continue;
274
+ for (const bucketKey of members) buckets.add(bucketKey);
275
+ }
276
+ if (buckets.size === 0) return;
244
277
  const thunks: Array<() => Promise<void>> = [];
245
- for (const bucketKey of members) {
278
+ for (const bucketKey of buckets) {
246
279
  const e = this.entries.get(bucketKey);
247
280
  if (!e || e.listeners.size === 0 || !e.refetch) continue;
248
281
  thunks.push(e.refetch);
@@ -253,9 +286,10 @@ export class LoaderStore {
253
286
  .filter((r): r is PromiseRejectedResult => r.status === "rejected")
254
287
  .map((r) => r.reason);
255
288
  if (reasons.length > 0) {
289
+ const label = names.map((n) => `"${n}"`).join(", ");
256
290
  throw new AggregateError(
257
291
  reasons,
258
- `refreshGroup("${group}") had ${reasons.length} failure(s)`,
292
+ `refreshGroups(${label}) had ${reasons.length} failure(s)`,
259
293
  );
260
294
  }
261
295
  }
@@ -346,6 +380,7 @@ export class LoaderStore {
346
380
  if (e.snapshot.isLoading && e.snapshot.error === null) return;
347
381
  e.snapshot = Object.freeze({
348
382
  value: e.snapshot.value,
383
+ hasValue: e.snapshot.hasValue,
349
384
  error: null,
350
385
  isLoading: true,
351
386
  requestId,
@@ -363,6 +398,7 @@ export class LoaderStore {
363
398
  if (!e || requestId !== e.latestRequestId) return;
364
399
  e.snapshot = Object.freeze({
365
400
  value,
401
+ hasValue: true,
366
402
  error: null,
367
403
  isLoading: false,
368
404
  requestId,
@@ -381,6 +417,7 @@ export class LoaderStore {
381
417
  if (!e || requestId !== e.latestRequestId) return;
382
418
  e.snapshot = Object.freeze({
383
419
  value: e.snapshot.value,
420
+ hasValue: e.snapshot.hasValue,
384
421
  error,
385
422
  isLoading: false,
386
423
  requestId,
package/src/loader.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rsc-router/loader (client version)
2
+ * @rangojs/router/loader (client version)
3
3
  *
4
4
  * Client-only stub for createLoader. Returns a minimal loader definition
5
5
  * ({ __brand, $$id }) that can be passed to hooks like useLoader.
@@ -38,10 +38,6 @@ export function createLoader<T>(
38
38
 
39
39
  // Implementation - client stub that just returns the loader definition
40
40
  // The $$id parameter is injected by Vite plugin, not user-provided
41
- //
42
- // NOTE: For export-only loader files, the Vite plugin replaces the entire
43
- // file with object literals (bypassing this function). This function only
44
- // runs when loaders are in mixed files (not export-only).
45
41
  export function createLoader<T>(
46
42
  _fn: LoaderFn<T, Record<string, string | undefined>, any>,
47
43
  _fetchable?: true | FetchableLoaderOptions,
@@ -449,10 +449,19 @@ export type RouteHelpers<T extends RouteDefinition, TEnv> = {
449
449
  ): CacheItem;
450
450
  };
451
451
  /**
452
- * Attach a ViewTransition boundary to the current segment or a group of routes
453
- *
454
- * Wraps segment content with React's `<ViewTransition>` component.
455
- * Only takes effect when React experimental is used (no-op on stable React).
452
+ * Attach a ViewTransition boundary to the current segment or a group of routes,
453
+ * and opt the route into same-route stale-while-revalidate navigation.
454
+ *
455
+ * Two effects, both opt-in via this helper:
456
+ * - Same-route navigation (same route, different params, e.g. /product/1 ->
457
+ * /product/2) reconciles the route subtree instead of remounting it, so the
458
+ * previous content is held while the new loader resolves rather than flashing
459
+ * the route's loading() skeleton. This works on ALL React versions (it is
460
+ * plain startTransition + Suspense; see segment-system.tsx inTransitionScope).
461
+ * - On React experimental, the segment content is additionally wrapped in
462
+ * `<ViewTransition>`, so the held same-route swap animates (update/share
463
+ * morph) and cross-route swaps animate exit/enter. The animation layer is a
464
+ * no-op on stable React; the content-hold is not.
456
465
  *
457
466
  * ```typescript
458
467
  * // Attach to a single route
@@ -24,7 +24,10 @@ import { isHandle, collectHandleData, type Handle } from "../handle.js";
24
24
  import { buildHandleSnapshot } from "../server/handle-store.js";
25
25
  import { getFetchableLoader } from "../server/fetchable-loader-store.js";
26
26
  import { _getRequestContext } from "../server/request-context.js";
27
- import { isInsideLoaderScope } from "../server/context.js";
27
+ import {
28
+ isInsideLoaderScope,
29
+ runInsideLoaderBodyScope,
30
+ } from "../server/context.js";
28
31
  import { debugLog } from "./logging.js";
29
32
 
30
33
  /**
@@ -353,8 +356,19 @@ function createLoaderExecutor<TEnv>(
353
356
  };
354
357
 
355
358
  const doneLoader = track(`loader:${loader.$$id}`, 2);
359
+ // Run the loader body inside loader scope so request-scoped reads
360
+ // (cookies()/headers() and non-cacheable ctx.get) are exempt from the
361
+ // cache-purity guards: loaders always run fresh, so their reads never leak
362
+ // into a cached segment. DSL loaders are already wrapped by fresh.ts; this
363
+ // also covers handler-invoked loaders (ctx.use(Loader) from a handler),
364
+ // which otherwise execute in the caller's cache scope and would wrongly
365
+ // throw. rendered() gating uses the captured isDslLoader (above), so this
366
+ // does not grant rendered() to handler-invoked loaders. Uses a body-only
367
+ // scope, so isInsideLoaderScope() / barrier / deadlock gating is unchanged.
356
368
  const promise = Promise.resolve(
357
- loaderFn(loaderCtx as LoaderContext<any, TEnv>),
369
+ runInsideLoaderBodyScope(() =>
370
+ loaderFn(loaderCtx as LoaderContext<any, TEnv>),
371
+ ),
358
372
  ).finally(() => {
359
373
  pendingLoaders.delete(loader.$$id);
360
374
  doneLoader();
@@ -282,6 +282,38 @@ async function* yieldFromStore<TEnv>(
282
282
  }
283
283
  }
284
284
 
285
+ /**
286
+ * Look up a prerendered (build-time cached) entry for the current route and, on
287
+ * a hit, yield its segments. Returns true when an entry was served (the caller
288
+ * should stop the pipeline) and false on a miss. Intercept navigations consult
289
+ * only the intercept-specific entry (`paramHash + "/i"`); a miss there falls
290
+ * through to the normal pipeline so intercept-resolution can run. Callers must
291
+ * guard on `prerenderStoreInstance` after `ensurePrerenderDeps()`.
292
+ */
293
+ async function* tryPrerenderLookup<TEnv>(
294
+ ctx: MatchContext<TEnv>,
295
+ state: MatchPipelineState,
296
+ pipelineStart: number,
297
+ handleStoreRef?: HandleStore,
298
+ ): AsyncGenerator<ResolvedSegment, boolean> {
299
+ const paramHash = _hashParams!(ctx.matched.params);
300
+ const isPassthroughPrerenderRoute = ctx.entries.some(
301
+ (entry) => entry.type === "route" && entry.isPassthrough === true,
302
+ );
303
+ const lookupHash = ctx.isIntercept ? paramHash + "/i" : paramHash;
304
+ const entry = await prerenderStoreInstance!.get(
305
+ ctx.matched.routeKey,
306
+ lookupHash,
307
+ {
308
+ pathname: ctx.pathname,
309
+ isPassthroughRoute: isPassthroughPrerenderRoute,
310
+ },
311
+ );
312
+ if (!entry) return false;
313
+ yield* yieldFromStore(entry, ctx, state, pipelineStart, handleStoreRef);
314
+ return true;
315
+ }
316
+
285
317
  /**
286
318
  * Async generator middleware type
287
319
  */
@@ -334,54 +366,13 @@ export function withCacheLookup<TEnv>(
334
366
  if (!ctx.isAction && !isHmr && ctx.matched.pr) {
335
367
  await ensurePrerenderDeps();
336
368
  if (prerenderStoreInstance) {
337
- const paramHash = _hashParams!(ctx.matched.params);
338
- const isPassthroughPrerenderRoute = ctx.entries.some(
339
- (entry) => entry.type === "route" && entry.isPassthrough === true,
369
+ const served = yield* tryPrerenderLookup(
370
+ ctx,
371
+ state,
372
+ pipelineStart,
373
+ handleStoreRef,
340
374
  );
341
-
342
- if (ctx.isIntercept) {
343
- // Intercept navigation: try intercept-specific prerender entry
344
- const entry = await prerenderStoreInstance.get(
345
- ctx.matched.routeKey,
346
- paramHash + "/i",
347
- {
348
- pathname: ctx.pathname,
349
- isPassthroughRoute: isPassthroughPrerenderRoute,
350
- },
351
- );
352
- if (entry) {
353
- yield* yieldFromStore(
354
- entry,
355
- ctx,
356
- state,
357
- pipelineStart,
358
- handleStoreRef,
359
- );
360
- return;
361
- }
362
- // No intercept prerender -- fall through to normal pipeline
363
- // (skip non-intercept prerender to let intercept-resolution run)
364
- } else {
365
- // Normal navigation: existing behavior
366
- const entry = await prerenderStoreInstance.get(
367
- ctx.matched.routeKey,
368
- paramHash,
369
- {
370
- pathname: ctx.pathname,
371
- isPassthroughRoute: isPassthroughPrerenderRoute,
372
- },
373
- );
374
- if (entry) {
375
- yield* yieldFromStore(
376
- entry,
377
- ctx,
378
- state,
379
- pipelineStart,
380
- handleStoreRef,
381
- );
382
- return;
383
- }
384
- }
375
+ if (served) return;
385
376
  }
386
377
  }
387
378
 
@@ -404,51 +395,13 @@ export function withCacheLookup<TEnv>(
404
395
  if (hasStatic) {
405
396
  await ensurePrerenderDeps();
406
397
  if (prerenderStoreInstance) {
407
- const paramHash = _hashParams!(ctx.matched.params);
408
- const isPassthroughPrerenderRoute = ctx.entries.some(
409
- (entry) => entry.type === "route" && entry.isPassthrough === true,
398
+ const served = yield* tryPrerenderLookup(
399
+ ctx,
400
+ state,
401
+ pipelineStart,
402
+ handleStoreRef,
410
403
  );
411
-
412
- if (ctx.isIntercept) {
413
- const entry = await prerenderStoreInstance.get(
414
- ctx.matched.routeKey,
415
- paramHash + "/i",
416
- {
417
- pathname: ctx.pathname,
418
- isPassthroughRoute: isPassthroughPrerenderRoute,
419
- },
420
- );
421
- if (entry) {
422
- yield* yieldFromStore(
423
- entry,
424
- ctx,
425
- state,
426
- pipelineStart,
427
- handleStoreRef,
428
- );
429
- return;
430
- }
431
- // No intercept prerender -- fall through to normal pipeline
432
- } else {
433
- const entry = await prerenderStoreInstance.get(
434
- ctx.matched.routeKey,
435
- paramHash,
436
- {
437
- pathname: ctx.pathname,
438
- isPassthroughRoute: isPassthroughPrerenderRoute,
439
- },
440
- );
441
- if (entry) {
442
- yield* yieldFromStore(
443
- entry,
444
- ctx,
445
- state,
446
- pipelineStart,
447
- handleStoreRef,
448
- );
449
- return;
450
- }
451
- }
404
+ if (served) return;
452
405
  }
453
406
  }
454
407
  }
@@ -169,10 +169,11 @@ export function withCacheStore<TEnv>(
169
169
  // skip (client already had them). Segments where the handler intentionally
170
170
  // returned null are not revalidation skips — re-rendering them will still
171
171
  // produce null, so proactive caching would be wasted work.
172
- const clientIdSet = new Set(ctx.clientSegmentIds);
173
172
  const hasNullComponents = allSegmentsToCache.some(
174
173
  (s) =>
175
- s.component === null && s.type !== "loader" && clientIdSet.has(s.id),
174
+ s.component === null &&
175
+ s.type !== "loader" &&
176
+ ctx.clientSegmentSet.has(s.id),
176
177
  );
177
178
 
178
179
  const requestCtx = getRequestContext();
@@ -216,6 +216,25 @@ export async function renderSegments(
216
216
  }
217
217
  // Separate segments by type, passing intercept segments for explicit injection
218
218
  const tree = segmentTreeWalk(normalizedSegments, normalizedInterceptSegments);
219
+
220
+ // A route is "in a transition scope" when its own segment OR any layout in
221
+ // its matched chain declares transition(). Both transition() forms land here:
222
+ // the per-route item form sets transition on the route entry, and the block
223
+ // wrapper form sets it on a transparent ancestor layout (dsl-helpers.ts). When
224
+ // in scope, the route and its route-owned layouts use param-agnostic keys so a
225
+ // same-route navigation reconciles (holds content) instead of remounting. The
226
+ // value is a static property of the route's position in the tree, so it is the
227
+ // same on every render of that route (SSR, navigation, action) — the keys
228
+ // never drift. Cross-route navigation still remounts: different routes have
229
+ // different segment ids regardless of transition scope.
230
+ const inTransitionScope = normalizedSegments.some(
231
+ (s) =>
232
+ s.transition != null &&
233
+ (s.type === "layout" ||
234
+ s.type === "route" ||
235
+ s.type === "error" ||
236
+ s.type === "notFound"),
237
+ );
219
238
  // Render content segments as siblings
220
239
  let content: ReactNode = null;
221
240
  for (const node of tree) {
@@ -228,17 +247,31 @@ export async function renderSegments(
228
247
  );
229
248
  const { component, id, params, loading } = node.segment;
230
249
 
231
- // Only include params in key for segments that belong to the route
232
- // - Routes: always include params (they render param-specific content)
233
- // - Error/notFound segments: always include params (they replace failed route content)
234
- // - Route's layouts (orphans): include params (children of parameterized route)
235
- // - Parent chain layouts: exclude params (shared across routes, param-agnostic)
236
- // This prevents unnecessary unmounting when params change
250
+ // Param-agnostic keys are opt-in via the transition() DSL (see
251
+ // inTransitionScope above). A route (and its route-owned layouts) inside a
252
+ // transition scope drops the param from its key, so navigating between two
253
+ // param values of the SAME route (e.g. /product/1 -> /product/2) reconciles
254
+ // the route subtree instead of remounting it. Combined with the
255
+ // startTransition wrap that shouldStartViewTransition already applies to
256
+ // transition routes (browser/partial-update.ts), the previous content stays
257
+ // on screen while the new loaders resolve (stale-while-revalidate) instead
258
+ // of flashing the loading skeleton. This works on stable React; experimental
259
+ // React adds the animated <ViewTransition> cross-fade on top.
260
+ //
261
+ // Outside a transition scope the key stays param-bearing and the route
262
+ // remounts on param change (the default: a fresh skeleton and fresh
263
+ // component state).
264
+ //
265
+ // error/notFound always keep param-bearing keys: createErrorSegment reuses
266
+ // the boundary layout's shortCode as the error segment id (router/
267
+ // error-handling.ts), so a param-agnostic error key could collide with that
268
+ // layout's key within the same render.
237
269
  const includeParams =
238
- node.segment.type === "route" ||
239
270
  node.segment.type === "error" ||
240
271
  node.segment.type === "notFound" ||
241
- (node.segment.type === "layout" && node.segment.belongsToRoute);
272
+ ((node.segment.type === "route" ||
273
+ (node.segment.type === "layout" && node.segment.belongsToRoute)) &&
274
+ !inTransitionScope);
242
275
 
243
276
  const paramStr =
244
277
  includeParams && params && Object.keys(params).length > 0
@@ -748,6 +748,17 @@ const loaderScopeALS: AsyncLocalStorage<{ active: true }> = ((
748
748
  globalThis as any
749
749
  )[LOADER_SCOPE_KEY] ??= new AsyncLocalStorage<{ active: true }>());
750
750
 
751
+ // Purity-only scope: marks that a loader FUNCTION BODY is executing, regardless
752
+ // of how the loader was invoked (DSL via runInsideLoaderScope, or handler-
753
+ // invoked via ctx.use). Consulted ONLY by isInsideCacheScope() to exempt
754
+ // request-scoped reads. It deliberately does NOT affect isInsideLoaderScope(),
755
+ // so rendered()/barrier/deadlock gating (which must distinguish DSL from
756
+ // handler-invoked loaders) is unchanged.
757
+ const LOADER_BODY_SCOPE_KEY = Symbol.for("rangojs-router:loader-body-scope");
758
+ const loaderBodyScopeALS: AsyncLocalStorage<{ active: true }> = ((
759
+ globalThis as any
760
+ )[LOADER_BODY_SCOPE_KEY] ??= new AsyncLocalStorage<{ active: true }>());
761
+
751
762
  /**
752
763
  * Check if the current execution is inside a cache() DSL boundary.
753
764
  * Returns false inside loader execution — loaders are always fresh
@@ -759,6 +770,10 @@ export function isInsideCacheScope(): boolean {
759
770
  // function re-executes on every request. Skip the guard when running
760
771
  // inside a loader.
761
772
  if (loaderScopeALS.getStore()?.active) return false;
773
+ // Also exempt handler-invoked loaders: their bodies run in a loader-body
774
+ // scope (not the DSL loader scope above), so request-scoped reads inside any
775
+ // loader — however invoked — are safe (loaders always re-run fresh).
776
+ if (loaderBodyScopeALS.getStore()?.active) return false;
762
777
  return true;
763
778
  }
764
779
 
@@ -779,3 +794,14 @@ export function isInsideLoaderScope(): boolean {
779
794
  export function runInsideLoaderScope<T>(fn: () => T): T {
780
795
  return loaderScopeALS.run({ active: true }, fn);
781
796
  }
797
+
798
+ /**
799
+ * Run `fn` inside a loader BODY scope. Marks loader-function execution for the
800
+ * cache-purity guard only (isInsideCacheScope), WITHOUT affecting
801
+ * isInsideLoaderScope()/rendered() gating. Applied to every loader body (DSL
802
+ * and handler-invoked via ctx.use) so request-scoped reads inside a loader
803
+ * never trip the cache-scope guards — loaders always run fresh.
804
+ */
805
+ export function runInsideLoaderBodyScope<T>(fn: () => T): T {
806
+ return loaderBodyScopeALS.run({ active: true }, fn);
807
+ }
@@ -9,6 +9,7 @@
9
9
 
10
10
  import type { CookieOptions } from "../router/middleware-types.js";
11
11
  import { getRequestContext } from "./request-context.js";
12
+ import { isInsideCacheScope } from "./context.js";
12
13
  import { INSIDE_CACHE_EXEC } from "../cache/taint.js";
13
14
 
14
15
  /**
@@ -84,10 +85,23 @@ export interface ReadonlyHeaders {
84
85
  type HeadersIterator<T> = IterableIterator<T>;
85
86
 
86
87
  /**
87
- * Throw if called inside a "use cache" function.
88
- * Reading request-scoped data (cookies, headers) inside a cached function
89
- * produces results that vary per request but the cache key does not include
90
- * those values, leading to one user's data being served to another.
88
+ * Throw if called inside a cache boundary — either a "use cache" function
89
+ * (`INSIDE_CACHE_EXEC` stamped on ctx by the cache runtime) or a `cache()`
90
+ * DSL boundary (`isInsideCacheScope()` the render-store flag set while
91
+ * resolving a `type: "cache"` route entry).
92
+ *
93
+ * Reading request-scoped data (cookies, headers) inside a cached scope
94
+ * produces per-request values that are NOT reflected in the cache key, so
95
+ * they would be frozen into the shared cache entry and served to the wrong
96
+ * users. This is the same hazard for both scopes: a `cache()` boundary caches
97
+ * everything except loaders (it is the document-level "PPR shell"), so a read
98
+ * here is baked into the shell exactly like a `"use cache"` return value is
99
+ * baked into its cache entry.
100
+ *
101
+ * `isInsideCacheScope()` returns false inside loaders (loaders always run
102
+ * fresh on every request, even on a cache hit), so reading cookies()/headers()
103
+ * from a loader is allowed — loaders are the dynamic "holes" of a cached
104
+ * document.
91
105
  */
92
106
  function assertNotInsideCacheContext(ctx: unknown, fnName: string): void {
93
107
  if (
@@ -106,6 +120,16 @@ function assertNotInsideCacheContext(ctx: unknown, fnName: string): void {
106
120
  ` const data = await getCachedData(locale); // locale is now in the cache key`,
107
121
  );
108
122
  }
123
+ if (isInsideCacheScope()) {
124
+ throw new Error(
125
+ `${fnName}() cannot be called inside a cache() boundary. ` +
126
+ `A cache() scope caches everything except loaders, so request-scoped ` +
127
+ `data (cookies, headers) read here would be frozen into the shared ` +
128
+ `cached shell and served to other users. Read it inside a loader ` +
129
+ `instead — loaders always run fresh on every request, even on a cache hit:\n\n` +
130
+ ` loader("user", () => getUser(cookies().get("session")?.value));`,
131
+ );
132
+ }
109
133
  }
110
134
 
111
135
  const HEADERS_MUTATION_METHODS = new Set(["set", "append", "delete"]);
@@ -567,8 +567,11 @@ export type ShouldRevalidateFn<TParams = GenericParams, TEnv = any> = (args: {
567
567
 
568
568
  // ── Segment metadata (which segment is being evaluated) ──────────────
569
569
 
570
- /** The type of segment being revalidated. */
571
- segmentType: "layout" | "route" | "parallel";
570
+ /**
571
+ * The type of segment being revalidated. `"loader"` is passed to revalidate
572
+ * functions attached to a `loader(Fn, () => [revalidate(...)])` registration.
573
+ */
574
+ segmentType: "layout" | "route" | "parallel" | "loader";
572
575
  /** Layout name (e.g., `"root"`, `"shop"`, `"auth"`). Only set for layout segments. */
573
576
  layoutName?: string;
574
577
  /** Slot name (e.g., `"@sidebar"`, `"@modal"`). Only set for parallel segments. */