@rangojs/router 0.0.0-experimental.2 → 0.0.0-experimental.204030a9

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 (1195) hide show
  1. package/AGENTS.md +9 -0
  2. package/README.md +1037 -4
  3. package/dist/__internal.d.ts +83 -0
  4. package/dist/__internal.d.ts.map +1 -0
  5. package/dist/__internal.js +19 -0
  6. package/dist/__internal.js.map +1 -0
  7. package/dist/__mocks__/version.d.ts +7 -0
  8. package/dist/__mocks__/version.d.ts.map +1 -0
  9. package/{src/__mocks__/version.ts → dist/__mocks__/version.js} +1 -0
  10. package/dist/__mocks__/version.js.map +1 -0
  11. package/dist/__tests__/client-href.test.d.ts +2 -0
  12. package/dist/__tests__/client-href.test.d.ts.map +1 -0
  13. package/dist/__tests__/client-href.test.js +74 -0
  14. package/dist/__tests__/client-href.test.js.map +1 -0
  15. package/dist/__tests__/component-utils.test.d.ts +2 -0
  16. package/dist/__tests__/component-utils.test.d.ts.map +1 -0
  17. package/dist/__tests__/component-utils.test.js +51 -0
  18. package/dist/__tests__/component-utils.test.js.map +1 -0
  19. package/dist/__tests__/event-controller.test.d.ts +2 -0
  20. package/dist/__tests__/event-controller.test.d.ts.map +1 -0
  21. package/dist/__tests__/event-controller.test.js +538 -0
  22. package/dist/__tests__/event-controller.test.js.map +1 -0
  23. package/dist/__tests__/helpers/route-tree.d.ts +118 -0
  24. package/dist/__tests__/helpers/route-tree.d.ts.map +1 -0
  25. package/dist/__tests__/helpers/route-tree.js +374 -0
  26. package/dist/__tests__/helpers/route-tree.js.map +1 -0
  27. package/dist/__tests__/match-result.test.d.ts +2 -0
  28. package/dist/__tests__/match-result.test.d.ts.map +1 -0
  29. package/dist/__tests__/match-result.test.js +154 -0
  30. package/dist/__tests__/match-result.test.js.map +1 -0
  31. package/dist/__tests__/navigation-store.test.d.ts +2 -0
  32. package/dist/__tests__/navigation-store.test.d.ts.map +1 -0
  33. package/dist/__tests__/navigation-store.test.js +440 -0
  34. package/dist/__tests__/navigation-store.test.js.map +1 -0
  35. package/dist/__tests__/partial-update.test.d.ts +2 -0
  36. package/dist/__tests__/partial-update.test.d.ts.map +1 -0
  37. package/dist/__tests__/partial-update.test.js +1009 -0
  38. package/dist/__tests__/partial-update.test.js.map +1 -0
  39. package/dist/__tests__/reverse-types.test.d.ts +8 -0
  40. package/dist/__tests__/reverse-types.test.d.ts.map +1 -0
  41. package/dist/__tests__/reverse-types.test.js +656 -0
  42. package/dist/__tests__/reverse-types.test.js.map +1 -0
  43. package/dist/__tests__/route-definition.test.d.ts +2 -0
  44. package/dist/__tests__/route-definition.test.d.ts.map +1 -0
  45. package/dist/__tests__/route-definition.test.js +55 -0
  46. package/dist/__tests__/route-definition.test.js.map +1 -0
  47. package/dist/__tests__/router-helpers.test.d.ts +2 -0
  48. package/dist/__tests__/router-helpers.test.d.ts.map +1 -0
  49. package/dist/__tests__/router-helpers.test.js +377 -0
  50. package/dist/__tests__/router-helpers.test.js.map +1 -0
  51. package/dist/__tests__/router-integration-2.test.d.ts +2 -0
  52. package/dist/__tests__/router-integration-2.test.d.ts.map +1 -0
  53. package/dist/__tests__/router-integration-2.test.js +426 -0
  54. package/dist/__tests__/router-integration-2.test.js.map +1 -0
  55. package/dist/__tests__/router-integration.test.d.ts +2 -0
  56. package/dist/__tests__/router-integration.test.d.ts.map +1 -0
  57. package/dist/__tests__/router-integration.test.js +1051 -0
  58. package/dist/__tests__/router-integration.test.js.map +1 -0
  59. package/dist/__tests__/search-params.test.d.ts +5 -0
  60. package/dist/__tests__/search-params.test.d.ts.map +1 -0
  61. package/dist/__tests__/search-params.test.js +306 -0
  62. package/dist/__tests__/search-params.test.js.map +1 -0
  63. package/dist/__tests__/segment-system.test.d.ts +2 -0
  64. package/dist/__tests__/segment-system.test.d.ts.map +1 -0
  65. package/dist/__tests__/segment-system.test.js +627 -0
  66. package/dist/__tests__/segment-system.test.js.map +1 -0
  67. package/dist/__tests__/static-handler-types.test.d.ts +8 -0
  68. package/dist/__tests__/static-handler-types.test.d.ts.map +1 -0
  69. package/dist/__tests__/static-handler-types.test.js +63 -0
  70. package/dist/__tests__/static-handler-types.test.js.map +1 -0
  71. package/dist/__tests__/urls.test.d.ts +2 -0
  72. package/dist/__tests__/urls.test.d.ts.map +1 -0
  73. package/dist/__tests__/urls.test.js +421 -0
  74. package/dist/__tests__/urls.test.js.map +1 -0
  75. package/dist/__tests__/use-mount.test.d.ts +2 -0
  76. package/dist/__tests__/use-mount.test.d.ts.map +1 -0
  77. package/dist/__tests__/use-mount.test.js +35 -0
  78. package/dist/__tests__/use-mount.test.js.map +1 -0
  79. package/dist/bin/rango.d.ts +2 -0
  80. package/dist/bin/rango.d.ts.map +1 -0
  81. package/dist/bin/rango.js +1779 -0
  82. package/dist/bin/rango.js.map +1 -0
  83. package/dist/browser/event-controller.d.ts +191 -0
  84. package/dist/browser/event-controller.d.ts.map +1 -0
  85. package/dist/browser/event-controller.js +559 -0
  86. package/dist/browser/event-controller.js.map +1 -0
  87. package/dist/browser/index.d.ts +2 -0
  88. package/dist/browser/index.d.ts.map +1 -0
  89. package/dist/browser/index.js +14 -0
  90. package/dist/browser/index.js.map +1 -0
  91. package/dist/browser/link-interceptor.d.ts +38 -0
  92. package/dist/browser/link-interceptor.d.ts.map +1 -0
  93. package/dist/browser/link-interceptor.js +99 -0
  94. package/dist/browser/link-interceptor.js.map +1 -0
  95. package/dist/browser/logging.d.ts +10 -0
  96. package/dist/browser/logging.d.ts.map +1 -0
  97. package/dist/browser/logging.js +29 -0
  98. package/dist/browser/logging.js.map +1 -0
  99. package/dist/browser/lru-cache.d.ts +17 -0
  100. package/dist/browser/lru-cache.d.ts.map +1 -0
  101. package/dist/browser/lru-cache.js +50 -0
  102. package/dist/browser/lru-cache.js.map +1 -0
  103. package/dist/browser/merge-segment-loaders.d.ts +39 -0
  104. package/dist/browser/merge-segment-loaders.d.ts.map +1 -0
  105. package/dist/browser/merge-segment-loaders.js +102 -0
  106. package/dist/browser/merge-segment-loaders.js.map +1 -0
  107. package/dist/browser/navigation-bridge.d.ts +102 -0
  108. package/dist/browser/navigation-bridge.d.ts.map +1 -0
  109. package/dist/browser/navigation-bridge.js +708 -0
  110. package/dist/browser/navigation-bridge.js.map +1 -0
  111. package/dist/browser/navigation-client.d.ts +25 -0
  112. package/dist/browser/navigation-client.d.ts.map +1 -0
  113. package/dist/browser/navigation-client.js +157 -0
  114. package/dist/browser/navigation-client.js.map +1 -0
  115. package/dist/browser/navigation-store.d.ts +101 -0
  116. package/dist/browser/navigation-store.d.ts.map +1 -0
  117. package/dist/browser/navigation-store.js +625 -0
  118. package/dist/browser/navigation-store.js.map +1 -0
  119. package/dist/browser/partial-update.d.ts +75 -0
  120. package/dist/browser/partial-update.d.ts.map +1 -0
  121. package/dist/browser/partial-update.js +426 -0
  122. package/dist/browser/partial-update.js.map +1 -0
  123. package/dist/browser/react/Link.d.ts +86 -0
  124. package/dist/browser/react/Link.d.ts.map +1 -0
  125. package/dist/browser/react/Link.js +128 -0
  126. package/dist/browser/react/Link.js.map +1 -0
  127. package/dist/browser/react/NavigationProvider.d.ts +63 -0
  128. package/dist/browser/react/NavigationProvider.d.ts.map +1 -0
  129. package/dist/browser/react/NavigationProvider.js +216 -0
  130. package/dist/browser/react/NavigationProvider.js.map +1 -0
  131. package/dist/browser/react/ScrollRestoration.d.ts +75 -0
  132. package/dist/browser/react/ScrollRestoration.d.ts.map +1 -0
  133. package/dist/browser/react/ScrollRestoration.js +57 -0
  134. package/dist/browser/react/ScrollRestoration.js.map +1 -0
  135. package/dist/browser/react/context.d.ts +46 -0
  136. package/dist/browser/react/context.d.ts.map +1 -0
  137. package/dist/browser/react/context.js +10 -0
  138. package/dist/browser/react/context.js.map +1 -0
  139. package/dist/browser/react/index.d.ts +11 -0
  140. package/dist/browser/react/index.d.ts.map +1 -0
  141. package/dist/browser/react/index.js +22 -0
  142. package/dist/browser/react/index.js.map +1 -0
  143. package/dist/browser/react/location-state-shared.d.ts +63 -0
  144. package/dist/browser/react/location-state-shared.d.ts.map +1 -0
  145. package/dist/browser/react/location-state-shared.js +81 -0
  146. package/dist/browser/react/location-state-shared.js.map +1 -0
  147. package/dist/browser/react/location-state.d.ts +23 -0
  148. package/dist/browser/react/location-state.d.ts.map +1 -0
  149. package/dist/browser/react/location-state.js +29 -0
  150. package/dist/browser/react/location-state.js.map +1 -0
  151. package/dist/browser/react/mount-context.d.ts +24 -0
  152. package/dist/browser/react/mount-context.d.ts.map +1 -0
  153. package/dist/browser/react/mount-context.js +24 -0
  154. package/dist/browser/react/mount-context.js.map +1 -0
  155. package/dist/browser/react/use-action.d.ts +64 -0
  156. package/dist/browser/react/use-action.d.ts.map +1 -0
  157. package/dist/browser/react/use-action.js +134 -0
  158. package/dist/browser/react/use-action.js.map +1 -0
  159. package/dist/browser/react/use-client-cache.d.ts +41 -0
  160. package/dist/browser/react/use-client-cache.d.ts.map +1 -0
  161. package/dist/browser/react/use-client-cache.js +39 -0
  162. package/dist/browser/react/use-client-cache.js.map +1 -0
  163. package/dist/browser/react/use-handle.d.ts +31 -0
  164. package/dist/browser/react/use-handle.d.ts.map +1 -0
  165. package/dist/browser/react/use-handle.js +144 -0
  166. package/dist/browser/react/use-handle.js.map +1 -0
  167. package/dist/browser/react/use-href.d.ts +33 -0
  168. package/dist/browser/react/use-href.d.ts.map +1 -0
  169. package/dist/browser/react/use-href.js +39 -0
  170. package/dist/browser/react/use-href.js.map +1 -0
  171. package/dist/browser/react/use-link-status.d.ts +37 -0
  172. package/dist/browser/react/use-link-status.d.ts.map +1 -0
  173. package/dist/browser/react/use-link-status.js +99 -0
  174. package/dist/browser/react/use-link-status.js.map +1 -0
  175. package/dist/browser/react/use-mount.d.ts +25 -0
  176. package/dist/browser/react/use-mount.d.ts.map +1 -0
  177. package/dist/browser/react/use-mount.js +30 -0
  178. package/dist/browser/react/use-mount.js.map +1 -0
  179. package/dist/browser/react/use-navigation.d.ts +27 -0
  180. package/dist/browser/react/use-navigation.d.ts.map +1 -0
  181. package/dist/browser/react/use-navigation.js +87 -0
  182. package/dist/browser/react/use-navigation.js.map +1 -0
  183. package/dist/browser/react/use-segments.d.ts +38 -0
  184. package/dist/browser/react/use-segments.d.ts.map +1 -0
  185. package/dist/browser/react/use-segments.js +130 -0
  186. package/dist/browser/react/use-segments.js.map +1 -0
  187. package/dist/browser/request-controller.d.ts +26 -0
  188. package/dist/browser/request-controller.d.ts.map +1 -0
  189. package/dist/browser/request-controller.js +147 -0
  190. package/dist/browser/request-controller.js.map +1 -0
  191. package/dist/browser/rsc-router.d.ts +129 -0
  192. package/dist/browser/rsc-router.d.ts.map +1 -0
  193. package/dist/browser/rsc-router.js +195 -0
  194. package/dist/browser/rsc-router.js.map +1 -0
  195. package/dist/browser/scroll-restoration.d.ts +93 -0
  196. package/dist/browser/scroll-restoration.d.ts.map +1 -0
  197. package/dist/browser/scroll-restoration.js +321 -0
  198. package/dist/browser/scroll-restoration.js.map +1 -0
  199. package/dist/browser/segment-structure-assert.d.ts +17 -0
  200. package/dist/browser/segment-structure-assert.d.ts.map +1 -0
  201. package/dist/browser/segment-structure-assert.js +59 -0
  202. package/dist/browser/segment-structure-assert.js.map +1 -0
  203. package/dist/browser/server-action-bridge.d.ts +26 -0
  204. package/dist/browser/server-action-bridge.d.ts.map +1 -0
  205. package/dist/browser/server-action-bridge.js +668 -0
  206. package/dist/browser/server-action-bridge.js.map +1 -0
  207. package/dist/browser/shallow.d.ts +12 -0
  208. package/dist/browser/shallow.d.ts.map +1 -0
  209. package/dist/browser/shallow.js +34 -0
  210. package/dist/browser/shallow.js.map +1 -0
  211. package/dist/browser/types.d.ts +369 -0
  212. package/dist/browser/types.d.ts.map +1 -0
  213. package/dist/browser/types.js +2 -0
  214. package/dist/browser/types.js.map +1 -0
  215. package/dist/build/__tests__/generate-cli.test.d.ts +2 -0
  216. package/dist/build/__tests__/generate-cli.test.d.ts.map +1 -0
  217. package/dist/build/__tests__/generate-cli.test.js +237 -0
  218. package/dist/build/__tests__/generate-cli.test.js.map +1 -0
  219. package/dist/build/__tests__/generate-manifest.test.d.ts +2 -0
  220. package/dist/build/__tests__/generate-manifest.test.d.ts.map +1 -0
  221. package/dist/build/__tests__/generate-manifest.test.js +119 -0
  222. package/dist/build/__tests__/generate-manifest.test.js.map +1 -0
  223. package/dist/build/__tests__/generate-route-types.test.d.ts +2 -0
  224. package/dist/build/__tests__/generate-route-types.test.d.ts.map +1 -0
  225. package/dist/build/__tests__/generate-route-types.test.js +620 -0
  226. package/dist/build/__tests__/generate-route-types.test.js.map +1 -0
  227. package/dist/build/__tests__/per-router-manifest.test.d.ts +2 -0
  228. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +1 -0
  229. package/dist/build/__tests__/per-router-manifest.test.js +308 -0
  230. package/dist/build/__tests__/per-router-manifest.test.js.map +1 -0
  231. package/dist/build/generate-manifest.d.ts +81 -0
  232. package/dist/build/generate-manifest.d.ts.map +1 -0
  233. package/dist/build/generate-manifest.js +276 -0
  234. package/dist/build/generate-manifest.js.map +1 -0
  235. package/dist/build/generate-route-types.d.ts +115 -0
  236. package/dist/build/generate-route-types.d.ts.map +1 -0
  237. package/dist/build/generate-route-types.js +740 -0
  238. package/dist/build/generate-route-types.js.map +1 -0
  239. package/dist/build/index.d.ts +21 -0
  240. package/dist/build/index.d.ts.map +1 -0
  241. package/dist/build/index.js +21 -0
  242. package/dist/build/index.js.map +1 -0
  243. package/dist/build/route-trie.d.ts +71 -0
  244. package/dist/build/route-trie.d.ts.map +1 -0
  245. package/dist/build/route-trie.js +175 -0
  246. package/dist/build/route-trie.js.map +1 -0
  247. package/dist/cache/__tests__/cache-scope.test.d.ts +2 -0
  248. package/dist/cache/__tests__/cache-scope.test.d.ts.map +1 -0
  249. package/dist/cache/__tests__/cache-scope.test.js +208 -0
  250. package/dist/cache/__tests__/cache-scope.test.js.map +1 -0
  251. package/dist/cache/__tests__/document-cache.test.d.ts +2 -0
  252. package/dist/cache/__tests__/document-cache.test.d.ts.map +1 -0
  253. package/dist/cache/__tests__/document-cache.test.js +345 -0
  254. package/dist/cache/__tests__/document-cache.test.js.map +1 -0
  255. package/dist/cache/__tests__/memory-segment-store.test.d.ts +2 -0
  256. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +1 -0
  257. package/dist/cache/__tests__/memory-segment-store.test.js +425 -0
  258. package/dist/cache/__tests__/memory-segment-store.test.js.map +1 -0
  259. package/dist/cache/__tests__/memory-store.test.d.ts +2 -0
  260. package/dist/cache/__tests__/memory-store.test.d.ts.map +1 -0
  261. package/dist/cache/__tests__/memory-store.test.js +367 -0
  262. package/dist/cache/__tests__/memory-store.test.js.map +1 -0
  263. package/dist/cache/cache-scope.d.ts +102 -0
  264. package/dist/cache/cache-scope.d.ts.map +1 -0
  265. package/dist/cache/cache-scope.js +440 -0
  266. package/dist/cache/cache-scope.js.map +1 -0
  267. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +2 -0
  268. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +1 -0
  269. package/dist/cache/cf/__tests__/cf-cache-store.test.js +330 -0
  270. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +1 -0
  271. package/dist/cache/cf/cf-cache-store.d.ts +165 -0
  272. package/dist/cache/cf/cf-cache-store.d.ts.map +1 -0
  273. package/dist/cache/cf/cf-cache-store.js +242 -0
  274. package/dist/cache/cf/cf-cache-store.js.map +1 -0
  275. package/dist/cache/cf/index.d.ts +14 -0
  276. package/dist/cache/cf/index.d.ts.map +1 -0
  277. package/dist/cache/cf/index.js +17 -0
  278. package/dist/cache/cf/index.js.map +1 -0
  279. package/dist/cache/document-cache.d.ts +64 -0
  280. package/dist/cache/document-cache.d.ts.map +1 -0
  281. package/dist/cache/document-cache.js +228 -0
  282. package/dist/cache/document-cache.js.map +1 -0
  283. package/dist/cache/index.d.ts +19 -0
  284. package/dist/cache/index.d.ts.map +1 -0
  285. package/dist/cache/index.js +21 -0
  286. package/dist/cache/index.js.map +1 -0
  287. package/dist/cache/memory-segment-store.d.ts +110 -0
  288. package/dist/cache/memory-segment-store.d.ts.map +1 -0
  289. package/dist/cache/memory-segment-store.js +117 -0
  290. package/dist/cache/memory-segment-store.js.map +1 -0
  291. package/dist/cache/memory-store.d.ts +41 -0
  292. package/dist/cache/memory-store.d.ts.map +1 -0
  293. package/dist/cache/memory-store.js +191 -0
  294. package/dist/cache/memory-store.js.map +1 -0
  295. package/dist/cache/types.d.ts +317 -0
  296. package/dist/cache/types.d.ts.map +1 -0
  297. package/dist/cache/types.js +12 -0
  298. package/dist/cache/types.js.map +1 -0
  299. package/dist/client.d.ts +248 -0
  300. package/dist/client.d.ts.map +1 -0
  301. package/dist/client.js +367 -0
  302. package/dist/client.js.map +1 -0
  303. package/dist/client.rsc.d.ts +26 -0
  304. package/dist/client.rsc.d.ts.map +1 -0
  305. package/dist/client.rsc.js +46 -0
  306. package/dist/client.rsc.js.map +1 -0
  307. package/dist/component-utils.d.ts +36 -0
  308. package/dist/component-utils.d.ts.map +1 -0
  309. package/dist/component-utils.js +61 -0
  310. package/dist/component-utils.js.map +1 -0
  311. package/dist/components/DefaultDocument.d.ts +13 -0
  312. package/dist/components/DefaultDocument.d.ts.map +1 -0
  313. package/dist/components/DefaultDocument.js +15 -0
  314. package/dist/components/DefaultDocument.js.map +1 -0
  315. package/dist/debug.d.ts +58 -0
  316. package/dist/debug.d.ts.map +1 -0
  317. package/dist/debug.js +157 -0
  318. package/dist/debug.js.map +1 -0
  319. package/dist/default-error-boundary.d.ts +11 -0
  320. package/dist/default-error-boundary.d.ts.map +1 -0
  321. package/dist/default-error-boundary.js +45 -0
  322. package/dist/default-error-boundary.js.map +1 -0
  323. package/dist/deps/browser.d.ts +2 -0
  324. package/dist/deps/browser.d.ts.map +1 -0
  325. package/dist/deps/browser.js +3 -0
  326. package/dist/deps/browser.js.map +1 -0
  327. package/dist/deps/html-stream-client.d.ts +2 -0
  328. package/dist/deps/html-stream-client.d.ts.map +1 -0
  329. package/dist/deps/html-stream-client.js +3 -0
  330. package/dist/deps/html-stream-client.js.map +1 -0
  331. package/dist/deps/html-stream-server.d.ts +2 -0
  332. package/dist/deps/html-stream-server.d.ts.map +1 -0
  333. package/dist/deps/html-stream-server.js +3 -0
  334. package/dist/deps/html-stream-server.js.map +1 -0
  335. package/dist/deps/rsc.d.ts +2 -0
  336. package/dist/deps/rsc.d.ts.map +1 -0
  337. package/dist/deps/rsc.js +4 -0
  338. package/dist/deps/rsc.js.map +1 -0
  339. package/dist/deps/ssr.d.ts +2 -0
  340. package/dist/deps/ssr.d.ts.map +1 -0
  341. package/dist/deps/ssr.js +3 -0
  342. package/dist/deps/ssr.js.map +1 -0
  343. package/dist/errors.d.ts +174 -0
  344. package/dist/errors.d.ts.map +1 -0
  345. package/dist/errors.js +241 -0
  346. package/dist/errors.js.map +1 -0
  347. package/dist/handle.d.ts +78 -0
  348. package/dist/handle.d.ts.map +1 -0
  349. package/dist/handle.js +82 -0
  350. package/dist/handle.js.map +1 -0
  351. package/dist/handles/MetaTags.d.ts +14 -0
  352. package/dist/handles/MetaTags.d.ts.map +1 -0
  353. package/dist/handles/MetaTags.js +136 -0
  354. package/dist/handles/MetaTags.js.map +1 -0
  355. package/dist/handles/index.d.ts +6 -0
  356. package/dist/handles/index.d.ts.map +1 -0
  357. package/dist/handles/index.js +6 -0
  358. package/dist/handles/index.js.map +1 -0
  359. package/dist/handles/meta.d.ts +39 -0
  360. package/dist/handles/meta.d.ts.map +1 -0
  361. package/dist/handles/meta.js +202 -0
  362. package/dist/handles/meta.js.map +1 -0
  363. package/dist/host/__tests__/errors.test.d.ts +2 -0
  364. package/dist/host/__tests__/errors.test.d.ts.map +1 -0
  365. package/dist/host/__tests__/errors.test.js +76 -0
  366. package/dist/host/__tests__/errors.test.js.map +1 -0
  367. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +2 -0
  368. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +1 -0
  369. package/dist/host/__tests__/pattern-comprehensive.test.js +732 -0
  370. package/dist/host/__tests__/pattern-comprehensive.test.js.map +1 -0
  371. package/dist/host/__tests__/pattern-matcher.test.d.ts +2 -0
  372. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +1 -0
  373. package/dist/host/__tests__/pattern-matcher.test.js +251 -0
  374. package/dist/host/__tests__/pattern-matcher.test.js.map +1 -0
  375. package/dist/host/__tests__/router.test.d.ts +2 -0
  376. package/dist/host/__tests__/router.test.d.ts.map +1 -0
  377. package/dist/host/__tests__/router.test.js +241 -0
  378. package/dist/host/__tests__/router.test.js.map +1 -0
  379. package/dist/host/__tests__/testing.test.d.ts +2 -0
  380. package/dist/host/__tests__/testing.test.d.ts.map +1 -0
  381. package/dist/host/__tests__/testing.test.js +64 -0
  382. package/dist/host/__tests__/testing.test.js.map +1 -0
  383. package/dist/host/__tests__/utils.test.d.ts +2 -0
  384. package/dist/host/__tests__/utils.test.d.ts.map +1 -0
  385. package/dist/host/__tests__/utils.test.js +29 -0
  386. package/dist/host/__tests__/utils.test.js.map +1 -0
  387. package/dist/host/cookie-handler.d.ts +34 -0
  388. package/dist/host/cookie-handler.d.ts.map +1 -0
  389. package/dist/host/cookie-handler.js +124 -0
  390. package/dist/host/cookie-handler.js.map +1 -0
  391. package/dist/host/errors.d.ts +56 -0
  392. package/dist/host/errors.d.ts.map +1 -0
  393. package/dist/host/errors.js +79 -0
  394. package/dist/host/errors.js.map +1 -0
  395. package/dist/host/index.d.ts +29 -0
  396. package/dist/host/index.d.ts.map +1 -0
  397. package/dist/host/index.js +32 -0
  398. package/dist/host/index.js.map +1 -0
  399. package/dist/host/pattern-matcher.d.ts +36 -0
  400. package/dist/host/pattern-matcher.d.ts.map +1 -0
  401. package/dist/host/pattern-matcher.js +172 -0
  402. package/dist/host/pattern-matcher.js.map +1 -0
  403. package/dist/host/router.d.ts +26 -0
  404. package/dist/host/router.d.ts.map +1 -0
  405. package/dist/host/router.js +218 -0
  406. package/dist/host/router.js.map +1 -0
  407. package/dist/host/testing.d.ts +36 -0
  408. package/dist/host/testing.d.ts.map +1 -0
  409. package/dist/host/testing.js +55 -0
  410. package/dist/host/testing.js.map +1 -0
  411. package/dist/host/types.d.ts +115 -0
  412. package/dist/host/types.d.ts.map +1 -0
  413. package/dist/host/types.js +7 -0
  414. package/dist/host/types.js.map +1 -0
  415. package/dist/host/utils.d.ts +21 -0
  416. package/dist/host/utils.d.ts.map +1 -0
  417. package/dist/host/utils.js +23 -0
  418. package/dist/host/utils.js.map +1 -0
  419. package/dist/href-client.d.ts +131 -0
  420. package/dist/href-client.d.ts.map +1 -0
  421. package/dist/href-client.js +64 -0
  422. package/dist/href-client.js.map +1 -0
  423. package/{src/href-context.ts → dist/href-context.d.ts} +7 -11
  424. package/dist/href-context.d.ts.map +1 -0
  425. package/dist/href-context.js +21 -0
  426. package/dist/href-context.js.map +1 -0
  427. package/dist/index.d.ts +73 -0
  428. package/dist/index.d.ts.map +1 -0
  429. package/dist/index.js +91 -0
  430. package/dist/index.js.map +1 -0
  431. package/dist/index.rsc.d.ts +32 -0
  432. package/dist/index.rsc.d.ts.map +1 -0
  433. package/dist/index.rsc.js +40 -0
  434. package/dist/index.rsc.js.map +1 -0
  435. package/dist/internal-debug.d.ts +2 -0
  436. package/dist/internal-debug.d.ts.map +1 -0
  437. package/dist/internal-debug.js +5 -0
  438. package/dist/internal-debug.js.map +1 -0
  439. package/dist/loader.d.ts +14 -0
  440. package/dist/loader.d.ts.map +1 -0
  441. package/dist/loader.js +20 -0
  442. package/dist/loader.js.map +1 -0
  443. package/dist/loader.rsc.d.ts +19 -0
  444. package/dist/loader.rsc.d.ts.map +1 -0
  445. package/dist/loader.rsc.js +99 -0
  446. package/dist/loader.rsc.js.map +1 -0
  447. package/dist/network-error-thrower.d.ts +17 -0
  448. package/dist/network-error-thrower.d.ts.map +1 -0
  449. package/dist/network-error-thrower.js +14 -0
  450. package/dist/network-error-thrower.js.map +1 -0
  451. package/dist/outlet-context.d.ts +13 -0
  452. package/dist/outlet-context.d.ts.map +1 -0
  453. package/dist/outlet-context.js +3 -0
  454. package/dist/outlet-context.js.map +1 -0
  455. package/dist/prerender/__tests__/param-hash.test.d.ts +2 -0
  456. package/dist/prerender/__tests__/param-hash.test.d.ts.map +1 -0
  457. package/dist/prerender/__tests__/param-hash.test.js +148 -0
  458. package/dist/prerender/__tests__/param-hash.test.js.map +1 -0
  459. package/dist/prerender/param-hash.d.ts +16 -0
  460. package/dist/prerender/param-hash.d.ts.map +1 -0
  461. package/dist/prerender/param-hash.js +36 -0
  462. package/dist/prerender/param-hash.js.map +1 -0
  463. package/dist/prerender/store.d.ts +38 -0
  464. package/dist/prerender/store.d.ts.map +1 -0
  465. package/dist/prerender/store.js +61 -0
  466. package/dist/prerender/store.js.map +1 -0
  467. package/dist/prerender.d.ts +66 -0
  468. package/dist/prerender.d.ts.map +1 -0
  469. package/dist/prerender.js +57 -0
  470. package/dist/prerender.js.map +1 -0
  471. package/dist/reverse.d.ts +196 -0
  472. package/dist/reverse.d.ts.map +1 -0
  473. package/dist/reverse.js +78 -0
  474. package/dist/reverse.js.map +1 -0
  475. package/dist/root-error-boundary.d.ts +33 -0
  476. package/dist/root-error-boundary.d.ts.map +1 -0
  477. package/dist/root-error-boundary.js +165 -0
  478. package/dist/root-error-boundary.js.map +1 -0
  479. package/dist/route-content-wrapper.d.ts +46 -0
  480. package/dist/route-content-wrapper.d.ts.map +1 -0
  481. package/dist/route-content-wrapper.js +77 -0
  482. package/dist/route-content-wrapper.js.map +1 -0
  483. package/dist/route-definition.d.ts +421 -0
  484. package/dist/route-definition.d.ts.map +1 -0
  485. package/dist/route-definition.js +868 -0
  486. package/dist/route-definition.js.map +1 -0
  487. package/dist/route-map-builder.d.ts +155 -0
  488. package/dist/route-map-builder.d.ts.map +1 -0
  489. package/dist/route-map-builder.js +237 -0
  490. package/dist/route-map-builder.js.map +1 -0
  491. package/dist/route-types.d.ts +165 -0
  492. package/dist/route-types.d.ts.map +1 -0
  493. package/dist/route-types.js +7 -0
  494. package/dist/route-types.js.map +1 -0
  495. package/dist/router/__tests__/handler-context.test.d.ts +2 -0
  496. package/dist/router/__tests__/handler-context.test.d.ts.map +1 -0
  497. package/dist/router/__tests__/handler-context.test.js +65 -0
  498. package/dist/router/__tests__/handler-context.test.js.map +1 -0
  499. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +2 -0
  500. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +1 -0
  501. package/dist/router/__tests__/loader-cycle-detection.test.js +221 -0
  502. package/dist/router/__tests__/loader-cycle-detection.test.js.map +1 -0
  503. package/dist/router/__tests__/match-context.test.d.ts +2 -0
  504. package/dist/router/__tests__/match-context.test.d.ts.map +1 -0
  505. package/dist/router/__tests__/match-context.test.js +92 -0
  506. package/dist/router/__tests__/match-context.test.js.map +1 -0
  507. package/dist/router/__tests__/match-pipelines.test.d.ts +2 -0
  508. package/dist/router/__tests__/match-pipelines.test.d.ts.map +1 -0
  509. package/dist/router/__tests__/match-pipelines.test.js +417 -0
  510. package/dist/router/__tests__/match-pipelines.test.js.map +1 -0
  511. package/dist/router/__tests__/match-result.test.d.ts +2 -0
  512. package/dist/router/__tests__/match-result.test.d.ts.map +1 -0
  513. package/dist/router/__tests__/match-result.test.js +457 -0
  514. package/dist/router/__tests__/match-result.test.js.map +1 -0
  515. package/dist/router/__tests__/on-error.test.d.ts +2 -0
  516. package/dist/router/__tests__/on-error.test.d.ts.map +1 -0
  517. package/dist/router/__tests__/on-error.test.js +678 -0
  518. package/dist/router/__tests__/on-error.test.js.map +1 -0
  519. package/dist/router/__tests__/pattern-matching.test.d.ts +2 -0
  520. package/dist/router/__tests__/pattern-matching.test.d.ts.map +1 -0
  521. package/dist/router/__tests__/pattern-matching.test.js +629 -0
  522. package/dist/router/__tests__/pattern-matching.test.js.map +1 -0
  523. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +2 -0
  524. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +1 -0
  525. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +155 -0
  526. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +1 -0
  527. package/dist/router/error-handling.d.ts +77 -0
  528. package/dist/router/error-handling.d.ts.map +1 -0
  529. package/dist/router/error-handling.js +202 -0
  530. package/dist/router/error-handling.js.map +1 -0
  531. package/dist/router/handler-context.d.ts +20 -0
  532. package/dist/router/handler-context.d.ts.map +1 -0
  533. package/dist/router/handler-context.js +198 -0
  534. package/dist/router/handler-context.js.map +1 -0
  535. package/dist/router/intercept-resolution.d.ts +66 -0
  536. package/dist/router/intercept-resolution.d.ts.map +1 -0
  537. package/dist/router/intercept-resolution.js +246 -0
  538. package/dist/router/intercept-resolution.js.map +1 -0
  539. package/dist/router/loader-resolution.d.ts +64 -0
  540. package/dist/router/loader-resolution.d.ts.map +1 -0
  541. package/dist/router/loader-resolution.js +284 -0
  542. package/dist/router/loader-resolution.js.map +1 -0
  543. package/dist/router/logging.d.ts +15 -0
  544. package/dist/router/logging.d.ts.map +1 -0
  545. package/dist/router/logging.js +99 -0
  546. package/dist/router/logging.js.map +1 -0
  547. package/dist/router/manifest.d.ts +22 -0
  548. package/dist/router/manifest.d.ts.map +1 -0
  549. package/dist/router/manifest.js +181 -0
  550. package/dist/router/manifest.js.map +1 -0
  551. package/dist/router/match-api.d.ts +35 -0
  552. package/dist/router/match-api.d.ts.map +1 -0
  553. package/dist/router/match-api.js +406 -0
  554. package/dist/router/match-api.js.map +1 -0
  555. package/dist/router/match-context.d.ts +206 -0
  556. package/dist/router/match-context.d.ts.map +1 -0
  557. package/dist/router/match-context.js +17 -0
  558. package/dist/router/match-context.js.map +1 -0
  559. package/dist/router/match-middleware/background-revalidation.d.ts +127 -0
  560. package/dist/router/match-middleware/background-revalidation.d.ts.map +1 -0
  561. package/dist/router/match-middleware/background-revalidation.js +75 -0
  562. package/dist/router/match-middleware/background-revalidation.js.map +1 -0
  563. package/dist/router/match-middleware/cache-lookup.d.ts +112 -0
  564. package/dist/router/match-middleware/cache-lookup.d.ts.map +1 -0
  565. package/dist/router/match-middleware/cache-lookup.js +257 -0
  566. package/dist/router/match-middleware/cache-lookup.js.map +1 -0
  567. package/dist/router/match-middleware/cache-store.d.ts +113 -0
  568. package/dist/router/match-middleware/cache-store.d.ts.map +1 -0
  569. package/dist/router/match-middleware/cache-store.js +108 -0
  570. package/dist/router/match-middleware/cache-store.js.map +1 -0
  571. package/dist/router/match-middleware/index.d.ts +81 -0
  572. package/dist/router/match-middleware/index.d.ts.map +1 -0
  573. package/dist/router/match-middleware/index.js +80 -0
  574. package/dist/router/match-middleware/index.js.map +1 -0
  575. package/dist/router/match-middleware/intercept-resolution.d.ts +117 -0
  576. package/dist/router/match-middleware/intercept-resolution.d.ts.map +1 -0
  577. package/dist/router/match-middleware/intercept-resolution.js +134 -0
  578. package/dist/router/match-middleware/intercept-resolution.js.map +1 -0
  579. package/dist/router/match-middleware/segment-resolution.d.ts +99 -0
  580. package/dist/router/match-middleware/segment-resolution.d.ts.map +1 -0
  581. package/dist/router/match-middleware/segment-resolution.js +53 -0
  582. package/dist/router/match-middleware/segment-resolution.js.map +1 -0
  583. package/dist/router/match-pipelines.d.ts +147 -0
  584. package/dist/router/match-pipelines.d.ts.map +1 -0
  585. package/dist/router/match-pipelines.js +82 -0
  586. package/dist/router/match-pipelines.js.map +1 -0
  587. package/dist/router/match-result.d.ts +126 -0
  588. package/dist/router/match-result.d.ts.map +1 -0
  589. package/dist/router/match-result.js +93 -0
  590. package/dist/router/match-result.js.map +1 -0
  591. package/dist/router/metrics.d.ts +20 -0
  592. package/dist/router/metrics.d.ts.map +1 -0
  593. package/dist/router/metrics.js +47 -0
  594. package/dist/router/metrics.js.map +1 -0
  595. package/dist/router/middleware.d.ts +249 -0
  596. package/dist/router/middleware.d.ts.map +1 -0
  597. package/dist/router/middleware.js +434 -0
  598. package/dist/router/middleware.js.map +1 -0
  599. package/dist/router/middleware.test.d.ts +2 -0
  600. package/dist/router/middleware.test.d.ts.map +1 -0
  601. package/dist/router/middleware.test.js +816 -0
  602. package/dist/router/middleware.test.js.map +1 -0
  603. package/dist/router/pattern-matching.d.ts +149 -0
  604. package/dist/router/pattern-matching.d.ts.map +1 -0
  605. package/dist/router/pattern-matching.js +349 -0
  606. package/dist/router/pattern-matching.js.map +1 -0
  607. package/dist/router/revalidation.d.ts +44 -0
  608. package/dist/router/revalidation.d.ts.map +1 -0
  609. package/dist/router/revalidation.js +147 -0
  610. package/dist/router/revalidation.js.map +1 -0
  611. package/dist/router/router-context.d.ts +135 -0
  612. package/dist/router/router-context.d.ts.map +1 -0
  613. package/dist/router/router-context.js +36 -0
  614. package/dist/router/router-context.js.map +1 -0
  615. package/dist/router/segment-resolution.d.ts +127 -0
  616. package/dist/router/segment-resolution.d.ts.map +1 -0
  617. package/dist/router/segment-resolution.js +919 -0
  618. package/dist/router/segment-resolution.js.map +1 -0
  619. package/dist/router/trie-matching.d.ts +40 -0
  620. package/dist/router/trie-matching.d.ts.map +1 -0
  621. package/dist/router/trie-matching.js +127 -0
  622. package/dist/router/trie-matching.js.map +1 -0
  623. package/dist/router/types.d.ts +136 -0
  624. package/dist/router/types.d.ts.map +1 -0
  625. package/dist/router/types.js +7 -0
  626. package/dist/router/types.js.map +1 -0
  627. package/dist/router.d.ts +753 -0
  628. package/dist/router.d.ts.map +1 -0
  629. package/dist/router.gen.d.ts +6 -0
  630. package/dist/router.gen.d.ts.map +1 -0
  631. package/dist/router.gen.js +6 -0
  632. package/dist/router.gen.js.map +1 -0
  633. package/dist/router.js +1304 -0
  634. package/dist/router.js.map +1 -0
  635. package/dist/rsc/__tests__/helpers.test.d.ts +2 -0
  636. package/dist/rsc/__tests__/helpers.test.d.ts.map +1 -0
  637. package/dist/rsc/__tests__/helpers.test.js +140 -0
  638. package/dist/rsc/__tests__/helpers.test.js.map +1 -0
  639. package/dist/rsc/handler.d.ts +45 -0
  640. package/dist/rsc/handler.d.ts.map +1 -0
  641. package/dist/rsc/handler.js +1172 -0
  642. package/dist/rsc/handler.js.map +1 -0
  643. package/dist/rsc/helpers.d.ts +16 -0
  644. package/dist/rsc/helpers.d.ts.map +1 -0
  645. package/dist/rsc/helpers.js +55 -0
  646. package/dist/rsc/helpers.js.map +1 -0
  647. package/dist/rsc/index.d.ts +22 -0
  648. package/dist/rsc/index.d.ts.map +1 -0
  649. package/dist/rsc/index.js +23 -0
  650. package/dist/rsc/index.js.map +1 -0
  651. package/dist/rsc/nonce.d.ts +9 -0
  652. package/dist/rsc/nonce.d.ts.map +1 -0
  653. package/dist/rsc/nonce.js +18 -0
  654. package/dist/rsc/nonce.js.map +1 -0
  655. package/dist/rsc/types.d.ts +206 -0
  656. package/dist/rsc/types.d.ts.map +1 -0
  657. package/dist/rsc/types.js +8 -0
  658. package/dist/rsc/types.js.map +1 -0
  659. package/dist/search-params.d.ts +103 -0
  660. package/dist/search-params.d.ts.map +1 -0
  661. package/dist/search-params.js +74 -0
  662. package/dist/search-params.js.map +1 -0
  663. package/dist/segment-system.d.ts +75 -0
  664. package/dist/segment-system.d.ts.map +1 -0
  665. package/dist/segment-system.js +336 -0
  666. package/dist/segment-system.js.map +1 -0
  667. package/dist/server/context.d.ts +245 -0
  668. package/dist/server/context.d.ts.map +1 -0
  669. package/dist/server/context.js +197 -0
  670. package/dist/server/context.js.map +1 -0
  671. package/dist/server/fetchable-loader-store.d.ts +18 -0
  672. package/dist/server/fetchable-loader-store.d.ts.map +1 -0
  673. package/dist/server/fetchable-loader-store.js +18 -0
  674. package/dist/server/fetchable-loader-store.js.map +1 -0
  675. package/dist/server/handle-store.d.ts +85 -0
  676. package/dist/server/handle-store.d.ts.map +1 -0
  677. package/dist/server/handle-store.js +142 -0
  678. package/dist/server/handle-store.js.map +1 -0
  679. package/dist/server/loader-registry.d.ts +55 -0
  680. package/dist/server/loader-registry.d.ts.map +1 -0
  681. package/dist/server/loader-registry.js +132 -0
  682. package/dist/server/loader-registry.js.map +1 -0
  683. package/dist/server/request-context.d.ts +226 -0
  684. package/dist/server/request-context.d.ts.map +1 -0
  685. package/dist/server/request-context.js +290 -0
  686. package/dist/server/request-context.js.map +1 -0
  687. package/dist/server/root-layout.d.ts +4 -0
  688. package/dist/server/root-layout.d.ts.map +1 -0
  689. package/dist/server/root-layout.js +5 -0
  690. package/dist/server/root-layout.js.map +1 -0
  691. package/dist/server.d.ts +15 -0
  692. package/dist/server.d.ts.map +1 -0
  693. package/dist/server.js +20 -0
  694. package/dist/server.js.map +1 -0
  695. package/dist/ssr/__tests__/ssr-handler.test.d.ts +2 -0
  696. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +1 -0
  697. package/dist/ssr/__tests__/ssr-handler.test.js +132 -0
  698. package/dist/ssr/__tests__/ssr-handler.test.js.map +1 -0
  699. package/dist/ssr/index.d.ts +98 -0
  700. package/dist/ssr/index.d.ts.map +1 -0
  701. package/dist/ssr/index.js +158 -0
  702. package/dist/ssr/index.js.map +1 -0
  703. package/dist/static-handler.d.ts +50 -0
  704. package/dist/static-handler.d.ts.map +1 -0
  705. package/dist/static-handler.gen.d.ts +5 -0
  706. package/dist/static-handler.gen.d.ts.map +1 -0
  707. package/dist/static-handler.gen.js +5 -0
  708. package/dist/static-handler.gen.js.map +1 -0
  709. package/dist/static-handler.js +29 -0
  710. package/dist/static-handler.js.map +1 -0
  711. package/dist/theme/ThemeProvider.d.ts +20 -0
  712. package/dist/theme/ThemeProvider.d.ts.map +1 -0
  713. package/dist/theme/ThemeProvider.js +240 -0
  714. package/dist/theme/ThemeProvider.js.map +1 -0
  715. package/dist/theme/ThemeScript.d.ts +48 -0
  716. package/dist/theme/ThemeScript.d.ts.map +1 -0
  717. package/dist/theme/ThemeScript.js +13 -0
  718. package/dist/theme/ThemeScript.js.map +1 -0
  719. package/dist/theme/__tests__/theme.test.d.ts +2 -0
  720. package/dist/theme/__tests__/theme.test.d.ts.map +1 -0
  721. package/dist/theme/__tests__/theme.test.js +103 -0
  722. package/dist/theme/__tests__/theme.test.js.map +1 -0
  723. package/dist/theme/constants.d.ts +29 -0
  724. package/dist/theme/constants.d.ts.map +1 -0
  725. package/dist/theme/constants.js +48 -0
  726. package/dist/theme/constants.js.map +1 -0
  727. package/dist/theme/index.d.ts +31 -0
  728. package/dist/theme/index.d.ts.map +1 -0
  729. package/dist/theme/index.js +36 -0
  730. package/dist/theme/index.js.map +1 -0
  731. package/dist/theme/theme-context.d.ts +40 -0
  732. package/dist/theme/theme-context.d.ts.map +1 -0
  733. package/dist/theme/theme-context.js +60 -0
  734. package/dist/theme/theme-context.js.map +1 -0
  735. package/dist/theme/theme-script.d.ts +27 -0
  736. package/dist/theme/theme-script.d.ts.map +1 -0
  737. package/dist/theme/theme-script.js +147 -0
  738. package/dist/theme/theme-script.js.map +1 -0
  739. package/dist/theme/types.d.ts +163 -0
  740. package/dist/theme/types.d.ts.map +1 -0
  741. package/dist/theme/types.js +11 -0
  742. package/dist/theme/types.js.map +1 -0
  743. package/dist/theme/use-theme.d.ts +12 -0
  744. package/dist/theme/use-theme.d.ts.map +1 -0
  745. package/dist/theme/use-theme.js +40 -0
  746. package/dist/theme/use-theme.js.map +1 -0
  747. package/dist/types.d.ts +1479 -0
  748. package/dist/types.d.ts.map +1 -0
  749. package/dist/types.js +10 -0
  750. package/dist/types.js.map +1 -0
  751. package/dist/urls.d.ts +441 -0
  752. package/dist/urls.d.ts.map +1 -0
  753. package/dist/urls.gen.d.ts +8 -0
  754. package/dist/urls.gen.d.ts.map +1 -0
  755. package/dist/urls.gen.js +8 -0
  756. package/dist/urls.gen.js.map +1 -0
  757. package/dist/urls.js +443 -0
  758. package/dist/urls.js.map +1 -0
  759. package/dist/use-loader.d.ts +127 -0
  760. package/dist/use-loader.d.ts.map +1 -0
  761. package/dist/use-loader.js +237 -0
  762. package/dist/use-loader.js.map +1 -0
  763. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +2 -0
  764. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +1 -0
  765. package/dist/vite/__tests__/ast-handler-extract.test.js +294 -0
  766. package/dist/vite/__tests__/ast-handler-extract.test.js.map +1 -0
  767. package/dist/vite/__tests__/expose-id-utils.test.d.ts +2 -0
  768. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +1 -0
  769. package/dist/vite/__tests__/expose-id-utils.test.js +224 -0
  770. package/dist/vite/__tests__/expose-id-utils.test.js.map +1 -0
  771. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +2 -0
  772. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +1 -0
  773. package/dist/vite/__tests__/expose-internal-ids.test.js +647 -0
  774. package/dist/vite/__tests__/expose-internal-ids.test.js.map +1 -0
  775. package/dist/vite/__tests__/expose-router-id.test.d.ts +2 -0
  776. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +1 -0
  777. package/dist/vite/__tests__/expose-router-id.test.js +39 -0
  778. package/dist/vite/__tests__/expose-router-id.test.js.map +1 -0
  779. package/dist/vite/ast-handler-extract.d.ts +49 -0
  780. package/dist/vite/ast-handler-extract.d.ts.map +1 -0
  781. package/dist/vite/ast-handler-extract.js +249 -0
  782. package/dist/vite/ast-handler-extract.js.map +1 -0
  783. package/dist/vite/expose-action-id.d.ts +19 -0
  784. package/dist/vite/expose-action-id.d.ts.map +1 -0
  785. package/dist/vite/expose-action-id.js +250 -0
  786. package/dist/vite/expose-action-id.js.map +1 -0
  787. package/dist/vite/expose-id-utils.d.ts +69 -0
  788. package/dist/vite/expose-id-utils.d.ts.map +1 -0
  789. package/dist/vite/expose-id-utils.js +289 -0
  790. package/dist/vite/expose-id-utils.js.map +1 -0
  791. package/dist/vite/expose-internal-ids.d.ts +22 -0
  792. package/dist/vite/expose-internal-ids.d.ts.map +1 -0
  793. package/dist/vite/expose-internal-ids.js +886 -0
  794. package/dist/vite/expose-internal-ids.js.map +1 -0
  795. package/dist/vite/index.d.ts +149 -0
  796. package/dist/vite/index.d.ts.map +1 -0
  797. package/dist/vite/index.js +6440 -809
  798. package/dist/vite/index.js.bak +5448 -0
  799. package/dist/vite/index.js.map +1 -0
  800. package/dist/vite/index.named-routes.gen.ts +103 -0
  801. package/dist/vite/package-resolution.d.ts +43 -0
  802. package/dist/vite/package-resolution.d.ts.map +1 -0
  803. package/{src/vite/package-resolution.ts → dist/vite/package-resolution.js} +53 -66
  804. package/dist/vite/package-resolution.js.map +1 -0
  805. package/dist/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
  806. package/dist/vite/virtual-entries.d.ts +25 -0
  807. package/dist/vite/virtual-entries.d.ts.map +1 -0
  808. package/{src/vite/virtual-entries.ts → dist/vite/virtual-entries.js} +18 -17
  809. package/dist/vite/virtual-entries.js.map +1 -0
  810. package/package.json +140 -57
  811. package/skills/breadcrumbs/SKILL.md +252 -0
  812. package/skills/bundle-analysis/SKILL.md +159 -0
  813. package/skills/cache-guide/SKILL.md +484 -0
  814. package/skills/caching/SKILL.md +276 -226
  815. package/skills/composability/SKILL.md +197 -0
  816. package/skills/debug-manifest/SKILL.md +112 -0
  817. package/skills/document-cache/SKILL.md +106 -53
  818. package/skills/fonts/SKILL.md +167 -0
  819. package/skills/handler-use/SKILL.md +364 -0
  820. package/skills/hooks/SKILL.md +621 -67
  821. package/skills/host-router/SKILL.md +243 -0
  822. package/skills/i18n/SKILL.md +276 -0
  823. package/skills/intercept/SKILL.md +265 -202
  824. package/skills/layout/SKILL.md +261 -146
  825. package/skills/links/SKILL.md +471 -0
  826. package/skills/loader/SKILL.md +701 -250
  827. package/skills/middleware/SKILL.md +254 -320
  828. package/skills/migrate-nextjs/SKILL.md +562 -0
  829. package/skills/migrate-react-router/SKILL.md +769 -0
  830. package/skills/mime-routes/SKILL.md +155 -0
  831. package/skills/observability/SKILL.md +137 -0
  832. package/skills/parallel/SKILL.md +399 -158
  833. package/skills/prerender/SKILL.md +666 -0
  834. package/skills/rango/SKILL.md +338 -0
  835. package/skills/react-compiler/SKILL.md +168 -0
  836. package/skills/response-routes/SKILL.md +468 -0
  837. package/skills/route/SKILL.md +417 -89
  838. package/skills/router-setup/SKILL.md +389 -268
  839. package/skills/server-actions/SKILL.md +751 -0
  840. package/skills/streams-and-websockets/SKILL.md +283 -0
  841. package/skills/tailwind/SKILL.md +129 -0
  842. package/skills/testing/SKILL.md +549 -0
  843. package/skills/theme/SKILL.md +36 -11
  844. package/skills/typesafety/SKILL.md +747 -174
  845. package/skills/use-cache/SKILL.md +353 -0
  846. package/skills/view-transitions/SKILL.md +294 -0
  847. package/src/__augment-tests__/augment.ts +81 -0
  848. package/src/__augment-tests__/augmented.check.ts +117 -0
  849. package/src/__internal.ts +273 -0
  850. package/src/bin/rango.ts +321 -0
  851. package/src/browser/action-coordinator.ts +114 -0
  852. package/src/browser/app-shell.ts +52 -0
  853. package/src/browser/app-version.ts +14 -0
  854. package/src/browser/event-controller.ts +172 -128
  855. package/src/browser/history-state.ts +101 -0
  856. package/src/browser/index.ts +3 -3
  857. package/src/browser/intercept-utils.ts +52 -0
  858. package/src/browser/link-interceptor.ts +24 -4
  859. package/src/browser/logging.ts +55 -0
  860. package/src/browser/merge-segment-loaders.ts +20 -12
  861. package/src/browser/navigation-bridge.ts +390 -557
  862. package/src/browser/navigation-client.ts +228 -70
  863. package/src/browser/navigation-store.ts +104 -63
  864. package/src/browser/navigation-transaction.ts +279 -0
  865. package/src/browser/network-error-handler.ts +61 -0
  866. package/src/browser/partial-update.ts +397 -303
  867. package/src/browser/prefetch/cache.ts +314 -0
  868. package/src/browser/prefetch/fetch.ts +282 -0
  869. package/src/browser/prefetch/observer.ts +65 -0
  870. package/src/browser/prefetch/policy.ts +48 -0
  871. package/src/browser/prefetch/queue.ts +191 -0
  872. package/src/browser/prefetch/resource-ready.ts +77 -0
  873. package/src/browser/rango-state.ts +152 -0
  874. package/src/browser/react/Link.tsx +258 -74
  875. package/src/browser/react/NavigationProvider.tsx +237 -49
  876. package/src/browser/react/context.ts +11 -0
  877. package/src/browser/react/filter-segment-order.ts +55 -0
  878. package/src/browser/react/index.ts +15 -12
  879. package/src/browser/react/location-state-shared.ts +269 -56
  880. package/src/browser/react/location-state.ts +90 -19
  881. package/src/browser/react/mount-context.ts +37 -0
  882. package/src/browser/react/nonce-context.ts +23 -0
  883. package/src/browser/react/shallow-equal.ts +27 -0
  884. package/src/browser/react/use-action.ts +29 -51
  885. package/src/browser/react/use-client-cache.ts +5 -3
  886. package/src/browser/react/use-handle.ts +41 -98
  887. package/src/browser/react/use-href.tsx +20 -188
  888. package/src/browser/react/use-link-status.ts +6 -5
  889. package/src/browser/react/use-mount.ts +31 -0
  890. package/src/browser/react/use-navigation.ts +49 -80
  891. package/src/browser/react/use-params.ts +77 -0
  892. package/src/browser/react/use-pathname.ts +47 -0
  893. package/src/browser/react/use-reverse.ts +106 -0
  894. package/src/browser/react/use-router.ts +96 -0
  895. package/src/browser/react/use-search-params.ts +56 -0
  896. package/src/browser/react/use-segments.ts +85 -99
  897. package/src/browser/response-adapter.ts +98 -0
  898. package/src/browser/rsc-router.tsx +273 -78
  899. package/src/browser/scroll-restoration.ts +132 -49
  900. package/src/browser/segment-reconciler.ts +243 -0
  901. package/src/browser/segment-structure-assert.ts +83 -0
  902. package/src/browser/server-action-bridge.ts +504 -589
  903. package/src/browser/shallow.ts +6 -1
  904. package/src/browser/types.ts +184 -58
  905. package/src/browser/validate-redirect-origin.ts +29 -0
  906. package/src/build/collect-fallback-refs.ts +107 -0
  907. package/src/build/generate-manifest.ts +463 -0
  908. package/src/build/generate-route-types.ts +41 -0
  909. package/src/build/index.ts +37 -0
  910. package/src/build/route-trie.ts +292 -0
  911. package/src/build/route-types/ast-helpers.ts +25 -0
  912. package/src/build/route-types/ast-route-extraction.ts +98 -0
  913. package/src/build/route-types/codegen.ts +102 -0
  914. package/src/build/route-types/include-resolution.ts +418 -0
  915. package/src/build/route-types/param-extraction.ts +48 -0
  916. package/src/build/route-types/per-module-writer.ts +131 -0
  917. package/src/build/route-types/router-processing.ts +659 -0
  918. package/src/build/route-types/scan-filter.ts +85 -0
  919. package/src/build/route-types/source-scan.ts +118 -0
  920. package/src/build/runtime-discovery.ts +220 -0
  921. package/src/cache/background-task.ts +34 -0
  922. package/src/cache/cache-key-utils.ts +44 -0
  923. package/src/cache/cache-policy.ts +125 -0
  924. package/src/cache/cache-runtime.ts +342 -0
  925. package/src/cache/cache-scope.ts +150 -306
  926. package/src/cache/cf/cf-cache-store.ts +619 -24
  927. package/src/cache/cf/index.ts +13 -3
  928. package/src/cache/document-cache.ts +116 -77
  929. package/src/cache/handle-capture.ts +81 -0
  930. package/src/cache/handle-snapshot.ts +41 -0
  931. package/src/cache/index.ts +1 -15
  932. package/src/cache/memory-segment-store.ts +191 -13
  933. package/src/cache/profile-registry.ts +73 -0
  934. package/src/cache/read-through-swr.ts +134 -0
  935. package/src/cache/segment-codec.ts +256 -0
  936. package/src/cache/taint.ts +153 -0
  937. package/src/cache/types.ts +76 -121
  938. package/src/client.rsc.tsx +15 -15
  939. package/src/client.tsx +145 -309
  940. package/src/component-utils.ts +4 -4
  941. package/src/components/DefaultDocument.tsx +6 -2
  942. package/src/context-var.ts +156 -0
  943. package/src/debug.ts +243 -0
  944. package/src/decode-loader-results.ts +36 -0
  945. package/src/errors.ts +138 -3
  946. package/src/handle.ts +90 -22
  947. package/src/handles/MetaTags.tsx +76 -23
  948. package/src/handles/breadcrumbs.ts +66 -0
  949. package/src/handles/index.ts +1 -0
  950. package/src/handles/meta.ts +32 -15
  951. package/src/host/cookie-handler.ts +165 -0
  952. package/src/host/errors.ts +97 -0
  953. package/src/host/index.ts +53 -0
  954. package/src/host/pattern-matcher.ts +214 -0
  955. package/src/host/router.ts +424 -0
  956. package/src/host/testing.ts +79 -0
  957. package/src/host/types.ts +175 -0
  958. package/src/host/utils.ts +25 -0
  959. package/src/href-client.ts +263 -49
  960. package/src/index.rsc.ts +190 -29
  961. package/src/index.ts +278 -38
  962. package/src/internal-debug.ts +11 -0
  963. package/src/loader-store.ts +500 -0
  964. package/src/loader.rsc.ts +24 -142
  965. package/src/loader.ts +21 -11
  966. package/src/missing-id-error.ts +68 -0
  967. package/src/network-error-thrower.tsx +3 -1
  968. package/src/outlet-context.ts +1 -1
  969. package/src/outlet-provider.tsx +45 -0
  970. package/src/prerender/param-hash.ts +37 -0
  971. package/src/prerender/store.ts +186 -0
  972. package/src/prerender.ts +524 -0
  973. package/src/response-utils.ts +37 -0
  974. package/src/reverse.ts +380 -0
  975. package/src/root-error-boundary.tsx +41 -29
  976. package/src/route-content-wrapper.tsx +15 -39
  977. package/src/route-definition/dsl-helpers.ts +1109 -0
  978. package/src/route-definition/helper-factories.ts +90 -0
  979. package/src/route-definition/helpers-types.ts +506 -0
  980. package/src/route-definition/index.ts +55 -0
  981. package/src/route-definition/redirect.ts +101 -0
  982. package/src/route-definition/resolve-handler-use.ts +155 -0
  983. package/src/route-definition/use-item-types.ts +32 -0
  984. package/src/route-definition.ts +1 -1371
  985. package/src/route-map-builder.ts +247 -112
  986. package/src/route-name.ts +53 -0
  987. package/src/route-types.ts +99 -42
  988. package/src/router/basename.ts +14 -0
  989. package/src/router/content-negotiation.ts +228 -0
  990. package/src/router/debug-manifest.ts +72 -0
  991. package/src/router/error-handling.ts +10 -10
  992. package/src/router/find-match.ts +160 -0
  993. package/src/router/handler-context.ts +420 -88
  994. package/src/router/intercept-resolution.ts +388 -0
  995. package/src/router/lazy-includes.ts +237 -0
  996. package/src/router/loader-resolution.ts +374 -128
  997. package/src/router/logging.ts +251 -0
  998. package/src/router/manifest.ts +187 -43
  999. package/src/router/match-api.ts +556 -0
  1000. package/src/router/match-context.ts +6 -4
  1001. package/src/router/match-handlers.ts +483 -0
  1002. package/src/router/match-middleware/background-revalidation.ts +108 -93
  1003. package/src/router/match-middleware/cache-lookup.ts +413 -10
  1004. package/src/router/match-middleware/cache-store.ts +99 -26
  1005. package/src/router/match-middleware/intercept-resolution.ts +57 -17
  1006. package/src/router/match-middleware/segment-resolution.ts +80 -6
  1007. package/src/router/match-pipelines.ts +10 -45
  1008. package/src/router/match-result.ts +156 -36
  1009. package/src/router/metrics.ts +241 -16
  1010. package/src/router/middleware-cookies.ts +55 -0
  1011. package/src/router/middleware-types.ts +209 -0
  1012. package/src/router/middleware.ts +359 -346
  1013. package/src/router/navigation-snapshot.ts +182 -0
  1014. package/src/router/pattern-matching.ts +416 -41
  1015. package/src/router/prerender-match.ts +502 -0
  1016. package/src/router/preview-match.ts +100 -0
  1017. package/src/router/request-classification.ts +286 -0
  1018. package/src/router/revalidation.ts +195 -40
  1019. package/src/router/route-snapshot.ts +245 -0
  1020. package/src/router/router-context.ts +45 -23
  1021. package/src/router/router-interfaces.ts +501 -0
  1022. package/src/router/router-options.ts +657 -0
  1023. package/src/router/router-registry.ts +21 -0
  1024. package/src/router/segment-resolution/fresh.ts +769 -0
  1025. package/src/router/segment-resolution/helpers.ts +268 -0
  1026. package/src/router/segment-resolution/loader-cache.ts +199 -0
  1027. package/src/router/segment-resolution/revalidation.ts +1420 -0
  1028. package/src/router/segment-resolution/static-store.ts +67 -0
  1029. package/src/router/segment-resolution/view-transition-default.ts +36 -0
  1030. package/src/router/segment-resolution.ts +21 -0
  1031. package/src/router/segment-wrappers.ts +291 -0
  1032. package/src/router/substitute-pattern-params.ts +56 -0
  1033. package/src/router/telemetry-otel.ts +299 -0
  1034. package/src/router/telemetry.ts +399 -0
  1035. package/src/router/timeout.ts +148 -0
  1036. package/src/router/trie-matching.ts +244 -0
  1037. package/src/router/types.ts +87 -4
  1038. package/src/router/url-params.ts +49 -0
  1039. package/src/router.ts +768 -3574
  1040. package/src/rsc/handler-context.ts +45 -0
  1041. package/src/rsc/handler.ts +894 -806
  1042. package/src/rsc/helpers.ts +201 -19
  1043. package/src/rsc/index.ts +5 -25
  1044. package/src/rsc/loader-fetch.ts +229 -0
  1045. package/src/rsc/manifest-init.ts +90 -0
  1046. package/src/rsc/nonce.ts +14 -0
  1047. package/src/rsc/origin-guard.ts +159 -0
  1048. package/src/rsc/progressive-enhancement.ts +395 -0
  1049. package/src/rsc/response-error.ts +37 -0
  1050. package/src/rsc/response-route-handler.ts +340 -0
  1051. package/src/rsc/rsc-rendering.ts +230 -0
  1052. package/src/rsc/runtime-warnings.ts +41 -0
  1053. package/src/rsc/server-action.ts +336 -0
  1054. package/src/rsc/ssr-setup.ts +144 -0
  1055. package/src/rsc/types.ts +54 -14
  1056. package/src/search-params.ts +230 -0
  1057. package/src/segment-content-promise.ts +67 -0
  1058. package/src/segment-loader-promise.ts +122 -0
  1059. package/src/segment-system.tsx +265 -115
  1060. package/src/serialize.ts +243 -0
  1061. package/src/server/context.ts +480 -90
  1062. package/src/server/cookie-store.ts +214 -0
  1063. package/src/server/fetchable-loader-store.ts +37 -0
  1064. package/src/server/handle-store.ts +117 -20
  1065. package/src/server/loader-registry.ts +24 -64
  1066. package/src/server/request-context.ts +613 -109
  1067. package/src/server.ts +36 -131
  1068. package/src/ssr/index.tsx +164 -25
  1069. package/src/static-handler.ts +126 -0
  1070. package/src/testing/cache-status.ts +166 -0
  1071. package/src/testing/collect-handle.ts +63 -0
  1072. package/src/testing/dispatch.ts +440 -0
  1073. package/src/testing/dom.entry.ts +22 -0
  1074. package/src/testing/e2e/fixture.ts +154 -0
  1075. package/src/testing/e2e/index.ts +149 -0
  1076. package/src/testing/e2e/matchers.ts +51 -0
  1077. package/src/testing/e2e/page-helpers.ts +272 -0
  1078. package/src/testing/e2e/parity.ts +306 -0
  1079. package/src/testing/e2e/server.ts +183 -0
  1080. package/src/testing/flight-matchers.ts +104 -0
  1081. package/src/testing/flight-runtime.d.ts +21 -0
  1082. package/src/testing/flight.entry.ts +22 -0
  1083. package/src/testing/flight.ts +182 -0
  1084. package/src/testing/generated-routes.ts +223 -0
  1085. package/src/testing/index.ts +98 -0
  1086. package/src/testing/internal/context.ts +151 -0
  1087. package/src/testing/render-route.tsx +536 -0
  1088. package/src/testing/run-loader.ts +296 -0
  1089. package/src/testing/run-middleware.ts +170 -0
  1090. package/src/testing/vitest-stubs/cloudflare-email.ts +9 -0
  1091. package/src/testing/vitest-stubs/cloudflare-workers.ts +21 -0
  1092. package/src/testing/vitest-stubs/plugin-rsc.ts +16 -0
  1093. package/src/testing/vitest-stubs/version.ts +5 -0
  1094. package/src/testing/vitest.ts +112 -0
  1095. package/src/theme/ThemeProvider.tsx +21 -15
  1096. package/src/theme/ThemeScript.tsx +5 -5
  1097. package/src/theme/constants.ts +11 -4
  1098. package/src/theme/index.ts +4 -14
  1099. package/src/theme/theme-context.ts +5 -31
  1100. package/src/theme/theme-script.ts +21 -18
  1101. package/src/theme/types.ts +1 -1
  1102. package/src/types/boundaries.ts +158 -0
  1103. package/src/types/cache-types.ts +198 -0
  1104. package/src/types/error-types.ts +192 -0
  1105. package/src/types/global-namespace.ts +113 -0
  1106. package/src/types/handler-context.ts +809 -0
  1107. package/src/types/index.ts +89 -0
  1108. package/src/types/loader-types.ts +209 -0
  1109. package/src/types/request-scope.ts +126 -0
  1110. package/src/types/route-config.ts +170 -0
  1111. package/src/types/route-entry.ts +120 -0
  1112. package/src/types/segments.ts +184 -0
  1113. package/src/types.ts +1 -1561
  1114. package/src/urls/include-helper.ts +164 -0
  1115. package/src/urls/index.ts +50 -0
  1116. package/src/urls/path-helper-types.ts +380 -0
  1117. package/src/urls/path-helper.ts +329 -0
  1118. package/src/urls/pattern-types.ts +124 -0
  1119. package/src/urls/response-types.ts +109 -0
  1120. package/src/urls/type-extraction.ts +282 -0
  1121. package/src/urls/urls-function.ts +94 -0
  1122. package/src/urls.ts +1 -726
  1123. package/src/use-loader.tsx +559 -108
  1124. package/src/vite/debug.ts +185 -0
  1125. package/src/vite/discovery/bundle-postprocess.ts +181 -0
  1126. package/src/vite/discovery/discover-routers.ts +398 -0
  1127. package/src/vite/discovery/discovery-errors.ts +194 -0
  1128. package/src/vite/discovery/gate-state.ts +171 -0
  1129. package/src/vite/discovery/prerender-collection.ts +480 -0
  1130. package/src/vite/discovery/route-types-writer.ts +214 -0
  1131. package/src/vite/discovery/self-gen-tracking.ts +73 -0
  1132. package/src/vite/discovery/state.ts +150 -0
  1133. package/src/vite/discovery/virtual-module-codegen.ts +193 -0
  1134. package/src/vite/index.ts +20 -785
  1135. package/src/vite/plugin-types.ts +170 -0
  1136. package/src/vite/plugins/cjs-to-esm.ts +94 -0
  1137. package/src/vite/plugins/client-ref-dedup.ts +131 -0
  1138. package/src/vite/plugins/client-ref-hashing.ts +128 -0
  1139. package/src/vite/plugins/cloudflare-protocol-loader-hook.d.mts +23 -0
  1140. package/src/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
  1141. package/src/vite/plugins/cloudflare-protocol-stub.ts +214 -0
  1142. package/src/vite/{expose-action-id.ts → plugins/expose-action-id.ts} +109 -66
  1143. package/src/vite/plugins/expose-id-utils.ts +303 -0
  1144. package/src/vite/plugins/expose-ids/export-analysis.ts +376 -0
  1145. package/src/vite/plugins/expose-ids/handler-transform.ts +156 -0
  1146. package/src/vite/plugins/expose-ids/loader-transform.ts +72 -0
  1147. package/src/vite/plugins/expose-ids/router-transform.ts +127 -0
  1148. package/src/vite/plugins/expose-ids/types.ts +45 -0
  1149. package/src/vite/plugins/expose-internal-ids.ts +796 -0
  1150. package/src/vite/plugins/performance-tracks.ts +92 -0
  1151. package/src/vite/plugins/refresh-cmd.ts +127 -0
  1152. package/src/vite/plugins/use-cache-transform.ts +338 -0
  1153. package/src/vite/plugins/version-injector.ts +99 -0
  1154. package/src/vite/plugins/version-plugin.ts +323 -0
  1155. package/src/vite/plugins/virtual-entries.ts +123 -0
  1156. package/src/vite/plugins/virtual-stub-plugin.ts +29 -0
  1157. package/src/vite/rango.ts +549 -0
  1158. package/src/vite/router-discovery.ts +1568 -0
  1159. package/src/vite/utils/ast-handler-extract.ts +517 -0
  1160. package/src/vite/utils/banner.ts +36 -0
  1161. package/src/vite/utils/bundle-analysis.ts +139 -0
  1162. package/src/vite/utils/client-chunks.ts +190 -0
  1163. package/src/vite/utils/forward-user-plugins.ts +193 -0
  1164. package/src/vite/utils/manifest-utils.ts +86 -0
  1165. package/src/vite/utils/package-resolution.ts +161 -0
  1166. package/src/vite/utils/prerender-utils.ts +222 -0
  1167. package/src/vite/utils/shared-utils.ts +251 -0
  1168. package/CLAUDE.md +0 -7
  1169. package/src/__tests__/component-utils.test.ts +0 -76
  1170. package/src/__tests__/route-definition.test.ts +0 -63
  1171. package/src/__tests__/urls.test.tsx +0 -436
  1172. package/src/browser/lru-cache.ts +0 -69
  1173. package/src/browser/request-controller.ts +0 -164
  1174. package/src/cache/__tests__/document-cache.test.ts +0 -522
  1175. package/src/cache/__tests__/memory-segment-store.test.ts +0 -487
  1176. package/src/cache/__tests__/memory-store.test.ts +0 -484
  1177. package/src/cache/cf/__tests__/cf-cache-store.test.ts +0 -428
  1178. package/src/cache/memory-store.ts +0 -253
  1179. package/src/href.ts +0 -177
  1180. package/src/route-utils.ts +0 -89
  1181. package/src/router/__tests__/match-context.test.ts +0 -104
  1182. package/src/router/__tests__/match-pipelines.test.ts +0 -537
  1183. package/src/router/__tests__/match-result.test.ts +0 -566
  1184. package/src/router/__tests__/on-error.test.ts +0 -935
  1185. package/src/router/__tests__/pattern-matching.test.ts +0 -577
  1186. package/src/router/middleware.test.ts +0 -1355
  1187. package/src/rsc/__tests__/helpers.test.ts +0 -175
  1188. package/src/server/__tests__/request-context.test.ts +0 -171
  1189. package/src/ssr/__tests__/ssr-handler.test.tsx +0 -188
  1190. package/src/theme/__tests__/theme.test.ts +0 -120
  1191. package/src/vite/__tests__/expose-loader-id.test.ts +0 -117
  1192. package/src/vite/expose-handle-id.ts +0 -209
  1193. package/src/vite/expose-loader-id.ts +0 -357
  1194. package/src/vite/expose-location-state-id.ts +0 -177
  1195. /package/src/vite/{version.d.ts → plugins/version.d.ts} +0 -0
