@rangojs/router 0.0.0-experimental.0b3f4e91 → 0.0.0-experimental.0c4f94c2

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 (890) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +2 -1
  3. package/dist/vite/index.js +507 -192
  4. package/package.json +3 -3
  5. package/skills/handler-use/SKILL.md +362 -0
  6. package/skills/intercept/SKILL.md +20 -0
  7. package/skills/layout/SKILL.md +22 -0
  8. package/skills/middleware/SKILL.md +32 -3
  9. package/skills/migrate-nextjs/SKILL.md +560 -0
  10. package/skills/migrate-react-router/SKILL.md +764 -0
  11. package/skills/parallel/SKILL.md +59 -0
  12. package/skills/prerender/SKILL.md +110 -68
  13. package/skills/rango/SKILL.md +24 -22
  14. package/skills/route/SKILL.md +24 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/navigation-bridge.ts +7 -1
  17. package/src/browser/navigation-client.ts +34 -6
  18. package/src/browser/partial-update.ts +5 -0
  19. package/src/browser/prefetch/cache.ts +16 -6
  20. package/src/browser/prefetch/fetch.ts +60 -4
  21. package/src/browser/react/Link.tsx +25 -2
  22. package/src/browser/react/use-handle.ts +9 -58
  23. package/src/browser/scroll-restoration.ts +10 -8
  24. package/src/browser/segment-reconciler.ts +26 -0
  25. package/src/build/generate-manifest.ts +3 -6
  26. package/src/build/route-trie.ts +50 -24
  27. package/src/build/route-types/scan-filter.ts +8 -1
  28. package/src/client.tsx +2 -56
  29. package/src/handle.ts +40 -0
  30. package/src/index.rsc.ts +3 -1
  31. package/src/index.ts +46 -6
  32. package/src/prerender/store.ts +5 -4
  33. package/src/prerender.ts +138 -77
  34. package/src/reverse.ts +25 -1
  35. package/src/route-definition/dsl-helpers.ts +194 -32
  36. package/src/route-definition/helpers-types.ts +61 -14
  37. package/src/route-definition/index.ts +3 -0
  38. package/src/route-definition/resolve-handler-use.ts +149 -0
  39. package/src/route-types.ts +11 -0
  40. package/src/router/content-negotiation.ts +100 -1
  41. package/src/router/handler-context.ts +46 -6
  42. package/src/router/loader-resolution.ts +147 -19
  43. package/src/router/match-api.ts +124 -189
  44. package/src/router/match-middleware/cache-lookup.ts +24 -7
  45. package/src/router/match-middleware/segment-resolution.ts +53 -0
  46. package/src/router/match-result.ts +82 -4
  47. package/src/router/navigation-snapshot.ts +182 -0
  48. package/src/router/prerender-match.ts +108 -8
  49. package/src/router/preview-match.ts +30 -102
  50. package/src/router/request-classification.ts +310 -0
  51. package/src/router/route-snapshot.ts +245 -0
  52. package/src/router/router-interfaces.ts +11 -0
  53. package/src/router/segment-resolution/fresh.ts +59 -2
  54. package/src/router/segment-resolution/revalidation.ts +79 -6
  55. package/src/router.ts +13 -1
  56. package/src/rsc/handler.ts +468 -377
  57. package/src/rsc/loader-fetch.ts +23 -3
  58. package/src/rsc/progressive-enhancement.ts +10 -2
  59. package/src/rsc/rsc-rendering.ts +5 -1
  60. package/src/rsc/server-action.ts +6 -0
  61. package/src/rsc/ssr-setup.ts +1 -1
  62. package/src/rsc/types.ts +1 -0
  63. package/src/segment-system.tsx +45 -11
  64. package/src/server/context.ts +14 -1
  65. package/src/server/handle-store.ts +19 -0
  66. package/src/server/request-context.ts +125 -3
  67. package/src/static-handler.ts +18 -6
  68. package/src/types/handler-context.ts +12 -2
  69. package/src/types/loader-types.ts +32 -4
  70. package/src/types/route-entry.ts +1 -1
  71. package/src/types/segments.ts +4 -0
  72. package/src/urls/path-helper-types.ts +39 -6
  73. package/src/urls/path-helper.ts +47 -12
  74. package/src/urls/response-types.ts +16 -6
  75. package/src/use-loader.tsx +77 -5
  76. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  77. package/src/vite/discovery/prerender-collection.ts +128 -74
  78. package/src/vite/discovery/state.ts +13 -4
  79. package/src/vite/index.ts +4 -0
  80. package/src/vite/plugin-types.ts +60 -5
  81. package/src/vite/plugins/expose-id-utils.ts +12 -0
  82. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  83. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  84. package/src/vite/plugins/refresh-cmd.ts +88 -26
  85. package/src/vite/rango.ts +2 -1
  86. package/src/vite/router-discovery.ts +178 -37
  87. package/src/vite/utils/prerender-utils.ts +37 -5
  88. package/dist/__internal.d.ts +0 -83
  89. package/dist/__internal.d.ts.map +0 -1
  90. package/dist/__internal.js +0 -19
  91. package/dist/__internal.js.map +0 -1
  92. package/dist/__mocks__/version.d.ts +0 -7
  93. package/dist/__mocks__/version.d.ts.map +0 -1
  94. package/dist/__mocks__/version.js +0 -7
  95. package/dist/__mocks__/version.js.map +0 -1
  96. package/dist/__tests__/client-href.test.d.ts +0 -2
  97. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  98. package/dist/__tests__/client-href.test.js +0 -74
  99. package/dist/__tests__/client-href.test.js.map +0 -1
  100. package/dist/__tests__/component-utils.test.d.ts +0 -2
  101. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  102. package/dist/__tests__/component-utils.test.js +0 -51
  103. package/dist/__tests__/component-utils.test.js.map +0 -1
  104. package/dist/__tests__/event-controller.test.d.ts +0 -2
  105. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  106. package/dist/__tests__/event-controller.test.js +0 -538
  107. package/dist/__tests__/event-controller.test.js.map +0 -1
  108. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  109. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  110. package/dist/__tests__/helpers/route-tree.js +0 -374
  111. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  112. package/dist/__tests__/match-result.test.d.ts +0 -2
  113. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  114. package/dist/__tests__/match-result.test.js +0 -154
  115. package/dist/__tests__/match-result.test.js.map +0 -1
  116. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  117. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  118. package/dist/__tests__/navigation-store.test.js +0 -440
  119. package/dist/__tests__/navigation-store.test.js.map +0 -1
  120. package/dist/__tests__/partial-update.test.d.ts +0 -2
  121. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  122. package/dist/__tests__/partial-update.test.js +0 -1009
  123. package/dist/__tests__/partial-update.test.js.map +0 -1
  124. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  125. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  126. package/dist/__tests__/reverse-types.test.js +0 -656
  127. package/dist/__tests__/reverse-types.test.js.map +0 -1
  128. package/dist/__tests__/route-definition.test.d.ts +0 -2
  129. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  130. package/dist/__tests__/route-definition.test.js +0 -55
  131. package/dist/__tests__/route-definition.test.js.map +0 -1
  132. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  133. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  134. package/dist/__tests__/router-helpers.test.js +0 -377
  135. package/dist/__tests__/router-helpers.test.js.map +0 -1
  136. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  137. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  138. package/dist/__tests__/router-integration-2.test.js +0 -426
  139. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  140. package/dist/__tests__/router-integration.test.d.ts +0 -2
  141. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  142. package/dist/__tests__/router-integration.test.js +0 -1051
  143. package/dist/__tests__/router-integration.test.js.map +0 -1
  144. package/dist/__tests__/search-params.test.d.ts +0 -5
  145. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  146. package/dist/__tests__/search-params.test.js +0 -306
  147. package/dist/__tests__/search-params.test.js.map +0 -1
  148. package/dist/__tests__/segment-system.test.d.ts +0 -2
  149. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  150. package/dist/__tests__/segment-system.test.js +0 -627
  151. package/dist/__tests__/segment-system.test.js.map +0 -1
  152. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  153. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  154. package/dist/__tests__/static-handler-types.test.js +0 -63
  155. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  156. package/dist/__tests__/urls.test.d.ts +0 -2
  157. package/dist/__tests__/urls.test.d.ts.map +0 -1
  158. package/dist/__tests__/urls.test.js +0 -421
  159. package/dist/__tests__/urls.test.js.map +0 -1
  160. package/dist/__tests__/use-mount.test.d.ts +0 -2
  161. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  162. package/dist/__tests__/use-mount.test.js +0 -35
  163. package/dist/__tests__/use-mount.test.js.map +0 -1
  164. package/dist/bin/rango.d.ts +0 -2
  165. package/dist/bin/rango.d.ts.map +0 -1
  166. package/dist/bin/rango.js.map +0 -1
  167. package/dist/browser/event-controller.d.ts +0 -191
  168. package/dist/browser/event-controller.d.ts.map +0 -1
  169. package/dist/browser/event-controller.js +0 -559
  170. package/dist/browser/event-controller.js.map +0 -1
  171. package/dist/browser/index.d.ts +0 -2
  172. package/dist/browser/index.d.ts.map +0 -1
  173. package/dist/browser/index.js +0 -14
  174. package/dist/browser/index.js.map +0 -1
  175. package/dist/browser/link-interceptor.d.ts +0 -38
  176. package/dist/browser/link-interceptor.d.ts.map +0 -1
  177. package/dist/browser/link-interceptor.js +0 -99
  178. package/dist/browser/link-interceptor.js.map +0 -1
  179. package/dist/browser/logging.d.ts +0 -10
  180. package/dist/browser/logging.d.ts.map +0 -1
  181. package/dist/browser/logging.js +0 -29
  182. package/dist/browser/logging.js.map +0 -1
  183. package/dist/browser/lru-cache.d.ts +0 -17
  184. package/dist/browser/lru-cache.d.ts.map +0 -1
  185. package/dist/browser/lru-cache.js +0 -50
  186. package/dist/browser/lru-cache.js.map +0 -1
  187. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  188. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  189. package/dist/browser/merge-segment-loaders.js +0 -102
  190. package/dist/browser/merge-segment-loaders.js.map +0 -1
  191. package/dist/browser/navigation-bridge.d.ts +0 -102
  192. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  193. package/dist/browser/navigation-bridge.js +0 -708
  194. package/dist/browser/navigation-bridge.js.map +0 -1
  195. package/dist/browser/navigation-client.d.ts +0 -25
  196. package/dist/browser/navigation-client.d.ts.map +0 -1
  197. package/dist/browser/navigation-client.js +0 -157
  198. package/dist/browser/navigation-client.js.map +0 -1
  199. package/dist/browser/navigation-store.d.ts +0 -101
  200. package/dist/browser/navigation-store.d.ts.map +0 -1
  201. package/dist/browser/navigation-store.js +0 -625
  202. package/dist/browser/navigation-store.js.map +0 -1
  203. package/dist/browser/partial-update.d.ts +0 -75
  204. package/dist/browser/partial-update.d.ts.map +0 -1
  205. package/dist/browser/partial-update.js +0 -426
  206. package/dist/browser/partial-update.js.map +0 -1
  207. package/dist/browser/react/Link.d.ts +0 -86
  208. package/dist/browser/react/Link.d.ts.map +0 -1
  209. package/dist/browser/react/Link.js +0 -128
  210. package/dist/browser/react/Link.js.map +0 -1
  211. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  212. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  213. package/dist/browser/react/NavigationProvider.js +0 -216
  214. package/dist/browser/react/NavigationProvider.js.map +0 -1
  215. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  216. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  217. package/dist/browser/react/ScrollRestoration.js +0 -57
  218. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  219. package/dist/browser/react/context.d.ts +0 -46
  220. package/dist/browser/react/context.d.ts.map +0 -1
  221. package/dist/browser/react/context.js +0 -10
  222. package/dist/browser/react/context.js.map +0 -1
  223. package/dist/browser/react/index.d.ts +0 -11
  224. package/dist/browser/react/index.d.ts.map +0 -1
  225. package/dist/browser/react/index.js +0 -22
  226. package/dist/browser/react/index.js.map +0 -1
  227. package/dist/browser/react/location-state-shared.d.ts +0 -63
  228. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  229. package/dist/browser/react/location-state-shared.js +0 -81
  230. package/dist/browser/react/location-state-shared.js.map +0 -1
  231. package/dist/browser/react/location-state.d.ts +0 -23
  232. package/dist/browser/react/location-state.d.ts.map +0 -1
  233. package/dist/browser/react/location-state.js +0 -29
  234. package/dist/browser/react/location-state.js.map +0 -1
  235. package/dist/browser/react/mount-context.d.ts +0 -24
  236. package/dist/browser/react/mount-context.d.ts.map +0 -1
  237. package/dist/browser/react/mount-context.js +0 -24
  238. package/dist/browser/react/mount-context.js.map +0 -1
  239. package/dist/browser/react/use-action.d.ts +0 -64
  240. package/dist/browser/react/use-action.d.ts.map +0 -1
  241. package/dist/browser/react/use-action.js +0 -134
  242. package/dist/browser/react/use-action.js.map +0 -1
  243. package/dist/browser/react/use-client-cache.d.ts +0 -41
  244. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  245. package/dist/browser/react/use-client-cache.js +0 -39
  246. package/dist/browser/react/use-client-cache.js.map +0 -1
  247. package/dist/browser/react/use-handle.d.ts +0 -31
  248. package/dist/browser/react/use-handle.d.ts.map +0 -1
  249. package/dist/browser/react/use-handle.js +0 -144
  250. package/dist/browser/react/use-handle.js.map +0 -1
  251. package/dist/browser/react/use-href.d.ts +0 -33
  252. package/dist/browser/react/use-href.d.ts.map +0 -1
  253. package/dist/browser/react/use-href.js +0 -39
  254. package/dist/browser/react/use-href.js.map +0 -1
  255. package/dist/browser/react/use-link-status.d.ts +0 -37
  256. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  257. package/dist/browser/react/use-link-status.js +0 -99
  258. package/dist/browser/react/use-link-status.js.map +0 -1
  259. package/dist/browser/react/use-mount.d.ts +0 -25
  260. package/dist/browser/react/use-mount.d.ts.map +0 -1
  261. package/dist/browser/react/use-mount.js +0 -30
  262. package/dist/browser/react/use-mount.js.map +0 -1
  263. package/dist/browser/react/use-navigation.d.ts +0 -27
  264. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  265. package/dist/browser/react/use-navigation.js +0 -87
  266. package/dist/browser/react/use-navigation.js.map +0 -1
  267. package/dist/browser/react/use-segments.d.ts +0 -38
  268. package/dist/browser/react/use-segments.d.ts.map +0 -1
  269. package/dist/browser/react/use-segments.js +0 -130
  270. package/dist/browser/react/use-segments.js.map +0 -1
  271. package/dist/browser/request-controller.d.ts +0 -26
  272. package/dist/browser/request-controller.d.ts.map +0 -1
  273. package/dist/browser/request-controller.js +0 -147
  274. package/dist/browser/request-controller.js.map +0 -1
  275. package/dist/browser/rsc-router.d.ts +0 -129
  276. package/dist/browser/rsc-router.d.ts.map +0 -1
  277. package/dist/browser/rsc-router.js +0 -195
  278. package/dist/browser/rsc-router.js.map +0 -1
  279. package/dist/browser/scroll-restoration.d.ts +0 -93
  280. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  281. package/dist/browser/scroll-restoration.js +0 -321
  282. package/dist/browser/scroll-restoration.js.map +0 -1
  283. package/dist/browser/segment-structure-assert.d.ts +0 -17
  284. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  285. package/dist/browser/segment-structure-assert.js +0 -59
  286. package/dist/browser/segment-structure-assert.js.map +0 -1
  287. package/dist/browser/server-action-bridge.d.ts +0 -26
  288. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  289. package/dist/browser/server-action-bridge.js +0 -668
  290. package/dist/browser/server-action-bridge.js.map +0 -1
  291. package/dist/browser/shallow.d.ts +0 -12
  292. package/dist/browser/shallow.d.ts.map +0 -1
  293. package/dist/browser/shallow.js +0 -34
  294. package/dist/browser/shallow.js.map +0 -1
  295. package/dist/browser/types.d.ts +0 -369
  296. package/dist/browser/types.d.ts.map +0 -1
  297. package/dist/browser/types.js +0 -2
  298. package/dist/browser/types.js.map +0 -1
  299. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  300. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  301. package/dist/build/__tests__/generate-cli.test.js +0 -237
  302. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  303. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  304. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  305. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  306. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  307. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  308. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  309. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  310. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  311. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  312. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  313. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  314. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  315. package/dist/build/generate-manifest.d.ts +0 -81
  316. package/dist/build/generate-manifest.d.ts.map +0 -1
  317. package/dist/build/generate-manifest.js +0 -276
  318. package/dist/build/generate-manifest.js.map +0 -1
  319. package/dist/build/generate-route-types.d.ts +0 -115
  320. package/dist/build/generate-route-types.d.ts.map +0 -1
  321. package/dist/build/generate-route-types.js +0 -740
  322. package/dist/build/generate-route-types.js.map +0 -1
  323. package/dist/build/index.d.ts +0 -21
  324. package/dist/build/index.d.ts.map +0 -1
  325. package/dist/build/index.js +0 -21
  326. package/dist/build/index.js.map +0 -1
  327. package/dist/build/route-trie.d.ts +0 -71
  328. package/dist/build/route-trie.d.ts.map +0 -1
  329. package/dist/build/route-trie.js +0 -175
  330. package/dist/build/route-trie.js.map +0 -1
  331. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  332. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  333. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  334. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  335. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  336. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  337. package/dist/cache/__tests__/document-cache.test.js +0 -345
  338. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  339. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  340. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  341. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  342. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  343. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  344. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  345. package/dist/cache/__tests__/memory-store.test.js +0 -367
  346. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  347. package/dist/cache/cache-scope.d.ts +0 -102
  348. package/dist/cache/cache-scope.d.ts.map +0 -1
  349. package/dist/cache/cache-scope.js +0 -440
  350. package/dist/cache/cache-scope.js.map +0 -1
  351. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  352. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  353. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  354. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  355. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  356. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  357. package/dist/cache/cf/cf-cache-store.js +0 -242
  358. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  359. package/dist/cache/cf/index.d.ts +0 -14
  360. package/dist/cache/cf/index.d.ts.map +0 -1
  361. package/dist/cache/cf/index.js +0 -17
  362. package/dist/cache/cf/index.js.map +0 -1
  363. package/dist/cache/document-cache.d.ts +0 -64
  364. package/dist/cache/document-cache.d.ts.map +0 -1
  365. package/dist/cache/document-cache.js +0 -228
  366. package/dist/cache/document-cache.js.map +0 -1
  367. package/dist/cache/index.d.ts +0 -19
  368. package/dist/cache/index.d.ts.map +0 -1
  369. package/dist/cache/index.js +0 -21
  370. package/dist/cache/index.js.map +0 -1
  371. package/dist/cache/memory-segment-store.d.ts +0 -110
  372. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  373. package/dist/cache/memory-segment-store.js +0 -117
  374. package/dist/cache/memory-segment-store.js.map +0 -1
  375. package/dist/cache/memory-store.d.ts +0 -41
  376. package/dist/cache/memory-store.d.ts.map +0 -1
  377. package/dist/cache/memory-store.js +0 -191
  378. package/dist/cache/memory-store.js.map +0 -1
  379. package/dist/cache/types.d.ts +0 -317
  380. package/dist/cache/types.d.ts.map +0 -1
  381. package/dist/cache/types.js +0 -12
  382. package/dist/cache/types.js.map +0 -1
  383. package/dist/client.d.ts +0 -248
  384. package/dist/client.d.ts.map +0 -1
  385. package/dist/client.js +0 -367
  386. package/dist/client.js.map +0 -1
  387. package/dist/client.rsc.d.ts +0 -26
  388. package/dist/client.rsc.d.ts.map +0 -1
  389. package/dist/client.rsc.js +0 -46
  390. package/dist/client.rsc.js.map +0 -1
  391. package/dist/component-utils.d.ts +0 -36
  392. package/dist/component-utils.d.ts.map +0 -1
  393. package/dist/component-utils.js +0 -61
  394. package/dist/component-utils.js.map +0 -1
  395. package/dist/components/DefaultDocument.d.ts +0 -13
  396. package/dist/components/DefaultDocument.d.ts.map +0 -1
  397. package/dist/components/DefaultDocument.js +0 -15
  398. package/dist/components/DefaultDocument.js.map +0 -1
  399. package/dist/debug.d.ts +0 -58
  400. package/dist/debug.d.ts.map +0 -1
  401. package/dist/debug.js +0 -157
  402. package/dist/debug.js.map +0 -1
  403. package/dist/default-error-boundary.d.ts +0 -11
  404. package/dist/default-error-boundary.d.ts.map +0 -1
  405. package/dist/default-error-boundary.js +0 -45
  406. package/dist/default-error-boundary.js.map +0 -1
  407. package/dist/deps/browser.d.ts +0 -2
  408. package/dist/deps/browser.d.ts.map +0 -1
  409. package/dist/deps/browser.js +0 -3
  410. package/dist/deps/browser.js.map +0 -1
  411. package/dist/deps/html-stream-client.d.ts +0 -2
  412. package/dist/deps/html-stream-client.d.ts.map +0 -1
  413. package/dist/deps/html-stream-client.js +0 -3
  414. package/dist/deps/html-stream-client.js.map +0 -1
  415. package/dist/deps/html-stream-server.d.ts +0 -2
  416. package/dist/deps/html-stream-server.d.ts.map +0 -1
  417. package/dist/deps/html-stream-server.js +0 -3
  418. package/dist/deps/html-stream-server.js.map +0 -1
  419. package/dist/deps/rsc.d.ts +0 -2
  420. package/dist/deps/rsc.d.ts.map +0 -1
  421. package/dist/deps/rsc.js +0 -4
  422. package/dist/deps/rsc.js.map +0 -1
  423. package/dist/deps/ssr.d.ts +0 -2
  424. package/dist/deps/ssr.d.ts.map +0 -1
  425. package/dist/deps/ssr.js +0 -3
  426. package/dist/deps/ssr.js.map +0 -1
  427. package/dist/errors.d.ts +0 -174
  428. package/dist/errors.d.ts.map +0 -1
  429. package/dist/errors.js +0 -241
  430. package/dist/errors.js.map +0 -1
  431. package/dist/handle.d.ts +0 -78
  432. package/dist/handle.d.ts.map +0 -1
  433. package/dist/handle.js +0 -82
  434. package/dist/handle.js.map +0 -1
  435. package/dist/handles/MetaTags.d.ts +0 -14
  436. package/dist/handles/MetaTags.d.ts.map +0 -1
  437. package/dist/handles/MetaTags.js +0 -136
  438. package/dist/handles/MetaTags.js.map +0 -1
  439. package/dist/handles/index.d.ts +0 -6
  440. package/dist/handles/index.d.ts.map +0 -1
  441. package/dist/handles/index.js +0 -6
  442. package/dist/handles/index.js.map +0 -1
  443. package/dist/handles/meta.d.ts +0 -39
  444. package/dist/handles/meta.d.ts.map +0 -1
  445. package/dist/handles/meta.js +0 -202
  446. package/dist/handles/meta.js.map +0 -1
  447. package/dist/host/__tests__/errors.test.d.ts +0 -2
  448. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  449. package/dist/host/__tests__/errors.test.js +0 -76
  450. package/dist/host/__tests__/errors.test.js.map +0 -1
  451. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  452. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  453. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  454. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  455. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  456. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  457. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  458. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  459. package/dist/host/__tests__/router.test.d.ts +0 -2
  460. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  461. package/dist/host/__tests__/router.test.js +0 -241
  462. package/dist/host/__tests__/router.test.js.map +0 -1
  463. package/dist/host/__tests__/testing.test.d.ts +0 -2
  464. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  465. package/dist/host/__tests__/testing.test.js +0 -64
  466. package/dist/host/__tests__/testing.test.js.map +0 -1
  467. package/dist/host/__tests__/utils.test.d.ts +0 -2
  468. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  469. package/dist/host/__tests__/utils.test.js +0 -29
  470. package/dist/host/__tests__/utils.test.js.map +0 -1
  471. package/dist/host/cookie-handler.d.ts +0 -34
  472. package/dist/host/cookie-handler.d.ts.map +0 -1
  473. package/dist/host/cookie-handler.js +0 -124
  474. package/dist/host/cookie-handler.js.map +0 -1
  475. package/dist/host/errors.d.ts +0 -56
  476. package/dist/host/errors.d.ts.map +0 -1
  477. package/dist/host/errors.js +0 -79
  478. package/dist/host/errors.js.map +0 -1
  479. package/dist/host/index.d.ts +0 -29
  480. package/dist/host/index.d.ts.map +0 -1
  481. package/dist/host/index.js +0 -32
  482. package/dist/host/index.js.map +0 -1
  483. package/dist/host/pattern-matcher.d.ts +0 -36
  484. package/dist/host/pattern-matcher.d.ts.map +0 -1
  485. package/dist/host/pattern-matcher.js +0 -172
  486. package/dist/host/pattern-matcher.js.map +0 -1
  487. package/dist/host/router.d.ts +0 -26
  488. package/dist/host/router.d.ts.map +0 -1
  489. package/dist/host/router.js +0 -218
  490. package/dist/host/router.js.map +0 -1
  491. package/dist/host/testing.d.ts +0 -36
  492. package/dist/host/testing.d.ts.map +0 -1
  493. package/dist/host/testing.js +0 -55
  494. package/dist/host/testing.js.map +0 -1
  495. package/dist/host/types.d.ts +0 -115
  496. package/dist/host/types.d.ts.map +0 -1
  497. package/dist/host/types.js +0 -7
  498. package/dist/host/types.js.map +0 -1
  499. package/dist/host/utils.d.ts +0 -21
  500. package/dist/host/utils.d.ts.map +0 -1
  501. package/dist/host/utils.js +0 -23
  502. package/dist/host/utils.js.map +0 -1
  503. package/dist/href-client.d.ts +0 -131
  504. package/dist/href-client.d.ts.map +0 -1
  505. package/dist/href-client.js +0 -64
  506. package/dist/href-client.js.map +0 -1
  507. package/dist/href-context.d.ts +0 -29
  508. package/dist/href-context.d.ts.map +0 -1
  509. package/dist/href-context.js +0 -21
  510. package/dist/href-context.js.map +0 -1
  511. package/dist/index.d.ts +0 -73
  512. package/dist/index.d.ts.map +0 -1
  513. package/dist/index.js +0 -91
  514. package/dist/index.js.map +0 -1
  515. package/dist/index.rsc.d.ts +0 -32
  516. package/dist/index.rsc.d.ts.map +0 -1
  517. package/dist/index.rsc.js +0 -40
  518. package/dist/index.rsc.js.map +0 -1
  519. package/dist/internal-debug.d.ts +0 -2
  520. package/dist/internal-debug.d.ts.map +0 -1
  521. package/dist/internal-debug.js +0 -5
  522. package/dist/internal-debug.js.map +0 -1
  523. package/dist/loader.d.ts +0 -14
  524. package/dist/loader.d.ts.map +0 -1
  525. package/dist/loader.js +0 -20
  526. package/dist/loader.js.map +0 -1
  527. package/dist/loader.rsc.d.ts +0 -19
  528. package/dist/loader.rsc.d.ts.map +0 -1
  529. package/dist/loader.rsc.js +0 -99
  530. package/dist/loader.rsc.js.map +0 -1
  531. package/dist/network-error-thrower.d.ts +0 -17
  532. package/dist/network-error-thrower.d.ts.map +0 -1
  533. package/dist/network-error-thrower.js +0 -14
  534. package/dist/network-error-thrower.js.map +0 -1
  535. package/dist/outlet-context.d.ts +0 -13
  536. package/dist/outlet-context.d.ts.map +0 -1
  537. package/dist/outlet-context.js +0 -3
  538. package/dist/outlet-context.js.map +0 -1
  539. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  540. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  541. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  542. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  543. package/dist/prerender/param-hash.d.ts +0 -16
  544. package/dist/prerender/param-hash.d.ts.map +0 -1
  545. package/dist/prerender/param-hash.js +0 -36
  546. package/dist/prerender/param-hash.js.map +0 -1
  547. package/dist/prerender/store.d.ts +0 -38
  548. package/dist/prerender/store.d.ts.map +0 -1
  549. package/dist/prerender/store.js +0 -61
  550. package/dist/prerender/store.js.map +0 -1
  551. package/dist/prerender.d.ts +0 -66
  552. package/dist/prerender.d.ts.map +0 -1
  553. package/dist/prerender.js +0 -57
  554. package/dist/prerender.js.map +0 -1
  555. package/dist/reverse.d.ts +0 -196
  556. package/dist/reverse.d.ts.map +0 -1
  557. package/dist/reverse.js +0 -78
  558. package/dist/reverse.js.map +0 -1
  559. package/dist/root-error-boundary.d.ts +0 -33
  560. package/dist/root-error-boundary.d.ts.map +0 -1
  561. package/dist/root-error-boundary.js +0 -165
  562. package/dist/root-error-boundary.js.map +0 -1
  563. package/dist/route-content-wrapper.d.ts +0 -46
  564. package/dist/route-content-wrapper.d.ts.map +0 -1
  565. package/dist/route-content-wrapper.js +0 -77
  566. package/dist/route-content-wrapper.js.map +0 -1
  567. package/dist/route-definition.d.ts +0 -421
  568. package/dist/route-definition.d.ts.map +0 -1
  569. package/dist/route-definition.js +0 -868
  570. package/dist/route-definition.js.map +0 -1
  571. package/dist/route-map-builder.d.ts +0 -155
  572. package/dist/route-map-builder.d.ts.map +0 -1
  573. package/dist/route-map-builder.js +0 -237
  574. package/dist/route-map-builder.js.map +0 -1
  575. package/dist/route-types.d.ts +0 -165
  576. package/dist/route-types.d.ts.map +0 -1
  577. package/dist/route-types.js +0 -7
  578. package/dist/route-types.js.map +0 -1
  579. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  580. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  581. package/dist/router/__tests__/handler-context.test.js +0 -65
  582. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  583. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  584. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  585. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  586. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  587. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  588. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  589. package/dist/router/__tests__/match-context.test.js +0 -92
  590. package/dist/router/__tests__/match-context.test.js.map +0 -1
  591. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  592. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  593. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  594. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  595. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  596. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  597. package/dist/router/__tests__/match-result.test.js +0 -457
  598. package/dist/router/__tests__/match-result.test.js.map +0 -1
  599. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  600. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  601. package/dist/router/__tests__/on-error.test.js +0 -678
  602. package/dist/router/__tests__/on-error.test.js.map +0 -1
  603. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  604. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  605. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  606. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  607. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  608. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  609. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  610. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  611. package/dist/router/error-handling.d.ts +0 -77
  612. package/dist/router/error-handling.d.ts.map +0 -1
  613. package/dist/router/error-handling.js +0 -202
  614. package/dist/router/error-handling.js.map +0 -1
  615. package/dist/router/handler-context.d.ts +0 -20
  616. package/dist/router/handler-context.d.ts.map +0 -1
  617. package/dist/router/handler-context.js +0 -198
  618. package/dist/router/handler-context.js.map +0 -1
  619. package/dist/router/intercept-resolution.d.ts +0 -66
  620. package/dist/router/intercept-resolution.d.ts.map +0 -1
  621. package/dist/router/intercept-resolution.js +0 -246
  622. package/dist/router/intercept-resolution.js.map +0 -1
  623. package/dist/router/loader-resolution.d.ts +0 -64
  624. package/dist/router/loader-resolution.d.ts.map +0 -1
  625. package/dist/router/loader-resolution.js +0 -284
  626. package/dist/router/loader-resolution.js.map +0 -1
  627. package/dist/router/logging.d.ts +0 -15
  628. package/dist/router/logging.d.ts.map +0 -1
  629. package/dist/router/logging.js +0 -99
  630. package/dist/router/logging.js.map +0 -1
  631. package/dist/router/manifest.d.ts +0 -22
  632. package/dist/router/manifest.d.ts.map +0 -1
  633. package/dist/router/manifest.js +0 -181
  634. package/dist/router/manifest.js.map +0 -1
  635. package/dist/router/match-api.d.ts +0 -35
  636. package/dist/router/match-api.d.ts.map +0 -1
  637. package/dist/router/match-api.js +0 -406
  638. package/dist/router/match-api.js.map +0 -1
  639. package/dist/router/match-context.d.ts +0 -206
  640. package/dist/router/match-context.d.ts.map +0 -1
  641. package/dist/router/match-context.js +0 -17
  642. package/dist/router/match-context.js.map +0 -1
  643. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  644. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  645. package/dist/router/match-middleware/background-revalidation.js +0 -75
  646. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  647. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  648. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  649. package/dist/router/match-middleware/cache-lookup.js +0 -257
  650. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  651. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  652. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  653. package/dist/router/match-middleware/cache-store.js +0 -108
  654. package/dist/router/match-middleware/cache-store.js.map +0 -1
  655. package/dist/router/match-middleware/index.d.ts +0 -81
  656. package/dist/router/match-middleware/index.d.ts.map +0 -1
  657. package/dist/router/match-middleware/index.js +0 -80
  658. package/dist/router/match-middleware/index.js.map +0 -1
  659. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  660. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  661. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  662. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  663. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  664. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  665. package/dist/router/match-middleware/segment-resolution.js +0 -53
  666. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  667. package/dist/router/match-pipelines.d.ts +0 -147
  668. package/dist/router/match-pipelines.d.ts.map +0 -1
  669. package/dist/router/match-pipelines.js +0 -82
  670. package/dist/router/match-pipelines.js.map +0 -1
  671. package/dist/router/match-result.d.ts +0 -126
  672. package/dist/router/match-result.d.ts.map +0 -1
  673. package/dist/router/match-result.js +0 -93
  674. package/dist/router/match-result.js.map +0 -1
  675. package/dist/router/metrics.d.ts +0 -20
  676. package/dist/router/metrics.d.ts.map +0 -1
  677. package/dist/router/metrics.js +0 -47
  678. package/dist/router/metrics.js.map +0 -1
  679. package/dist/router/middleware.d.ts +0 -249
  680. package/dist/router/middleware.d.ts.map +0 -1
  681. package/dist/router/middleware.js +0 -434
  682. package/dist/router/middleware.js.map +0 -1
  683. package/dist/router/middleware.test.d.ts +0 -2
  684. package/dist/router/middleware.test.d.ts.map +0 -1
  685. package/dist/router/middleware.test.js +0 -816
  686. package/dist/router/middleware.test.js.map +0 -1
  687. package/dist/router/pattern-matching.d.ts +0 -149
  688. package/dist/router/pattern-matching.d.ts.map +0 -1
  689. package/dist/router/pattern-matching.js +0 -349
  690. package/dist/router/pattern-matching.js.map +0 -1
  691. package/dist/router/revalidation.d.ts +0 -44
  692. package/dist/router/revalidation.d.ts.map +0 -1
  693. package/dist/router/revalidation.js +0 -147
  694. package/dist/router/revalidation.js.map +0 -1
  695. package/dist/router/router-context.d.ts +0 -135
  696. package/dist/router/router-context.d.ts.map +0 -1
  697. package/dist/router/router-context.js +0 -36
  698. package/dist/router/router-context.js.map +0 -1
  699. package/dist/router/segment-resolution.d.ts +0 -127
  700. package/dist/router/segment-resolution.d.ts.map +0 -1
  701. package/dist/router/segment-resolution.js +0 -919
  702. package/dist/router/segment-resolution.js.map +0 -1
  703. package/dist/router/trie-matching.d.ts +0 -40
  704. package/dist/router/trie-matching.d.ts.map +0 -1
  705. package/dist/router/trie-matching.js +0 -127
  706. package/dist/router/trie-matching.js.map +0 -1
  707. package/dist/router/types.d.ts +0 -136
  708. package/dist/router/types.d.ts.map +0 -1
  709. package/dist/router/types.js +0 -7
  710. package/dist/router/types.js.map +0 -1
  711. package/dist/router.d.ts +0 -753
  712. package/dist/router.d.ts.map +0 -1
  713. package/dist/router.gen.d.ts +0 -6
  714. package/dist/router.gen.d.ts.map +0 -1
  715. package/dist/router.gen.js +0 -6
  716. package/dist/router.gen.js.map +0 -1
  717. package/dist/router.js +0 -1304
  718. package/dist/router.js.map +0 -1
  719. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  720. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  721. package/dist/rsc/__tests__/helpers.test.js +0 -140
  722. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  723. package/dist/rsc/handler.d.ts +0 -45
  724. package/dist/rsc/handler.d.ts.map +0 -1
  725. package/dist/rsc/handler.js +0 -1172
  726. package/dist/rsc/handler.js.map +0 -1
  727. package/dist/rsc/helpers.d.ts +0 -16
  728. package/dist/rsc/helpers.d.ts.map +0 -1
  729. package/dist/rsc/helpers.js +0 -55
  730. package/dist/rsc/helpers.js.map +0 -1
  731. package/dist/rsc/index.d.ts +0 -22
  732. package/dist/rsc/index.d.ts.map +0 -1
  733. package/dist/rsc/index.js +0 -23
  734. package/dist/rsc/index.js.map +0 -1
  735. package/dist/rsc/nonce.d.ts +0 -9
  736. package/dist/rsc/nonce.d.ts.map +0 -1
  737. package/dist/rsc/nonce.js +0 -18
  738. package/dist/rsc/nonce.js.map +0 -1
  739. package/dist/rsc/types.d.ts +0 -206
  740. package/dist/rsc/types.d.ts.map +0 -1
  741. package/dist/rsc/types.js +0 -8
  742. package/dist/rsc/types.js.map +0 -1
  743. package/dist/search-params.d.ts +0 -103
  744. package/dist/search-params.d.ts.map +0 -1
  745. package/dist/search-params.js +0 -74
  746. package/dist/search-params.js.map +0 -1
  747. package/dist/segment-system.d.ts +0 -75
  748. package/dist/segment-system.d.ts.map +0 -1
  749. package/dist/segment-system.js +0 -336
  750. package/dist/segment-system.js.map +0 -1
  751. package/dist/server/context.d.ts +0 -245
  752. package/dist/server/context.d.ts.map +0 -1
  753. package/dist/server/context.js +0 -197
  754. package/dist/server/context.js.map +0 -1
  755. package/dist/server/fetchable-loader-store.d.ts +0 -18
  756. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  757. package/dist/server/fetchable-loader-store.js +0 -18
  758. package/dist/server/fetchable-loader-store.js.map +0 -1
  759. package/dist/server/handle-store.d.ts +0 -85
  760. package/dist/server/handle-store.d.ts.map +0 -1
  761. package/dist/server/handle-store.js +0 -142
  762. package/dist/server/handle-store.js.map +0 -1
  763. package/dist/server/loader-registry.d.ts +0 -55
  764. package/dist/server/loader-registry.d.ts.map +0 -1
  765. package/dist/server/loader-registry.js +0 -132
  766. package/dist/server/loader-registry.js.map +0 -1
  767. package/dist/server/request-context.d.ts +0 -226
  768. package/dist/server/request-context.d.ts.map +0 -1
  769. package/dist/server/request-context.js +0 -290
  770. package/dist/server/request-context.js.map +0 -1
  771. package/dist/server/root-layout.d.ts +0 -4
  772. package/dist/server/root-layout.d.ts.map +0 -1
  773. package/dist/server/root-layout.js +0 -5
  774. package/dist/server/root-layout.js.map +0 -1
  775. package/dist/server.d.ts +0 -15
  776. package/dist/server.d.ts.map +0 -1
  777. package/dist/server.js +0 -20
  778. package/dist/server.js.map +0 -1
  779. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  780. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  781. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  782. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  783. package/dist/ssr/index.d.ts +0 -98
  784. package/dist/ssr/index.d.ts.map +0 -1
  785. package/dist/ssr/index.js +0 -158
  786. package/dist/ssr/index.js.map +0 -1
  787. package/dist/static-handler.d.ts +0 -50
  788. package/dist/static-handler.d.ts.map +0 -1
  789. package/dist/static-handler.gen.d.ts +0 -5
  790. package/dist/static-handler.gen.d.ts.map +0 -1
  791. package/dist/static-handler.gen.js +0 -5
  792. package/dist/static-handler.gen.js.map +0 -1
  793. package/dist/static-handler.js +0 -29
  794. package/dist/static-handler.js.map +0 -1
  795. package/dist/theme/ThemeProvider.d.ts +0 -20
  796. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  797. package/dist/theme/ThemeProvider.js +0 -240
  798. package/dist/theme/ThemeProvider.js.map +0 -1
  799. package/dist/theme/ThemeScript.d.ts +0 -48
  800. package/dist/theme/ThemeScript.d.ts.map +0 -1
  801. package/dist/theme/ThemeScript.js +0 -13
  802. package/dist/theme/ThemeScript.js.map +0 -1
  803. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  804. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  805. package/dist/theme/__tests__/theme.test.js +0 -103
  806. package/dist/theme/__tests__/theme.test.js.map +0 -1
  807. package/dist/theme/constants.d.ts +0 -29
  808. package/dist/theme/constants.d.ts.map +0 -1
  809. package/dist/theme/constants.js +0 -48
  810. package/dist/theme/constants.js.map +0 -1
  811. package/dist/theme/index.d.ts +0 -31
  812. package/dist/theme/index.d.ts.map +0 -1
  813. package/dist/theme/index.js +0 -36
  814. package/dist/theme/index.js.map +0 -1
  815. package/dist/theme/theme-context.d.ts +0 -40
  816. package/dist/theme/theme-context.d.ts.map +0 -1
  817. package/dist/theme/theme-context.js +0 -60
  818. package/dist/theme/theme-context.js.map +0 -1
  819. package/dist/theme/theme-script.d.ts +0 -27
  820. package/dist/theme/theme-script.d.ts.map +0 -1
  821. package/dist/theme/theme-script.js +0 -147
  822. package/dist/theme/theme-script.js.map +0 -1
  823. package/dist/theme/types.d.ts +0 -163
  824. package/dist/theme/types.d.ts.map +0 -1
  825. package/dist/theme/types.js +0 -11
  826. package/dist/theme/types.js.map +0 -1
  827. package/dist/theme/use-theme.d.ts +0 -12
  828. package/dist/theme/use-theme.d.ts.map +0 -1
  829. package/dist/theme/use-theme.js +0 -40
  830. package/dist/theme/use-theme.js.map +0 -1
  831. package/dist/types.d.ts +0 -1479
  832. package/dist/types.d.ts.map +0 -1
  833. package/dist/types.js +0 -10
  834. package/dist/types.js.map +0 -1
  835. package/dist/urls.d.ts +0 -441
  836. package/dist/urls.d.ts.map +0 -1
  837. package/dist/urls.gen.d.ts +0 -8
  838. package/dist/urls.gen.d.ts.map +0 -1
  839. package/dist/urls.gen.js +0 -8
  840. package/dist/urls.gen.js.map +0 -1
  841. package/dist/urls.js +0 -443
  842. package/dist/urls.js.map +0 -1
  843. package/dist/use-loader.d.ts +0 -127
  844. package/dist/use-loader.d.ts.map +0 -1
  845. package/dist/use-loader.js +0 -237
  846. package/dist/use-loader.js.map +0 -1
  847. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  848. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  849. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  850. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  851. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  852. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  853. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  854. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  855. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  856. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  857. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  858. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  859. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  860. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  861. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  862. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  863. package/dist/vite/ast-handler-extract.d.ts +0 -49
  864. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  865. package/dist/vite/ast-handler-extract.js +0 -249
  866. package/dist/vite/ast-handler-extract.js.map +0 -1
  867. package/dist/vite/expose-action-id.d.ts +0 -19
  868. package/dist/vite/expose-action-id.d.ts.map +0 -1
  869. package/dist/vite/expose-action-id.js +0 -250
  870. package/dist/vite/expose-action-id.js.map +0 -1
  871. package/dist/vite/expose-id-utils.d.ts +0 -69
  872. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  873. package/dist/vite/expose-id-utils.js +0 -289
  874. package/dist/vite/expose-id-utils.js.map +0 -1
  875. package/dist/vite/expose-internal-ids.d.ts +0 -22
  876. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  877. package/dist/vite/expose-internal-ids.js +0 -886
  878. package/dist/vite/expose-internal-ids.js.map +0 -1
  879. package/dist/vite/index.d.ts +0 -149
  880. package/dist/vite/index.d.ts.map +0 -1
  881. package/dist/vite/index.js.map +0 -1
  882. package/dist/vite/index.named-routes.gen.ts +0 -103
  883. package/dist/vite/package-resolution.d.ts +0 -43
  884. package/dist/vite/package-resolution.d.ts.map +0 -1
  885. package/dist/vite/package-resolution.js +0 -112
  886. package/dist/vite/package-resolution.js.map +0 -1
  887. package/dist/vite/virtual-entries.d.ts +0 -25
  888. package/dist/vite/virtual-entries.d.ts.map +0 -1
  889. package/dist/vite/virtual-entries.js +0 -110
  890. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1,868 +0,0 @@
