@rangojs/router 0.0.0-experimental.0b82333f

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 (1108) hide show
  1. package/AGENTS.md +9 -0
  2. package/README.md +899 -0
  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/dist/__mocks__/version.js +7 -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 +1601 -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/dist/href-context.d.ts +29 -0
  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 +5214 -0
  798. package/dist/vite/index.js.map +1 -0
  799. package/dist/vite/index.named-routes.gen.ts +103 -0
  800. package/dist/vite/package-resolution.d.ts +43 -0
  801. package/dist/vite/package-resolution.d.ts.map +1 -0
  802. package/dist/vite/package-resolution.js +112 -0
  803. package/dist/vite/package-resolution.js.map +1 -0
  804. package/dist/vite/virtual-entries.d.ts +25 -0
  805. package/dist/vite/virtual-entries.d.ts.map +1 -0
  806. package/dist/vite/virtual-entries.js +110 -0
  807. package/dist/vite/virtual-entries.js.map +1 -0
  808. package/package.json +177 -0
  809. package/skills/breadcrumbs/SKILL.md +250 -0
  810. package/skills/cache-guide/SKILL.md +262 -0
  811. package/skills/caching/SKILL.md +220 -0
  812. package/skills/composability/SKILL.md +172 -0
  813. package/skills/debug-manifest/SKILL.md +112 -0
  814. package/skills/document-cache/SKILL.md +182 -0
  815. package/skills/fonts/SKILL.md +167 -0
  816. package/skills/hooks/SKILL.md +704 -0
  817. package/skills/host-router/SKILL.md +218 -0
  818. package/skills/intercept/SKILL.md +313 -0
  819. package/skills/layout/SKILL.md +310 -0
  820. package/skills/links/SKILL.md +239 -0
  821. package/skills/loader/SKILL.md +596 -0
  822. package/skills/middleware/SKILL.md +339 -0
  823. package/skills/mime-routes/SKILL.md +128 -0
  824. package/skills/parallel/SKILL.md +305 -0
  825. package/skills/prerender/SKILL.md +643 -0
  826. package/skills/rango/SKILL.md +118 -0
  827. package/skills/response-routes/SKILL.md +411 -0
  828. package/skills/route/SKILL.md +385 -0
  829. package/skills/router-setup/SKILL.md +439 -0
  830. package/skills/tailwind/SKILL.md +129 -0
  831. package/skills/theme/SKILL.md +79 -0
  832. package/skills/typesafety/SKILL.md +623 -0
  833. package/skills/use-cache/SKILL.md +324 -0
  834. package/src/__internal.ts +273 -0
  835. package/src/bin/rango.ts +321 -0
  836. package/src/browser/action-coordinator.ts +97 -0
  837. package/src/browser/action-response-classifier.ts +99 -0
  838. package/src/browser/event-controller.ts +899 -0
  839. package/src/browser/history-state.ts +80 -0
  840. package/src/browser/index.ts +18 -0
  841. package/src/browser/intercept-utils.ts +52 -0
  842. package/src/browser/link-interceptor.ts +141 -0
  843. package/src/browser/logging.ts +55 -0
  844. package/src/browser/merge-segment-loaders.ts +134 -0
  845. package/src/browser/navigation-bridge.ts +640 -0
  846. package/src/browser/navigation-client.ts +215 -0
  847. package/src/browser/navigation-store.ts +806 -0
  848. package/src/browser/navigation-transaction.ts +295 -0
  849. package/src/browser/network-error-handler.ts +61 -0
  850. package/src/browser/partial-update.ts +552 -0
  851. package/src/browser/prefetch/cache.ts +154 -0
  852. package/src/browser/prefetch/fetch.ts +135 -0
  853. package/src/browser/prefetch/observer.ts +65 -0
  854. package/src/browser/prefetch/policy.ts +48 -0
  855. package/src/browser/prefetch/queue.ts +88 -0
  856. package/src/browser/rango-state.ts +112 -0
  857. package/src/browser/react/Link.tsx +360 -0
  858. package/src/browser/react/NavigationProvider.tsx +386 -0
  859. package/src/browser/react/ScrollRestoration.tsx +94 -0
  860. package/src/browser/react/context.ts +59 -0
  861. package/src/browser/react/filter-segment-order.ts +11 -0
  862. package/src/browser/react/index.ts +52 -0
  863. package/src/browser/react/location-state-shared.ts +162 -0
  864. package/src/browser/react/location-state.ts +107 -0
  865. package/src/browser/react/mount-context.ts +37 -0
  866. package/src/browser/react/nonce-context.ts +23 -0
  867. package/src/browser/react/shallow-equal.ts +27 -0
  868. package/src/browser/react/use-action.ts +218 -0
  869. package/src/browser/react/use-client-cache.ts +58 -0
  870. package/src/browser/react/use-handle.ts +162 -0
  871. package/src/browser/react/use-href.tsx +40 -0
  872. package/src/browser/react/use-link-status.ts +135 -0
  873. package/src/browser/react/use-mount.ts +31 -0
  874. package/src/browser/react/use-navigation.ts +99 -0
  875. package/src/browser/react/use-params.ts +65 -0
  876. package/src/browser/react/use-pathname.ts +47 -0
  877. package/src/browser/react/use-router.ts +63 -0
  878. package/src/browser/react/use-search-params.ts +56 -0
  879. package/src/browser/react/use-segments.ts +171 -0
  880. package/src/browser/response-adapter.ts +73 -0
  881. package/src/browser/rsc-router.tsx +431 -0
  882. package/src/browser/scroll-restoration.ts +384 -0
  883. package/src/browser/segment-reconciler.ts +216 -0
  884. package/src/browser/segment-structure-assert.ts +83 -0
  885. package/src/browser/server-action-bridge.ts +667 -0
  886. package/src/browser/shallow.ts +40 -0
  887. package/src/browser/types.ts +538 -0
  888. package/src/browser/validate-redirect-origin.ts +29 -0
  889. package/src/build/generate-manifest.ts +438 -0
  890. package/src/build/generate-route-types.ts +36 -0
  891. package/src/build/index.ts +35 -0
  892. package/src/build/route-trie.ts +265 -0
  893. package/src/build/route-types/ast-helpers.ts +25 -0
  894. package/src/build/route-types/ast-route-extraction.ts +98 -0
  895. package/src/build/route-types/codegen.ts +102 -0
  896. package/src/build/route-types/include-resolution.ts +411 -0
  897. package/src/build/route-types/param-extraction.ts +48 -0
  898. package/src/build/route-types/per-module-writer.ts +128 -0
  899. package/src/build/route-types/router-processing.ts +469 -0
  900. package/src/build/route-types/scan-filter.ts +78 -0
  901. package/src/build/runtime-discovery.ts +231 -0
  902. package/src/cache/background-task.ts +34 -0
  903. package/src/cache/cache-key-utils.ts +44 -0
  904. package/src/cache/cache-policy.ts +125 -0
  905. package/src/cache/cache-runtime.ts +338 -0
  906. package/src/cache/cache-scope.ts +382 -0
  907. package/src/cache/cf/cf-cache-store.ts +540 -0
  908. package/src/cache/cf/index.ts +25 -0
  909. package/src/cache/document-cache.ts +369 -0
  910. package/src/cache/handle-capture.ts +81 -0
  911. package/src/cache/handle-snapshot.ts +41 -0
  912. package/src/cache/index.ts +43 -0
  913. package/src/cache/memory-segment-store.ts +328 -0
  914. package/src/cache/profile-registry.ts +73 -0
  915. package/src/cache/read-through-swr.ts +134 -0
  916. package/src/cache/segment-codec.ts +256 -0
  917. package/src/cache/taint.ts +98 -0
  918. package/src/cache/types.ts +342 -0
  919. package/src/client.rsc.tsx +85 -0
  920. package/src/client.tsx +601 -0
  921. package/src/component-utils.ts +76 -0
  922. package/src/components/DefaultDocument.tsx +27 -0
  923. package/src/context-var.ts +86 -0
  924. package/src/debug.ts +243 -0
  925. package/src/default-error-boundary.tsx +88 -0
  926. package/src/deps/browser.ts +8 -0
  927. package/src/deps/html-stream-client.ts +2 -0
  928. package/src/deps/html-stream-server.ts +2 -0
  929. package/src/deps/rsc.ts +10 -0
  930. package/src/deps/ssr.ts +2 -0
  931. package/src/errors.ts +365 -0
  932. package/src/handle.ts +135 -0
  933. package/src/handles/MetaTags.tsx +246 -0
  934. package/src/handles/breadcrumbs.ts +66 -0
  935. package/src/handles/index.ts +7 -0
  936. package/src/handles/meta.ts +264 -0
  937. package/src/host/cookie-handler.ts +165 -0
  938. package/src/host/errors.ts +97 -0
  939. package/src/host/index.ts +53 -0
  940. package/src/host/pattern-matcher.ts +214 -0
  941. package/src/host/router.ts +352 -0
  942. package/src/host/testing.ts +79 -0
  943. package/src/host/types.ts +146 -0
  944. package/src/host/utils.ts +25 -0
  945. package/src/href-client.ts +222 -0
  946. package/src/index.rsc.ts +233 -0
  947. package/src/index.ts +277 -0
  948. package/src/internal-debug.ts +11 -0
  949. package/src/loader.rsc.ts +89 -0
  950. package/src/loader.ts +64 -0
  951. package/src/network-error-thrower.tsx +23 -0
  952. package/src/outlet-context.ts +15 -0
  953. package/src/outlet-provider.tsx +45 -0
  954. package/src/prerender/param-hash.ts +37 -0
  955. package/src/prerender/store.ts +185 -0
  956. package/src/prerender.ts +463 -0
  957. package/src/reverse.ts +330 -0
  958. package/src/root-error-boundary.tsx +289 -0
  959. package/src/route-content-wrapper.tsx +196 -0
  960. package/src/route-definition/dsl-helpers.ts +934 -0
  961. package/src/route-definition/helper-factories.ts +200 -0
  962. package/src/route-definition/helpers-types.ts +430 -0
  963. package/src/route-definition/index.ts +52 -0
  964. package/src/route-definition/redirect.ts +93 -0
  965. package/src/route-definition.ts +1 -0
  966. package/src/route-map-builder.ts +275 -0
  967. package/src/route-name.ts +53 -0
  968. package/src/route-types.ts +259 -0
  969. package/src/router/content-negotiation.ts +116 -0
  970. package/src/router/debug-manifest.ts +72 -0
  971. package/src/router/error-handling.ts +287 -0
  972. package/src/router/find-match.ts +158 -0
  973. package/src/router/handler-context.ts +451 -0
  974. package/src/router/intercept-resolution.ts +395 -0
  975. package/src/router/lazy-includes.ts +234 -0
  976. package/src/router/loader-resolution.ts +420 -0
  977. package/src/router/logging.ts +248 -0
  978. package/src/router/manifest.ts +267 -0
  979. package/src/router/match-api.ts +620 -0
  980. package/src/router/match-context.ts +266 -0
  981. package/src/router/match-handlers.ts +440 -0
  982. package/src/router/match-middleware/background-revalidation.ts +223 -0
  983. package/src/router/match-middleware/cache-lookup.ts +634 -0
  984. package/src/router/match-middleware/cache-store.ts +295 -0
  985. package/src/router/match-middleware/index.ts +81 -0
  986. package/src/router/match-middleware/intercept-resolution.ts +306 -0
  987. package/src/router/match-middleware/segment-resolution.ts +192 -0
  988. package/src/router/match-pipelines.ts +179 -0
  989. package/src/router/match-result.ts +219 -0
  990. package/src/router/metrics.ts +282 -0
  991. package/src/router/middleware-cookies.ts +55 -0
  992. package/src/router/middleware-types.ts +222 -0
  993. package/src/router/middleware.ts +748 -0
  994. package/src/router/pattern-matching.ts +563 -0
  995. package/src/router/prerender-match.ts +402 -0
  996. package/src/router/preview-match.ts +170 -0
  997. package/src/router/revalidation.ts +289 -0
  998. package/src/router/router-context.ts +316 -0
  999. package/src/router/router-interfaces.ts +452 -0
  1000. package/src/router/router-options.ts +592 -0
  1001. package/src/router/router-registry.ts +24 -0
  1002. package/src/router/segment-resolution/fresh.ts +570 -0
  1003. package/src/router/segment-resolution/helpers.ts +263 -0
  1004. package/src/router/segment-resolution/loader-cache.ts +198 -0
  1005. package/src/router/segment-resolution/revalidation.ts +1239 -0
  1006. package/src/router/segment-resolution/static-store.ts +67 -0
  1007. package/src/router/segment-resolution.ts +21 -0
  1008. package/src/router/segment-wrappers.ts +289 -0
  1009. package/src/router/telemetry-otel.ts +299 -0
  1010. package/src/router/telemetry.ts +300 -0
  1011. package/src/router/timeout.ts +148 -0
  1012. package/src/router/trie-matching.ts +239 -0
  1013. package/src/router/types.ts +170 -0
  1014. package/src/router.ts +1002 -0
  1015. package/src/rsc/handler-context.ts +45 -0
  1016. package/src/rsc/handler.ts +1089 -0
  1017. package/src/rsc/helpers.ts +198 -0
  1018. package/src/rsc/index.ts +36 -0
  1019. package/src/rsc/loader-fetch.ts +209 -0
  1020. package/src/rsc/manifest-init.ts +86 -0
  1021. package/src/rsc/nonce.ts +32 -0
  1022. package/src/rsc/origin-guard.ts +141 -0
  1023. package/src/rsc/progressive-enhancement.ts +379 -0
  1024. package/src/rsc/response-error.ts +37 -0
  1025. package/src/rsc/response-route-handler.ts +347 -0
  1026. package/src/rsc/rsc-rendering.ts +237 -0
  1027. package/src/rsc/runtime-warnings.ts +42 -0
  1028. package/src/rsc/server-action.ts +348 -0
  1029. package/src/rsc/ssr-setup.ts +128 -0
  1030. package/src/rsc/types.ts +263 -0
  1031. package/src/search-params.ts +230 -0
  1032. package/src/segment-system.tsx +454 -0
  1033. package/src/server/context.ts +591 -0
  1034. package/src/server/cookie-store.ts +190 -0
  1035. package/src/server/fetchable-loader-store.ts +37 -0
  1036. package/src/server/handle-store.ts +308 -0
  1037. package/src/server/loader-registry.ts +133 -0
  1038. package/src/server/request-context.ts +914 -0
  1039. package/src/server/root-layout.tsx +10 -0
  1040. package/src/server/tsconfig.json +14 -0
  1041. package/src/server.ts +51 -0
  1042. package/src/ssr/index.tsx +365 -0
  1043. package/src/static-handler.ts +114 -0
  1044. package/src/theme/ThemeProvider.tsx +297 -0
  1045. package/src/theme/ThemeScript.tsx +61 -0
  1046. package/src/theme/constants.ts +62 -0
  1047. package/src/theme/index.ts +48 -0
  1048. package/src/theme/theme-context.ts +44 -0
  1049. package/src/theme/theme-script.ts +155 -0
  1050. package/src/theme/types.ts +182 -0
  1051. package/src/theme/use-theme.ts +44 -0
  1052. package/src/types/boundaries.ts +158 -0
  1053. package/src/types/cache-types.ts +198 -0
  1054. package/src/types/error-types.ts +192 -0
  1055. package/src/types/global-namespace.ts +100 -0
  1056. package/src/types/handler-context.ts +687 -0
  1057. package/src/types/index.ts +88 -0
  1058. package/src/types/loader-types.ts +183 -0
  1059. package/src/types/route-config.ts +170 -0
  1060. package/src/types/route-entry.ts +102 -0
  1061. package/src/types/segments.ts +148 -0
  1062. package/src/types.ts +1 -0
  1063. package/src/urls/include-helper.ts +197 -0
  1064. package/src/urls/index.ts +53 -0
  1065. package/src/urls/path-helper-types.ts +339 -0
  1066. package/src/urls/path-helper.ts +329 -0
  1067. package/src/urls/pattern-types.ts +95 -0
  1068. package/src/urls/response-types.ts +106 -0
  1069. package/src/urls/type-extraction.ts +372 -0
  1070. package/src/urls/urls-function.ts +98 -0
  1071. package/src/urls.ts +1 -0
  1072. package/src/use-loader.tsx +354 -0
  1073. package/src/vite/discovery/bundle-postprocess.ts +184 -0
  1074. package/src/vite/discovery/discover-routers.ts +344 -0
  1075. package/src/vite/discovery/prerender-collection.ts +385 -0
  1076. package/src/vite/discovery/route-types-writer.ts +258 -0
  1077. package/src/vite/discovery/self-gen-tracking.ts +47 -0
  1078. package/src/vite/discovery/state.ts +110 -0
  1079. package/src/vite/discovery/virtual-module-codegen.ts +203 -0
  1080. package/src/vite/index.ts +16 -0
  1081. package/src/vite/plugin-types.ts +131 -0
  1082. package/src/vite/plugins/cjs-to-esm.ts +93 -0
  1083. package/src/vite/plugins/client-ref-dedup.ts +115 -0
  1084. package/src/vite/plugins/client-ref-hashing.ts +105 -0
  1085. package/src/vite/plugins/expose-action-id.ts +365 -0
  1086. package/src/vite/plugins/expose-id-utils.ts +287 -0
  1087. package/src/vite/plugins/expose-ids/export-analysis.ts +296 -0
  1088. package/src/vite/plugins/expose-ids/handler-transform.ts +179 -0
  1089. package/src/vite/plugins/expose-ids/loader-transform.ts +74 -0
  1090. package/src/vite/plugins/expose-ids/router-transform.ts +110 -0
  1091. package/src/vite/plugins/expose-ids/types.ts +45 -0
  1092. package/src/vite/plugins/expose-internal-ids.ts +569 -0
  1093. package/src/vite/plugins/refresh-cmd.ts +65 -0
  1094. package/src/vite/plugins/use-cache-transform.ts +323 -0
  1095. package/src/vite/plugins/version-injector.ts +83 -0
  1096. package/src/vite/plugins/version-plugin.ts +254 -0
  1097. package/src/vite/plugins/version.d.ts +12 -0
  1098. package/src/vite/plugins/virtual-entries.ts +123 -0
  1099. package/src/vite/plugins/virtual-stub-plugin.ts +29 -0
  1100. package/src/vite/rango.ts +510 -0
  1101. package/src/vite/router-discovery.ts +785 -0
  1102. package/src/vite/utils/ast-handler-extract.ts +517 -0
  1103. package/src/vite/utils/banner.ts +36 -0
  1104. package/src/vite/utils/bundle-analysis.ts +137 -0
  1105. package/src/vite/utils/manifest-utils.ts +70 -0
  1106. package/src/vite/utils/package-resolution.ts +121 -0
  1107. package/src/vite/utils/prerender-utils.ts +189 -0
  1108. package/src/vite/utils/shared-utils.ts +169 -0