@@ -1,9 +1,117 @@
1
1
  "use client";
2
2
 
3
- import { useCallback, useContext, useEffect, useRef, useState } from "react";
3
+ import {
4
+ isValidElement,
5
+ startTransition,
6
+ useCallback,
7
+ useContext,
8
+ useEffect,
9
+ useMemo,
10
+ useRef,
11
+ useState,
12
+ type ReactNode,
13
+ } from "react";
4
14
  import { OutletContext, type OutletContextValue } from "./outlet-context.js";
15
+ import { loaderStore, type LoaderEntry } from "./loader-store.js";
5
16
  import type { LoaderDefinition, LoadOptions } from "./types.js";
6
17
 
18
+ /**
19
+ * A shareable GET — a `load()` call that reads data (GET or defaulted method)
20
+ * with no request body. Params are allowed. This is the gate for keyed sharing:
21
+ * when a hook is given an explicit `key`, every shareable GET writes to the
22
+ * keyed bucket so co-keyed readers (including parameterized views) refresh
23
+ * together. Non-GET methods and body-bearing calls are mutations and stay local
24
+ * to the call site.
25
+ */
26
+ function isShareableGet(options: LoadOptions | undefined): boolean {
27
+ if (!options) return true;
28
+ if (options.method && options.method !== "GET") return false;
29
+ if ("body" in options && (options as { body?: unknown }).body !== undefined) {
30
+ return false;
31
+ }
32
+ return true;
33
+ }
34
+
35
+ /**
36
+ * Plain route-context refetch — a `load()` call with no options or a
37
+ * trivially-defaulted GET (no params, no body). Results from these are
38
+ * broadcast to every component reading the same loader id via the shared
39
+ * store, so a layout's refetch button updates page + parallel-slot reads
40
+ * automatically.
41
+ *
42
+ * Calls with explicit `params`, an explicit non-GET method, or a `body`
43
+ * stay local to the call site — that preserves the today-semantics of
44
+ * `useFetchLoader(SearchLoader).load({ params: { q } })` style code where
45
+ * each component owns its own fetched view. (An explicit `key` opts a
46
+ * parameterized GET back into sharing; see `isShareableGet`.)
47
+ */
48
+ function isPlainRefetch(options: LoadOptions | undefined): boolean {
49
+ if (!isShareableGet(options)) return false;
50
+ if (options?.params && Object.keys(options.params).length > 0) return false;
51
+ return true;
52
+ }
53
+
54
+ // Per-hook unique suffix for grouped reads that have no explicit `key`. Such a
55
+ // read must NOT share the bare `loader.$$id` bucket, or a cross-loader group
56
+ // refresh would leak into unrelated unkeyed readers of the same loader (which
57
+ // the contract keeps local). Sharing within a group is opt-in via an explicit
58
+ // `key`; without one, each grouped read gets its own private bucket. The value
59
+ // is only ever used as a client-side store bucket key (never rendered), so the
60
+ // counter has no SSR/hydration consistency requirement.
61
+ let privateGroupBucketSeq = 0;
62
+
63
+ /**
64
+ * Extract a specific loader's data from a content ReactNode.
65
+ *
66
+ * When a route registers loaders via loader(), the resolved data lives in
67
+ * the route's OutletProvider (rendered as <Outlet /> content). Parallel
68
+ * slots are siblings of <Outlet />, so they can't find it by walking
69
+ * the parent context chain. This helper traverses wrapper elements
70
+ * (MountContextProvider, ViewTransition, etc.) to reach the OutletProvider
71
+ * and extract the loader data directly.
72
+ */
73
+ const NOT_FOUND = Symbol("not-found");
74
+
75
+ function extractContentLoaderData(
76
+ node: ReactNode,
77
+ loaderId: string,
78
+ ): unknown | typeof NOT_FOUND {
79
+ if (!isValidElement(node)) return NOT_FOUND;
80
+ const props = node.props as Record<string, any> | undefined;
81
+ if (!props) return NOT_FOUND;
82
+
83
+ // Direct OutletProvider with loaderData
84
+ if (props.loaderData && loaderId in props.loaderData) {
85
+ return props.loaderData[loaderId];
86
+ }
87
+
88
+ // LoaderBoundary: loaderIds + loaderDataPromise (already resolved array).
89
+ // When the segment has loading(), loaderData is resolved inside
90
+ // LoaderBoundary via use(). If the promise was pre-awaited (forceAwait
91
+ // or isAction), the prop is a raw array we can index into.
92
+ if (
93
+ props.loaderIds &&
94
+ Array.isArray(props.loaderIds) &&
95
+ props.loaderDataPromise &&
96
+ !(props.loaderDataPromise instanceof Promise)
97
+ ) {
98
+ const idx = (props.loaderIds as string[]).indexOf(loaderId);
99
+ if (idx !== -1) {
100
+ const data = (props.loaderDataPromise as any[])[idx];
101
+ // loaderDataPromise entries may be { ok, data } result objects
102
+ if (data && typeof data === "object" && "ok" in data) {
103
+ return data.ok ? data.data : NOT_FOUND;
104
+ }
105
+ return data;
106
+ }
107
+ }
108
+
109
+ // Traverse into wrapper elements (MountContextProvider, ViewTransition,
110
+ // Suspense wrappers, etc.)
111
+ if (props.children) return extractContentLoaderData(props.children, loaderId);
112
+ return NOT_FOUND;
113
+ }
114
+
7
115
  /**
8
116
  * Payload returned by loader RSC requests
9
117
  */