1
- import { getContext, getNamePrefix, getUrlPrefix, } from "./server/context";
2
- import { invariant } from "./errors";
3
- import { isStaticHandler } from "./static-handler.js";
4
- import RootLayout from "./server/root-layout";
5
- /**
6
- * Check if a value is a RouteConfig object
7
- */
8
- function isRouteConfig(value) {
9
- return (typeof value === "object" &&
10
- value !== null &&
11
- "path" in value &&
12
- typeof value.path === "string");
13
- }
14
- /**
15
- * Define routes with optional trailing slash configuration
16
- *
17
- * @example
18
- * ```typescript
19
- * // Simple string paths
20
- * const routes = route({
21
- * blog: "/blog",
22
- * post: "/blog/:id",
23
- * });
24
- *
25
- * // With trailing slash config
26
- * const routes = route({
27
- * blog: "/blog",
28
- * api: { path: "/api", trailingSlash: "ignore" },
29
- * }, { trailingSlash: "never" }); // global default
30
- * ```
31
- */
32
- export function route(input, options) {
33
- const trailingSlash = {};
34
- const routes = flattenRoutes(input, "", trailingSlash, options?.trailingSlash);
35
- // Attach trailing slash config as a non-enumerable property
36
- // This keeps backwards compatibility while passing the config through
37
- const result = routes;
38
- if (Object.keys(trailingSlash).length > 0) {
39
- Object.defineProperty(result, "__trailingSlash", {
40
- value: trailingSlash,
41
- enumerable: false,
42
- writable: false,
43
- });
44
- }
45
- return result;
46
- }
47
- /**
48
- * Flatten nested route definitions
49
- */
50
- function flattenRoutes(routes, prefix, trailingSlashConfig, defaultTrailingSlash) {
51
- const flattened = {};
52
- for (const [key, value] of Object.entries(routes)) {
53
- const fullKey = prefix + key;
54
- if (typeof value === "string") {
55
- // Direct route pattern - include prefix
56
- flattened[fullKey] = value;
57
- // Apply default trailing slash if set
58
- if (defaultTrailingSlash) {
59
- trailingSlashConfig[fullKey] = defaultTrailingSlash;
60
- }
61
- }
62
- else if (isRouteConfig(value)) {
63
- // Route config object with path and optional trailingSlash
64
- flattened[fullKey] = value.path;
65
- // Use route-specific config or fall back to default
66
- const mode = value.trailingSlash ?? defaultTrailingSlash;
67
- if (mode) {
68
- trailingSlashConfig[fullKey] = mode;
69
- }
70
- }
71
- else {
72
- // Nested routes - flatten recursively
73
- const nested = flattenRoutes(value, `${fullKey}.`, trailingSlashConfig, defaultTrailingSlash);
74
- Object.assign(flattened, nested);
75
- }
76
- }
77
- return flattened;
78
- }
79
- /**
80
- * Check if an item contains routes (directly or inside nested structures like cache).
81
- * Used to determine if a layout or cache should be treated as an orphan.
82
- */
83
- const hasRoutesInItem = (item) => {
84
- if (item.type === "route")
85
- return true;
86
- // Lazy includes contain deferred routes — treat them as having routes
87
- // to prevent the parent layout from being misclassified as orphan,
88
- // which would clear its parent pointer and break the middleware chain.
89
- if (item.type === "include")
90
- return true;
91
- if (item.type === "cache" && item.uses) {
92
- return item.uses.some((child) => hasRoutesInItem(child));
93
- }
94
- if (item.type === "layout" && item.uses) {
95
- return item.uses.some((child) => hasRoutesInItem(child));
96
- }
97
- return false;
98
- };
99
- const revalidate = (fn) => {
100
- const ctx = getContext().getStore();
101
- if (!ctx)
102
- throw new Error("revalidate() must be called inside map()");
103
- // Attach to last entry in stack
104
- const parent = ctx.parent;
105
- if (!parent || !("revalidate" in parent)) {
106
- invariant(false, "No parent entry available for revalidate()");
107
- }
108
- const name = `$${getContext().getNextIndex("revalidate")}`;
109
- parent.revalidate.push(fn);
110
- return { name, type: "revalidate" };
111
- };
112
- /**
113
- * Error boundary helper - attaches an error fallback to the current entry
114
- *
115
- * When an error occurs during rendering of this segment or its children,
116
- * the fallback will be rendered instead. The fallback can be:
117
- * - A static ReactNode (e.g., <ErrorPage />)
118
- * - A handler function that receives error info and reset function
119
- *
120
- * Error boundaries catch errors from:
121
- * - Middleware execution
122
- * - Loader execution
123
- * - Handler/component rendering
124
- *
125
- * @example
126
- * ```typescript
127
- * layout(<ShopLayout />, () => [
128
- * errorBoundary(<ShopErrorFallback />),
129
- * route("products.detail", ProductDetail),
130
- * ])
131
- *
132
- * // Or with handler for dynamic error UI:
133
- * route("products.detail", ProductDetail, () => [
134
- * errorBoundary(({ error, reset }) => (
135
- * <div>
136
- * <h2>Product failed to load</h2>
137
- * <p>{error.message}</p>
138
- * <button onClick={reset}>Retry</button>
139
- * </div>
140
- * )),
141
- * ])
142
- * ```
143
- */
144
- const errorBoundary = (fallback) => {
145
- const ctx = getContext().getStore();
146
- if (!ctx)
147
- throw new Error("errorBoundary() must be called inside map()");
148
- // Attach to parent entry in stack
149
- const parent = ctx.parent;
150
- if (!parent || !("errorBoundary" in parent)) {
151
- invariant(false, "No parent entry available for errorBoundary()");
152
- }
153
- const name = `$${getContext().getNextIndex("errorBoundary")}`;
154
- parent.errorBoundary.push(fallback);
155
- return { name, type: "errorBoundary" };
156
- };
157
- /**
158
- * NotFound boundary helper - attaches a not-found fallback to the current entry
159
- *
160
- * When a DataNotFoundError is thrown (via notFound()) during rendering of this
161
- * segment or its children, the fallback will be rendered instead. The fallback can be:
162
- * - A static ReactNode (e.g., <ProductNotFound />)
163
- * - A handler function that receives not found info
164
- *
165
- * NotFound boundaries catch DataNotFoundError from:
166
- * - Loader execution
167
- * - Handler/component rendering
168
- *
169
- * @example
170
- * ```typescript
171
- * layout(<ShopLayout />, () => [
172
- * notFoundBoundary(<ProductNotFound />),
173
- * route("products.detail", ProductDetail),
174
- * ])
175
- *
176
- * // Or with handler for dynamic not found UI:
177
- * route("products.detail", ProductDetail, () => [
178
- * notFoundBoundary(({ notFound }) => (
179
- * <div>
180
- * <h2>Product not found</h2>
181
- * <p>{notFound.message}</p>
182
- * <a href="/products">Browse all products</a>
183
- * </div>
184
- * )),
185
- * ])
186
- * ```
187
- */
188
- const notFoundBoundary = (fallback) => {
189
- const ctx = getContext().getStore();
190
- if (!ctx)
191
- throw new Error("notFoundBoundary() must be called inside map()");
192
- // Attach to parent entry in stack
193
- const parent = ctx.parent;
194
- if (!parent || !("notFoundBoundary" in parent)) {
195
- invariant(false, "No parent entry available for notFoundBoundary()");
196
- }
197
- const name = `$${getContext().getNextIndex("notFoundBoundary")}`;
198
- parent.notFoundBoundary.push(fallback);
199
- return { name, type: "notFoundBoundary" };
200
- };
201
- /**
202
- * When helper - defines a condition for intercept activation
203
- *
204
- * Only valid inside intercept() use() callback. The when() function
205
- * is captured by the intercept and stored in its `when` array.
206
- * During soft navigation, all when() conditions must return true
207
- * for the intercept to activate.
208
- */
209
- const when = (fn) => {
210
- const ctx = getContext().getStore();
211
- if (!ctx)
212
- throw new Error("when() must be called inside intercept()");
213
- // The when() function needs to be captured by the intercept's tempParent
214
- // which should have a `when` array. If not present, we're not inside intercept()
215
- const parent = ctx.parent;
216
- if (!parent || !("when" in parent)) {
217
- invariant(false, "when() can only be used inside intercept() use() callback");
218
- }
219
- const name = `$${getContext().getNextIndex("when")}`;
220
- parent.when.push(fn);
221
- return { name, type: "when" };
222
- };
223
- /**
224
- * Cache helper - defines caching configuration for segments
225
- *
226
- * Creates a cache boundary that applies to all children unless overridden.
227
- * When used without children, attaches cache config to the parent entry
228
- * (e.g., for loader-specific caching).
229
- *
230
- * Supports three call signatures:
231
- * - cache() - no args, uses app-level defaults (for loader caching)
232
- * - cache(() => [...]) - wraps children with app-level defaults
233
- * - cache({ ttl: 60 }, () => [...]) - with explicit options
234
- */
235
- const cache = (optionsOrChildren, maybeChildren) => {
236
- const store = getContext();
237
- const ctx = store.getStore();
238
- if (!ctx)
239
- throw new Error("cache() must be called inside map()");
240
- // Handle overloaded signature: cache(), cache(children), or cache(options, children)
241
- let options;
242
- let children;
243
- if (optionsOrChildren === undefined) {
244
- // cache() - no args, use defaults
245
- options = {};
246
- children = undefined;
247
- }
248
- else if (typeof optionsOrChildren === "function") {
249
- // cache(() => [...]) - use empty options (will use defaults)
250
- options = {};
251
- children = optionsOrChildren;
252
- }
253
- else {
254
- // cache(options, children) - explicit options
255
- options = optionsOrChildren;
256
- children = maybeChildren;
257
- }
258
- const name = `$${store.getNextIndex("cache")}`;
259
- const cacheConfig = { options };
260
- // If no children, create an orphan cache entry (like orphan layouts)
261
- // This allows cache() to wrap subsequent siblings
262
- if (!children) {
263
- const parent = ctx.parent;
264
- // Check if we're inside a loader() use() callback - special case for loader caching
265
- if (parent && parent.type === "loader") {
266
- // Direct assignment to loader entry's cache field
267
- parent.cache = cacheConfig;
268
- return { name, type: "cache" };
269
- }
270
- // Create orphan cache entry (like orphan layout)
271
- // Subsequent siblings in the same array will attach to this entry
272
- const namespace = `${ctx.namespace}.${store.getNextIndex("cache")}`;
273
- const cacheUrlPrefix = getUrlPrefix();
274
- const entry = {
275
- id: namespace,
276
- shortCode: store.getShortCode("cache"),
277
- type: "cache",
278
- parent: parent, // link to current parent for hierarchy
279
- cache: cacheConfig,
280
- handler: RootLayout,
281
- middleware: [],
282
- revalidate: [],
283
- errorBoundary: [],
284
- notFoundBoundary: [],
285
- layout: [],
286
- parallel: [],
287
- intercept: [],
288
- loader: [],
289
- ...(cacheUrlPrefix ? { mountPath: cacheUrlPrefix } : {}),
290
- };
291
- // Attach to parent's layout array (cache entries are structural like layouts)
292
- if (parent && "layout" in parent) {
293
- parent.layout.push(entry);
294
- }
295
- // Update context parent so subsequent siblings attach to this cache entry
296
- // This makes cache() act as sugar for cache(() => [...])
297
- ctx.parent = entry;
298
- return { name: namespace, type: "cache" };
299
- }
300
- // With children: create a cache entry (like layout with caching semantics)
301
- const cacheNextIndex = store.getNextIndex("cache");
302
- const namespace = `${ctx.namespace}.${cacheNextIndex}`;
303
- const cacheShortCode = store.getShortCode("cache");
304
- const cacheUrlPrefix2 = getUrlPrefix();
305
- const entry = {
306
- id: namespace,
307
- shortCode: cacheShortCode,
308
- type: "cache",
309
- parent: ctx.parent,
310
- cache: cacheConfig,
311
- // Cache entries render like layouts (with Outlet as default handler)
312
- handler: RootLayout, // RootLayout just renders <Outlet />
313
- middleware: [],
314
- revalidate: [],
315
- errorBoundary: [],
316
- notFoundBoundary: [],
317
- layout: [],
318
- parallel: [],
319
- intercept: [],
320
- loader: [],
321
- ...(cacheUrlPrefix2 ? { mountPath: cacheUrlPrefix2 } : {}),
322
- };
323
- // Run children with cache entry as parent
324
- const result = store.run(namespace, entry, children);
325
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `cache() children callback must return an array of use items [${namespace}]`);
326
- // Check if this cache has routes (including nested caches/layouts)
327
- const hasRoutes = result &&
328
- Array.isArray(result) &&
329
- result.some((item) => hasRoutesInItem(item));
330
- if (!hasRoutes) {
331
- const parent = ctx.parent;
332
- if (parent && "layout" in parent) {
333
- // Attach to parent's layout array (cache entries are structural like layouts)
334
- entry.parent = null;
335
- parent.layout.push(entry);
336
- }
337
- }
338
- return { name: namespace, type: "cache", uses: result };
339
- };
340
- const middleware = (...fn) => {
341
- const ctx = getContext().getStore();
342
- if (!ctx)
343
- throw new Error("middleware() must be called inside map()");
344
- // Attach to last entry in stack
345
- const parent = ctx.parent;
346
- if (!parent || !("middleware" in parent)) {
347
- invariant(false, "No parent entry available for middleware()");
348
- }
349
- const name = `$${getContext().getNextIndex("middleware")}`;
350
- parent.middleware.push(...fn);
351
- return { name, type: "middleware" };
352
- };
353
- const parallel = (slots, use) => {
354
- const store = getContext();
355
- const ctx = store.getStore();
356
- if (!ctx)
357
- throw new Error("parallel() must be called inside map()");
358
- if (!ctx.parent || !ctx.parent?.parallel) {
359
- invariant(false, "No parent entry available for parallel()");
360
- }
361
- invariant(ctx.parent.type !== "parallel", "parallel() cannot be nested inside another parallel()");
362
- const namespace = `${ctx.namespace}.$${store.getNextIndex("parallel")}`;
363
- // Unwrap any static handler definitions in parallel slots
364
- const unwrappedSlots = {};
365
- let hasStaticSlot = false;
366
- for (const [slotName, slotHandler] of Object.entries(slots)) {
367
- if (isStaticHandler(slotHandler)) {
368
- hasStaticSlot = true;
369
- unwrappedSlots[slotName] = slotHandler.handler;
370
- }
371
- else {
372
- unwrappedSlots[slotName] = slotHandler;
373
- }
374
- }
375
- // Create full EntryData for parallel with its own loaders/revalidate/loading
376
- const parallelUrlPrefix = getUrlPrefix();
377
- const entry = {
378
- id: namespace,
379
- shortCode: store.getShortCode("parallel"),
380
- type: "parallel",
381
- parent: null, // Parallels don't participate in parent chain traversal
382
- handler: unwrappedSlots,
383
- loading: undefined, // Allow loading() to attach loading state
384
- middleware: [],
385
- revalidate: [],
386
- errorBoundary: [],
387
- notFoundBoundary: [],
388
- layout: [],
389
- parallel: [],
390
- intercept: [],
391
- loader: [],
392
- ...(parallelUrlPrefix ? { mountPath: parallelUrlPrefix } : {}),
393
- ...(hasStaticSlot ? { isStaticPrerender: true } : {}),
394
- };
395
- // Run use callback if provided to collect loaders, revalidate, loading
396
- if (use && typeof use === "function") {
397
- const result = store.run(namespace, entry, use);
398
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `parallel() use() callback must return an array of use items [${namespace}]`);
399
- }
400
- ctx.parent.parallel.push(entry);
401
- return { name: namespace, type: "parallel" };
402
- };
403
- /**
404
- * Intercept helper - defines an intercepting route for soft navigation
405
- */
406
- const intercept = (slotName, routeName, handler, use) => {
407
- const store = getContext();
408
- const ctx = store.getStore();
409
- if (!ctx)
410
- throw new Error("intercept() must be called inside map()");
411
- if (!ctx.parent || !ctx.parent?.intercept) {
412
- invariant(false, "No parent entry available for intercept()");
413
- }
414
- invariant(ctx.parent.type !== "parallel", "intercept() cannot be used inside parallel()");
415
- const namespace = `${ctx.namespace}.$${store.getNextIndex("intercept")}.${slotName}`;
416
- // Apply name prefix to routeName (from include())
417
- // This ensures intercepts match prefixed route keys
418
- const namePrefix = getNamePrefix();
419
- const prefixedRouteName = namePrefix ? `${namePrefix}.${routeName}` : routeName;
420
- // Create intercept entry with its own loaders/revalidate/middleware/when
421
- const entry = {
422
- slotName: slotName,
423
- routeName: prefixedRouteName,
424
- handler,
425
- middleware: [],
426
- revalidate: [],
427
- errorBoundary: [],
428
- notFoundBoundary: [],
429
- loader: [],
430
- when: [], // Selector conditions for conditional interception
431
- };
432
- // Run use callback if provided to collect loaders, revalidate, middleware, etc.
433
- if (use && typeof use === "function") {
434
- // Create a temporary parent context for the use() callback
435
- // so that middleware, loader, revalidate attach to the intercept entry
436
- const originalParent = ctx.parent;
437
- // Capture layouts in a temporary array
438
- const capturedLayouts = [];
439
- const tempParent = {
440
- ...originalParent,
441
- middleware: entry.middleware,
442
- revalidate: entry.revalidate,
443
- errorBoundary: entry.errorBoundary,
444
- notFoundBoundary: entry.notFoundBoundary,
445
- loader: entry.loader,
446
- layout: capturedLayouts, // Capture layout() calls
447
- when: entry.when, // Capture when() conditions
448
- // Use getter/setter to capture loading on the entry
449
- get loading() {
450
- return entry.loading;
451
- },
452
- set loading(value) {
453
- entry.loading = value;
454
- },
455
- };
456
- ctx.parent = tempParent;
457
- const result = use();
458
- // Restore original parent
459
- ctx.parent = originalParent;
460
- // Extract layout from captured layouts (use first one if multiple)
461
- // Layout inside intercept should always be ReactNode or Handler, not Record slots
462
- if (capturedLayouts.length > 0 && capturedLayouts[0].type === "layout") {
463
- entry.layout = capturedLayouts[0].handler;
464
- }
465
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `intercept() use() callback must return an array of use items [${namespace}]`);
466
- }
467
- ctx.parent.intercept.push(entry);
468
- return { name: namespace, type: "intercept" };
469
- };
470
- /**
471
- * Loader helper - attaches a loader to the current entry
472
- */
473
- const loaderFn = (loaderDef, use) => {
474
- const store = getContext();
475
- const ctx = store.getStore();
476
- if (!ctx)
477
- throw new Error("loader() must be called inside map()");
478
- // Attach to last entry in stack
479
- if (!ctx.parent || !ctx.parent?.loader) {
480
- invariant(false, "No parent entry available for loader()");
481
- }
482
- const name = `${ctx.namespace}.$${store.getNextIndex("loader")}`;
483
- // Create loader entry with empty revalidate array
484
- const loaderEntry = {
485
- loader: loaderDef,
486
- revalidate: [],
487
- };
488
- // If use() callback provided, run it to collect revalidation rules
489
- if (use && typeof use === "function") {
490
- // Temporarily set context for revalidate() calls to target this loader
491
- const originalParent = ctx.parent;
492
- // Create a temporary "parent" that has the revalidate array we want to populate
493
- const tempParent = {
494
- ...originalParent,
495
- revalidate: loaderEntry.revalidate,
496
- };
497
- ctx.parent = tempParent;
498
- const result = use();
499
- // Restore original parent
500
- ctx.parent = originalParent;
501
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `loader() use() callback must return an array of use items [${name}]`);
502
- }
503
- ctx.parent.loader.push(loaderEntry);
504
- return { name, type: "loader" };
505
- };
506
- /**
507
- * Loading helper - attaches a loading component to the current entry
508
- * Loading components are static (no context) and shown during navigation
509
- */
510
- const loadingFn = (component, options) => {
511
- const store = getContext();
512
- const ctx = store.getStore();
513
- if (!ctx)
514
- throw new Error("loading() must be called inside map()");
515
- const parent = ctx.parent;
516
- if (!parent || !("loading" in parent)) {
517
- invariant(false, "No parent entry available for loading()");
518
- }
519
- // If ssr: false and we're in SSR, set loading to false
520
- if (options?.ssr === false && ctx.isSSR) {
521
- parent.loading = false;
522
- }
523
- else {
524
- parent.loading = component;
525
- }
526
- const name = `$${store.getNextIndex("loading")}`;
527
- return { name, type: "loading" };
528
- };
529
- const routeFn = (name, handler, use) => {
530
- const store = getContext();
531
- const ctx = store.getStore();
532
- if (!ctx)
533
- throw new Error("route() must be called inside map()");
534
- const namespace = `${ctx.namespace}.${store.getNextIndex("route")}.${name}`;
535
- const entry = {
536
- id: namespace,
537
- shortCode: store.getShortCode("route"),
538
- type: "route",
539
- parent: ctx.parent,
540
- handler,
541
- loading: undefined, // Allow loading() to attach loading state
542
- middleware: [],
543
- revalidate: [],
544
- errorBoundary: [],
545
- notFoundBoundary: [],
546
- layout: [],
547
- parallel: [],
548
- intercept: [],
549
- loader: [],
550
- };
551
- /* We will throw if user is registring same route name twice */
552
- invariant(ctx.manifest.get(name) === undefined, `Duplicate route name: ${name} at ${namespace}`);
553
- /* Register route entry */
554
- ctx.manifest.set(name, entry);
555
- /* Run use and attach handlers */
556
- if (use && typeof use === "function") {
557
- const result = store.run(namespace, entry, use);
558
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `route() use() callback must return an array of use items [${namespace}]`);
559
- return { name: namespace, type: "route", uses: result };
560
- }
561
- /* typesafe item */
562
- return { name: namespace, type: "route" };
563
- };
564
- const layout = (handler, use) => {
565
- const store = getContext();
566
- const ctx = store.getStore();
567
- if (!ctx)
568
- throw new Error("layout() must be called inside map()");
569
- invariant(!ctx.parent || ctx.parent.type !== "parallel", "layout() cannot be used inside parallel()");
570
- const isRoot = !ctx.parent || ctx.parent === null;
571
- const nextIndex = isRoot ? "$root" : store.getNextIndex("layout");
572
- const namespace = `${ctx.namespace}.${nextIndex}`;
573
- const shortCode = store.getShortCode("layout");
574
- // Unwrap static handler definition, extract the actual handler function
575
- const isStatic = isStaticHandler(handler);
576
- const unwrappedHandler = isStatic ? handler.handler : handler;
577
- const urlPrefix = getUrlPrefix();
578
- const entry = {
579
- id: namespace,
580
- shortCode,
581
- type: "layout",
582
- parent: ctx.parent,
583
- handler: unwrappedHandler,
584
- loading: undefined, // Allow loading() to attach loading state
585
- middleware: [],
586
- revalidate: [],
587
- errorBoundary: [],
588
- notFoundBoundary: [],
589
- parallel: [],
590
- intercept: [],
591
- layout: [],
592
- loader: [],
593
- ...(urlPrefix ? { mountPath: urlPrefix } : {}),
594
- ...(isStatic ? { isStaticPrerender: true } : {}),
595
- };
596
- // Run use callback if provided
597
- let result;
598
- if (use && typeof use === "function") {
599
- result = store.run(namespace, entry, use);
600
- invariant(Array.isArray(result) && result.every((item) => isValidUseItem(item)), `layout() use() callback must return an array of use items [${namespace}]`);
601
- }
602
- // Check if this is an orphan layout (no routes in children, including nested caches)
603
- const hasRoutes = result &&
604
- Array.isArray(result) &&
605
- result.some((item) => hasRoutesInItem(item));
606
- if (!hasRoutes) {
607
- // Orphan layouts must not contain other layouts as children.
608
- // If we're here, all child layouts are also orphan (if any had routes,
609
- // hasRoutesInItem would have returned true). Nested orphan chains are
610
- // confusing — use sibling orphan layouts instead.
611
- if (result) {
612
- invariant(!result.some((item) => item?.type === "layout"), `orphan layout cannot contain other layouts as children [${namespace}]`);
613
- }
614
- const parent = ctx.parent;
615
- // Allow orphan layouts at root level if they're part of map() builder result
616
- if (!parent || parent === null) {
617
- if (!isRoot) {
618
- invariant(false, `Orphan layout cannot be used at non-root level without parent [${namespace}]`);
619
- }
620
- // Root-level orphan is allowed (e.g., sibling layouts in map() builder)
621
- }
622
- else {
623
- // Has parent - register as orphan layout
624
- invariant(parent.type === "route" ||
625
- parent.type === "layout" ||
626
- parent.type === "cache", `Orphan layouts can only be defined inside route or layout > check [${namespace}]`);
627
- // Clear parent pointer for orphan layouts to prevent duplicate processing
628
- entry.parent = null;
629
- parent.layout.push(entry);
630
- }
631
- }
632
- if (result) {
633
- return { name: namespace, type: "layout", uses: result };
634
- }
635
- return {
636
- name: namespace,
637
- type: "layout",
638
- };
639
- };
640
- const isValidUseItem = (item) => {
641
- return (typeof item === "undefined" ||
642
- item === null ||
643
- (item &&
644
- typeof item === "object" &&
645
- "type" in item &&
646
- [
647
- "layout",
648
- "route",
649
- "middleware",
650
- "revalidate",
651
- "parallel",
652
- "intercept",
653
- "loader",
654
- "loading",
655
- "errorBoundary",
656
- "notFoundBoundary",
657
- "when",
658
- "cache",
659
- "include", // For urls() include() helper
660
- ].includes(item.type)));
661
- };
662
- const isOrphanLayout = (item) => {
663
- return (item.type === "layout" &&
664
- !item.uses?.some((child) => hasRoutesInItem(child)));
665
- };
666
- /*
667
- * Create revalidate helper
668
- */
669
- const createRevalidateHelper = () => {
670
- return revalidate;
671
- };
672
- /**
673
- * Create errorBoundary helper
674
- */
675
- const createErrorBoundaryHelper = () => {
676
- return errorBoundary;
677
- };
678
- /**
679
- * Create notFoundBoundary helper
680
- */
681
- const createNotFoundBoundaryHelper = () => {
682
- return notFoundBoundary;
683
- };
684
- /**
685
- * Create middleware helper
686
- */
687
- const createMiddlewareHelper = () => {
688
- return middleware;
689
- };
690
- /**
691
- * Create parallel helper
692
- */
693
- const createParallelHelper = () => {
694
- return parallel;
695
- };
696
- /**
697
- * Create intercept helper
698
- */
699
- const createInterceptHelper = () => {
700
- return intercept;
701
- };
702
- /**
703
- * Create loader helper
704
- */
705
- const createLoaderHelper = () => {
706
- return loaderFn;
707
- };
708
- /**
709
- * Create loading helper
710
- */
711
- const createLoadingHelper = () => {
712
- return loadingFn;
713
- };
714
- /**
715
- * Create route helper
716
- */
717
- const createRouteHelper = () => {
718
- return routeFn;
719
- };
720
- /**
721
- * Create layout helper
722
- */
723
- const createLayoutHelper = () => {
724
- return layout;
725
- };
726
- /**
727
- * Create when helper for intercept conditions
728
- */
729
- const createWhenHelper = () => {
730
- return when;
731
- };
732
- /**
733
- * Create cache helper for cache configuration
734
- */
735
- const createCacheHelper = () => {
736
- return cache;
737
- };
738
- /**
739
- * Type-safe handler definition helper
740
- *
741
- */
742
- export function map(builder) {
743
- const handler = () => {
744
- // Check if it's a builder function (array-based API)
745
- invariant(typeof builder === "function", "map() expects a builder function as its argument");
746
- // Create helpers
747
- const helpers = {
748
- route: createRouteHelper(),
749
- layout: createLayoutHelper(),
750
- parallel: createParallelHelper(),
751
- intercept: createInterceptHelper(),
752
- middleware: createMiddlewareHelper(),
753
- revalidate: createRevalidateHelper(),
754
- loader: createLoaderHelper(),
755
- loading: createLoadingHelper(),
756
- errorBoundary: createErrorBoundaryHelper(),
757
- notFoundBoundary: createNotFoundBoundaryHelper(),
758
- when: createWhenHelper(),
759
- cache: createCacheHelper(),
760
- };
761
- return [layout(RootLayout, () => builder(helpers))].flat(3);
762
- };
763
- // Cast to RouteHandlers to carry the route type brand
764
- return handler;
765
- }
766
- /**
767
- * Create RouteHelpers for inline route definitions
768
- * Used internally by router.map() for inline handler syntax
769
- */
770
- export function createRouteHelpers() {
771
- return {
772
- route: createRouteHelper(),
773
- layout: createLayoutHelper(),
774
- parallel: createParallelHelper(),
775
- intercept: createInterceptHelper(),
776
- middleware: createMiddlewareHelper(),
777
- revalidate: createRevalidateHelper(),
778
- loader: createLoaderHelper(),
779
- loading: createLoadingHelper(),
780
- errorBoundary: createErrorBoundaryHelper(),
781
- notFoundBoundary: createNotFoundBoundaryHelper(),
782
- when: createWhenHelper(),
783
- cache: createCacheHelper(),
784
- };
785
- }
786
- /**
787
- * Create a loader definition
788
- *
789
- * Loaders are RSC-compatible data fetchers that:
790
- * - Run after middleware, before handlers
791
- * - Are scoped to where attached (layout/route subtree)
792
- * - Revalidate independently from UI segments
793
- * - Are memoized per request (multiple ctx.use() calls return same value)
794
- *
795
- * Use the `"use server"` directive inside the loader function to ensure
796
- * the function is stripped from client bundles.
797
- *
798
- * Return type is automatically inferred from the callback.
799
- *
800
- * @param fn - Async function that fetches data (should contain "use server" directive)
801
- * @param fetchable - Optional flag to make the loader fetchable via useFetchLoader
802
- *
803
- * @example
804
- * ```typescript
805
- * // loaders/cart.ts - return type inferred from callback
806
- * export const CartLoader = createLoader(async (ctx) => {
807
- * "use server";
808
- * const user = ctx.get("user");
809
- * return await db.cart.get(user.id); // Return type inferred!
810
- * });
811
- *
812
- * // loaders/product.ts - return type inferred
813
- * export const ProductLoader = createLoader(async (ctx) => {
814
- * "use server";
815
- * const { slug } = ctx.params;
816
- * return await db.products.findBySlug(slug); // Return type inferred!
817
- * });
818
- *
819
- * // Usage in handlers
820
- * layout(<ShopLayout />, () => [
821
- * loader(CartLoader),
822
- * loader(CartLoader, () => [
823
- * revalidate(({ actionId }) => actionId?.includes("Cart") ?? false),
824
- * ]),
825
- * ])
826
- *
827
- * // Server-side access
828
- * route("cart", (ctx) => {
829
- * const cart = ctx.use(CartLoader);
830
- * return <CartPage cart={cart} />;
831
- * });
832
- *
833
- * // Client-side access
834
- * const cart = useLoader(CartLoader);
835
- * ```
836
- */
837
- // Re-export createLoader from loader.rsc.ts for RSC/server context
838
- export { createLoader } from "./loader.rsc.js";
839
- /**
840
- * Create a soft redirect Response for middleware short-circuit
841
- *
842
- * Returns a Response that signals a client-side navigation to the target URL.
843
- * Unlike Response.redirect() which causes a full page reload, this redirect
844
- * is handled by the router for SPA-style navigation.
845
- *
846
- * @param url - The URL to redirect to
847
- * @param status - HTTP status code (default: 302)
848
- *
849
- * @example
850
- * ```typescript
851
- * middleware((ctx, next) => {
852
- * if (!ctx.get('user')) {
853
- * return redirect('/login');
854
- * }
855
- * next();
856
- * })
857
- * ```
858
- */
859
- export function redirect(url, status = 302) {
860
- return new Response(null, {
861
- status,
862
- headers: {
863
- Location: url,
864
- "X-RSC-Redirect": "soft",
865
- },
866
- });
867
- }
868
- //# sourceMappingURL=route-definition.js.map