@@ -0,0 +1,596 @@
1
+ ---
2
+ name: loader
3
+ description: Define data loaders for fetching data in routes with createLoader
4
+ argument-hint: [loader]
5
+ ---
6
+
7
+ # Data Loaders with loader()
8
+
9
+ Loaders fetch data on the server and stream it to the client.
10
+
11
+ ## Creating a Loader
12
+
13
+ ```typescript
14
+ import { createLoader } from "@rangojs/router";
15
+
16
+ export const ProductLoader = createLoader(async (ctx) => {
17
+ "use server";
18
+
19
+ const product = await ctx.env.DB.prepare(
20
+ "SELECT * FROM products WHERE slug = ?",
21
+ )
22
+ .bind(ctx.params.slug)
23
+ .first();
24
+
25
+ return { product };
26
+ });
27
+ ```
28
+
29
+ ### Supported export patterns
30
+
31
+ All of the following are equivalent and fully supported by the Vite transform:
32
+
33
+ ```typescript
34
+ // Direct export (most common)
35
+ export const ProductLoader = createLoader(handler);
36
+
37
+ // Separate declaration + named export
38
+ const ProductLoader = createLoader(handler);
39
+ export { ProductLoader };
40
+
41
+ // Aliased export
42
+ const InternalLoader = createLoader(handler);
43
+ export { InternalLoader as ProductLoader };
44
+
45
+ // Aliased import
46
+ import { createLoader as cl } from "@rangojs/router";
47
+ export const ProductLoader = cl(handler);
48
+ ```
49
+
50
+ The `export const` form and the `const + export { }` form both work for
51
+ client stubs, ID injection, and loader manifest tracking.
52
+
53
+ ## Using Loaders in Routes
54
+
55
+ ```typescript
56
+ import { urls } from "@rangojs/router";
57
+ import { ProductLoader } from "./loaders/product";
58
+
59
+ export const urlpatterns = urls(({ path, loader }) => [
60
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
61
+ loader(ProductLoader),
62
+ ]),
63
+ ]);
64
+ ```
65
+
66
+ ## Consuming Loader Data
67
+
68
+ Loaders are the **live data layer** — they resolve fresh on every request.
69
+ The way you consume them depends on whether you're in a server component
70
+ (route handler) or a client component.
71
+
72
+ > **IMPORTANT: Prefer consuming loaders in client components.** Keeping data
73
+ > fetching in loaders and consumption in client components creates a clean
74
+ > separation: the server-side handler renders static markup that can be
75
+ > freely cached with `cache()`, while loader data stays fresh on every
76
+ > request. When you consume loaders in server handlers via `ctx.use()`, the
77
+ > handler output depends on the loader data, which means caching the handler
78
+ > also caches the data — defeating the purpose of the live data layer.
79
+
80
+ ### In Client Components (Preferred)
81
+
82
+ Client components use `useLoader()` from `@rangojs/router/client`.
83
+ The loader **must** be registered with `loader()` in the route's DSL
84
+ segments so the framework knows to resolve it during SSR and stream
85
+ the data to the client:
86
+
87
+ ```typescript
88
+ "use client";
89
+ import { useLoader } from "@rangojs/router/client";
90
+ import { ProductLoader } from "./loaders/product";
91
+
92
+ function ProductDetails() {
93
+ const { data } = useLoader(ProductLoader);
94
+ return <div>{data.product.description}</div>;
95
+ }
96
+ ```
97
+
98
+ ```typescript
99
+ // Route definition — loader() registration required for client consumption
100
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
101
+ loader(ProductLoader), // Required for useLoader() in client components
102
+ ]);
103
+ ```
104
+
105
+ ### In Route Handlers (Server Components)
106
+
107
+ In server components, use `ctx.use(Loader)` directly in the route handler.
108
+ This doesn't require `loader()` registration in the DSL — it works
109
+ standalone. **However**, prefer client-side consumption when possible (see
110
+ note above).
111
+
112
+ ```typescript
113
+ import { ProductLoader } from "./loaders/product";
114
+
115
+ // Route handler — server component
116
+ path("/product/:slug", async (ctx) => {
117
+ const { product } = await ctx.use(ProductLoader);
118
+ return <h1>{product.name}</h1>;
119
+ }, { name: "product" })
120
+ ```
121
+
122
+ When you do register with `loader()` in the DSL, `ctx.use()` returns the
123
+ same memoized result — loaders never run twice per request.
124
+
125
+ **Never use `useLoader()` in server components** — it is a client-only API.
126
+
127
+ ### Summary
128
+
129
+ | Context | API | `loader()` DSL required? |
130
+ | ---------------------------- | ------------------- | ------------------------ |
131
+ | Client component (preferred) | `useLoader(Loader)` | **Yes** |
132
+ | Route handler (server) | `ctx.use(Loader)` | No |
133
+
134
+ ## Loader Context
135
+
136
+ Loaders receive the same context as route handlers:
137
+
138
+ ```typescript
139
+ export const ProductLoader = createLoader(async (ctx) => {
140
+ "use server";
141
+
142
+ // URL params (may include client-provided overrides for fetchable loaders)
143
+ const { slug } = ctx.params;
144
+
145
+ // Server-trusted route params (from URL pattern matching, cannot be overridden)
146
+ const { slug: trustedSlug } = ctx.routeParams;
147
+
148
+ // Query params
149
+ const variant = ctx.url.searchParams.get("variant");
150
+
151
+ // Platform bindings (DB, KV, etc.) — plain bindings from createRouter<TEnv>()
152
+ const db = ctx.env.DB;
153
+
154
+ // Request headers
155
+ const auth = ctx.request.headers.get("Authorization");
156
+
157
+ // Variables set by middleware (from RSCRouter.Vars augmentation)
158
+ const user = ctx.get("user");
159
+
160
+ return { product: await fetchProduct(slug) };
161
+ });
162
+ ```
163
+
164
+ ### params vs routeParams
165
+
166
+ - `ctx.params` — merged route params + explicit loader params. For fetchable
167
+ loaders called with `load(Loader, { params: { ... } })`, explicit params
168
+ override route-matched params.
169
+ - `ctx.routeParams` — server-trusted route params from URL pattern matching.
170
+ Cannot be overridden by client-provided params.
171
+
172
+ Use `ctx.routeParams` when you need trusted route identity for authorization
173
+ or resource scoping:
174
+
175
+ ```typescript
176
+ export const OrderLoader = createLoader(async (ctx) => {
177
+ "use server";
178
+
179
+ // Use routeParams for auth checks — client cannot spoof the URL-matched ID
180
+ const { orderId } = ctx.routeParams;
181
+ const user = ctx.get("user");
182
+
183
+ const order = await db.orders.get(orderId);
184
+ if (order.userId !== user.id)
185
+ throw new Response("Forbidden", { status: 403 });
186
+
187
+ return { order };
188
+ });
189
+ ```
190
+
191
+ ## Loader with Children
192
+
193
+ Add caching or revalidation to specific loaders:
194
+
195
+ ```typescript
196
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
197
+ // Cached loader
198
+ loader(ProductLoader, () => [cache({ ttl: 300 })]),
199
+
200
+ // Loader with revalidation control
201
+ loader(RelatedProductsLoader, () => [
202
+ revalidate(() => false), // Never revalidate
203
+ ]),
204
+
205
+ // Loader that revalidates after cart actions
206
+ loader(CartLoader, () => [
207
+ revalidate(({ actionId }) => actionId?.includes("Cart") ?? false),
208
+ ]),
209
+ ]);
210
+ ```
211
+
212
+ ### Revalidation Contracts for Loader Dependencies
213
+
214
+ If a loader reads `ctx.get()` data produced by an outer handler/layout, share
215
+ the same named revalidation contract across producer and consumer segments.
216
+
217
+ ```typescript
218
+ // revalidation-contracts.ts
219
+ export const revalidateAccountScope = ({ actionId }) =>
220
+ actionId?.includes("src/actions/account.ts#") ?? false;
221
+
222
+ layout(AccountLayout, () => [
223
+ revalidate(revalidateAccountScope), // producer reruns
224
+ path("/account/orders", OrdersPage, { name: "account.orders" }, () => [
225
+ loader(OrdersLoader, () => [
226
+ revalidate(revalidateAccountScope), // consumer reruns
227
+ ]),
228
+ ]),
229
+ ]);
230
+ ```
231
+
232
+ For segments that depend on multiple upstream domains, compose multiple
233
+ contracts on both sides.
234
+
235
+ To keep loader route trees concise, export helper wrappers:
236
+
237
+ ```typescript
238
+ import { revalidate } from "@rangojs/router";
239
+
240
+ export const revalidateAccount = () => [revalidate(revalidateAccountScope)];
241
+
242
+ layout(AccountLayout, () => [
243
+ revalidateAccount(),
244
+ path("/account/orders", OrdersPage, { name: "account.orders" }, () => [
245
+ loader(OrdersLoader, () => [revalidateAccount()]),
246
+ ]),
247
+ ]);
248
+ ```
249
+
250
+ ## Loaders: The Live Data Layer
251
+
252
+ Loaders are the live data layer of the router. They resolve fresh on every
253
+ request, even when the route's UI segments are served from cache. This is a
254
+ core design principle — route-level `cache()` caches rendered components but
255
+ never caches loader data. Loaders are excluded at storage time and re-resolved
256
+ on retrieval.
257
+
258
+ This means `cache()` gives you cached UI + fresh data by default. Pre-rendering
259
+ follows the same rule: at build time, loaders are skipped entirely (there is no
260
+ real request context), and at runtime the worker resolves them fresh against
261
+ the live database.
262
+
263
+ ### Opting a Loader into Caching
264
+
265
+ To cache a specific loader's data, attach a `cache()` child:
266
+
267
+ ```typescript
268
+ loader(ProductLoader, () => [cache({ ttl: 300 })]),
269
+ ```
270
+
271
+ The loader's data is cached independently from the route's segment cache,
272
+ using the same `SegmentCacheStore` (app-level or per-loader override).
273
+
274
+ Values are serialized through RSC Flight, so loaders can return ReactNode,
275
+ Promises, null, and any RSC-serializable type — all round-trip correctly
276
+ through the cache.
277
+
278
+ ### Cache Key
279
+
280
+ The default cache key is `loader:{loaderId}:{pathname}:{sortedParams}`.
281
+ This can be customized at two levels:
282
+
283
+ ```typescript
284
+ // Full override — key function replaces the default entirely
285
+ loader(ProductLoader, () => [
286
+ cache({
287
+ ttl: 300,
288
+ key: (ctx) => `product:${ctx.params.slug}:${cookies().get("locale")?.value ?? "en"}`,
289
+ }),
290
+ ]),
291
+
292
+ // Store-level keyGenerator — modifies the default key (e.g., adds a region prefix)
293
+ // Set in the store configuration, applies to all entries in that store
294
+ ```
295
+
296
+ Resolution priority (same as route-level `cache()`):
297
+
298
+ 1. `key(ctx)` from cache options — full override
299
+ 2. `store.keyGenerator(ctx, defaultKey)` — store-level modification
300
+ 3. Default key — `loader:{id}:{pathname}:{params}`
301
+
302
+ If a custom key function throws, it falls back to the default key silently
303
+ (logged to console.error).
304
+
305
+ ### Tags for Invalidation
306
+
307
+ ```typescript
308
+ // Static tags
309
+ loader(ProductLoader, () => [
310
+ cache({ ttl: 300, tags: ["products", "catalog"] }),
311
+ ]),
312
+
313
+ // Dynamic tags
314
+ loader(ProductLoader, () => [
315
+ cache({
316
+ ttl: 300,
317
+ tags: (ctx) => [`product:${ctx.params.slug}`, "products"],
318
+ }),
319
+ ]),
320
+ ```
321
+
322
+ ### Stale-While-Revalidate
323
+
324
+ ```typescript
325
+ loader(ProductLoader, () => [
326
+ cache({ ttl: 60, swr: 300 }),
327
+ ]),
328
+ ```
329
+
330
+ During the SWR window (60-360s), stale data is returned immediately while
331
+ fresh data is fetched in the background via `waitUntil`. After the SWR window
332
+ expires (360s+), the entry is treated as a cache miss.
333
+
334
+ ### Conditional Caching
335
+
336
+ Skip the cache at runtime based on request properties:
337
+
338
+ ```typescript
339
+ loader(ProductLoader, () => [
340
+ cache({
341
+ ttl: 300,
342
+ condition: (ctx) => !ctx.request.headers.has("authorization"),
343
+ }),
344
+ ]),
345
+ ```
346
+
347
+ When `condition` returns false, the loader runs fresh and the cache is bypassed
348
+ entirely (no read, no write).
349
+
350
+ ### Per-Loader Store Override
351
+
352
+ ```typescript
353
+ const hotStore = new MemorySegmentCacheStore({ defaults: { ttl: 10 } });
354
+
355
+ loader(PricingLoader, () => [
356
+ cache({ store: hotStore }),
357
+ ]),
358
+ ```
359
+
360
+ Without an explicit store, the loader uses the app-level store from the
361
+ handler config (`cache.store`).
362
+
363
+ ## Multiple Loaders
364
+
365
+ Routes can have multiple loaders that run in parallel:
366
+
367
+ ```typescript
368
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
369
+ loader(ProductLoader),
370
+ loader(RelatedProductsLoader),
371
+ loader(ReviewsLoader),
372
+ ]);
373
+ ```
374
+
375
+ ## Layout Loaders
376
+
377
+ Loaders on layouts are shared by all child routes:
378
+
379
+ ```typescript
380
+ layout(<ShopLayout />, () => [
381
+ // These loaders are available to all shop routes
382
+ loader(CartLoader),
383
+ loader(CategoriesLoader),
384
+
385
+ path("/shop", ShopIndex, { name: "index" }),
386
+ path("/shop/product/:slug", ProductPage, { name: "product" }),
387
+ ])
388
+ ```
389
+
390
+ ## Passing Loaders as Props
391
+
392
+ Loaders can be passed as props from server to client components. RSC serialization
393
+ uses `toJSON()` to send only `{ __brand, $$id }` — the loader function is stripped.
394
+
395
+ ```typescript
396
+ // Server component (route handler)
397
+ import { SlowLoader } from "../loaders";
398
+
399
+ path("/dashboard", () => <DashboardContent loader={SlowLoader} />, { name: "dashboard" }, () => [
400
+ loader(SlowLoader),
401
+ loading(<DashboardSkeleton />),
402
+ ])
403
+
404
+ // Client component — use typeof for type-safe props
405
+ "use client";
406
+ import { useLoader } from "@rangojs/router/client";
407
+ import type { SlowLoader } from "../loaders";
408
+
409
+ function DashboardContent({ loader }: { loader: typeof SlowLoader }) {
410
+ const { data } = useLoader(loader);
411
+ return <div>{data.message}</div>;
412
+ }
413
+ ```
414
+
415
+ Use `typeof MyLoader` for the prop type — it infers the full generic automatically.
416
+
417
+ ## Streaming with Suspense
418
+
419
+ Loaders stream data. Use Suspense for loading states:
420
+
421
+ ```typescript
422
+ // In route definition
423
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
424
+ loader(ProductLoader),
425
+ loading(<ProductSkeleton />), // Shows while loader streams
426
+ ])
427
+
428
+ // Or in component
429
+ function ProductPage() {
430
+ return (
431
+ <Suspense fallback={<ProductSkeleton />}>
432
+ <ProductDetails />
433
+ </Suspense>
434
+ );
435
+ }
436
+ ```
437
+
438
+ ## Fetchable Loaders
439
+
440
+ By default, loaders only run during SSR and navigation. Pass `true` as the second
441
+ argument to `createLoader` to make a loader **fetchable** — callable from the client
442
+ via `useFetchLoader()` and `load()`:
443
+
444
+ ```typescript
445
+ import { createLoader } from "@rangojs/router";
446
+
447
+ export const SearchLoader = createLoader(async (ctx) => {
448
+ "use server";
449
+
450
+ const query = ctx.params.query ?? "";
451
+ const results = await ctx.env.DB.prepare(
452
+ "SELECT * FROM products WHERE name LIKE ?",
453
+ )
454
+ .bind(`%${query}%`)
455
+ .all();
456
+
457
+ return { results: results.results ?? [] };
458
+ }, true); // true = fetchable
459
+ ```
460
+
461
+ ### Fetchable Loader with Middleware
462
+
463
+ Pass an options object instead of `true` to attach per-loader middleware.
464
+ This middleware runs only on `_rsc_loader` fetch requests (client-side
465
+ `load()` / `useFetchLoader()` calls), not during SSR `ctx.use()` execution:
466
+
467
+ ```typescript
468
+ import { createLoader } from "@rangojs/router";
469
+ import { authMiddleware } from "../middleware/auth";
470
+ import { rateLimitMiddleware } from "../middleware/rate-limit";
471
+
472
+ export const ProtectedLoader = createLoader(
473
+ async (ctx) => {
474
+ "use server";
475
+
476
+ const user = ctx.get("user");
477
+ return { orders: await db.orders.list(user.id) };
478
+ },
479
+ { middleware: [authMiddleware, rateLimitMiddleware] },
480
+ );
481
+ ```
482
+
483
+ The middleware uses the same `MiddlewareFn` signature as route/app middleware,
484
+ so you can reuse existing middleware functions directly.
485
+
486
+ Fetchable loaders support both GET and POST (PUT, PATCH, DELETE) from the client.
487
+ The `load()` function auto-detects the body type:
488
+
489
+ - **JSON body** (`body: { ... }`) — sent as `application/json`, available as `ctx.body`
490
+ - **FormData body** (`body: formData`) — sent as `multipart/form-data`, available as `ctx.formData`
491
+
492
+ ### Mutation Context
493
+
494
+ When a fetchable loader receives a POST/PUT/PATCH/DELETE request, the context
495
+ includes additional fields depending on the body type:
496
+
497
+ ```typescript
498
+ export const MutationLoader = createLoader(async (ctx) => {
499
+ "use server";
500
+
501
+ // JSON body — available as ctx.body (parsed object)
502
+ const data = ctx.body as { name: string; email: string };
503
+
504
+ // FormData body — available as ctx.formData
505
+ const file = ctx.formData?.get("file") as File | null;
506
+ const name = ctx.formData?.get("name") as string | null;
507
+
508
+ // Route params are always available
509
+ const { slug } = ctx.params;
510
+
511
+ return { success: true };
512
+ }, true);
513
+ ```
514
+
515
+ ### File Upload Example
516
+
517
+ ```typescript
518
+ // loaders/upload.ts
519
+ import { createLoader } from "@rangojs/router";
520
+
521
+ export const FileUploadLoader = createLoader(async (ctx) => {
522
+ "use server";
523
+
524
+ const file = ctx.formData?.get("file") as File | null;
525
+ if (file && file.size > 0) {
526
+ // Save to R2, D1, etc.
527
+ await ctx.env.BUCKET.put(file.name, file.stream());
528
+ return { uploaded: { name: file.name, size: file.size, type: file.type } };
529
+ }
530
+ return { uploaded: null };
531
+ }, true);
532
+ ```
533
+
534
+ Client usage — see `/hooks useFetchLoader` for the full client-side pattern.
535
+
536
+ ## Complete Example
537
+
538
+ ```typescript
539
+ // loaders/shop.ts
540
+ import { createLoader } from "@rangojs/router";
541
+
542
+ export const ProductLoader = createLoader(async (ctx) => {
543
+ "use server";
544
+
545
+ const product = await ctx.env.DB
546
+ .prepare("SELECT * FROM products WHERE slug = ?")
547
+ .bind(ctx.params.slug)
548
+ .first();
549
+
550
+ if (!product) {
551
+ throw new Response("Product not found", { status: 404 });
552
+ }
553
+
554
+ return { product };
555
+ });
556
+
557
+ export const CartLoader = createLoader(async (ctx) => {
558
+ "use server";
559
+
560
+ const user = ctx.get("user");
561
+ if (!user) return { cart: null };
562
+
563
+ const cart = await ctx.env.KV.get(`cart:${user.id}`, "json");
564
+ return { cart };
565
+ });
566
+
567
+ // urls.tsx
568
+ export const urlpatterns = urls(({ path, layout, loader, loading, cache, revalidate }) => [
569
+ layout(<ShopLayout />, () => [
570
+ // Shared cart loader for all shop routes
571
+ loader(CartLoader, () => [
572
+ revalidate(({ actionId }) => actionId?.includes("Cart") ?? false),
573
+ ]),
574
+
575
+ path("/shop/product/:slug", ProductPage, { name: "product" }, () => [
576
+ loader(ProductLoader, () => [cache({ ttl: 60 })]),
577
+ loading(<ProductSkeleton />),
578
+ ]),
579
+ ]),
580
+ ]);
581
+
582
+ // pages/product.tsx — server component (route handler)
583
+ import { ProductLoader, CartLoader } from "./loaders/shop";
584
+
585
+ async function ProductPage(ctx) {
586
+ const { product } = await ctx.use(ProductLoader);
587
+ const { cart } = await ctx.use(CartLoader);
588
+
589
+ return (
590
+ <div>
591
+ <h1>{product.name}</h1>
592
+ <AddToCartButton productId={product.id} inCart={cart?.items.includes(product.id)} />
593
+ </div>
594
+ );
595
+ }
596
+ ```