@@ -13,12 +121,9 @@ interface LoaderRscPayload<T = unknown> {
13
121
  }
14
122
 
15
123
  /**
16
- * Load function type with form action support
124
+ * Load function type for fetching loader data from the client
17
125
  */
18
- export type LoadFunction<T> = ((options?: LoadOptions) => Promise<T>) & {
19
- /** Form action for progressive enhancement - can be passed to form action prop */
20
- action: (formData: FormData) => Promise<void>;
21
- };
126
+ export type LoadFunction<T> = (options?: LoadOptions) => Promise<T>;
22
127
 
23
128
  /**
24
129
  * Result type for useLoader hook (strict - data is required)
@@ -62,6 +167,40 @@ export interface UseLoaderOptions {
62
167
  * @default true
63
168
  */
64
169
  throwOnError?: boolean;
170
+ /**
171
+ * Client refresh key. Partitions the shared refresh store so that only hooks
172
+ * using the same `key` refresh together when one of them calls `load()`.
173
+ *
174
+ * Without a `key` (default), a plain `load()` on a route-registered loader
175
+ * broadcasts to every reader of that loader, and any parameterized / unregistered
176
+ * load stays local to the calling hook. With a `key`:
177
+ * - readers of the same loader that share a `key` form one refresh group —
178
+ * a `load()` from any of them updates the whole group, including
179
+ * parameterized GETs;
180
+ * - readers with different keys are independent;
181
+ * - it works even when the loader is NOT registered on the route (keyed
182
+ * `useFetchLoader`), letting unrelated components opt into sharing.
183
+ *
184
+ * This is a client-side refresh identity only. It is unrelated to the server
185
+ * `cache({ key })` option and to `revalidate()`; it never changes the request
186
+ * sent to the server.
187
+ */
188
+ key?: string;
189
+ /**
190
+ * Cross-loader refresh group tag(s). Tag reads of DIFFERENT loaders with a
191
+ * shared name, then call `useRefreshLoaders()(name)` to refresh the whole group
192
+ * at once. Pass an array to tag one read into several groups — it is refreshed
193
+ * when ANY of its groups is refreshed, so a coarse tag can cover the whole set
194
+ * while a finer tag targets a subset. Each member is refreshed with a plain GET
195
+ * against the current route URL — no params, no body, no mutation methods —
196
+ * because a group spans heterogeneous loaders with different param/return
197
+ * shapes.
198
+ *
199
+ * For parameterized sharing of a SINGLE loader, use `key` instead; group
200
+ * members should be registered or non-parameterized-keyed reads (a plain-GET
201
+ * group refresh would drop any per-call params).
202
+ */
203
+ refreshGroup?: string | string[];
65
204
  }
