@rangojs/router 0.0.0-experimental.42 → 0.0.0-experimental.44

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 (835) hide show
  1. package/dist/bin/rango.js +8 -3
  2. package/dist/vite/index.js +136 -197
  3. package/package.json +1 -1
  4. package/skills/caching/SKILL.md +37 -4
  5. package/src/browser/event-controller.ts +5 -0
  6. package/src/browser/navigation-bridge.ts +1 -11
  7. package/src/browser/navigation-client.ts +70 -24
  8. package/src/browser/navigation-transaction.ts +11 -9
  9. package/src/browser/partial-update.ts +39 -9
  10. package/src/browser/prefetch/cache.ts +54 -2
  11. package/src/browser/prefetch/fetch.ts +22 -12
  12. package/src/browser/prefetch/queue.ts +53 -13
  13. package/src/browser/react/Link.tsx +9 -1
  14. package/src/browser/react/NavigationProvider.tsx +27 -0
  15. package/src/browser/rsc-router.tsx +109 -57
  16. package/src/browser/scroll-restoration.ts +20 -11
  17. package/src/browser/types.ts +9 -0
  18. package/src/build/route-types/router-processing.ts +12 -2
  19. package/src/cache/cache-scope.ts +2 -2
  20. package/src/cache/cf/cf-cache-store.ts +453 -11
  21. package/src/cache/cf/index.ts +5 -1
  22. package/src/cache/index.ts +1 -0
  23. package/src/route-definition/redirect.ts +2 -2
  24. package/src/router/middleware.ts +2 -1
  25. package/src/server/request-context.ts +10 -4
  26. package/src/ssr/index.tsx +1 -0
  27. package/src/vite/discovery/state.ts +0 -2
  28. package/src/vite/plugin-types.ts +0 -83
  29. package/src/vite/plugins/expose-action-id.ts +1 -3
  30. package/src/vite/plugins/version-plugin.ts +13 -1
  31. package/src/vite/rango.ts +144 -209
  32. package/src/vite/router-discovery.ts +0 -8
  33. package/dist/__internal.d.ts +0 -83
  34. package/dist/__internal.d.ts.map +0 -1
  35. package/dist/__internal.js +0 -19
  36. package/dist/__internal.js.map +0 -1
  37. package/dist/__mocks__/version.d.ts +0 -7
  38. package/dist/__mocks__/version.d.ts.map +0 -1
  39. package/dist/__mocks__/version.js +0 -7
  40. package/dist/__mocks__/version.js.map +0 -1
  41. package/dist/__tests__/client-href.test.d.ts +0 -2
  42. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  43. package/dist/__tests__/client-href.test.js +0 -74
  44. package/dist/__tests__/client-href.test.js.map +0 -1
  45. package/dist/__tests__/component-utils.test.d.ts +0 -2
  46. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  47. package/dist/__tests__/component-utils.test.js +0 -51
  48. package/dist/__tests__/component-utils.test.js.map +0 -1
  49. package/dist/__tests__/event-controller.test.d.ts +0 -2
  50. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  51. package/dist/__tests__/event-controller.test.js +0 -538
  52. package/dist/__tests__/event-controller.test.js.map +0 -1
  53. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  54. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  55. package/dist/__tests__/helpers/route-tree.js +0 -374
  56. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  57. package/dist/__tests__/match-result.test.d.ts +0 -2
  58. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  59. package/dist/__tests__/match-result.test.js +0 -154
  60. package/dist/__tests__/match-result.test.js.map +0 -1
  61. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  62. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  63. package/dist/__tests__/navigation-store.test.js +0 -440
  64. package/dist/__tests__/navigation-store.test.js.map +0 -1
  65. package/dist/__tests__/partial-update.test.d.ts +0 -2
  66. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  67. package/dist/__tests__/partial-update.test.js +0 -1009
  68. package/dist/__tests__/partial-update.test.js.map +0 -1
  69. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  70. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  71. package/dist/__tests__/reverse-types.test.js +0 -656
  72. package/dist/__tests__/reverse-types.test.js.map +0 -1
  73. package/dist/__tests__/route-definition.test.d.ts +0 -2
  74. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  75. package/dist/__tests__/route-definition.test.js +0 -55
  76. package/dist/__tests__/route-definition.test.js.map +0 -1
  77. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  78. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  79. package/dist/__tests__/router-helpers.test.js +0 -377
  80. package/dist/__tests__/router-helpers.test.js.map +0 -1
  81. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  82. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  83. package/dist/__tests__/router-integration-2.test.js +0 -426
  84. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  85. package/dist/__tests__/router-integration.test.d.ts +0 -2
  86. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  87. package/dist/__tests__/router-integration.test.js +0 -1051
  88. package/dist/__tests__/router-integration.test.js.map +0 -1
  89. package/dist/__tests__/search-params.test.d.ts +0 -5
  90. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  91. package/dist/__tests__/search-params.test.js +0 -306
  92. package/dist/__tests__/search-params.test.js.map +0 -1
  93. package/dist/__tests__/segment-system.test.d.ts +0 -2
  94. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  95. package/dist/__tests__/segment-system.test.js +0 -627
  96. package/dist/__tests__/segment-system.test.js.map +0 -1
  97. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  98. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  99. package/dist/__tests__/static-handler-types.test.js +0 -63
  100. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  101. package/dist/__tests__/urls.test.d.ts +0 -2
  102. package/dist/__tests__/urls.test.d.ts.map +0 -1
  103. package/dist/__tests__/urls.test.js +0 -421
  104. package/dist/__tests__/urls.test.js.map +0 -1
  105. package/dist/__tests__/use-mount.test.d.ts +0 -2
  106. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  107. package/dist/__tests__/use-mount.test.js +0 -35
  108. package/dist/__tests__/use-mount.test.js.map +0 -1
  109. package/dist/bin/rango.d.ts +0 -2
  110. package/dist/bin/rango.d.ts.map +0 -1
  111. package/dist/bin/rango.js.map +0 -1
  112. package/dist/browser/event-controller.d.ts +0 -191
  113. package/dist/browser/event-controller.d.ts.map +0 -1
  114. package/dist/browser/event-controller.js +0 -559
  115. package/dist/browser/event-controller.js.map +0 -1
  116. package/dist/browser/index.d.ts +0 -2
  117. package/dist/browser/index.d.ts.map +0 -1
  118. package/dist/browser/index.js +0 -14
  119. package/dist/browser/index.js.map +0 -1
  120. package/dist/browser/link-interceptor.d.ts +0 -38
  121. package/dist/browser/link-interceptor.d.ts.map +0 -1
  122. package/dist/browser/link-interceptor.js +0 -99
  123. package/dist/browser/link-interceptor.js.map +0 -1
  124. package/dist/browser/logging.d.ts +0 -10
  125. package/dist/browser/logging.d.ts.map +0 -1
  126. package/dist/browser/logging.js +0 -29
  127. package/dist/browser/logging.js.map +0 -1
  128. package/dist/browser/lru-cache.d.ts +0 -17
  129. package/dist/browser/lru-cache.d.ts.map +0 -1
  130. package/dist/browser/lru-cache.js +0 -50
  131. package/dist/browser/lru-cache.js.map +0 -1
  132. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  133. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  134. package/dist/browser/merge-segment-loaders.js +0 -102
  135. package/dist/browser/merge-segment-loaders.js.map +0 -1
  136. package/dist/browser/navigation-bridge.d.ts +0 -102
  137. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  138. package/dist/browser/navigation-bridge.js +0 -708
  139. package/dist/browser/navigation-bridge.js.map +0 -1
  140. package/dist/browser/navigation-client.d.ts +0 -25
  141. package/dist/browser/navigation-client.d.ts.map +0 -1
  142. package/dist/browser/navigation-client.js +0 -157
  143. package/dist/browser/navigation-client.js.map +0 -1
  144. package/dist/browser/navigation-store.d.ts +0 -101
  145. package/dist/browser/navigation-store.d.ts.map +0 -1
  146. package/dist/browser/navigation-store.js +0 -625
  147. package/dist/browser/navigation-store.js.map +0 -1
  148. package/dist/browser/partial-update.d.ts +0 -75
  149. package/dist/browser/partial-update.d.ts.map +0 -1
  150. package/dist/browser/partial-update.js +0 -426
  151. package/dist/browser/partial-update.js.map +0 -1
  152. package/dist/browser/react/Link.d.ts +0 -86
  153. package/dist/browser/react/Link.d.ts.map +0 -1
  154. package/dist/browser/react/Link.js +0 -128
  155. package/dist/browser/react/Link.js.map +0 -1
  156. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  157. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  158. package/dist/browser/react/NavigationProvider.js +0 -216
  159. package/dist/browser/react/NavigationProvider.js.map +0 -1
  160. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  161. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  162. package/dist/browser/react/ScrollRestoration.js +0 -57
  163. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  164. package/dist/browser/react/context.d.ts +0 -46
  165. package/dist/browser/react/context.d.ts.map +0 -1
  166. package/dist/browser/react/context.js +0 -10
  167. package/dist/browser/react/context.js.map +0 -1
  168. package/dist/browser/react/index.d.ts +0 -11
  169. package/dist/browser/react/index.d.ts.map +0 -1
  170. package/dist/browser/react/index.js +0 -22
  171. package/dist/browser/react/index.js.map +0 -1
  172. package/dist/browser/react/location-state-shared.d.ts +0 -63
  173. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  174. package/dist/browser/react/location-state-shared.js +0 -81
  175. package/dist/browser/react/location-state-shared.js.map +0 -1
  176. package/dist/browser/react/location-state.d.ts +0 -23
  177. package/dist/browser/react/location-state.d.ts.map +0 -1
  178. package/dist/browser/react/location-state.js +0 -29
  179. package/dist/browser/react/location-state.js.map +0 -1
  180. package/dist/browser/react/mount-context.d.ts +0 -24
  181. package/dist/browser/react/mount-context.d.ts.map +0 -1
  182. package/dist/browser/react/mount-context.js +0 -24
  183. package/dist/browser/react/mount-context.js.map +0 -1
  184. package/dist/browser/react/use-action.d.ts +0 -64
  185. package/dist/browser/react/use-action.d.ts.map +0 -1
  186. package/dist/browser/react/use-action.js +0 -134
  187. package/dist/browser/react/use-action.js.map +0 -1
  188. package/dist/browser/react/use-client-cache.d.ts +0 -41
  189. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  190. package/dist/browser/react/use-client-cache.js +0 -39
  191. package/dist/browser/react/use-client-cache.js.map +0 -1
  192. package/dist/browser/react/use-handle.d.ts +0 -31
  193. package/dist/browser/react/use-handle.d.ts.map +0 -1
  194. package/dist/browser/react/use-handle.js +0 -144
  195. package/dist/browser/react/use-handle.js.map +0 -1
  196. package/dist/browser/react/use-href.d.ts +0 -33
  197. package/dist/browser/react/use-href.d.ts.map +0 -1
  198. package/dist/browser/react/use-href.js +0 -39
  199. package/dist/browser/react/use-href.js.map +0 -1
  200. package/dist/browser/react/use-link-status.d.ts +0 -37
  201. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  202. package/dist/browser/react/use-link-status.js +0 -99
  203. package/dist/browser/react/use-link-status.js.map +0 -1
  204. package/dist/browser/react/use-mount.d.ts +0 -25
  205. package/dist/browser/react/use-mount.d.ts.map +0 -1
  206. package/dist/browser/react/use-mount.js +0 -30
  207. package/dist/browser/react/use-mount.js.map +0 -1
  208. package/dist/browser/react/use-navigation.d.ts +0 -27
  209. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  210. package/dist/browser/react/use-navigation.js +0 -87
  211. package/dist/browser/react/use-navigation.js.map +0 -1
  212. package/dist/browser/react/use-segments.d.ts +0 -38
  213. package/dist/browser/react/use-segments.d.ts.map +0 -1
  214. package/dist/browser/react/use-segments.js +0 -130
  215. package/dist/browser/react/use-segments.js.map +0 -1
  216. package/dist/browser/request-controller.d.ts +0 -26
  217. package/dist/browser/request-controller.d.ts.map +0 -1
  218. package/dist/browser/request-controller.js +0 -147
  219. package/dist/browser/request-controller.js.map +0 -1
  220. package/dist/browser/rsc-router.d.ts +0 -129
  221. package/dist/browser/rsc-router.d.ts.map +0 -1
  222. package/dist/browser/rsc-router.js +0 -195
  223. package/dist/browser/rsc-router.js.map +0 -1
  224. package/dist/browser/scroll-restoration.d.ts +0 -93
  225. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  226. package/dist/browser/scroll-restoration.js +0 -321
  227. package/dist/browser/scroll-restoration.js.map +0 -1
  228. package/dist/browser/segment-structure-assert.d.ts +0 -17
  229. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  230. package/dist/browser/segment-structure-assert.js +0 -59
  231. package/dist/browser/segment-structure-assert.js.map +0 -1
  232. package/dist/browser/server-action-bridge.d.ts +0 -26
  233. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  234. package/dist/browser/server-action-bridge.js +0 -668
  235. package/dist/browser/server-action-bridge.js.map +0 -1
  236. package/dist/browser/shallow.d.ts +0 -12
  237. package/dist/browser/shallow.d.ts.map +0 -1
  238. package/dist/browser/shallow.js +0 -34
  239. package/dist/browser/shallow.js.map +0 -1
  240. package/dist/browser/types.d.ts +0 -369
  241. package/dist/browser/types.d.ts.map +0 -1
  242. package/dist/browser/types.js +0 -2
  243. package/dist/browser/types.js.map +0 -1
  244. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  245. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  246. package/dist/build/__tests__/generate-cli.test.js +0 -237
  247. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  248. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  249. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  250. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  251. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  252. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  253. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  254. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  255. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  256. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  257. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  258. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  259. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  260. package/dist/build/generate-manifest.d.ts +0 -81
  261. package/dist/build/generate-manifest.d.ts.map +0 -1
  262. package/dist/build/generate-manifest.js +0 -276
  263. package/dist/build/generate-manifest.js.map +0 -1
  264. package/dist/build/generate-route-types.d.ts +0 -115
  265. package/dist/build/generate-route-types.d.ts.map +0 -1
  266. package/dist/build/generate-route-types.js +0 -740
  267. package/dist/build/generate-route-types.js.map +0 -1
  268. package/dist/build/index.d.ts +0 -21
  269. package/dist/build/index.d.ts.map +0 -1
  270. package/dist/build/index.js +0 -21
  271. package/dist/build/index.js.map +0 -1
  272. package/dist/build/route-trie.d.ts +0 -71
  273. package/dist/build/route-trie.d.ts.map +0 -1
  274. package/dist/build/route-trie.js +0 -175
  275. package/dist/build/route-trie.js.map +0 -1
  276. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  277. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  278. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  279. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  280. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  281. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  282. package/dist/cache/__tests__/document-cache.test.js +0 -345
  283. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  284. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  285. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  286. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  287. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  288. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  289. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  290. package/dist/cache/__tests__/memory-store.test.js +0 -367
  291. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  292. package/dist/cache/cache-scope.d.ts +0 -102
  293. package/dist/cache/cache-scope.d.ts.map +0 -1
  294. package/dist/cache/cache-scope.js +0 -440
  295. package/dist/cache/cache-scope.js.map +0 -1
  296. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  297. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  298. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  299. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  300. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  301. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  302. package/dist/cache/cf/cf-cache-store.js +0 -242
  303. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  304. package/dist/cache/cf/index.d.ts +0 -14
  305. package/dist/cache/cf/index.d.ts.map +0 -1
  306. package/dist/cache/cf/index.js +0 -17
  307. package/dist/cache/cf/index.js.map +0 -1
  308. package/dist/cache/document-cache.d.ts +0 -64
  309. package/dist/cache/document-cache.d.ts.map +0 -1
  310. package/dist/cache/document-cache.js +0 -228
  311. package/dist/cache/document-cache.js.map +0 -1
  312. package/dist/cache/index.d.ts +0 -19
  313. package/dist/cache/index.d.ts.map +0 -1
  314. package/dist/cache/index.js +0 -21
  315. package/dist/cache/index.js.map +0 -1
  316. package/dist/cache/memory-segment-store.d.ts +0 -110
  317. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  318. package/dist/cache/memory-segment-store.js +0 -117
  319. package/dist/cache/memory-segment-store.js.map +0 -1
  320. package/dist/cache/memory-store.d.ts +0 -41
  321. package/dist/cache/memory-store.d.ts.map +0 -1
  322. package/dist/cache/memory-store.js +0 -191
  323. package/dist/cache/memory-store.js.map +0 -1
  324. package/dist/cache/types.d.ts +0 -317
  325. package/dist/cache/types.d.ts.map +0 -1
  326. package/dist/cache/types.js +0 -12
  327. package/dist/cache/types.js.map +0 -1
  328. package/dist/client.d.ts +0 -248
  329. package/dist/client.d.ts.map +0 -1
  330. package/dist/client.js +0 -367
  331. package/dist/client.js.map +0 -1
  332. package/dist/client.rsc.d.ts +0 -26
  333. package/dist/client.rsc.d.ts.map +0 -1
  334. package/dist/client.rsc.js +0 -46
  335. package/dist/client.rsc.js.map +0 -1
  336. package/dist/component-utils.d.ts +0 -36
  337. package/dist/component-utils.d.ts.map +0 -1
  338. package/dist/component-utils.js +0 -61
  339. package/dist/component-utils.js.map +0 -1
  340. package/dist/components/DefaultDocument.d.ts +0 -13
  341. package/dist/components/DefaultDocument.d.ts.map +0 -1
  342. package/dist/components/DefaultDocument.js +0 -15
  343. package/dist/components/DefaultDocument.js.map +0 -1
  344. package/dist/debug.d.ts +0 -58
  345. package/dist/debug.d.ts.map +0 -1
  346. package/dist/debug.js +0 -157
  347. package/dist/debug.js.map +0 -1
  348. package/dist/default-error-boundary.d.ts +0 -11
  349. package/dist/default-error-boundary.d.ts.map +0 -1
  350. package/dist/default-error-boundary.js +0 -45
  351. package/dist/default-error-boundary.js.map +0 -1
  352. package/dist/deps/browser.d.ts +0 -2
  353. package/dist/deps/browser.d.ts.map +0 -1
  354. package/dist/deps/browser.js +0 -3
  355. package/dist/deps/browser.js.map +0 -1
  356. package/dist/deps/html-stream-client.d.ts +0 -2
  357. package/dist/deps/html-stream-client.d.ts.map +0 -1
  358. package/dist/deps/html-stream-client.js +0 -3
  359. package/dist/deps/html-stream-client.js.map +0 -1
  360. package/dist/deps/html-stream-server.d.ts +0 -2
  361. package/dist/deps/html-stream-server.d.ts.map +0 -1
  362. package/dist/deps/html-stream-server.js +0 -3
  363. package/dist/deps/html-stream-server.js.map +0 -1
  364. package/dist/deps/rsc.d.ts +0 -2
  365. package/dist/deps/rsc.d.ts.map +0 -1
  366. package/dist/deps/rsc.js +0 -4
  367. package/dist/deps/rsc.js.map +0 -1
  368. package/dist/deps/ssr.d.ts +0 -2
  369. package/dist/deps/ssr.d.ts.map +0 -1
  370. package/dist/deps/ssr.js +0 -3
  371. package/dist/deps/ssr.js.map +0 -1
  372. package/dist/errors.d.ts +0 -174
  373. package/dist/errors.d.ts.map +0 -1
  374. package/dist/errors.js +0 -241
  375. package/dist/errors.js.map +0 -1
  376. package/dist/handle.d.ts +0 -78
  377. package/dist/handle.d.ts.map +0 -1
  378. package/dist/handle.js +0 -82
  379. package/dist/handle.js.map +0 -1
  380. package/dist/handles/MetaTags.d.ts +0 -14
  381. package/dist/handles/MetaTags.d.ts.map +0 -1
  382. package/dist/handles/MetaTags.js +0 -136
  383. package/dist/handles/MetaTags.js.map +0 -1
  384. package/dist/handles/index.d.ts +0 -6
  385. package/dist/handles/index.d.ts.map +0 -1
  386. package/dist/handles/index.js +0 -6
  387. package/dist/handles/index.js.map +0 -1
  388. package/dist/handles/meta.d.ts +0 -39
  389. package/dist/handles/meta.d.ts.map +0 -1
  390. package/dist/handles/meta.js +0 -202
  391. package/dist/handles/meta.js.map +0 -1
  392. package/dist/host/__tests__/errors.test.d.ts +0 -2
  393. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  394. package/dist/host/__tests__/errors.test.js +0 -76
  395. package/dist/host/__tests__/errors.test.js.map +0 -1
  396. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  397. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  398. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  399. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  400. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  401. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  402. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  403. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  404. package/dist/host/__tests__/router.test.d.ts +0 -2
  405. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  406. package/dist/host/__tests__/router.test.js +0 -241
  407. package/dist/host/__tests__/router.test.js.map +0 -1
  408. package/dist/host/__tests__/testing.test.d.ts +0 -2
  409. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  410. package/dist/host/__tests__/testing.test.js +0 -64
  411. package/dist/host/__tests__/testing.test.js.map +0 -1
  412. package/dist/host/__tests__/utils.test.d.ts +0 -2
  413. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  414. package/dist/host/__tests__/utils.test.js +0 -29
  415. package/dist/host/__tests__/utils.test.js.map +0 -1
  416. package/dist/host/cookie-handler.d.ts +0 -34
  417. package/dist/host/cookie-handler.d.ts.map +0 -1
  418. package/dist/host/cookie-handler.js +0 -124
  419. package/dist/host/cookie-handler.js.map +0 -1
  420. package/dist/host/errors.d.ts +0 -56
  421. package/dist/host/errors.d.ts.map +0 -1
  422. package/dist/host/errors.js +0 -79
  423. package/dist/host/errors.js.map +0 -1
  424. package/dist/host/index.d.ts +0 -29
  425. package/dist/host/index.d.ts.map +0 -1
  426. package/dist/host/index.js +0 -32
  427. package/dist/host/index.js.map +0 -1
  428. package/dist/host/pattern-matcher.d.ts +0 -36
  429. package/dist/host/pattern-matcher.d.ts.map +0 -1
  430. package/dist/host/pattern-matcher.js +0 -172
  431. package/dist/host/pattern-matcher.js.map +0 -1
  432. package/dist/host/router.d.ts +0 -26
  433. package/dist/host/router.d.ts.map +0 -1
  434. package/dist/host/router.js +0 -218
  435. package/dist/host/router.js.map +0 -1
  436. package/dist/host/testing.d.ts +0 -36
  437. package/dist/host/testing.d.ts.map +0 -1
  438. package/dist/host/testing.js +0 -55
  439. package/dist/host/testing.js.map +0 -1
  440. package/dist/host/types.d.ts +0 -115
  441. package/dist/host/types.d.ts.map +0 -1
  442. package/dist/host/types.js +0 -7
  443. package/dist/host/types.js.map +0 -1
  444. package/dist/host/utils.d.ts +0 -21
  445. package/dist/host/utils.d.ts.map +0 -1
  446. package/dist/host/utils.js +0 -23
  447. package/dist/host/utils.js.map +0 -1
  448. package/dist/href-client.d.ts +0 -131
  449. package/dist/href-client.d.ts.map +0 -1
  450. package/dist/href-client.js +0 -64
  451. package/dist/href-client.js.map +0 -1
  452. package/dist/href-context.d.ts +0 -29
  453. package/dist/href-context.d.ts.map +0 -1
  454. package/dist/href-context.js +0 -21
  455. package/dist/href-context.js.map +0 -1
  456. package/dist/index.d.ts +0 -73
  457. package/dist/index.d.ts.map +0 -1
  458. package/dist/index.js +0 -91
  459. package/dist/index.js.map +0 -1
  460. package/dist/index.rsc.d.ts +0 -32
  461. package/dist/index.rsc.d.ts.map +0 -1
  462. package/dist/index.rsc.js +0 -40
  463. package/dist/index.rsc.js.map +0 -1
  464. package/dist/internal-debug.d.ts +0 -2
  465. package/dist/internal-debug.d.ts.map +0 -1
  466. package/dist/internal-debug.js +0 -5
  467. package/dist/internal-debug.js.map +0 -1
  468. package/dist/loader.d.ts +0 -14
  469. package/dist/loader.d.ts.map +0 -1
  470. package/dist/loader.js +0 -20
  471. package/dist/loader.js.map +0 -1
  472. package/dist/loader.rsc.d.ts +0 -19
  473. package/dist/loader.rsc.d.ts.map +0 -1
  474. package/dist/loader.rsc.js +0 -99
  475. package/dist/loader.rsc.js.map +0 -1
  476. package/dist/network-error-thrower.d.ts +0 -17
  477. package/dist/network-error-thrower.d.ts.map +0 -1
  478. package/dist/network-error-thrower.js +0 -14
  479. package/dist/network-error-thrower.js.map +0 -1
  480. package/dist/outlet-context.d.ts +0 -13
  481. package/dist/outlet-context.d.ts.map +0 -1
  482. package/dist/outlet-context.js +0 -3
  483. package/dist/outlet-context.js.map +0 -1
  484. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  485. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  486. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  487. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  488. package/dist/prerender/param-hash.d.ts +0 -16
  489. package/dist/prerender/param-hash.d.ts.map +0 -1
  490. package/dist/prerender/param-hash.js +0 -36
  491. package/dist/prerender/param-hash.js.map +0 -1
  492. package/dist/prerender/store.d.ts +0 -38
  493. package/dist/prerender/store.d.ts.map +0 -1
  494. package/dist/prerender/store.js +0 -61
  495. package/dist/prerender/store.js.map +0 -1
  496. package/dist/prerender.d.ts +0 -66
  497. package/dist/prerender.d.ts.map +0 -1
  498. package/dist/prerender.js +0 -57
  499. package/dist/prerender.js.map +0 -1
  500. package/dist/reverse.d.ts +0 -196
  501. package/dist/reverse.d.ts.map +0 -1
  502. package/dist/reverse.js +0 -78
  503. package/dist/reverse.js.map +0 -1
  504. package/dist/root-error-boundary.d.ts +0 -33
  505. package/dist/root-error-boundary.d.ts.map +0 -1
  506. package/dist/root-error-boundary.js +0 -165
  507. package/dist/root-error-boundary.js.map +0 -1
  508. package/dist/route-content-wrapper.d.ts +0 -46
  509. package/dist/route-content-wrapper.d.ts.map +0 -1
  510. package/dist/route-content-wrapper.js +0 -77
  511. package/dist/route-content-wrapper.js.map +0 -1
  512. package/dist/route-definition.d.ts +0 -421
  513. package/dist/route-definition.d.ts.map +0 -1
  514. package/dist/route-definition.js +0 -868
  515. package/dist/route-definition.js.map +0 -1
  516. package/dist/route-map-builder.d.ts +0 -155
  517. package/dist/route-map-builder.d.ts.map +0 -1
  518. package/dist/route-map-builder.js +0 -237
  519. package/dist/route-map-builder.js.map +0 -1
  520. package/dist/route-types.d.ts +0 -165
  521. package/dist/route-types.d.ts.map +0 -1
  522. package/dist/route-types.js +0 -7
  523. package/dist/route-types.js.map +0 -1
  524. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  525. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  526. package/dist/router/__tests__/handler-context.test.js +0 -65
  527. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  528. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  529. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  530. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  531. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  532. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  533. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  534. package/dist/router/__tests__/match-context.test.js +0 -92
  535. package/dist/router/__tests__/match-context.test.js.map +0 -1
  536. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  537. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  538. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  539. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  540. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  541. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  542. package/dist/router/__tests__/match-result.test.js +0 -457
  543. package/dist/router/__tests__/match-result.test.js.map +0 -1
  544. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  545. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  546. package/dist/router/__tests__/on-error.test.js +0 -678
  547. package/dist/router/__tests__/on-error.test.js.map +0 -1
  548. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  549. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  550. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  551. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  552. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  553. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  554. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  555. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  556. package/dist/router/error-handling.d.ts +0 -77
  557. package/dist/router/error-handling.d.ts.map +0 -1
  558. package/dist/router/error-handling.js +0 -202
  559. package/dist/router/error-handling.js.map +0 -1
  560. package/dist/router/handler-context.d.ts +0 -20
  561. package/dist/router/handler-context.d.ts.map +0 -1
  562. package/dist/router/handler-context.js +0 -198
  563. package/dist/router/handler-context.js.map +0 -1
  564. package/dist/router/intercept-resolution.d.ts +0 -66
  565. package/dist/router/intercept-resolution.d.ts.map +0 -1
  566. package/dist/router/intercept-resolution.js +0 -246
  567. package/dist/router/intercept-resolution.js.map +0 -1
  568. package/dist/router/loader-resolution.d.ts +0 -64
  569. package/dist/router/loader-resolution.d.ts.map +0 -1
  570. package/dist/router/loader-resolution.js +0 -284
  571. package/dist/router/loader-resolution.js.map +0 -1
  572. package/dist/router/logging.d.ts +0 -15
  573. package/dist/router/logging.d.ts.map +0 -1
  574. package/dist/router/logging.js +0 -99
  575. package/dist/router/logging.js.map +0 -1
  576. package/dist/router/manifest.d.ts +0 -22
  577. package/dist/router/manifest.d.ts.map +0 -1
  578. package/dist/router/manifest.js +0 -181
  579. package/dist/router/manifest.js.map +0 -1
  580. package/dist/router/match-api.d.ts +0 -35
  581. package/dist/router/match-api.d.ts.map +0 -1
  582. package/dist/router/match-api.js +0 -406
  583. package/dist/router/match-api.js.map +0 -1
  584. package/dist/router/match-context.d.ts +0 -206
  585. package/dist/router/match-context.d.ts.map +0 -1
  586. package/dist/router/match-context.js +0 -17
  587. package/dist/router/match-context.js.map +0 -1
  588. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  589. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  590. package/dist/router/match-middleware/background-revalidation.js +0 -75
  591. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  592. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  593. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  594. package/dist/router/match-middleware/cache-lookup.js +0 -257
  595. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  596. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  597. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  598. package/dist/router/match-middleware/cache-store.js +0 -108
  599. package/dist/router/match-middleware/cache-store.js.map +0 -1
  600. package/dist/router/match-middleware/index.d.ts +0 -81
  601. package/dist/router/match-middleware/index.d.ts.map +0 -1
  602. package/dist/router/match-middleware/index.js +0 -80
  603. package/dist/router/match-middleware/index.js.map +0 -1
  604. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  605. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  606. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  607. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  608. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  609. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  610. package/dist/router/match-middleware/segment-resolution.js +0 -53
  611. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  612. package/dist/router/match-pipelines.d.ts +0 -147
  613. package/dist/router/match-pipelines.d.ts.map +0 -1
  614. package/dist/router/match-pipelines.js +0 -82
  615. package/dist/router/match-pipelines.js.map +0 -1
  616. package/dist/router/match-result.d.ts +0 -126
  617. package/dist/router/match-result.d.ts.map +0 -1
  618. package/dist/router/match-result.js +0 -93
  619. package/dist/router/match-result.js.map +0 -1
  620. package/dist/router/metrics.d.ts +0 -20
  621. package/dist/router/metrics.d.ts.map +0 -1
  622. package/dist/router/metrics.js +0 -47
  623. package/dist/router/metrics.js.map +0 -1
  624. package/dist/router/middleware.d.ts +0 -249
  625. package/dist/router/middleware.d.ts.map +0 -1
  626. package/dist/router/middleware.js +0 -434
  627. package/dist/router/middleware.js.map +0 -1
  628. package/dist/router/middleware.test.d.ts +0 -2
  629. package/dist/router/middleware.test.d.ts.map +0 -1
  630. package/dist/router/middleware.test.js +0 -816
  631. package/dist/router/middleware.test.js.map +0 -1
  632. package/dist/router/pattern-matching.d.ts +0 -149
  633. package/dist/router/pattern-matching.d.ts.map +0 -1
  634. package/dist/router/pattern-matching.js +0 -349
  635. package/dist/router/pattern-matching.js.map +0 -1
  636. package/dist/router/revalidation.d.ts +0 -44
  637. package/dist/router/revalidation.d.ts.map +0 -1
  638. package/dist/router/revalidation.js +0 -147
  639. package/dist/router/revalidation.js.map +0 -1
  640. package/dist/router/router-context.d.ts +0 -135
  641. package/dist/router/router-context.d.ts.map +0 -1
  642. package/dist/router/router-context.js +0 -36
  643. package/dist/router/router-context.js.map +0 -1
  644. package/dist/router/segment-resolution.d.ts +0 -127
  645. package/dist/router/segment-resolution.d.ts.map +0 -1
  646. package/dist/router/segment-resolution.js +0 -919
  647. package/dist/router/segment-resolution.js.map +0 -1
  648. package/dist/router/trie-matching.d.ts +0 -40
  649. package/dist/router/trie-matching.d.ts.map +0 -1
  650. package/dist/router/trie-matching.js +0 -127
  651. package/dist/router/trie-matching.js.map +0 -1
  652. package/dist/router/types.d.ts +0 -136
  653. package/dist/router/types.d.ts.map +0 -1
  654. package/dist/router/types.js +0 -7
  655. package/dist/router/types.js.map +0 -1
  656. package/dist/router.d.ts +0 -753
  657. package/dist/router.d.ts.map +0 -1
  658. package/dist/router.gen.d.ts +0 -6
  659. package/dist/router.gen.d.ts.map +0 -1
  660. package/dist/router.gen.js +0 -6
  661. package/dist/router.gen.js.map +0 -1
  662. package/dist/router.js +0 -1304
  663. package/dist/router.js.map +0 -1
  664. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  665. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  666. package/dist/rsc/__tests__/helpers.test.js +0 -140
  667. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  668. package/dist/rsc/handler.d.ts +0 -45
  669. package/dist/rsc/handler.d.ts.map +0 -1
  670. package/dist/rsc/handler.js +0 -1172
  671. package/dist/rsc/handler.js.map +0 -1
  672. package/dist/rsc/helpers.d.ts +0 -16
  673. package/dist/rsc/helpers.d.ts.map +0 -1
  674. package/dist/rsc/helpers.js +0 -55
  675. package/dist/rsc/helpers.js.map +0 -1
  676. package/dist/rsc/index.d.ts +0 -22
  677. package/dist/rsc/index.d.ts.map +0 -1
  678. package/dist/rsc/index.js +0 -23
  679. package/dist/rsc/index.js.map +0 -1
  680. package/dist/rsc/nonce.d.ts +0 -9
  681. package/dist/rsc/nonce.d.ts.map +0 -1
  682. package/dist/rsc/nonce.js +0 -18
  683. package/dist/rsc/nonce.js.map +0 -1
  684. package/dist/rsc/types.d.ts +0 -206
  685. package/dist/rsc/types.d.ts.map +0 -1
  686. package/dist/rsc/types.js +0 -8
  687. package/dist/rsc/types.js.map +0 -1
  688. package/dist/search-params.d.ts +0 -103
  689. package/dist/search-params.d.ts.map +0 -1
  690. package/dist/search-params.js +0 -74
  691. package/dist/search-params.js.map +0 -1
  692. package/dist/segment-system.d.ts +0 -75
  693. package/dist/segment-system.d.ts.map +0 -1
  694. package/dist/segment-system.js +0 -336
  695. package/dist/segment-system.js.map +0 -1
  696. package/dist/server/context.d.ts +0 -245
  697. package/dist/server/context.d.ts.map +0 -1
  698. package/dist/server/context.js +0 -197
  699. package/dist/server/context.js.map +0 -1
  700. package/dist/server/fetchable-loader-store.d.ts +0 -18
  701. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  702. package/dist/server/fetchable-loader-store.js +0 -18
  703. package/dist/server/fetchable-loader-store.js.map +0 -1
  704. package/dist/server/handle-store.d.ts +0 -85
  705. package/dist/server/handle-store.d.ts.map +0 -1
  706. package/dist/server/handle-store.js +0 -142
  707. package/dist/server/handle-store.js.map +0 -1
  708. package/dist/server/loader-registry.d.ts +0 -55
  709. package/dist/server/loader-registry.d.ts.map +0 -1
  710. package/dist/server/loader-registry.js +0 -132
  711. package/dist/server/loader-registry.js.map +0 -1
  712. package/dist/server/request-context.d.ts +0 -226
  713. package/dist/server/request-context.d.ts.map +0 -1
  714. package/dist/server/request-context.js +0 -290
  715. package/dist/server/request-context.js.map +0 -1
  716. package/dist/server/root-layout.d.ts +0 -4
  717. package/dist/server/root-layout.d.ts.map +0 -1
  718. package/dist/server/root-layout.js +0 -5
  719. package/dist/server/root-layout.js.map +0 -1
  720. package/dist/server.d.ts +0 -15
  721. package/dist/server.d.ts.map +0 -1
  722. package/dist/server.js +0 -20
  723. package/dist/server.js.map +0 -1
  724. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  725. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  726. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  727. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  728. package/dist/ssr/index.d.ts +0 -98
  729. package/dist/ssr/index.d.ts.map +0 -1
  730. package/dist/ssr/index.js +0 -158
  731. package/dist/ssr/index.js.map +0 -1
  732. package/dist/static-handler.d.ts +0 -50
  733. package/dist/static-handler.d.ts.map +0 -1
  734. package/dist/static-handler.gen.d.ts +0 -5
  735. package/dist/static-handler.gen.d.ts.map +0 -1
  736. package/dist/static-handler.gen.js +0 -5
  737. package/dist/static-handler.gen.js.map +0 -1
  738. package/dist/static-handler.js +0 -29
  739. package/dist/static-handler.js.map +0 -1
  740. package/dist/theme/ThemeProvider.d.ts +0 -20
  741. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  742. package/dist/theme/ThemeProvider.js +0 -240
  743. package/dist/theme/ThemeProvider.js.map +0 -1
  744. package/dist/theme/ThemeScript.d.ts +0 -48
  745. package/dist/theme/ThemeScript.d.ts.map +0 -1
  746. package/dist/theme/ThemeScript.js +0 -13
  747. package/dist/theme/ThemeScript.js.map +0 -1
  748. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  749. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  750. package/dist/theme/__tests__/theme.test.js +0 -103
  751. package/dist/theme/__tests__/theme.test.js.map +0 -1
  752. package/dist/theme/constants.d.ts +0 -29
  753. package/dist/theme/constants.d.ts.map +0 -1
  754. package/dist/theme/constants.js +0 -48
  755. package/dist/theme/constants.js.map +0 -1
  756. package/dist/theme/index.d.ts +0 -31
  757. package/dist/theme/index.d.ts.map +0 -1
  758. package/dist/theme/index.js +0 -36
  759. package/dist/theme/index.js.map +0 -1
  760. package/dist/theme/theme-context.d.ts +0 -40
  761. package/dist/theme/theme-context.d.ts.map +0 -1
  762. package/dist/theme/theme-context.js +0 -60
  763. package/dist/theme/theme-context.js.map +0 -1
  764. package/dist/theme/theme-script.d.ts +0 -27
  765. package/dist/theme/theme-script.d.ts.map +0 -1
  766. package/dist/theme/theme-script.js +0 -147
  767. package/dist/theme/theme-script.js.map +0 -1
  768. package/dist/theme/types.d.ts +0 -163
  769. package/dist/theme/types.d.ts.map +0 -1
  770. package/dist/theme/types.js +0 -11
  771. package/dist/theme/types.js.map +0 -1
  772. package/dist/theme/use-theme.d.ts +0 -12
  773. package/dist/theme/use-theme.d.ts.map +0 -1
  774. package/dist/theme/use-theme.js +0 -40
  775. package/dist/theme/use-theme.js.map +0 -1
  776. package/dist/types.d.ts +0 -1479
  777. package/dist/types.d.ts.map +0 -1
  778. package/dist/types.js +0 -10
  779. package/dist/types.js.map +0 -1
  780. package/dist/urls.d.ts +0 -441
  781. package/dist/urls.d.ts.map +0 -1
  782. package/dist/urls.gen.d.ts +0 -8
  783. package/dist/urls.gen.d.ts.map +0 -1
  784. package/dist/urls.gen.js +0 -8
  785. package/dist/urls.gen.js.map +0 -1
  786. package/dist/urls.js +0 -443
  787. package/dist/urls.js.map +0 -1
  788. package/dist/use-loader.d.ts +0 -127
  789. package/dist/use-loader.d.ts.map +0 -1
  790. package/dist/use-loader.js +0 -237
  791. package/dist/use-loader.js.map +0 -1
  792. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  793. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  794. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  795. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  796. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  797. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  798. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  799. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  800. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  801. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  802. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  803. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  804. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  805. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  806. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  807. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  808. package/dist/vite/ast-handler-extract.d.ts +0 -49
  809. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  810. package/dist/vite/ast-handler-extract.js +0 -249
  811. package/dist/vite/ast-handler-extract.js.map +0 -1
  812. package/dist/vite/expose-action-id.d.ts +0 -19
  813. package/dist/vite/expose-action-id.d.ts.map +0 -1
  814. package/dist/vite/expose-action-id.js +0 -250
  815. package/dist/vite/expose-action-id.js.map +0 -1
  816. package/dist/vite/expose-id-utils.d.ts +0 -69
  817. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  818. package/dist/vite/expose-id-utils.js +0 -289
  819. package/dist/vite/expose-id-utils.js.map +0 -1
  820. package/dist/vite/expose-internal-ids.d.ts +0 -22
  821. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  822. package/dist/vite/expose-internal-ids.js +0 -886
  823. package/dist/vite/expose-internal-ids.js.map +0 -1
  824. package/dist/vite/index.d.ts +0 -149
  825. package/dist/vite/index.d.ts.map +0 -1
  826. package/dist/vite/index.js.map +0 -1
  827. package/dist/vite/index.named-routes.gen.ts +0 -103
  828. package/dist/vite/package-resolution.d.ts +0 -43
  829. package/dist/vite/package-resolution.d.ts.map +0 -1
  830. package/dist/vite/package-resolution.js +0 -112
  831. package/dist/vite/package-resolution.js.map +0 -1
  832. package/dist/vite/virtual-entries.d.ts +0 -25
  833. package/dist/vite/virtual-entries.d.ts.map +0 -1
  834. package/dist/vite/virtual-entries.js +0 -110
  835. 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