@rangojs/router 0.0.0-experimental.760a71d9 → 0.0.0-experimental.78

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 (932) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +130 -47
  3. package/dist/vite/index.js +716 -237
  4. package/package.json +3 -3
  5. package/skills/cache-guide/SKILL.md +32 -0
  6. package/skills/caching/SKILL.md +8 -0
  7. package/skills/handler-use/SKILL.md +362 -0
  8. package/skills/intercept/SKILL.md +20 -0
  9. package/skills/layout/SKILL.md +22 -0
  10. package/skills/links/SKILL.md +3 -1
  11. package/skills/loader/SKILL.md +53 -43
  12. package/skills/middleware/SKILL.md +34 -3
  13. package/skills/migrate-nextjs/SKILL.md +560 -0
  14. package/skills/migrate-react-router/SKILL.md +764 -0
  15. package/skills/parallel/SKILL.md +126 -0
  16. package/skills/prerender/SKILL.md +110 -68
  17. package/skills/rango/SKILL.md +24 -22
  18. package/skills/route/SKILL.md +55 -0
  19. package/skills/router-setup/SKILL.md +87 -2
  20. package/skills/typesafety/SKILL.md +10 -0
  21. package/src/__internal.ts +1 -1
  22. package/src/browser/app-version.ts +14 -0
  23. package/src/browser/navigation-bridge.ts +37 -5
  24. package/src/browser/navigation-client.ts +98 -46
  25. package/src/browser/navigation-store.ts +43 -8
  26. package/src/browser/partial-update.ts +41 -7
  27. package/src/browser/prefetch/cache.ts +16 -6
  28. package/src/browser/prefetch/fetch.ts +68 -6
  29. package/src/browser/prefetch/queue.ts +61 -29
  30. package/src/browser/prefetch/resource-ready.ts +77 -0
  31. package/src/browser/react/Link.tsx +67 -8
  32. package/src/browser/react/NavigationProvider.tsx +13 -4
  33. package/src/browser/react/context.ts +7 -2
  34. package/src/browser/react/use-handle.ts +9 -58
  35. package/src/browser/react/use-router.ts +21 -8
  36. package/src/browser/rsc-router.tsx +26 -3
  37. package/src/browser/scroll-restoration.ts +10 -8
  38. package/src/browser/segment-reconciler.ts +36 -14
  39. package/src/browser/server-action-bridge.ts +8 -6
  40. package/src/browser/types.ts +27 -5
  41. package/src/build/generate-manifest.ts +6 -6
  42. package/src/build/generate-route-types.ts +3 -0
  43. package/src/build/route-trie.ts +50 -24
  44. package/src/build/route-types/include-resolution.ts +8 -1
  45. package/src/build/route-types/router-processing.ts +211 -72
  46. package/src/build/route-types/scan-filter.ts +8 -1
  47. package/src/cache/cache-scope.ts +46 -5
  48. package/src/cache/taint.ts +55 -0
  49. package/src/client.tsx +84 -230
  50. package/src/context-var.ts +72 -2
  51. package/src/handle.ts +40 -0
  52. package/src/index.rsc.ts +3 -1
  53. package/src/index.ts +46 -6
  54. package/src/prerender/store.ts +5 -4
  55. package/src/prerender.ts +138 -77
  56. package/src/reverse.ts +25 -1
  57. package/src/route-definition/dsl-helpers.ts +194 -32
  58. package/src/route-definition/helpers-types.ts +67 -19
  59. package/src/route-definition/index.ts +3 -0
  60. package/src/route-definition/redirect.ts +9 -1
  61. package/src/route-definition/resolve-handler-use.ts +149 -0
  62. package/src/route-types.ts +11 -0
  63. package/src/router/content-negotiation.ts +100 -1
  64. package/src/router/handler-context.ts +82 -23
  65. package/src/router/intercept-resolution.ts +9 -4
  66. package/src/router/loader-resolution.ts +156 -21
  67. package/src/router/match-api.ts +124 -189
  68. package/src/router/match-middleware/background-revalidation.ts +12 -1
  69. package/src/router/match-middleware/cache-lookup.ts +40 -13
  70. package/src/router/match-middleware/cache-store.ts +21 -4
  71. package/src/router/match-middleware/segment-resolution.ts +53 -0
  72. package/src/router/match-result.ts +82 -4
  73. package/src/router/middleware-types.ts +6 -8
  74. package/src/router/middleware.ts +2 -5
  75. package/src/router/navigation-snapshot.ts +182 -0
  76. package/src/router/prerender-match.ts +110 -10
  77. package/src/router/preview-match.ts +30 -102
  78. package/src/router/request-classification.ts +310 -0
  79. package/src/router/route-snapshot.ts +245 -0
  80. package/src/router/router-context.ts +1 -0
  81. package/src/router/router-interfaces.ts +36 -4
  82. package/src/router/router-options.ts +37 -11
  83. package/src/router/segment-resolution/fresh.ts +80 -9
  84. package/src/router/segment-resolution/helpers.ts +29 -24
  85. package/src/router/segment-resolution/revalidation.ts +91 -8
  86. package/src/router/types.ts +1 -0
  87. package/src/router.ts +54 -5
  88. package/src/rsc/handler.ts +472 -372
  89. package/src/rsc/loader-fetch.ts +23 -3
  90. package/src/rsc/manifest-init.ts +5 -1
  91. package/src/rsc/progressive-enhancement.ts +14 -2
  92. package/src/rsc/rsc-rendering.ts +10 -1
  93. package/src/rsc/server-action.ts +8 -0
  94. package/src/rsc/ssr-setup.ts +2 -2
  95. package/src/rsc/types.ts +9 -1
  96. package/src/segment-content-promise.ts +67 -0
  97. package/src/segment-loader-promise.ts +122 -0
  98. package/src/segment-system.tsx +11 -61
  99. package/src/server/context.ts +50 -1
  100. package/src/server/handle-store.ts +19 -0
  101. package/src/server/loader-registry.ts +9 -8
  102. package/src/server/request-context.ts +175 -15
  103. package/src/ssr/index.tsx +3 -0
  104. package/src/static-handler.ts +18 -6
  105. package/src/types/cache-types.ts +4 -4
  106. package/src/types/handler-context.ts +37 -19
  107. package/src/types/loader-types.ts +36 -9
  108. package/src/types/route-entry.ts +1 -1
  109. package/src/types/segments.ts +1 -1
  110. package/src/urls/path-helper-types.ts +39 -6
  111. package/src/urls/path-helper.ts +47 -12
  112. package/src/urls/pattern-types.ts +12 -0
  113. package/src/urls/response-types.ts +16 -6
  114. package/src/use-loader.tsx +77 -5
  115. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  116. package/src/vite/discovery/discover-routers.ts +5 -1
  117. package/src/vite/discovery/prerender-collection.ts +128 -74
  118. package/src/vite/discovery/state.ts +13 -4
  119. package/src/vite/index.ts +4 -0
  120. package/src/vite/plugin-types.ts +60 -5
  121. package/src/vite/plugins/expose-id-utils.ts +12 -0
  122. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  123. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  124. package/src/vite/plugins/performance-tracks.ts +88 -0
  125. package/src/vite/plugins/refresh-cmd.ts +88 -26
  126. package/src/vite/rango.ts +19 -2
  127. package/src/vite/router-discovery.ts +178 -37
  128. package/src/vite/utils/prerender-utils.ts +37 -5
  129. package/src/vite/utils/shared-utils.ts +3 -2
  130. package/dist/__internal.d.ts +0 -83
  131. package/dist/__internal.d.ts.map +0 -1
  132. package/dist/__internal.js +0 -19
  133. package/dist/__internal.js.map +0 -1
  134. package/dist/__mocks__/version.d.ts +0 -7
  135. package/dist/__mocks__/version.d.ts.map +0 -1
  136. package/dist/__mocks__/version.js +0 -7
  137. package/dist/__mocks__/version.js.map +0 -1
  138. package/dist/__tests__/client-href.test.d.ts +0 -2
  139. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  140. package/dist/__tests__/client-href.test.js +0 -74
  141. package/dist/__tests__/client-href.test.js.map +0 -1
  142. package/dist/__tests__/component-utils.test.d.ts +0 -2
  143. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  144. package/dist/__tests__/component-utils.test.js +0 -51
  145. package/dist/__tests__/component-utils.test.js.map +0 -1
  146. package/dist/__tests__/event-controller.test.d.ts +0 -2
  147. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  148. package/dist/__tests__/event-controller.test.js +0 -538
  149. package/dist/__tests__/event-controller.test.js.map +0 -1
  150. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  151. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  152. package/dist/__tests__/helpers/route-tree.js +0 -374
  153. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  154. package/dist/__tests__/match-result.test.d.ts +0 -2
  155. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  156. package/dist/__tests__/match-result.test.js +0 -154
  157. package/dist/__tests__/match-result.test.js.map +0 -1
  158. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  159. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  160. package/dist/__tests__/navigation-store.test.js +0 -440
  161. package/dist/__tests__/navigation-store.test.js.map +0 -1
  162. package/dist/__tests__/partial-update.test.d.ts +0 -2
  163. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  164. package/dist/__tests__/partial-update.test.js +0 -1009
  165. package/dist/__tests__/partial-update.test.js.map +0 -1
  166. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  167. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  168. package/dist/__tests__/reverse-types.test.js +0 -656
  169. package/dist/__tests__/reverse-types.test.js.map +0 -1
  170. package/dist/__tests__/route-definition.test.d.ts +0 -2
  171. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  172. package/dist/__tests__/route-definition.test.js +0 -55
  173. package/dist/__tests__/route-definition.test.js.map +0 -1
  174. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  175. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  176. package/dist/__tests__/router-helpers.test.js +0 -377
  177. package/dist/__tests__/router-helpers.test.js.map +0 -1
  178. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  179. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  180. package/dist/__tests__/router-integration-2.test.js +0 -426
  181. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  182. package/dist/__tests__/router-integration.test.d.ts +0 -2
  183. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  184. package/dist/__tests__/router-integration.test.js +0 -1051
  185. package/dist/__tests__/router-integration.test.js.map +0 -1
  186. package/dist/__tests__/search-params.test.d.ts +0 -5
  187. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  188. package/dist/__tests__/search-params.test.js +0 -306
  189. package/dist/__tests__/search-params.test.js.map +0 -1
  190. package/dist/__tests__/segment-system.test.d.ts +0 -2
  191. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  192. package/dist/__tests__/segment-system.test.js +0 -627
  193. package/dist/__tests__/segment-system.test.js.map +0 -1
  194. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  195. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  196. package/dist/__tests__/static-handler-types.test.js +0 -63
  197. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  198. package/dist/__tests__/urls.test.d.ts +0 -2
  199. package/dist/__tests__/urls.test.d.ts.map +0 -1
  200. package/dist/__tests__/urls.test.js +0 -421
  201. package/dist/__tests__/urls.test.js.map +0 -1
  202. package/dist/__tests__/use-mount.test.d.ts +0 -2
  203. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  204. package/dist/__tests__/use-mount.test.js +0 -35
  205. package/dist/__tests__/use-mount.test.js.map +0 -1
  206. package/dist/bin/rango.d.ts +0 -2
  207. package/dist/bin/rango.d.ts.map +0 -1
  208. package/dist/bin/rango.js.map +0 -1
  209. package/dist/browser/event-controller.d.ts +0 -191
  210. package/dist/browser/event-controller.d.ts.map +0 -1
  211. package/dist/browser/event-controller.js +0 -559
  212. package/dist/browser/event-controller.js.map +0 -1
  213. package/dist/browser/index.d.ts +0 -2
  214. package/dist/browser/index.d.ts.map +0 -1
  215. package/dist/browser/index.js +0 -14
  216. package/dist/browser/index.js.map +0 -1
  217. package/dist/browser/link-interceptor.d.ts +0 -38
  218. package/dist/browser/link-interceptor.d.ts.map +0 -1
  219. package/dist/browser/link-interceptor.js +0 -99
  220. package/dist/browser/link-interceptor.js.map +0 -1
  221. package/dist/browser/logging.d.ts +0 -10
  222. package/dist/browser/logging.d.ts.map +0 -1
  223. package/dist/browser/logging.js +0 -29
  224. package/dist/browser/logging.js.map +0 -1
  225. package/dist/browser/lru-cache.d.ts +0 -17
  226. package/dist/browser/lru-cache.d.ts.map +0 -1
  227. package/dist/browser/lru-cache.js +0 -50
  228. package/dist/browser/lru-cache.js.map +0 -1
  229. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  230. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  231. package/dist/browser/merge-segment-loaders.js +0 -102
  232. package/dist/browser/merge-segment-loaders.js.map +0 -1
  233. package/dist/browser/navigation-bridge.d.ts +0 -102
  234. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  235. package/dist/browser/navigation-bridge.js +0 -708
  236. package/dist/browser/navigation-bridge.js.map +0 -1
  237. package/dist/browser/navigation-client.d.ts +0 -25
  238. package/dist/browser/navigation-client.d.ts.map +0 -1
  239. package/dist/browser/navigation-client.js +0 -157
  240. package/dist/browser/navigation-client.js.map +0 -1
  241. package/dist/browser/navigation-store.d.ts +0 -101
  242. package/dist/browser/navigation-store.d.ts.map +0 -1
  243. package/dist/browser/navigation-store.js +0 -625
  244. package/dist/browser/navigation-store.js.map +0 -1
  245. package/dist/browser/partial-update.d.ts +0 -75
  246. package/dist/browser/partial-update.d.ts.map +0 -1
  247. package/dist/browser/partial-update.js +0 -426
  248. package/dist/browser/partial-update.js.map +0 -1
  249. package/dist/browser/react/Link.d.ts +0 -86
  250. package/dist/browser/react/Link.d.ts.map +0 -1
  251. package/dist/browser/react/Link.js +0 -128
  252. package/dist/browser/react/Link.js.map +0 -1
  253. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  254. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  255. package/dist/browser/react/NavigationProvider.js +0 -216
  256. package/dist/browser/react/NavigationProvider.js.map +0 -1
  257. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  258. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  259. package/dist/browser/react/ScrollRestoration.js +0 -57
  260. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  261. package/dist/browser/react/context.d.ts +0 -46
  262. package/dist/browser/react/context.d.ts.map +0 -1
  263. package/dist/browser/react/context.js +0 -10
  264. package/dist/browser/react/context.js.map +0 -1
  265. package/dist/browser/react/index.d.ts +0 -11
  266. package/dist/browser/react/index.d.ts.map +0 -1
  267. package/dist/browser/react/index.js +0 -22
  268. package/dist/browser/react/index.js.map +0 -1
  269. package/dist/browser/react/location-state-shared.d.ts +0 -63
  270. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  271. package/dist/browser/react/location-state-shared.js +0 -81
  272. package/dist/browser/react/location-state-shared.js.map +0 -1
  273. package/dist/browser/react/location-state.d.ts +0 -23
  274. package/dist/browser/react/location-state.d.ts.map +0 -1
  275. package/dist/browser/react/location-state.js +0 -29
  276. package/dist/browser/react/location-state.js.map +0 -1
  277. package/dist/browser/react/mount-context.d.ts +0 -24
  278. package/dist/browser/react/mount-context.d.ts.map +0 -1
  279. package/dist/browser/react/mount-context.js +0 -24
  280. package/dist/browser/react/mount-context.js.map +0 -1
  281. package/dist/browser/react/use-action.d.ts +0 -64
  282. package/dist/browser/react/use-action.d.ts.map +0 -1
  283. package/dist/browser/react/use-action.js +0 -134
  284. package/dist/browser/react/use-action.js.map +0 -1
  285. package/dist/browser/react/use-client-cache.d.ts +0 -41
  286. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  287. package/dist/browser/react/use-client-cache.js +0 -39
  288. package/dist/browser/react/use-client-cache.js.map +0 -1
  289. package/dist/browser/react/use-handle.d.ts +0 -31
  290. package/dist/browser/react/use-handle.d.ts.map +0 -1
  291. package/dist/browser/react/use-handle.js +0 -144
  292. package/dist/browser/react/use-handle.js.map +0 -1
  293. package/dist/browser/react/use-href.d.ts +0 -33
  294. package/dist/browser/react/use-href.d.ts.map +0 -1
  295. package/dist/browser/react/use-href.js +0 -39
  296. package/dist/browser/react/use-href.js.map +0 -1
  297. package/dist/browser/react/use-link-status.d.ts +0 -37
  298. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  299. package/dist/browser/react/use-link-status.js +0 -99
  300. package/dist/browser/react/use-link-status.js.map +0 -1
  301. package/dist/browser/react/use-mount.d.ts +0 -25
  302. package/dist/browser/react/use-mount.d.ts.map +0 -1
  303. package/dist/browser/react/use-mount.js +0 -30
  304. package/dist/browser/react/use-mount.js.map +0 -1
  305. package/dist/browser/react/use-navigation.d.ts +0 -27
  306. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  307. package/dist/browser/react/use-navigation.js +0 -87
  308. package/dist/browser/react/use-navigation.js.map +0 -1
  309. package/dist/browser/react/use-segments.d.ts +0 -38
  310. package/dist/browser/react/use-segments.d.ts.map +0 -1
  311. package/dist/browser/react/use-segments.js +0 -130
  312. package/dist/browser/react/use-segments.js.map +0 -1
  313. package/dist/browser/request-controller.d.ts +0 -26
  314. package/dist/browser/request-controller.d.ts.map +0 -1
  315. package/dist/browser/request-controller.js +0 -147
  316. package/dist/browser/request-controller.js.map +0 -1
  317. package/dist/browser/rsc-router.d.ts +0 -129
  318. package/dist/browser/rsc-router.d.ts.map +0 -1
  319. package/dist/browser/rsc-router.js +0 -195
  320. package/dist/browser/rsc-router.js.map +0 -1
  321. package/dist/browser/scroll-restoration.d.ts +0 -93
  322. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  323. package/dist/browser/scroll-restoration.js +0 -321
  324. package/dist/browser/scroll-restoration.js.map +0 -1
  325. package/dist/browser/segment-structure-assert.d.ts +0 -17
  326. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  327. package/dist/browser/segment-structure-assert.js +0 -59
  328. package/dist/browser/segment-structure-assert.js.map +0 -1
  329. package/dist/browser/server-action-bridge.d.ts +0 -26
  330. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  331. package/dist/browser/server-action-bridge.js +0 -668
  332. package/dist/browser/server-action-bridge.js.map +0 -1
  333. package/dist/browser/shallow.d.ts +0 -12
  334. package/dist/browser/shallow.d.ts.map +0 -1
  335. package/dist/browser/shallow.js +0 -34
  336. package/dist/browser/shallow.js.map +0 -1
  337. package/dist/browser/types.d.ts +0 -369
  338. package/dist/browser/types.d.ts.map +0 -1
  339. package/dist/browser/types.js +0 -2
  340. package/dist/browser/types.js.map +0 -1
  341. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  342. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  343. package/dist/build/__tests__/generate-cli.test.js +0 -237
  344. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  345. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  346. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  347. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  348. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  349. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  350. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  351. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  352. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  353. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  354. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  355. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  356. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  357. package/dist/build/generate-manifest.d.ts +0 -81
  358. package/dist/build/generate-manifest.d.ts.map +0 -1
  359. package/dist/build/generate-manifest.js +0 -276
  360. package/dist/build/generate-manifest.js.map +0 -1
  361. package/dist/build/generate-route-types.d.ts +0 -115
  362. package/dist/build/generate-route-types.d.ts.map +0 -1
  363. package/dist/build/generate-route-types.js +0 -740
  364. package/dist/build/generate-route-types.js.map +0 -1
  365. package/dist/build/index.d.ts +0 -21
  366. package/dist/build/index.d.ts.map +0 -1
  367. package/dist/build/index.js +0 -21
  368. package/dist/build/index.js.map +0 -1
  369. package/dist/build/route-trie.d.ts +0 -71
  370. package/dist/build/route-trie.d.ts.map +0 -1
  371. package/dist/build/route-trie.js +0 -175
  372. package/dist/build/route-trie.js.map +0 -1
  373. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  374. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  375. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  376. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  377. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  378. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  379. package/dist/cache/__tests__/document-cache.test.js +0 -345
  380. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  381. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  382. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  383. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  384. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  385. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  386. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  387. package/dist/cache/__tests__/memory-store.test.js +0 -367
  388. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  389. package/dist/cache/cache-scope.d.ts +0 -102
  390. package/dist/cache/cache-scope.d.ts.map +0 -1
  391. package/dist/cache/cache-scope.js +0 -440
  392. package/dist/cache/cache-scope.js.map +0 -1
  393. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  394. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  395. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  396. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  397. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  398. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  399. package/dist/cache/cf/cf-cache-store.js +0 -242
  400. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  401. package/dist/cache/cf/index.d.ts +0 -14
  402. package/dist/cache/cf/index.d.ts.map +0 -1
  403. package/dist/cache/cf/index.js +0 -17
  404. package/dist/cache/cf/index.js.map +0 -1
  405. package/dist/cache/document-cache.d.ts +0 -64
  406. package/dist/cache/document-cache.d.ts.map +0 -1
  407. package/dist/cache/document-cache.js +0 -228
  408. package/dist/cache/document-cache.js.map +0 -1
  409. package/dist/cache/index.d.ts +0 -19
  410. package/dist/cache/index.d.ts.map +0 -1
  411. package/dist/cache/index.js +0 -21
  412. package/dist/cache/index.js.map +0 -1
  413. package/dist/cache/memory-segment-store.d.ts +0 -110
  414. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  415. package/dist/cache/memory-segment-store.js +0 -117
  416. package/dist/cache/memory-segment-store.js.map +0 -1
  417. package/dist/cache/memory-store.d.ts +0 -41
  418. package/dist/cache/memory-store.d.ts.map +0 -1
  419. package/dist/cache/memory-store.js +0 -191
  420. package/dist/cache/memory-store.js.map +0 -1
  421. package/dist/cache/types.d.ts +0 -317
  422. package/dist/cache/types.d.ts.map +0 -1
  423. package/dist/cache/types.js +0 -12
  424. package/dist/cache/types.js.map +0 -1
  425. package/dist/client.d.ts +0 -248
  426. package/dist/client.d.ts.map +0 -1
  427. package/dist/client.js +0 -367
  428. package/dist/client.js.map +0 -1
  429. package/dist/client.rsc.d.ts +0 -26
  430. package/dist/client.rsc.d.ts.map +0 -1
  431. package/dist/client.rsc.js +0 -46
  432. package/dist/client.rsc.js.map +0 -1
  433. package/dist/component-utils.d.ts +0 -36
  434. package/dist/component-utils.d.ts.map +0 -1
  435. package/dist/component-utils.js +0 -61
  436. package/dist/component-utils.js.map +0 -1
  437. package/dist/components/DefaultDocument.d.ts +0 -13
  438. package/dist/components/DefaultDocument.d.ts.map +0 -1
  439. package/dist/components/DefaultDocument.js +0 -15
  440. package/dist/components/DefaultDocument.js.map +0 -1
  441. package/dist/debug.d.ts +0 -58
  442. package/dist/debug.d.ts.map +0 -1
  443. package/dist/debug.js +0 -157
  444. package/dist/debug.js.map +0 -1
  445. package/dist/default-error-boundary.d.ts +0 -11
  446. package/dist/default-error-boundary.d.ts.map +0 -1
  447. package/dist/default-error-boundary.js +0 -45
  448. package/dist/default-error-boundary.js.map +0 -1
  449. package/dist/deps/browser.d.ts +0 -2
  450. package/dist/deps/browser.d.ts.map +0 -1
  451. package/dist/deps/browser.js +0 -3
  452. package/dist/deps/browser.js.map +0 -1
  453. package/dist/deps/html-stream-client.d.ts +0 -2
  454. package/dist/deps/html-stream-client.d.ts.map +0 -1
  455. package/dist/deps/html-stream-client.js +0 -3
  456. package/dist/deps/html-stream-client.js.map +0 -1
  457. package/dist/deps/html-stream-server.d.ts +0 -2
  458. package/dist/deps/html-stream-server.d.ts.map +0 -1
  459. package/dist/deps/html-stream-server.js +0 -3
  460. package/dist/deps/html-stream-server.js.map +0 -1
  461. package/dist/deps/rsc.d.ts +0 -2
  462. package/dist/deps/rsc.d.ts.map +0 -1
  463. package/dist/deps/rsc.js +0 -4
  464. package/dist/deps/rsc.js.map +0 -1
  465. package/dist/deps/ssr.d.ts +0 -2
  466. package/dist/deps/ssr.d.ts.map +0 -1
  467. package/dist/deps/ssr.js +0 -3
  468. package/dist/deps/ssr.js.map +0 -1
  469. package/dist/errors.d.ts +0 -174
  470. package/dist/errors.d.ts.map +0 -1
  471. package/dist/errors.js +0 -241
  472. package/dist/errors.js.map +0 -1
  473. package/dist/handle.d.ts +0 -78
  474. package/dist/handle.d.ts.map +0 -1
  475. package/dist/handle.js +0 -82
  476. package/dist/handle.js.map +0 -1
  477. package/dist/handles/MetaTags.d.ts +0 -14
  478. package/dist/handles/MetaTags.d.ts.map +0 -1
  479. package/dist/handles/MetaTags.js +0 -136
  480. package/dist/handles/MetaTags.js.map +0 -1
  481. package/dist/handles/index.d.ts +0 -6
  482. package/dist/handles/index.d.ts.map +0 -1
  483. package/dist/handles/index.js +0 -6
  484. package/dist/handles/index.js.map +0 -1
  485. package/dist/handles/meta.d.ts +0 -39
  486. package/dist/handles/meta.d.ts.map +0 -1
  487. package/dist/handles/meta.js +0 -202
  488. package/dist/handles/meta.js.map +0 -1
  489. package/dist/host/__tests__/errors.test.d.ts +0 -2
  490. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  491. package/dist/host/__tests__/errors.test.js +0 -76
  492. package/dist/host/__tests__/errors.test.js.map +0 -1
  493. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  494. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  495. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  496. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  497. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  498. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  499. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  500. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  501. package/dist/host/__tests__/router.test.d.ts +0 -2
  502. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  503. package/dist/host/__tests__/router.test.js +0 -241
  504. package/dist/host/__tests__/router.test.js.map +0 -1
  505. package/dist/host/__tests__/testing.test.d.ts +0 -2
  506. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  507. package/dist/host/__tests__/testing.test.js +0 -64
  508. package/dist/host/__tests__/testing.test.js.map +0 -1
  509. package/dist/host/__tests__/utils.test.d.ts +0 -2
  510. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  511. package/dist/host/__tests__/utils.test.js +0 -29
  512. package/dist/host/__tests__/utils.test.js.map +0 -1
  513. package/dist/host/cookie-handler.d.ts +0 -34
  514. package/dist/host/cookie-handler.d.ts.map +0 -1
  515. package/dist/host/cookie-handler.js +0 -124
  516. package/dist/host/cookie-handler.js.map +0 -1
  517. package/dist/host/errors.d.ts +0 -56
  518. package/dist/host/errors.d.ts.map +0 -1
  519. package/dist/host/errors.js +0 -79
  520. package/dist/host/errors.js.map +0 -1
  521. package/dist/host/index.d.ts +0 -29
  522. package/dist/host/index.d.ts.map +0 -1
  523. package/dist/host/index.js +0 -32
  524. package/dist/host/index.js.map +0 -1
  525. package/dist/host/pattern-matcher.d.ts +0 -36
  526. package/dist/host/pattern-matcher.d.ts.map +0 -1
  527. package/dist/host/pattern-matcher.js +0 -172
  528. package/dist/host/pattern-matcher.js.map +0 -1
  529. package/dist/host/router.d.ts +0 -26
  530. package/dist/host/router.d.ts.map +0 -1
  531. package/dist/host/router.js +0 -218
  532. package/dist/host/router.js.map +0 -1
  533. package/dist/host/testing.d.ts +0 -36
  534. package/dist/host/testing.d.ts.map +0 -1
  535. package/dist/host/testing.js +0 -55
  536. package/dist/host/testing.js.map +0 -1
  537. package/dist/host/types.d.ts +0 -115
  538. package/dist/host/types.d.ts.map +0 -1
  539. package/dist/host/types.js +0 -7
  540. package/dist/host/types.js.map +0 -1
  541. package/dist/host/utils.d.ts +0 -21
  542. package/dist/host/utils.d.ts.map +0 -1
  543. package/dist/host/utils.js +0 -23
  544. package/dist/host/utils.js.map +0 -1
  545. package/dist/href-client.d.ts +0 -131
  546. package/dist/href-client.d.ts.map +0 -1
  547. package/dist/href-client.js +0 -64
  548. package/dist/href-client.js.map +0 -1
  549. package/dist/href-context.d.ts +0 -29
  550. package/dist/href-context.d.ts.map +0 -1
  551. package/dist/href-context.js +0 -21
  552. package/dist/href-context.js.map +0 -1
  553. package/dist/index.d.ts +0 -73
  554. package/dist/index.d.ts.map +0 -1
  555. package/dist/index.js +0 -91
  556. package/dist/index.js.map +0 -1
  557. package/dist/index.rsc.d.ts +0 -32
  558. package/dist/index.rsc.d.ts.map +0 -1
  559. package/dist/index.rsc.js +0 -40
  560. package/dist/index.rsc.js.map +0 -1
  561. package/dist/internal-debug.d.ts +0 -2
  562. package/dist/internal-debug.d.ts.map +0 -1
  563. package/dist/internal-debug.js +0 -5
  564. package/dist/internal-debug.js.map +0 -1
  565. package/dist/loader.d.ts +0 -14
  566. package/dist/loader.d.ts.map +0 -1
  567. package/dist/loader.js +0 -20
  568. package/dist/loader.js.map +0 -1
  569. package/dist/loader.rsc.d.ts +0 -19
  570. package/dist/loader.rsc.d.ts.map +0 -1
  571. package/dist/loader.rsc.js +0 -99
  572. package/dist/loader.rsc.js.map +0 -1
  573. package/dist/network-error-thrower.d.ts +0 -17
  574. package/dist/network-error-thrower.d.ts.map +0 -1
  575. package/dist/network-error-thrower.js +0 -14
  576. package/dist/network-error-thrower.js.map +0 -1
  577. package/dist/outlet-context.d.ts +0 -13
  578. package/dist/outlet-context.d.ts.map +0 -1
  579. package/dist/outlet-context.js +0 -3
  580. package/dist/outlet-context.js.map +0 -1
  581. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  582. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  583. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  584. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  585. package/dist/prerender/param-hash.d.ts +0 -16
  586. package/dist/prerender/param-hash.d.ts.map +0 -1
  587. package/dist/prerender/param-hash.js +0 -36
  588. package/dist/prerender/param-hash.js.map +0 -1
  589. package/dist/prerender/store.d.ts +0 -38
  590. package/dist/prerender/store.d.ts.map +0 -1
  591. package/dist/prerender/store.js +0 -61
  592. package/dist/prerender/store.js.map +0 -1
  593. package/dist/prerender.d.ts +0 -66
  594. package/dist/prerender.d.ts.map +0 -1
  595. package/dist/prerender.js +0 -57
  596. package/dist/prerender.js.map +0 -1
  597. package/dist/reverse.d.ts +0 -196
  598. package/dist/reverse.d.ts.map +0 -1
  599. package/dist/reverse.js +0 -78
  600. package/dist/reverse.js.map +0 -1
  601. package/dist/root-error-boundary.d.ts +0 -33
  602. package/dist/root-error-boundary.d.ts.map +0 -1
  603. package/dist/root-error-boundary.js +0 -165
  604. package/dist/root-error-boundary.js.map +0 -1
  605. package/dist/route-content-wrapper.d.ts +0 -46
  606. package/dist/route-content-wrapper.d.ts.map +0 -1
  607. package/dist/route-content-wrapper.js +0 -77
  608. package/dist/route-content-wrapper.js.map +0 -1
  609. package/dist/route-definition.d.ts +0 -421
  610. package/dist/route-definition.d.ts.map +0 -1
  611. package/dist/route-definition.js +0 -868
  612. package/dist/route-definition.js.map +0 -1
  613. package/dist/route-map-builder.d.ts +0 -155
  614. package/dist/route-map-builder.d.ts.map +0 -1
  615. package/dist/route-map-builder.js +0 -237
  616. package/dist/route-map-builder.js.map +0 -1
  617. package/dist/route-types.d.ts +0 -165
  618. package/dist/route-types.d.ts.map +0 -1
  619. package/dist/route-types.js +0 -7
  620. package/dist/route-types.js.map +0 -1
  621. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  622. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  623. package/dist/router/__tests__/handler-context.test.js +0 -65
  624. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  625. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  626. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  627. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  628. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  629. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  630. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  631. package/dist/router/__tests__/match-context.test.js +0 -92
  632. package/dist/router/__tests__/match-context.test.js.map +0 -1
  633. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  634. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  635. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  636. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  637. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  638. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  639. package/dist/router/__tests__/match-result.test.js +0 -457
  640. package/dist/router/__tests__/match-result.test.js.map +0 -1
  641. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  642. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  643. package/dist/router/__tests__/on-error.test.js +0 -678
  644. package/dist/router/__tests__/on-error.test.js.map +0 -1
  645. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  646. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  647. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  648. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  649. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  650. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  651. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  652. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  653. package/dist/router/error-handling.d.ts +0 -77
  654. package/dist/router/error-handling.d.ts.map +0 -1
  655. package/dist/router/error-handling.js +0 -202
  656. package/dist/router/error-handling.js.map +0 -1
  657. package/dist/router/handler-context.d.ts +0 -20
  658. package/dist/router/handler-context.d.ts.map +0 -1
  659. package/dist/router/handler-context.js +0 -198
  660. package/dist/router/handler-context.js.map +0 -1
  661. package/dist/router/intercept-resolution.d.ts +0 -66
  662. package/dist/router/intercept-resolution.d.ts.map +0 -1
  663. package/dist/router/intercept-resolution.js +0 -246
  664. package/dist/router/intercept-resolution.js.map +0 -1
  665. package/dist/router/loader-resolution.d.ts +0 -64
  666. package/dist/router/loader-resolution.d.ts.map +0 -1
  667. package/dist/router/loader-resolution.js +0 -284
  668. package/dist/router/loader-resolution.js.map +0 -1
  669. package/dist/router/logging.d.ts +0 -15
  670. package/dist/router/logging.d.ts.map +0 -1
  671. package/dist/router/logging.js +0 -99
  672. package/dist/router/logging.js.map +0 -1
  673. package/dist/router/manifest.d.ts +0 -22
  674. package/dist/router/manifest.d.ts.map +0 -1
  675. package/dist/router/manifest.js +0 -181
  676. package/dist/router/manifest.js.map +0 -1
  677. package/dist/router/match-api.d.ts +0 -35
  678. package/dist/router/match-api.d.ts.map +0 -1
  679. package/dist/router/match-api.js +0 -406
  680. package/dist/router/match-api.js.map +0 -1
  681. package/dist/router/match-context.d.ts +0 -206
  682. package/dist/router/match-context.d.ts.map +0 -1
  683. package/dist/router/match-context.js +0 -17
  684. package/dist/router/match-context.js.map +0 -1
  685. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  686. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  687. package/dist/router/match-middleware/background-revalidation.js +0 -75
  688. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  689. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  690. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  691. package/dist/router/match-middleware/cache-lookup.js +0 -257
  692. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  693. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  694. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  695. package/dist/router/match-middleware/cache-store.js +0 -108
  696. package/dist/router/match-middleware/cache-store.js.map +0 -1
  697. package/dist/router/match-middleware/index.d.ts +0 -81
  698. package/dist/router/match-middleware/index.d.ts.map +0 -1
  699. package/dist/router/match-middleware/index.js +0 -80
  700. package/dist/router/match-middleware/index.js.map +0 -1
  701. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  702. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  703. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  704. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  705. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  706. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  707. package/dist/router/match-middleware/segment-resolution.js +0 -53
  708. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  709. package/dist/router/match-pipelines.d.ts +0 -147
  710. package/dist/router/match-pipelines.d.ts.map +0 -1
  711. package/dist/router/match-pipelines.js +0 -82
  712. package/dist/router/match-pipelines.js.map +0 -1
  713. package/dist/router/match-result.d.ts +0 -126
  714. package/dist/router/match-result.d.ts.map +0 -1
  715. package/dist/router/match-result.js +0 -93
  716. package/dist/router/match-result.js.map +0 -1
  717. package/dist/router/metrics.d.ts +0 -20
  718. package/dist/router/metrics.d.ts.map +0 -1
  719. package/dist/router/metrics.js +0 -47
  720. package/dist/router/metrics.js.map +0 -1
  721. package/dist/router/middleware.d.ts +0 -249
  722. package/dist/router/middleware.d.ts.map +0 -1
  723. package/dist/router/middleware.js +0 -434
  724. package/dist/router/middleware.js.map +0 -1
  725. package/dist/router/middleware.test.d.ts +0 -2
  726. package/dist/router/middleware.test.d.ts.map +0 -1
  727. package/dist/router/middleware.test.js +0 -816
  728. package/dist/router/middleware.test.js.map +0 -1
  729. package/dist/router/pattern-matching.d.ts +0 -149
  730. package/dist/router/pattern-matching.d.ts.map +0 -1
  731. package/dist/router/pattern-matching.js +0 -349
  732. package/dist/router/pattern-matching.js.map +0 -1
  733. package/dist/router/revalidation.d.ts +0 -44
  734. package/dist/router/revalidation.d.ts.map +0 -1
  735. package/dist/router/revalidation.js +0 -147
  736. package/dist/router/revalidation.js.map +0 -1
  737. package/dist/router/router-context.d.ts +0 -135
  738. package/dist/router/router-context.d.ts.map +0 -1
  739. package/dist/router/router-context.js +0 -36
  740. package/dist/router/router-context.js.map +0 -1
  741. package/dist/router/segment-resolution.d.ts +0 -127
  742. package/dist/router/segment-resolution.d.ts.map +0 -1
  743. package/dist/router/segment-resolution.js +0 -919
  744. package/dist/router/segment-resolution.js.map +0 -1
  745. package/dist/router/trie-matching.d.ts +0 -40
  746. package/dist/router/trie-matching.d.ts.map +0 -1
  747. package/dist/router/trie-matching.js +0 -127
  748. package/dist/router/trie-matching.js.map +0 -1
  749. package/dist/router/types.d.ts +0 -136
  750. package/dist/router/types.d.ts.map +0 -1
  751. package/dist/router/types.js +0 -7
  752. package/dist/router/types.js.map +0 -1
  753. package/dist/router.d.ts +0 -753
  754. package/dist/router.d.ts.map +0 -1
  755. package/dist/router.gen.d.ts +0 -6
  756. package/dist/router.gen.d.ts.map +0 -1
  757. package/dist/router.gen.js +0 -6
  758. package/dist/router.gen.js.map +0 -1
  759. package/dist/router.js +0 -1304
  760. package/dist/router.js.map +0 -1
  761. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  762. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  763. package/dist/rsc/__tests__/helpers.test.js +0 -140
  764. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  765. package/dist/rsc/handler.d.ts +0 -45
  766. package/dist/rsc/handler.d.ts.map +0 -1
  767. package/dist/rsc/handler.js +0 -1172
  768. package/dist/rsc/handler.js.map +0 -1
  769. package/dist/rsc/helpers.d.ts +0 -16
  770. package/dist/rsc/helpers.d.ts.map +0 -1
  771. package/dist/rsc/helpers.js +0 -55
  772. package/dist/rsc/helpers.js.map +0 -1
  773. package/dist/rsc/index.d.ts +0 -22
  774. package/dist/rsc/index.d.ts.map +0 -1
  775. package/dist/rsc/index.js +0 -23
  776. package/dist/rsc/index.js.map +0 -1
  777. package/dist/rsc/nonce.d.ts +0 -9
  778. package/dist/rsc/nonce.d.ts.map +0 -1
  779. package/dist/rsc/nonce.js +0 -18
  780. package/dist/rsc/nonce.js.map +0 -1
  781. package/dist/rsc/types.d.ts +0 -206
  782. package/dist/rsc/types.d.ts.map +0 -1
  783. package/dist/rsc/types.js +0 -8
  784. package/dist/rsc/types.js.map +0 -1
  785. package/dist/search-params.d.ts +0 -103
  786. package/dist/search-params.d.ts.map +0 -1
  787. package/dist/search-params.js +0 -74
  788. package/dist/search-params.js.map +0 -1
  789. package/dist/segment-system.d.ts +0 -75
  790. package/dist/segment-system.d.ts.map +0 -1
  791. package/dist/segment-system.js +0 -336
  792. package/dist/segment-system.js.map +0 -1
  793. package/dist/server/context.d.ts +0 -245
  794. package/dist/server/context.d.ts.map +0 -1
  795. package/dist/server/context.js +0 -197
  796. package/dist/server/context.js.map +0 -1
  797. package/dist/server/fetchable-loader-store.d.ts +0 -18
  798. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  799. package/dist/server/fetchable-loader-store.js +0 -18
  800. package/dist/server/fetchable-loader-store.js.map +0 -1
  801. package/dist/server/handle-store.d.ts +0 -85
  802. package/dist/server/handle-store.d.ts.map +0 -1
  803. package/dist/server/handle-store.js +0 -142
  804. package/dist/server/handle-store.js.map +0 -1
  805. package/dist/server/loader-registry.d.ts +0 -55
  806. package/dist/server/loader-registry.d.ts.map +0 -1
  807. package/dist/server/loader-registry.js +0 -132
  808. package/dist/server/loader-registry.js.map +0 -1
  809. package/dist/server/request-context.d.ts +0 -226
  810. package/dist/server/request-context.d.ts.map +0 -1
  811. package/dist/server/request-context.js +0 -290
  812. package/dist/server/request-context.js.map +0 -1
  813. package/dist/server/root-layout.d.ts +0 -4
  814. package/dist/server/root-layout.d.ts.map +0 -1
  815. package/dist/server/root-layout.js +0 -5
  816. package/dist/server/root-layout.js.map +0 -1
  817. package/dist/server.d.ts +0 -15
  818. package/dist/server.d.ts.map +0 -1
  819. package/dist/server.js +0 -20
  820. package/dist/server.js.map +0 -1
  821. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  822. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  823. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  824. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  825. package/dist/ssr/index.d.ts +0 -98
  826. package/dist/ssr/index.d.ts.map +0 -1
  827. package/dist/ssr/index.js +0 -158
  828. package/dist/ssr/index.js.map +0 -1
  829. package/dist/static-handler.d.ts +0 -50
  830. package/dist/static-handler.d.ts.map +0 -1
  831. package/dist/static-handler.gen.d.ts +0 -5
  832. package/dist/static-handler.gen.d.ts.map +0 -1
  833. package/dist/static-handler.gen.js +0 -5
  834. package/dist/static-handler.gen.js.map +0 -1
  835. package/dist/static-handler.js +0 -29
  836. package/dist/static-handler.js.map +0 -1
  837. package/dist/theme/ThemeProvider.d.ts +0 -20
  838. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  839. package/dist/theme/ThemeProvider.js +0 -240
  840. package/dist/theme/ThemeProvider.js.map +0 -1
  841. package/dist/theme/ThemeScript.d.ts +0 -48
  842. package/dist/theme/ThemeScript.d.ts.map +0 -1
  843. package/dist/theme/ThemeScript.js +0 -13
  844. package/dist/theme/ThemeScript.js.map +0 -1
  845. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  846. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  847. package/dist/theme/__tests__/theme.test.js +0 -103
  848. package/dist/theme/__tests__/theme.test.js.map +0 -1
  849. package/dist/theme/constants.d.ts +0 -29
  850. package/dist/theme/constants.d.ts.map +0 -1
  851. package/dist/theme/constants.js +0 -48
  852. package/dist/theme/constants.js.map +0 -1
  853. package/dist/theme/index.d.ts +0 -31
  854. package/dist/theme/index.d.ts.map +0 -1
  855. package/dist/theme/index.js +0 -36
  856. package/dist/theme/index.js.map +0 -1
  857. package/dist/theme/theme-context.d.ts +0 -40
  858. package/dist/theme/theme-context.d.ts.map +0 -1
  859. package/dist/theme/theme-context.js +0 -60
  860. package/dist/theme/theme-context.js.map +0 -1
  861. package/dist/theme/theme-script.d.ts +0 -27
  862. package/dist/theme/theme-script.d.ts.map +0 -1
  863. package/dist/theme/theme-script.js +0 -147
  864. package/dist/theme/theme-script.js.map +0 -1
  865. package/dist/theme/types.d.ts +0 -163
  866. package/dist/theme/types.d.ts.map +0 -1
  867. package/dist/theme/types.js +0 -11
  868. package/dist/theme/types.js.map +0 -1
  869. package/dist/theme/use-theme.d.ts +0 -12
  870. package/dist/theme/use-theme.d.ts.map +0 -1
  871. package/dist/theme/use-theme.js +0 -40
  872. package/dist/theme/use-theme.js.map +0 -1
  873. package/dist/types.d.ts +0 -1479
  874. package/dist/types.d.ts.map +0 -1
  875. package/dist/types.js +0 -10
  876. package/dist/types.js.map +0 -1
  877. package/dist/urls.d.ts +0 -441
  878. package/dist/urls.d.ts.map +0 -1
  879. package/dist/urls.gen.d.ts +0 -8
  880. package/dist/urls.gen.d.ts.map +0 -1
  881. package/dist/urls.gen.js +0 -8
  882. package/dist/urls.gen.js.map +0 -1
  883. package/dist/urls.js +0 -443
  884. package/dist/urls.js.map +0 -1
  885. package/dist/use-loader.d.ts +0 -127
  886. package/dist/use-loader.d.ts.map +0 -1
  887. package/dist/use-loader.js +0 -237
  888. package/dist/use-loader.js.map +0 -1
  889. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  890. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  891. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  892. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  893. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  894. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  895. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  896. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  897. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  898. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  899. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  900. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  901. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  902. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  903. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  904. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  905. package/dist/vite/ast-handler-extract.d.ts +0 -49
  906. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  907. package/dist/vite/ast-handler-extract.js +0 -249
  908. package/dist/vite/ast-handler-extract.js.map +0 -1
  909. package/dist/vite/expose-action-id.d.ts +0 -19
  910. package/dist/vite/expose-action-id.d.ts.map +0 -1
  911. package/dist/vite/expose-action-id.js +0 -250
  912. package/dist/vite/expose-action-id.js.map +0 -1
  913. package/dist/vite/expose-id-utils.d.ts +0 -69
  914. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  915. package/dist/vite/expose-id-utils.js +0 -289
  916. package/dist/vite/expose-id-utils.js.map +0 -1
  917. package/dist/vite/expose-internal-ids.d.ts +0 -22
  918. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  919. package/dist/vite/expose-internal-ids.js +0 -886
  920. package/dist/vite/expose-internal-ids.js.map +0 -1
  921. package/dist/vite/index.d.ts +0 -149
  922. package/dist/vite/index.d.ts.map +0 -1
  923. package/dist/vite/index.js.map +0 -1
  924. package/dist/vite/index.named-routes.gen.ts +0 -103
  925. package/dist/vite/package-resolution.d.ts +0 -43
  926. package/dist/vite/package-resolution.d.ts.map +0 -1
  927. package/dist/vite/package-resolution.js +0 -112
  928. package/dist/vite/package-resolution.js.map +0 -1
  929. package/dist/vite/virtual-entries.d.ts +0 -25
  930. package/dist/vite/virtual-entries.d.ts.map +0 -1
  931. package/dist/vite/virtual-entries.js +0 -110
  932. package/dist/vite/virtual-entries.js.map +0 -1