66
205
 
67
206
  /**
@@ -69,61 +208,288 @@ export interface UseLoaderOptions {
69
208
  */
70
209
  function useLoaderInternal<T>(
71
210
  loader: LoaderDefinition<T>,
72
- options?: UseLoaderOptions
211
+ options?: UseLoaderOptions,
73
212
  ): UseFetchLoaderResult<T> {
74
213
  const context = useContext(OutletContext);
75
214
 
76
- // Get data from context (SSR/navigation)
77
- const getContextData = useCallback((): T | undefined => {
215
+ // Get data from context (SSR/navigation). `hasContextData` distinguishes
216
+ // "loader registered on the route, value happens to be undefined" from
217
+ // "loader is not in any parent's context at all". The shared store is
218
+ // only consulted when the loader really is in route context — that
219
+ // preserves per-component isolation for ad-hoc useFetchLoader callers
220
+ // who use the same fetchable loader without registering it.
221
+ const { contextData, hasContextData } = useMemo((): {
222
+ contextData: T | undefined;
223
+ hasContextData: boolean;
224
+ } => {
78
225
  let current: OutletContextValue | null | undefined = context;
79
226
  while (current) {
80
227
  if (current.loaderData && loader.$$id in current.loaderData) {
81
- return current.loaderData[loader.$$id] as T;
228
+ return {
229
+ contextData: current.loaderData[loader.$$id] as T,
230
+ hasContextData: true,
231
+ };
232
+ }
233
+ // Check content element — the route's OutletProvider is rendered as
234
+ // <Outlet /> content (a child), so its loaderData isn't in the parent
235
+ // chain. Parallel slots need to reach into it to find route-level loaders.
236
+ const contentData = extractContentLoaderData(
237
+ current.content,
238
+ loader.$$id,
239
+ );
240
+ if (contentData !== NOT_FOUND) {
241
+ return { contextData: contentData as T, hasContextData: true };
82
242
  }
83
243
  current = current.parent;
84
244
  }
85
- return undefined;
245
+ return { contextData: undefined, hasContextData: false };
86
246
  }, [context, loader.$$id]);
87
247
 
88
- const contextData = getContextData();
89
-
90
- // Local state for fetched data (from load() calls)
91
- const [fetchedData, setFetchedData] = useState<T | undefined>(undefined);
92
- const [isLoading, setIsLoading] = useState(false);
93
- const [error, setError] = useState<Error | null>(null);
94
-
95
- // Track context data changes to reset fetched data on navigation
248
+ // Shared subscription: every component reading the same loader id sees
249
+ // the same snapshot, so a plain refetch from one component propagates to
250
+ // the others. Mirrors the convention used by useParams / useLinkStatus —
251
+ // useState seeded from the store, useEffect subscribes for updates and
252
+ // calls setState inside startTransition so subscriber re-renders don't
253
+ // trip Suspense fallbacks during a refetch (matches the per-hook
254
+ // startTransition the old code wrapped setFetchedData in).
255
+ const loaderId = loader.$$id;
256
+ // Client refresh key. The shared store is partitioned by bucket key so that
257
+ // only hooks with the same `key` refresh together. Default (no key) keeps the
258
+ // historical behavior: one bucket per loader id.
259
+ const key = options?.key;
260
+ // Normalize the refresh-group tag(s) to a stable, deduped, sorted list. The
261
+ // joined `groupKey` string is the subscribe effect's dependency, so passing an
262
+ // inline array literal (`refreshGroup={["a", "b"]}`) does not force a
263
+ // resubscribe on every render. An empty list means "no groups" — identical to
264
+ // omitting the option (`hasGroups` stays false, no private bucket is created).
265
+ const refreshGroupOption = options?.refreshGroup;
266
+ const groupKey =
267
+ refreshGroupOption === undefined
268
+ ? ""
269
+ : JSON.stringify(
270
+ typeof refreshGroupOption === "string"
271
+ ? [refreshGroupOption]
272
+ : [...new Set(refreshGroupOption)].sort(),
273
+ );
274
+ const groupList = useMemo<string[]>(
275
+ () => (groupKey === "" ? [] : (JSON.parse(groupKey) as string[])),
276
+ [groupKey],
277
+ );
278
+ const hasGroups = groupList.length > 0;
279
+ // A grouped reader with no explicit key gets a private per-hook bucket so a
280
+ // cross-loader group refresh cannot leak into the bare `loader.$$id` bucket
281
+ // shared by unrelated unkeyed readers. Sharing within a group is opt-in via
282
+ // an explicit `key`.
283
+ const privateBucketIdRef = useRef<string | null>(null);
284
+ if (hasGroups && key === undefined && privateBucketIdRef.current === null) {
285
+ privateBucketIdRef.current = `__rg${privateGroupBucketSeq++}`;
286
+ }
287
+ const effectiveKey =
288
+ key ?? (hasGroups ? privateBucketIdRef.current! : undefined);
289
+ const bucketKey =
290
+ effectiveKey === undefined ? loaderId : `${loaderId}::${effectiveKey}`;
291
+
292
+ // Plain-GET refresh thunk registered with the store for cross-loader group
293
+ // refresh (useRefreshLoaders). Always shares into this hook's bucket, never
294
+ // touches lastSharedRequestIdRef (so a group refresh never render-throws —
295
+ // errors surface via `error` and reject the refreshGroups() promise instead),
296
+ // and sends no params/body. Stable across navigations (depends only on
297
+ // loaderId + bucketKey), so the store keeps one current thunk per bucket.
298
+ const groupRefetch = useCallback(async (): Promise<void> => {
299
+ if (!loaderId) return;
300
+ const requestId = loaderStore.reserveRequestId(bucketKey);
301
+ loaderStore.beginRequest(bucketKey, requestId);
302
+ try {
303
+ const url = new URL(window.location.href);
304
+ url.searchParams.set("_rsc_loader", loaderId);
305
+ const response = fetch(url.toString(), {
306
+ method: "GET",
307
+ headers: { Accept: "text/x-component" },
308
+ });
309
+ const { createFromFetch } = await import("./deps/browser.js");
310
+ const payload = await createFromFetch<LoaderRscPayload<T>>(response);
311
+ if (payload.loaderError) {
312
+ throw new Error(payload.loaderError.message);
313
+ }
314
+ loaderStore.finishData(bucketKey, requestId, payload.loaderResult);
315
+ } catch (e) {
316
+ const err = e instanceof Error ? e : new Error(String(e));
317
+ loaderStore.finishError(bucketKey, requestId, err);
318
+ throw err;
319
+ } finally {
320
+ loaderStore.setLoading(bucketKey, requestId, false);
321
+ }
322
+ }, [loaderId, bucketKey]);
323
+
324
+ const [sharedState, setSharedState] = useState<{
325
+ bucketKey: string;
326
+ snapshot: LoaderEntry;
327
+ }>(() => ({
328
+ bucketKey,
329
+ snapshot: loaderStore.getSnapshot(bucketKey),
330
+ }));
331
+ const sharedSnapshot =
332
+ sharedState.bucketKey === bucketKey
333
+ ? sharedState.snapshot
334
+ : loaderStore.getSnapshot(bucketKey);
335
+ useEffect(() => {
336
+ // Sync any value the store committed between this hook's lazy
337
+ // initializer and effect-time (e.g. a sibling that mounted earlier
338
+ // already triggered a load()).
339
+ const initial = loaderStore.getSnapshot(bucketKey);
340
+ if (initial !== sharedSnapshot) {
341
+ startTransition(() => {
342
+ setSharedState({ bucketKey, snapshot: initial });
343
+ });
344
+ }
345
+ // ephemeral: a reader with no route context has no route-context reset
346
+ // trigger, so its keyed bucket is reference-counted by the store. A
347
+ // route-registered reader makes the bucket sticky (reset via clearFamily).
348
+ return loaderStore.subscribe(
349
+ bucketKey,
350
+ () => {
351
+ const next = loaderStore.getSnapshot(bucketKey);
352
+ startTransition(() => {
353
+ setSharedState({ bucketKey, snapshot: next });
354
+ });
355
+ },
356
+ {
357
+ loaderId,
358
+ ephemeral: !hasContextData,
359
+ group: hasGroups ? groupList : undefined,
360
+ refetch: hasGroups ? groupRefetch : undefined,
361
+ },
362
+ );
363
+ // eslint-disable-next-line react-hooks/exhaustive-deps -- intentional:
364
+ // sharedSnapshot is captured for the one-shot init sync; we don't want
365
+ // to re-subscribe on every snapshot change. bucketKey, hasContextData,
366
+ // groupKey, and groupRefetch are the only inputs that require a fresh
367
+ // subscription (groupList is memoized on groupKey; groupRefetch is stable
368
+ // per bucketKey).
369
+ }, [bucketKey, hasContextData, groupKey, groupRefetch]);
370
+
371
+ // Local state holds the result of:
372
+ // - parameterized / mutation `load()` calls (load({ params }), POST,
373
+ // etc.) — stay scoped so concurrent same-loader different-params
374
+ // fetches don't clobber each other through the shared store;
375
+ // - any `load()` made by hooks that are NOT in route context (i.e.
376
+ // useFetchLoader of an unregistered loader) — keeping those local
377
+ // prevents two unrelated components from accidentally sharing data
378
+ // through the global store just because they reference the same
379
+ // loader id.
380
+ // `has` distinguishes a committed local result (including `null`/`undefined`)
381
+ // from "no local load yet", so a load() that resolves to a falsy value is not
382
+ // discarded in favor of the shared snapshot or the seeded context.
383
+ const [localFetchedData, setLocalFetchedData] = useState<{
384
+ has: boolean;
385
+ value: T | undefined;
386
+ }>({ has: false, value: undefined });
387
+ const [localIsLoading, setLocalIsLoading] = useState(false);
388
+ const [localError, setLocalError] = useState<Error | null>(null);
389
+
390
+ // Local request id, mirrors the per-hook gating the previous
391
+ // implementation provided. Two quick parameterized loads from the same
392
+ // hook (e.g. load({ params: { q: "a" } }) then load({ params: { q: "b" } }))
393
+ // can resolve out of order — only the latest must commit.
394
+ const localRequestIdRef = useRef(0);
395
+
396
+ // Tracks the request id of the most recent SHARED load() this hook
397
+ // initiated. The render-throw rule below uses it to scope the throw
398
+ // to the originating hook only — sibling readers see the error in
399
+ // `error` but don't blow up their own boundaries.
400
+ const lastSharedRequestIdRef = useRef<number | null>(null);
401
+
402
+ // Reset on navigation. clear() bumps the entry's latest request id so
403
+ // any pre-navigation load() promise that resolves later fails its gate
404
+ // and is dropped — fixes the race where a stale fetch overwrites the
405
+ // new route's context.
96
406
  const prevContextDataRef = useRef(contextData);
97
407
  useEffect(() => {
98
408
  if (prevContextDataRef.current !== contextData) {
99
- // Navigation happened, clear fetched data so context takes precedence
100
- setFetchedData(undefined);
101
- setError(null);
409
+ setLocalFetchedData({ has: false, value: undefined });
410
+ setLocalIsLoading(false);
411
+ setLocalError(null);
412
+ lastSharedRequestIdRef.current = null;
413
+ // Reset every sticky bucket of this loader (keyed or not). Ephemeral
414
+ // (unregistered keyed) buckets are left to their refcount lifecycle.
415
+ loaderStore.clearFamily(loaderId);
102
416
  prevContextDataRef.current = contextData;
103
417
  }
104
- }, [contextData]);
105
-
106
- // Data priority: fetched data (if any) > context data
107
- const data = fetchedData ?? contextData;
418
+ }, [contextData, loaderId]);
419
+
420
+ // Read priority: a committed parameterized load() result overrides the shared
421
+ // snapshot; a committed shared snapshot overrides the server-seeded context.
422
+ // `has`/`hasValue` gate each level so a committed falsy value is not skipped.
423
+ const data = localFetchedData.has
424
+ ? localFetchedData.value
425
+ : sharedSnapshot.hasValue
426
+ ? (sharedSnapshot.value as T | undefined)
427
+ : contextData;
428
+ const isLoading = localIsLoading || sharedSnapshot.isLoading;
429
+ const error = localError ?? sharedSnapshot.error;
108
430
 
109
431
  const throwOnError = options?.throwOnError ?? true;
110
432
 
111
- // Load function for fetching data
433
+ // Refs for values used inside load() that should NOT cause callback identity
434
+ // churn. loader.$$id can change if a reusable component receives a different
435
+ // loader without remounting; data changes on every navigation. Refs keep the
436
+ // callback stable while always reading the latest values.
437
+ const loaderIdRef = useRef(loaderId);
438
+ loaderIdRef.current = loaderId;
439
+ const bucketKeyRef = useRef(bucketKey);
440
+ bucketKeyRef.current = bucketKey;
441
+ const dataRef = useRef(data);
442
+ dataRef.current = data;
443
+ const hasContextDataRef = useRef(hasContextData);
444
+ hasContextDataRef.current = hasContextData;
445
+
446
+ // Load function for fetching data via the ?_rsc_loader endpoint.
447
+ // Supports GET (data fetching) and POST/PUT/PATCH/DELETE (mutations).
112
448
  const load = useCallback(
113
449
  async (loadOptions?: LoadOptions): Promise<T> => {
114
- // Verify the loader has $$id
115
- if (!loader.$$id) {
450
+ const id = loaderIdRef.current;
451
+ if (!id) {
116
452
  throw new Error(
117
- `Loader is missing $$id. Make sure the exposeLoaderId Vite plugin is enabled.`
453
+ `Loader is missing $$id. Make sure the exposeLoaderId Vite plugin is enabled.`,
118
454
  );
119
455
  }
120
456
 
121
- setIsLoading(true);
122
- setError(null);
457
+ const bucket = bucketKeyRef.current;
458
+ // A dedicated bucket means this read owns a bucket distinct from the bare
459
+ // loader id — either an explicit `key` (`$$id::key`) or a refreshGroup's
460
+ // private bucket (`$$id::<private>`).
461
+ const hasDedicatedBucket = bucket !== id;
462
+
463
+ // Deciding shared vs local:
464
+ // - With a dedicated bucket, every shareable GET (params allowed) writes
465
+ // to that bucket — the key/group is an explicit opt-in to sharing, and
466
+ // a direct load() must land in the same bucket a group refresh uses.
467
+ // - On the bare loader-id bucket, sharing is only correct when the
468
+ // loader is registered on the route and the call is a plain refetch —
469
+ // otherwise two unrelated components calling load() on the same
470
+ // fetchable loader would overwrite each other's local view.
471
+ // Mutations (non-GET / body) stay local in both cases.
472
+ const shared = hasDedicatedBucket
473
+ ? isShareableGet(loadOptions)
474
+ : isPlainRefetch(loadOptions) && hasContextDataRef.current;
475
+ let sharedRequestId = -1;
476
+ let localRequestId = -1;
477
+ if (shared) {
478
+ sharedRequestId = loaderStore.reserveRequestId(bucket);
479
+ lastSharedRequestIdRef.current = sharedRequestId;
480
+ // beginRequest flips loading on AND clears any prior error so a
481
+ // throwOnError: false consumer doesn't keep showing the stale
482
+ // error during the retry. Gated on requestId === latest.
483
+ loaderStore.beginRequest(bucket, sharedRequestId);
484
+ } else {
485
+ localRequestId = ++localRequestIdRef.current;
486
+ setLocalIsLoading(true);
487
+ setLocalError(null);
488
+ }
123
489
 
124
490
  try {
125
- const url = new URL(window.location.pathname, window.location.origin);
126
- url.searchParams.set("_rsc_loader", loader.$$id);
491
+ const url = new URL(window.location.href);
492
+ url.searchParams.set("_rsc_loader", id);
127
493
 
128
494
  const method = loadOptions?.method ?? "GET";
129
495
  const isBodyMethod = method !== "GET";
@@ -131,29 +497,58 @@ function useLoaderInternal<T>(
131
497
  let fetchOptions: RequestInit;
132
498
 
133
499
  if (isBodyMethod) {
134
- // POST/PUT/PATCH/DELETE - send params and body as JSON
135
- const bodyPayload: { params?: Record<string, string>; body?: unknown } = {};
136
- if (loadOptions?.params && Object.keys(loadOptions.params).length > 0) {
137
- bodyPayload.params = loadOptions.params;
138
- }
139
- if ("body" in (loadOptions ?? {}) && (loadOptions as any).body !== undefined) {
140
- bodyPayload.body = (loadOptions as any).body;
500
+ const bodyValue =
501
+ "body" in (loadOptions ?? {})
502
+ ? (loadOptions as any).body
503
+ : undefined;
504
+ const hasParams =
505
+ loadOptions?.params && Object.keys(loadOptions.params).length > 0;
506
+
507
+ if (bodyValue instanceof FormData) {
508
+ // FormData body — send as multipart/form-data (preserves File objects).
509
+ // Params are appended as a JSON string in a special field.
510
+ if (hasParams) {
511
+ bodyValue.set(
512
+ "_rsc_loader_params",
513
+ JSON.stringify(loadOptions!.params),
514
+ );
515
+ }
516
+ fetchOptions = {
517
+ method,
518
+ headers: { Accept: "text/x-component" },
519
+ body: bodyValue,
520
+ };
521
+ } else {
522
+ // JSON body — send params and body as JSON
523
+ const bodyPayload: {
524
+ params?: Record<string, string>;
525
+ body?: unknown;
526
+ } = {};
527
+ if (hasParams) {
528
+ bodyPayload.params = loadOptions!.params;
529
+ }
530
+ if (bodyValue !== undefined) {
531
+ bodyPayload.body = bodyValue;
532
+ }
533
+
534
+ fetchOptions = {
535
+ method,
536
+ headers: {
537
+ Accept: "text/x-component",
538
+ "Content-Type": "application/json",
539
+ },
540
+ body: JSON.stringify(bodyPayload),
541
+ };
141
542
  }
142
-
143
- fetchOptions = {
144
- method,
145
- headers: {
146
- Accept: "text/x-component",
147
- "Content-Type": "application/json",
148
- },
149
- body: JSON.stringify(bodyPayload),
150
- };
151
543
  } else {
152
544
  // GET - send params in query string
153
- if (loadOptions?.params && Object.keys(loadOptions.params).length > 0) {
545
+ if (
546
+ loadOptions?.params &&
547
+ Object.keys(loadOptions.params).length > 0
548
+ ) {
154
549
  url.searchParams.set(
155
550
  "_rsc_loader_params",
156
- JSON.stringify(loadOptions.params)
551
+ JSON.stringify(loadOptions.params),
157
552
  );
158
553
  }
159
554
 
@@ -175,73 +570,67 @@ function useLoaderInternal<T>(
175
570
  }
176
571
 
177
572
  const result = payload.loaderResult;
178
- setFetchedData(result);
573
+ if (shared) {
574
+ // finishData is gated on requestId; a stale response is dropped.
575
+ loaderStore.finishData(bucket, sharedRequestId, result);
576
+ } else if (localRequestId === localRequestIdRef.current) {
577
+ // Local-branch gate, mirrors the shared-branch requestId check:
578
+ // if a newer load() was issued from this hook before this one
579
+ // resolved, drop the stale result.
580
+ startTransition(() => {
581
+ setLocalFetchedData({ has: true, value: result });
582
+ setLocalIsLoading(false);
583
+ });
584
+ }
179
585
  return result;
180
586
  } catch (e) {
181
587
  const err = e instanceof Error ? e : new Error(String(e));
182
- setError(err);
183
- if (throwOnError) {
184
- throw err;
588
+ if (shared) {
589
+ loaderStore.finishError(bucket, sharedRequestId, err);
590
+ } else if (localRequestId === localRequestIdRef.current) {
591
+ setLocalError(err);
592
+ setLocalIsLoading(false);
185
593
  }
186
- // When throwOnError is false, return the current data (previous successful
187
- // value or undefined). Caller should check error state for error handling.
188
- return data as T;
189
- } finally {
190
- setIsLoading(false);
191
- }
192
- },
193
- [throwOnError]
194
- );
195
-
196
- // Form action for progressive enhancement
197
- // This wrapper is for useFetchLoader's load.action - it manages state internally
198
- // and doesn't use React's useActionState. For true PE, use loader.action directly
199
- // with useActionState.
200
- const action = useCallback(
201
- async (formData: FormData): Promise<void> => {
202
- if (!loader.action) {
203
- throw new Error(
204
- `Loader "${loader.$$id}" does not have an action. ` +
205
- `Make sure the loader is created with fetchable: true.`
206
- );
207
- }
208
-
209
- setIsLoading(true);
210
- setError(null);
211
-
212
- try {
213
- // Pass null as prevState - this wrapper manages state internally
214
- const result = await loader.action(null, formData);
215
- setFetchedData(result);
216
- } catch (e) {
217
- const err = e instanceof Error ? e : new Error(String(e));
218
- setError(err);
219
594
  if (throwOnError) {
220
595
  throw err;
221
596
  }
597
+ // When throwOnError is false, return the latest data snapshot (previous
598
+ // successful value or undefined). Caller should check error state.
599
+ return dataRef.current as T;
222
600
  } finally {
223
- setIsLoading(false);
601
+ if (shared) {
602
+ // setLoading is gated; only the latest request flips the flag off.
603
+ loaderStore.setLoading(bucket, sharedRequestId, false);
604
+ }
224
605
  }
225
606
  },
226
- [throwOnError]
607
+ [throwOnError],
227
608
  );
228
609
 
229
- // Attach action to load function
230
- const loadWithAction = load as LoadFunction<T>;
231
- loadWithAction.action = action;
232
-
233
- // Throw during render if there's an error and throwOnError is true
234
- // This allows ErrorBoundaries to catch async errors from load()
235
- if (error && throwOnError) {
236
- throw error;
610
+ // Throw during render if there's an error and throwOnError is true.
611
+ // - Local errors always belong to this hook, so always throw on opt-in.
612
+ // - Shared errors throw only when this hook initiated the failing
613
+ // request (entry.requestId matches lastSharedRequestIdRef). Sibling
614
+ // readers expose the error via `error` but do not throw, so a
615
+ // throwOnError: true reader never explodes because of someone else's
616
+ // throwOnError: false load() failure.
617
+ if (throwOnError) {
618
+ if (localError) throw localError;
619
+ if (
620
+ sharedSnapshot.error &&
621
+ lastSharedRequestIdRef.current !== null &&
622
+ sharedSnapshot.requestId === lastSharedRequestIdRef.current
623
+ ) {
624
+ throw sharedSnapshot.error;
625
+ }
237
626
  }
238
627
 
239
628
  return {
240
629
  data,
241
630
  isLoading,
242
631
  error,
243
- load: loadWithAction,
244
- refetch: loadWithAction,
632
+ load,
633
+ refetch: load,
245
634
  };
246
635
  }
247
636
 
@@ -276,8 +665,8 @@ function useLoaderInternal<T>(
276
665
  */
277
666
  export function useLoader<T>(
278
667
  loader: LoaderDefinition<T>,
279
- options?: UseLoaderOptions
280
- ): UseLoaderResult<T> {
668
+ options?: UseLoaderOptions,
669
+ ): UseLoaderResult<Rango.FlightSerialize<T>> {
281
670
  const result = useLoaderInternal(loader, options);
282
671
 
283
672
  // Strict mode: throw if data is not in context
@@ -285,11 +674,11 @@ export function useLoader<T>(
285
674
  throw new Error(
286
675
  `useLoader: Loader "${loader.$$id}" data not found in context. ` +
287
676
  `Make sure the loader is registered on the route with loader(). ` +
288
- `If you need on-demand fetching, use useFetchLoader() instead.`
677
+ `If you need on-demand fetching, use useFetchLoader() instead.`,
289
678
  );
290
679
  }
291
680
 
292
- return result as UseLoaderResult<T>;
681
+ return result as UseLoaderResult<Rango.FlightSerialize<T>>;
293
682
  }
294
683
 
295
684
  /**
@@ -340,7 +729,69 @@ export function useLoader<T>(
340
729
  */
341
730
  export function useFetchLoader<T>(
342
731
  loader: LoaderDefinition<T>,
343
- options?: UseLoaderOptions
344
- ): UseFetchLoaderResult<T> {
345
- return useLoaderInternal(loader, options);
732
+ options?: UseLoaderOptions,
733
+ ): UseFetchLoaderResult<Rango.FlightSerialize<T>> {
734
+ return useLoaderInternal(loader, options) as UseFetchLoaderResult<
735
+ Rango.FlightSerialize<T>
736
+ >;
737
+ }
738
+
739
+ /**
740
+ * Get a stable function that refreshes loaders by cross-loader group tag.
741
+ *
742
+ * The returned `refresh(groups)` takes one group name or an array of names and
743
+ * re-runs every currently-mounted read tagged with ANY of them, with a plain GET
744
+ * against the current route URL. This is the cross-loader counterpart to the
745
+ * single-loader `key`: use it to refresh a set of DIFFERENT loaders together
746
+ * (e.g. profile + orders after an account switch). Members are tagged via
747
+ * `useLoader(Loader, { refreshGroup })` / `useFetchLoader(Loader, { refreshGroup })`,
748
+ * where `refreshGroup` is one name or several.
749
+ *
750
+ * Passing the group(s) to the returned function rather than to the hook lets a
751
+ * single `useRefreshLoaders()` instance refresh different groups depending on
752
+ * context, and lets one call refresh several groups at once — their members are
753
+ * unioned and deduped, so a loader tagged into two of the named groups is fetched
754
+ * exactly once.
755
+ *
756
+ * Group refresh never render-throws: a failing member surfaces its error via
757
+ * that read's `error` state, and the returned promise rejects with an
758
+ * `AggregateError` of the failures so the caller can handle them at the await
759
+ * site. Each loader is refreshed in place — no params, no body, no mutations.
760
+ *
761
+ * @example
762
+ * ```tsx
763
+ * "use client";
764
+ * import { useLoader, useRefreshLoaders } from "rsc-router/client";
765
+ *
766
+ * function Profile() {
767
+ * const { data } = useLoader(ProfileLoader, { key: userId, refreshGroup: "account" });
768
+ * return <span>{data.name}</span>;
769
+ * }
770
+ * function Orders() {
771
+ * // Tagged into two groups: refreshed by "account" (the whole set) or "orders".
772
+ * const { data } = useLoader(OrdersLoader, {
773
+ * key: userId,
774
+ * refreshGroup: ["account", "orders"],
775
+ * });
776
+ * return <span>{data.count} orders</span>;
777
+ * }
778
+ * function RefreshButtons() {
779
+ * const refresh = useRefreshLoaders();
780
+ * return (
781
+ * <>
782
+ * <button onClick={() => refresh("account")}>Refresh account</button>
783
+ * <button onClick={() => refresh("orders")}>Refresh orders</button>
784
+ * <button onClick={() => refresh(["account", "orders"])}>Refresh both</button>
785
+ * </>
786
+ * );
787
+ * }
788
+ * ```
789
+ */
790
+ export function useRefreshLoaders(): (
791
+ groups: string | string[],
792
+ ) => Promise<void> {
793
+ return useCallback(
794
+ (groups: string | string[]) => loaderStore.refreshGroups(groups),
795
+ [],
796
+ );
346
797
  }