@@ -0,0 +1,764 @@
1
+ ---
2
+ name: migrate-react-router
3
+ description: Migrate a React Router v7/v6 project to @rangojs/router. Use when the user asks to "migrate from React Router", "convert React Router to Rango", "replace React Router", "move from Remix to Rango", or has a React Router / Remix app they want to port.
4
+ argument-hint: path-to-react-router-app
5
+ ---
6
+
7
+ # Migrate from React Router to @rangojs/router
8
+
9
+ Covers React Router v7 (framework mode and library mode), v6, and Remix v2.
10
+
11
+ ## Why Rango
12
+
13
+ Common reasons to migrate:
14
+
15
+ - **Server components by default** — move from client-first route rendering to
16
+ server-first UI and data fetching.
17
+ See: `/router-setup`, `/route`
18
+ - **Django-style route definition** — `urls()`, `path()`, and `layout()` make
19
+ the route tree explicit instead of splitting behavior across route modules or
20
+ router config objects.
21
+ See: `/route`, `/layout`
22
+ - **Named routes** — reverse URLs by route name instead of repeating path
23
+ strings in links, redirects, and navigation logic.
24
+ See: `/links`, `/typesafety`
25
+ - **Clear execution model** — request scope, render scope, segment boundaries,
26
+ and shared `ctx` behavior are explicit instead of being inferred from route
27
+ module conventions.
28
+ See: `/middleware`, `/loader`
29
+ - **Live data layer** — `createLoader()` and `loader()` keep data fresh
30
+ independently of cached UI. A route can serve cached segments while loaders
31
+ still resolve live on every request.
32
+ See: `/loader`, `/caching`, `/cache-guide`
33
+ - **Explicit caching model** — `cache()` DSL, `revalidate()`, `use cache`, and
34
+ custom cache stores make data and render caching a first-class part of the router.
35
+ See: `/caching`, `/cache-guide`, `/use-cache`
36
+ - **Build-time rendering** — `Static()` and `Prerender()` provide explicit
37
+ build-time rendering for routes that benefit from it.
38
+ See: `/prerender`
39
+ - **Composable route tree** — layouts, includes, middleware, parallels, and
40
+ intercepts compose directly in the route definition.
41
+ See: `/composability`, `/parallel`, `/intercept`
42
+ - **Multi-router flexibility** — support multiple routers, domain routing, and
43
+ more advanced host-routing setups than a single client router tree.
44
+ See: `/host-router`
45
+
46
+ ## Identify the mode first
47
+
48
+ React Router v7 has two modes that require different migration paths:
49
+
50
+ - **Framework mode** (`@react-router/dev` plugin, file-based routing, route module
51
+ API with `loader`/`action`/`meta`/`headers`/`shouldRevalidate` exports) — this is
52
+ the Remix successor. Migration involves replacing the route module convention with
53
+ Rango's `urls()` DSL and server component handlers.
54
+
55
+ - **Library mode** (`createBrowserRouter` or `<BrowserRouter>`, client-side only) —
56
+ migration involves moving from client-side routing to server-rendered RSC with the
57
+ `urls()` DSL.
58
+
59
+ React Router v6 and Remix v2 follow the same patterns as v7 library mode and
60
+ framework mode respectively.
61
+
62
+ ## Migration Strategy
63
+
64
+ Work route-by-route, bottom-up. Start with leaf routes, then layouts, then
65
+ loaders/actions. Verify each route works before moving to the next.
66
+
67
+ ## 1. Project Setup
68
+
69
+ Replace React Router tooling with Vite + Rango:
70
+
71
+ ```bash
72
+ # Framework mode:
73
+ npm remove react-router @react-router/dev @react-router/node @react-router/serve
74
+ # Library mode:
75
+ npm remove react-router react-router-dom
76
+
77
+ npm install @rangojs/router
78
+ ```
79
+
80
+ Replace the `@react-router/dev` Vite plugin with `rango()`:
81
+
82
+ ```typescript
83
+ // vite.config.ts
84
+ // Before: import { reactRouter } from "@react-router/dev/vite";
85
+ import { defineConfig } from "vite";
86
+ import { rango } from "@rangojs/router/vite";
87
+
88
+ export default defineConfig({
89
+ plugins: [rango()],
90
+ });
91
+ ```
92
+
93
+ Delete `react-router.config.ts` — route configuration moves to the `urls()` DSL.
94
+
95
+ ```typescript
96
+ // src/router.tsx
97
+ import { createRouter } from "@rangojs/router";
98
+ import { Document } from "./document";
99
+ import { urlpatterns } from "./urls";
100
+
101
+ export default createRouter({
102
+ document: Document,
103
+ }).routes(urlpatterns);
104
+ ```
105
+
106
+ ## 2. Route Mapping
107
+
108
+ ### RR7 framework mode: route modules → urls() DSL
109
+
110
+ In framework mode, each route is a file with conventional exports (`loader`,
111
+ `action`, `default`, `meta`, `headers`, `shouldRevalidate`, `handle`,
112
+ `ErrorBoundary`, `HydrateFallback`). In Rango, all of these become part of the
113
+ `urls()` DSL or move into the server component handler:
114
+
115
+ ```text
116
+ RR7 route module export → Rango equivalent
117
+ ─────────────────────────────────────────────────────
118
+ default (Component) → handler in path()
119
+ loader → fetch in handler, or createLoader()
120
+ action → "use server" function
121
+ meta → ctx.use(Meta) in handler
122
+ headers → ctx.header() in handler or middleware
123
+ shouldRevalidate → revalidate() DSL
124
+ ErrorBoundary → errorBoundary() DSL
125
+ HydrateFallback → loading() DSL
126
+ handle → createHandle() for cross-segment data (breadcrumbs, etc.)
127
+ clientLoader / clientAction → "use client" component with React hooks
128
+ ```
129
+
130
+ #### Example: full route module migration
131
+
132
+ ```typescript
133
+ // RR7 framework mode: app/routes/product.$slug.tsx
134
+ import type { Route } from "./+types/product.$slug";
135
+
136
+ export async function loader({ params }: Route.LoaderArgs) {
137
+ const product = await getProduct(params.slug);
138
+ if (!product) throw new Response("Not Found", { status: 404 });
139
+ return { product };
140
+ }
141
+
142
+ export async function action({ request }: Route.ActionArgs) {
143
+ const formData = await request.formData();
144
+ await addToCart(formData.get("productId") as string);
145
+ return { ok: true };
146
+ }
147
+
148
+ export function meta({ data }: Route.MetaArgs) {
149
+ return [{ title: data.product.name }];
150
+ }
151
+
152
+ export function headers() {
153
+ return { "Cache-Control": "max-age=300" };
154
+ }
155
+
156
+ export function shouldRevalidate({ actionResult }) {
157
+ return !!actionResult;
158
+ }
159
+
160
+ export default function ProductPage({ loaderData }: Route.ComponentProps) {
161
+ return <div>{loaderData.product.name}</div>;
162
+ }
163
+
164
+ export function ErrorBoundary() {
165
+ return <div>Product error</div>;
166
+ }
167
+ ```
168
+
169
+ ```typescript
170
+ // Rango: urls.tsx + handler
171
+ import { notFound } from "@rangojs/router";
172
+
173
+ const ProductPage: Handler<"product"> = async (ctx) => {
174
+ const product = await getProduct(ctx.params.slug);
175
+ if (!product) notFound("Product not found");
176
+
177
+ const meta = ctx.use(Meta);
178
+ meta({ title: product.name });
179
+ ctx.header("Cache-Control", "max-age=300");
180
+
181
+ return <div>{product.name}</div>;
182
+ };
183
+
184
+ // In urls.tsx:
185
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
186
+ revalidate(({ actionId }) => !!actionId),
187
+ errorBoundary(() => <div>Product error</div>),
188
+ loading(<ProductSkeleton />),
189
+ ])
190
+ ```
191
+
192
+ Key shift: the route module's scattered exports consolidate into the handler
193
+ (data fetching, meta, headers) and the DSL (revalidation, error boundary, loading).
194
+
195
+ ### RR7 file routing → urls() DSL
196
+
197
+ | RR7 file path | Rango |
198
+ | ---------------------------------------- | ------------------------------------------------------------- |
199
+ | `app/routes/_index.tsx` | `path("/", HomePage, { name: "home" })` |
200
+ | `app/routes/about.tsx` | `path("/about", AboutPage, { name: "about" })` |
201
+ | `app/routes/blog.$slug.tsx` | `path("/blog/:slug", BlogPost, { name: "blogPost" })` |
202
+ | `app/routes/files.$.tsx` (splat) | `path("/files/:path+", FileBrowser, { name: "files" })` |
203
+ | `app/routes/dashboard.tsx` (layout) | `layout(<DashboardLayout />, () => [...])` |
204
+ | `app/routes/dashboard._index.tsx` | `path("/dashboard", DashboardIndex, { name: "dashboard" })` |
205
+ | `app/routes/dashboard.settings.tsx` | `path("/dashboard/settings", Settings, { name: "settings" })` |
206
+ | `app/routes/_auth.tsx` (pathless layout) | `layout(<AuthLayout />, () => [...])` |
207
+ | `app/routes/_auth.login.tsx` | `path("/login", LoginPage, { name: "login" })` |
208
+
209
+ ### Library mode: config routes → urls() DSL
210
+
211
+ | React Router | Rango |
212
+ | -------------------------------------- | ------------------------------------------------------- |
213
+ | `path: "/"` | `path("/", HomePage, { name: "home" })` |
214
+ | `path: "about"` | `path("/about", AboutPage, { name: "about" })` |
215
+ | `path: "blog/:slug"` | `path("/blog/:slug", BlogPost, { name: "blogPost" })` |
216
+ | `path: "files/*"` (splat) | `path("/files/:path+", FileBrowser, { name: "files" })` |
217
+ | `path: "docs/:lang?"` (optional param) | `path("/docs/:lang?", Docs, { name: "docs" })` |
218
+
219
+ ### Layouts
220
+
221
+ React Router layouts use `<Outlet />` — same concept in Rango:
222
+
223
+ ```typescript
224
+ // React Router:
225
+ function DashboardLayout() {
226
+ return (
227
+ <div className="dashboard">
228
+ <Outlet />
229
+ </div>
230
+ );
231
+ }
232
+
233
+ // route config:
234
+ { path: "dashboard", element: <DashboardLayout />, children: [...] }
235
+
236
+ // Rango: same <Outlet />, from @rangojs/router/client
237
+ import { Outlet } from "@rangojs/router/client";
238
+
239
+ layout(<DashboardLayout />, () => [
240
+ path("/dashboard", DashboardIndex, { name: "dashboard" }),
241
+ path("/dashboard/settings", Settings, { name: "settings" }),
242
+ ])
243
+ ```
244
+
245
+ ### Dynamic layouts (with data)
246
+
247
+ ```typescript
248
+ // React Router: useLoaderData() in layout component
249
+ function DashboardLayout() {
250
+ const { user } = useLoaderData();
251
+ return <Shell user={user}><Outlet /></Shell>;
252
+ }
253
+
254
+ // Rango: handler function layout (server component)
255
+ layout(async (ctx) => {
256
+ const user = ctx.get("user");
257
+ return (
258
+ <Shell user={user}>
259
+ <Outlet />
260
+ </Shell>
261
+ );
262
+ }, () => [
263
+ path("/dashboard", DashboardIndex, { name: "dashboard" }),
264
+ ])
265
+ ```
266
+
267
+ ### Nested routes
268
+
269
+ React Router's nested route tree maps directly to Rango's `layout()` nesting:
270
+
271
+ ```typescript
272
+ // React Router:
273
+ createBrowserRouter([{
274
+ path: "/",
275
+ element: <RootLayout />,
276
+ children: [
277
+ { path: "dashboard",
278
+ element: <DashboardLayout />,
279
+ children: [
280
+ { index: true, element: <DashboardIndex /> },
281
+ { path: "settings", element: <Settings /> },
282
+ ]
283
+ },
284
+ ]
285
+ }])
286
+
287
+ // Rango:
288
+ urls(({ path, layout }) => [
289
+ layout(<RootLayout />, () => [
290
+ layout(<DashboardLayout />, () => [
291
+ path("/dashboard", DashboardIndex, { name: "dashboard" }),
292
+ path("/dashboard/settings", Settings, { name: "settings" }),
293
+ ]),
294
+ ]),
295
+ ])
296
+ ```
297
+
298
+ ### Route groups / pathless layouts
299
+
300
+ React Router's pathless routes (layout routes without a path) are Rango's
301
+ layouts without a URL prefix:
302
+
303
+ ```typescript
304
+ // React Router: { element: <AuthLayout />, children: [...] }
305
+
306
+ // Rango: layout with no URL segment
307
+ layout(<AuthLayout />, () => [
308
+ path("/login", LoginPage, { name: "login" }),
309
+ path("/register", RegisterPage, { name: "register" }),
310
+ ])
311
+ ```
312
+
313
+ ### Index routes
314
+
315
+ ```typescript
316
+ // React Router: { index: true, element: <Home /> }
317
+
318
+ // Rango: path with "/" inside a layout
319
+ layout(<RootLayout />, () => [
320
+ path("/", HomePage, { name: "home" }),
321
+ ])
322
+ ```
323
+
324
+ ## 3. Data Fetching
325
+
326
+ ### Loaders → handler (the default migration)
327
+
328
+ In React Router, loaders and components are separate: the loader fetches data,
329
+ the component renders it via `useLoaderData()`. In Rango, server component
330
+ handlers do both — combine the loader and component into a single handler:
331
+
332
+ ```typescript
333
+ // React Router: separate loader + component
334
+ export async function loader({ params }) {
335
+ const product = await getProduct(params.slug);
336
+ return { product };
337
+ }
338
+ function ProductPage() {
339
+ const { product } = useLoaderData();
340
+ return <div>{product.name}</div>;
341
+ }
342
+
343
+ // Rango: handler fetches and renders directly
344
+ const ProductPage: Handler<"product"> = async (ctx) => {
345
+ const product = await getProduct(ctx.params.slug);
346
+ return <div>{product.name}</div>;
347
+ };
348
+ ```
349
+
350
+ This is the standard migration path. The handler IS the loader — it fetches
351
+ data, then returns JSX. No separate data-fetching layer needed.
352
+
353
+ ### When to use createLoader()
354
+
355
+ Rango's `createLoader()` is a live data layer, not a loader migration target.
356
+ Use it only when you need capabilities beyond what the handler provides:
357
+
358
+ - **Client-side reactive data** — `useLoader()` in client components for data
359
+ that updates without a full page navigation
360
+ - **Shared data across segments** — a loader registered on a layout is available
361
+ to all child routes via `ctx.use(Loader)` or `useLoader(Loader)`
362
+ - **Independent revalidation** — `revalidate()` on a specific loader after actions
363
+ - **Per-loader caching** — `loader(L, () => [cache({ ttl: 60 })])`
364
+
365
+ If the React Router loader just fetches data for its page component, merge it
366
+ into the handler. See `/loader` for when the live data layer is useful.
367
+
368
+ ### Actions
369
+
370
+ React Router form actions map to Rango server actions:
371
+
372
+ ```typescript
373
+ // React Router:
374
+ export async function action({ request }) {
375
+ const formData = await request.formData();
376
+ await updateUser(formData.get("name"));
377
+ return redirect("/profile");
378
+ }
379
+ function EditProfile() {
380
+ return (
381
+ <Form method="post">
382
+ <input name="name" />
383
+ <button type="submit">Save</button>
384
+ </Form>
385
+ );
386
+ }
387
+
388
+ // Rango: "use server" action + native form or useActionState
389
+ "use server";
390
+ import { redirect } from "@rangojs/router";
391
+
392
+ export async function updateProfile(formData: FormData): Promise<void> {
393
+ await updateUser(formData.get("name") as string);
394
+ throw redirect("/profile");
395
+ }
396
+
397
+ // Client component:
398
+ function EditProfile() {
399
+ return (
400
+ <form action={updateProfile}>
401
+ <input name="name" />
402
+ <button type="submit">Save</button>
403
+ </form>
404
+ );
405
+ }
406
+ ```
407
+
408
+ Key difference: React Router actions are route-scoped (declared per route).
409
+ Rango actions are function-scoped (`"use server"` on any exported async function).
410
+
411
+ ### useLoaderData
412
+
413
+ There is no `useLoaderData()` in Rango. For most cases, the handler fetches
414
+ and renders directly (see above). When a client component needs live reactive
415
+ data, use `createLoader()` + `useLoader()`:
416
+
417
+ ```typescript
418
+ // React Router: useLoaderData() in client component
419
+ function ProductPrice() {
420
+ const { price } = useLoaderData();
421
+ return <span>{price}</span>;
422
+ }
423
+
424
+ // Rango: useLoader() reads from a registered loader (live data layer)
425
+ "use client";
426
+ import { useLoader } from "@rangojs/router/client";
427
+ import { PriceLoader } from "../loaders";
428
+
429
+ function ProductPrice() {
430
+ const { data } = useLoader(PriceLoader);
431
+ return <span>{data.price}</span>;
432
+ }
433
+ ```
434
+
435
+ `useLoader()` provides live data that stays fresh — it re-fetches on navigation
436
+ and after actions (controlled by `revalidate()`). This is different from
437
+ `useLoaderData()` which just reads a snapshot.
438
+
439
+ ### useActionData
440
+
441
+ React Router's `useActionData()` reads the return value of a route-scoped
442
+ `action()`. In Rango, actions are standard React server actions (`"use server"`),
443
+ so all React patterns apply directly:
444
+
445
+ ```typescript
446
+ // React Router:
447
+ export async function action({ request }) {
448
+ const form = await request.formData();
449
+ const errors = validate(form);
450
+ if (errors) return { errors };
451
+ await save(form);
452
+ return { ok: true };
453
+ }
454
+ function EditForm() {
455
+ const data = useActionData();
456
+ return (
457
+ <Form method="post">
458
+ {data?.errors && <p>{data.errors}</p>}
459
+ <input name="title" />
460
+ <button>Save</button>
461
+ </Form>
462
+ );
463
+ }
464
+
465
+ // Rango: useActionState (standard React hook)
466
+ "use client";
467
+ import { useActionState } from "react";
468
+ import { saveForm } from "../actions"; // "use server" function
469
+
470
+ function EditForm() {
471
+ const [state, action, pending] = useActionState(saveForm, null);
472
+ return (
473
+ <form action={action}>
474
+ {state?.errors && <p>{state.errors}</p>}
475
+ <input name="title" />
476
+ <button disabled={pending}>Save</button>
477
+ </form>
478
+ );
479
+ }
480
+ ```
481
+
482
+ Since Rango uses RSC server actions, all React action patterns work:
483
+ `useActionState`, `useOptimistic`, `useTransition`, `startTransition`,
484
+ and plain `<form action={serverAction}>`. No framework-specific hook needed.
485
+
486
+ ### clientLoader / clientAction (framework mode)
487
+
488
+ RR7 framework mode's `clientLoader` and `clientAction` run in the browser.
489
+ Rango does not have a framework-level client loader/action concept — these
490
+ migrate to standard React client-side code:
491
+
492
+ ```typescript
493
+ // RR7: clientLoader fetching from a third-party API
494
+ export async function clientLoader() {
495
+ const res = await fetch("https://api.weather.com/current?city=london");
496
+ return res.json();
497
+ }
498
+
499
+ // Rango: "use client" component with hooks
500
+ "use client";
501
+ import { useState, useEffect } from "react";
502
+
503
+ function WeatherWidget() {
504
+ const [weather, setWeather] = useState(null);
505
+ useEffect(() => {
506
+ fetch("https://api.weather.com/current?city=london")
507
+ .then((r) => r.json())
508
+ .then(setWeather);
509
+ }, []);
510
+ if (!weather) return <span>Loading...</span>;
511
+ return <span>{weather.temp}°C</span>;
512
+ }
513
+ ```
514
+
515
+ The general rule: anything that ran in `clientLoader`/`clientAction` moves into
516
+ React hooks (`useState`, `useEffect`, `useActionState`, `useOptimistic`) inside
517
+ a `"use client"` component. There is no framework wrapper — it's just React.
518
+
519
+ ### shouldRevalidate (framework mode)
520
+
521
+ RR7's `shouldRevalidate` export maps directly to Rango's `revalidate()` DSL:
522
+
523
+ ```typescript
524
+ // RR7:
525
+ export function shouldRevalidate({ actionResult, currentParams, nextParams }) {
526
+ if (actionResult) return true;
527
+ return currentParams.slug !== nextParams.slug;
528
+ }
529
+
530
+ // Rango:
531
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
532
+ revalidate(({ actionId, currentParams, nextParams }) => {
533
+ if (actionId) return true;
534
+ return currentParams.slug !== nextParams.slug;
535
+ }),
536
+ ]);
537
+ ```
538
+
539
+ Note: RR7's `shouldRevalidate` controls client-side loader re-fetching. Rango's
540
+ `revalidate()` controls which segments re-run during partial rendering after
541
+ navigation or actions. The intent is the same — skip unnecessary work — but
542
+ the mechanism is segment-level rather than loader-level.
543
+
544
+ ## 4. Middleware / Route Protection
545
+
546
+ React Router doesn't have built-in middleware. Protection is typically done in loaders:
547
+
548
+ ```typescript
549
+ // React Router: auth check in loader
550
+ export async function loader({ request }) {
551
+ const user = await getUser(request);
552
+ if (!user) throw redirect("/login");
553
+ return { user };
554
+ }
555
+
556
+ // Rango: router.use() for request-level auth
557
+ const router = createRouter({})
558
+ .use(authInit) // all routes — resolves session
559
+ .use("/dashboard/*", requireAuth) // scoped guard
560
+ .routes(urlpatterns);
561
+ ```
562
+
563
+ Use `router.use()` for auth guards (wraps entire request including actions).
564
+ Use DSL `middleware()` for render-level concerns (context shaping, headers).
565
+ See `/middleware`.
566
+
567
+ ## 5. Loading & Error States
568
+
569
+ ### Loading / Suspense
570
+
571
+ ```typescript
572
+ // React Router: defer() + Suspense, or HydrateFallback
573
+ export async function loader() {
574
+ return defer({ data: fetchData() });
575
+ }
576
+
577
+ // Rango: loading() DSL for automatic Suspense boundaries
578
+ path("/dashboard", DashboardPage, { name: "dashboard" }, () => [
579
+ loading(<DashboardSkeleton />),
580
+ ])
581
+ ```
582
+
583
+ ### Error boundaries
584
+
585
+ ```typescript
586
+ // React Router:
587
+ { path: "dashboard", element: <Dashboard />, errorElement: <ErrorPage /> }
588
+
589
+ // or with ErrorBoundary component:
590
+ function ErrorBoundary() {
591
+ const error = useRouteError();
592
+ return <div>Error: {error.message}</div>;
593
+ }
594
+
595
+ // Rango: errorBoundary() wrapping a group of routes
596
+ layout(<DashboardLayout />, () => [
597
+ errorBoundary(({ error, reset }) => (
598
+ <div>
599
+ <h2>Something went wrong</h2>
600
+ <button onClick={reset}>Try again</button>
601
+ </div>
602
+ )),
603
+ path("/dashboard", DashboardIndex, { name: "dashboard" }),
604
+ path("/dashboard/settings", Settings, { name: "settings" }),
605
+ ])
606
+ ```
607
+
608
+ ### Not found
609
+
610
+ ```typescript
611
+ // React Router: { path: "*", element: <NotFound /> }
612
+
613
+ // Rango (app-level):
614
+ createRouter({
615
+ notFound: ({ pathname }) => <NotFoundPage pathname={pathname} />,
616
+ })
617
+
618
+ // Rango (route-level — catches notFound() thrown in handlers/loaders):
619
+ layout(<ShopLayout />, () => [
620
+ notFoundBoundary(<ProductNotFound />),
621
+ path("/product/:slug", ProductPage, { name: "product" }),
622
+ ])
623
+ ```
624
+
625
+ ## 6. Navigation
626
+
627
+ | React Router | Rango |
628
+ | ----------------------------------------- | -------------------------------------------------------------------------------- |
629
+ | `import { Link } from "react-router-dom"` | `import { Link } from "@rangojs/router/client"` |
630
+ | `<Link to="/about">` | `<Link to="/about">` |
631
+ | `useNavigate()` | `useRouter()` from `@rangojs/router/client` |
632
+ | `navigate("/about")` | `useRouter().push("/about")` |
633
+ | `navigate("/about", { replace: true })` | `useRouter().replace("/about")` |
634
+ | `navigate(-1)` | `useRouter().back()` |
635
+ | `useLocation().pathname` | `usePathname()` from `@rangojs/router/client` |
636
+ | `useSearchParams()` | `useSearchParams()` from `@rangojs/router/client` |
637
+ | `useParams()` | `useParams()` from `@rangojs/router/client` (or `ctx.params` in server handlers) |
638
+ | `<NavLink>` | `<Link>` with `usePathname()` for active state |
639
+
640
+ ### useNavigate → useRouter
641
+
642
+ ```typescript
643
+ // React Router:
644
+ const navigate = useNavigate();
645
+ navigate("/dashboard");
646
+ navigate(-1);
647
+
648
+ // Rango:
649
+ const router = useRouter();
650
+ router.push("/dashboard");
651
+ router.back();
652
+ ```
653
+
654
+ ## 7. Metadata / Head
655
+
656
+ ```typescript
657
+ // React Router: meta function export (framework mode)
658
+ export function meta() {
659
+ return [{ title: "Home" }, { name: "description", content: "Welcome" }];
660
+ }
661
+
662
+ // Rango: Meta handle in server handlers
663
+ import { Meta } from "@rangojs/router";
664
+
665
+ const HomePage: Handler<"home"> = (ctx) => {
666
+ const meta = ctx.use(Meta);
667
+ meta({ title: "Home" });
668
+ meta({ name: "description", content: "Welcome" });
669
+ return <div>Home page</div>;
670
+ };
671
+ ```
672
+
673
+ Add `<MetaTags />` in the Document component's `<head>`:
674
+
675
+ ```typescript
676
+ import { MetaTags } from "@rangojs/router/client";
677
+
678
+ function Document({ children }: { children: ReactNode }) {
679
+ return (
680
+ <html>
681
+ <head>
682
+ <MetaTags />
683
+ </head>
684
+ <body>{children}</body>
685
+ </html>
686
+ );
687
+ }
688
+ ```
689
+
690
+ ## 8. API / Resource Routes
691
+
692
+ ```typescript
693
+ // React Router (framework mode):
694
+ // app/routes/api.users.ts
695
+ export async function loader() {
696
+ return Response.json(await getUsers());
697
+ }
698
+
699
+ // Rango: response routes
700
+ path.json(
701
+ "/api/users",
702
+ async () => {
703
+ return await getUsers();
704
+ },
705
+ { name: "apiUsers" },
706
+ );
707
+ ```
708
+
709
+ See `/response-routes` for `path.json()`, `path.text()`, `path.html()`, etc.
710
+
711
+ ## 9. Theme / Dark Mode
712
+
713
+ Rango has a built-in theme system with FOUC prevention. If the React Router app
714
+ uses a custom theme provider or `next-themes`, replace it with Rango's theme API:
715
+
716
+ ```typescript
717
+ const router = createRouter({
718
+ theme: true, // or { defaultTheme: "system", attribute: "class" }
719
+ });
720
+ ```
721
+
722
+ Client components use `useTheme()` to read and toggle:
723
+
724
+ ```typescript
725
+ "use client";
726
+ import { useTheme } from "@rangojs/router/theme";
727
+
728
+ function ThemeToggle() {
729
+ const { theme, setTheme } = useTheme();
730
+ return <button onClick={() => setTheme(theme === "dark" ? "light" : "dark")}>{theme}</button>;
731
+ }
732
+ ```
733
+
734
+ See `/theme` for full API including system detection and cookie persistence.
735
+
736
+ ## 10. Key Conceptual Differences
737
+
738
+ | Concept | React Router | Rango |
739
+ | ------------------- | ----------------------------------- | -------------------------------------- |
740
+ | Rendering | Client-side by default, SSR opt-in | Server components by default (RSC) |
741
+ | Data loading | `loader()` + `useLoaderData()` | Direct fetch in server components |
742
+ | Form actions | Route-scoped `action()` | Function-scoped `"use server"` |
743
+ | Route definition | File-based or `createBrowserRouter` | `urls()` DSL with `path()`, `layout()` |
744
+ | Middleware | Not built-in (use loaders) | `router.use()` + DSL `middleware()` |
745
+ | Parallel routes | Not built-in | `parallel()` DSL |
746
+ | Intercepting routes | Not built-in | `intercept()` DSL |
747
+ | Caching | Not built-in | `cache()` DSL, `"use cache"` |
748
+ | Type-safe routes | Partial (v7 framework mode) | Full: params, names, href, reverse |
749
+
750
+ ## Migration Checklist
751
+
752
+ 1. [ ] Set up Vite config with `rango()` plugin
753
+ 2. [ ] Create Document component with `<MetaTags />` in head
754
+ 3. [ ] Create `router.tsx` with `createRouter()`
755
+ 4. [ ] Convert route config / file routes to `urls()` DSL
756
+ 5. [ ] Migrate layouts — keep `<Outlet />` (import from `@rangojs/router/client`)
757
+ 6. [ ] Merge loaders + components into handler functions (fetch + render in one place)
758
+ 7. [ ] Convert React Router actions to `"use server"` functions
759
+ 8. [ ] Migrate auth guards from loaders to `router.use()`
760
+ 9. [ ] Replace `react-router-dom` Link/navigation with `@rangojs/router/client`
761
+ 10. [ ] Convert error boundaries to `errorBoundary()` DSL
762
+ 11. [ ] Update metadata to use `Meta` handle + `<MetaTags />`
763
+ 12. [ ] Replace custom theme provider with `theme: true` in createRouter (see `/theme`)
764
+ 13. [ ] Run `npx rango generate src/` to generate route types