@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,1051 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { describe, it, expect } from "vitest";
3
- import { urls } from "../urls.js";
4
- import { createLoader } from "../loader.js";
5
- import { buildRouteTree } from "./helpers/route-tree.js";
6
- // Dummy components
7
- const RootLayout = (_jsx("div", { children: "root" }));
8
- const AuthLayout = (_jsx("div", { children: "auth" }));
9
- const BlogLayout = (_jsx("div", { children: "blog-layout" }));
10
- const ShopLayout = (_jsx("div", { children: "shop-layout" }));
11
- const HomePage = (_jsx("div", { children: "home" }));
12
- const AboutPage = (_jsx("div", { children: "about" }));
13
- const BlogIndex = (_jsx("div", { children: "blog-index" }));
14
- const BlogPost = (_jsx("div", { children: "blog-post" }));
15
- const UserProfile = (_jsx("div", { children: "user-profile" }));
16
- const Dashboard = (_jsx("div", { children: "dashboard" }));
17
- const ProductList = (_jsx("div", { children: "product-list" }));
18
- const ProductDetail = (_jsx("div", { children: "product-detail" }));
19
- const ProductModal = (_jsx("div", { children: "product-modal" }));
20
- const Sidebar = (_jsx("div", { children: "sidebar" }));
21
- const MainContent = (_jsx("div", { children: "main" }));
22
- const LoadingSpinner = (_jsx("div", { children: "loading..." }));
23
- const ErrorFallback = (_jsx("div", { children: "error" }));
24
- const NotFoundFallback = (_jsx("div", { children: "not found" }));
25
- // Dummy middleware
26
- const authMiddleware = async (_ctx, next) => next();
27
- const logMiddleware = async (_ctx, next) => next();
28
- const rateLimitMiddleware = async (_ctx, next) => next();
29
- // Dummy loaders
30
- const PostLoader = createLoader(async () => ({ title: "Post" }));
31
- const UserLoader = createLoader(async () => ({ name: "User" }));
32
- describe("route tree inspection", () => {
33
- // -------------------------------------------------------------------------
34
- // Pattern extraction & matching
35
- // -------------------------------------------------------------------------
36
- it("extracts route patterns", () => {
37
- const tree = buildRouteTree(urls(({ path }) => [
38
- path("/", HomePage, { name: "home" }),
39
- path("/about", AboutPage, { name: "about" }),
40
- ]));
41
- expect(tree.routes()).toEqual({
42
- home: "/",
43
- about: "/about",
44
- });
45
- });
46
- it("matches URLs and extracts params", () => {
47
- const tree = buildRouteTree(urls(({ path, layout }) => [
48
- path("/", HomePage, { name: "home" }),
49
- layout(BlogLayout, () => [
50
- path("/blog", BlogIndex, { name: "blog.index" }),
51
- path("/blog/:slug", BlogPost, { name: "blog.post" }),
52
- ]),
53
- path("/users/:id", UserProfile, { name: "users.profile" }),
54
- ]));
55
- expect(tree.match("/").routeKey).toBe("home");
56
- expect(tree.match("/blog").routeKey).toBe("blog.index");
57
- expect(tree.match("/blog/hello").routeKey).toBe("blog.post");
58
- expect(tree.match("/blog/hello").params).toEqual({ slug: "hello" });
59
- expect(tree.match("/users/42").params).toEqual({ id: "42" });
60
- expect(tree.match("/nonexistent")).toBeNull();
61
- });
62
- it("handles optional and constrained params", () => {
63
- const tree = buildRouteTree(urls(({ path }) => [
64
- path("/:locale(en|fr)?/about", AboutPage, { name: "about" }),
65
- ]));
66
- expect(tree.match("/about").routeKey).toBe("about");
67
- expect(tree.match("/fr/about").params).toEqual({ locale: "fr" });
68
- expect(tree.match("/de/about")).toBeNull();
69
- });
70
- it("handles include() with prefix and name prefix", () => {
71
- const blogPatterns = urls(({ path }) => [
72
- path("/", BlogIndex, { name: "index" }),
73
- path("/:slug", BlogPost, { name: "post" }),
74
- ]);
75
- const tree = buildRouteTree(urls(({ path, include }) => [
76
- path("/", HomePage, { name: "home" }),
77
- include("/blog", blogPatterns, { name: "blog" }),
78
- ]));
79
- expect(tree.routes()).toEqual({
80
- home: "/",
81
- "blog.index": "/blog",
82
- "blog.post": "/blog/:slug",
83
- });
84
- expect(tree.match("/blog").routeKey).toBe("blog.index");
85
- expect(tree.match("/blog/my-article").params).toEqual({
86
- slug: "my-article",
87
- });
88
- });
89
- // -------------------------------------------------------------------------
90
- // Segment IDs
91
- // -------------------------------------------------------------------------
92
- it("assigns segment IDs to flat routes", () => {
93
- const tree = buildRouteTree(urls(({ path }) => [
94
- path("/", HomePage, { name: "home" }),
95
- path("/about", AboutPage, { name: "about" }),
96
- ]));
97
- expect(tree.segmentId("home")).toBe("M0L0R0");
98
- expect(tree.segmentId("about")).toBe("M0L0R1");
99
- });
100
- it("assigns segment IDs to layouts and nested routes", () => {
101
- const tree = buildRouteTree(urls(({ path, layout }) => [
102
- layout(BlogLayout, () => [
103
- path("/blog", BlogIndex, { name: "blog.index" }),
104
- path("/blog/:slug", BlogPost, { name: "blog.post" }),
105
- ]),
106
- ]));
107
- expect(tree.segmentId("blog.index")).toBe("M0L0L0R0");
108
- expect(tree.segmentId("blog.post")).toBe("M0L0L0R1");
109
- const entry = tree.entry("blog.index");
110
- expect(entry.parent.type).toBe("layout");
111
- expect(entry.parent.shortCode).toBe("M0L0L0");
112
- });
113
- it("traces full segment path", () => {
114
- const tree = buildRouteTree(urls(({ path, layout }) => [
115
- layout(RootLayout, () => [
116
- path("/", HomePage, { name: "home" }),
117
- layout(BlogLayout, () => [
118
- path("/blog", BlogIndex, { name: "blog.index" }),
119
- path("/blog/:slug", BlogPost, { name: "blog.post" }),
120
- ]),
121
- ]),
122
- ]));
123
- const segPath = tree.segmentPath("blog.post");
124
- expect(segPath.map((s) => s.id)).toEqual([
125
- "M0L0", // synthetic root
126
- "M0L0L0", // root layout
127
- "M0L0L0L0", // blog layout
128
- "M0L0L0L0R1", // blog post (R1 because blog.index is R0)
129
- ]);
130
- expect(segPath.map((s) => s.type)).toEqual([
131
- "layout", "layout", "layout", "route",
132
- ]);
133
- });
134
- it("lists all segment IDs", () => {
135
- const tree = buildRouteTree(urls(({ path, layout }) => [
136
- layout(RootLayout, () => [
137
- path("/", HomePage, { name: "home" }),
138
- path("/about", AboutPage, { name: "about" }),
139
- ]),
140
- ]));
141
- expect(tree.segmentIds()).toEqual({
142
- home: "M0L0L0R0",
143
- about: "M0L0L0R1",
144
- });
145
- });
146
- // -------------------------------------------------------------------------
147
- // Middleware
148
- // -------------------------------------------------------------------------
149
- it("detects middleware on a layout", () => {
150
- const tree = buildRouteTree(urls(({ path, layout, middleware }) => [
151
- layout(RootLayout, () => [
152
- middleware(authMiddleware),
153
- path("/", HomePage, { name: "home" }),
154
- ]),
155
- ]));
156
- // Middleware is attached to the layout entry, not the route
157
- const homeEntry = tree.entry("home");
158
- const layoutEntry = homeEntry.parent;
159
- expect(layoutEntry.middleware).toHaveLength(1);
160
- expect(layoutEntry.middleware[0]).toBe(authMiddleware);
161
- });
162
- it("builds middleware chain through nested layouts", () => {
163
- const tree = buildRouteTree(urls(({ path, layout, middleware }) => [
164
- layout(RootLayout, () => [
165
- middleware(logMiddleware),
166
- layout(AuthLayout, () => [
167
- middleware(authMiddleware),
168
- path("/dashboard", Dashboard, { name: "dashboard" }),
169
- ]),
170
- ]),
171
- ]));
172
- const chain = tree.middlewareChain("dashboard");
173
- expect(chain).toEqual([
174
- { segmentId: "M0L0L0", count: 1 },
175
- { segmentId: "M0L0L0L0", count: 1 },
176
- ]);
177
- });
178
- it("handles multiple middleware on same layout", () => {
179
- const tree = buildRouteTree(urls(({ path, layout, middleware }) => [
180
- layout(RootLayout, () => [
181
- middleware(logMiddleware, authMiddleware, rateLimitMiddleware),
182
- path("/", HomePage, { name: "home" }),
183
- ]),
184
- ]));
185
- const homeEntry = tree.entry("home");
186
- expect(homeEntry.parent.middleware).toHaveLength(3);
187
- const chain = tree.middlewareChain("home");
188
- expect(chain).toEqual([
189
- { segmentId: "M0L0L0", count: 3 },
190
- ]);
191
- });
192
- // -------------------------------------------------------------------------
193
- // Loaders
194
- // -------------------------------------------------------------------------
195
- it("detects loaders on a route", () => {
196
- const tree = buildRouteTree(urls(({ path, loader }) => [
197
- path("/blog/:slug", BlogPost, { name: "blog.post" }, () => [
198
- loader(PostLoader),
199
- ]),
200
- ]));
201
- expect(tree.hasLoaders("blog.post")).toBe(true);
202
- expect(tree.loaders("blog.post")).toHaveLength(1);
203
- expect(tree.loaders("blog.post")[0].loader).toBe(PostLoader);
204
- });
205
- it("detects multiple loaders", () => {
206
- const tree = buildRouteTree(urls(({ path, loader }) => [
207
- path("/users/:id", UserProfile, { name: "users.profile" }, () => [
208
- loader(UserLoader),
209
- loader(PostLoader),
210
- ]),
211
- ]));
212
- expect(tree.loaders("users.profile")).toHaveLength(2);
213
- });
214
- it("route without loaders returns empty", () => {
215
- const tree = buildRouteTree(urls(({ path }) => [
216
- path("/", HomePage, { name: "home" }),
217
- ]));
218
- expect(tree.hasLoaders("home")).toBe(false);
219
- expect(tree.loaders("home")).toHaveLength(0);
220
- });
221
- // -------------------------------------------------------------------------
222
- // Intercepts
223
- // -------------------------------------------------------------------------
224
- it("detects intercept on a layout", () => {
225
- const tree = buildRouteTree(urls(({ path, layout, intercept }) => [
226
- layout(ShopLayout, () => [
227
- path("/products", ProductList, { name: "products" }),
228
- path("/products/:id", ProductDetail, { name: "product.detail" }),
229
- intercept("@modal", "product.detail", ProductModal),
230
- ]),
231
- ]));
232
- // Intercepts are stored on the layout entry (parent of products)
233
- const productsEntry = tree.entry("products");
234
- const layoutEntry = productsEntry.parent;
235
- expect(layoutEntry.intercept).toHaveLength(1);
236
- expect(layoutEntry.intercept[0].slotName).toBe("@modal");
237
- expect(layoutEntry.intercept[0].routeName).toBe("product.detail");
238
- });
239
- it("detects intercept with when() condition", () => {
240
- const whenFn = (ctx) => ctx.from.pathname.startsWith("/products");
241
- const tree = buildRouteTree(urls(({ path, layout, intercept, when }) => [
242
- layout(ShopLayout, () => [
243
- path("/products", ProductList, { name: "products" }),
244
- path("/products/:id", ProductDetail, { name: "product.detail" }),
245
- intercept("@modal", "product.detail", ProductModal, () => [
246
- when(whenFn),
247
- ]),
248
- ]),
249
- ]));
250
- const productsEntry = tree.entry("products");
251
- const layoutEntry = productsEntry.parent;
252
- const interceptEntry = layoutEntry.intercept[0];
253
- expect(interceptEntry.when).toHaveLength(1);
254
- expect(interceptEntry.when[0]).toBe(whenFn);
255
- });
256
- it("intercepts() returns structured info", () => {
257
- const tree = buildRouteTree(urls(({ path, layout, intercept, when, loader }) => [
258
- layout(ShopLayout, () => [
259
- path("/products", ProductList, { name: "products" }),
260
- path("/products/:id", ProductDetail, { name: "product.detail" }),
261
- intercept("@modal", "product.detail", ProductModal, () => [
262
- when(() => true),
263
- loader(PostLoader),
264
- ]),
265
- ]),
266
- ]));
267
- const productsEntry = tree.entry("products");
268
- const layoutEntry = productsEntry.parent;
269
- // Intercepts live on the parent layout entry
270
- expect(layoutEntry.intercept).toHaveLength(1);
271
- expect(layoutEntry.intercept[0].slotName).toBe("@modal");
272
- expect(layoutEntry.intercept[0].when).toHaveLength(1);
273
- expect(layoutEntry.intercept[0].loader).toHaveLength(1);
274
- // Also test via helper methods using the layout's manifest key
275
- const intercepts = tree.intercepts("products");
276
- // intercepts() looks up the named route, not the layout
277
- // The layout holding intercepts is accessed via entry().parent
278
- const layoutIntercepts = layoutEntry.intercept.map((i) => ({
279
- slotName: i.slotName,
280
- routeName: i.routeName,
281
- hasWhen: i.when.length > 0,
282
- whenCount: i.when.length,
283
- hasLoader: i.loader.length > 0,
284
- hasMiddleware: i.middleware.length > 0,
285
- }));
286
- expect(layoutIntercepts).toHaveLength(1);
287
- expect(layoutIntercepts[0].slotName).toBe("@modal");
288
- expect(layoutIntercepts[0].hasWhen).toBe(true);
289
- expect(layoutIntercepts[0].hasLoader).toBe(true);
290
- });
291
- // -------------------------------------------------------------------------
292
- // Parallel slots
293
- // -------------------------------------------------------------------------
294
- it("detects parallel slots", () => {
295
- const tree = buildRouteTree(urls(({ path, layout, parallel }) => [
296
- layout(RootLayout, () => [
297
- path("/", HomePage, { name: "home" }),
298
- parallel({ "@sidebar": Sidebar, "@main": MainContent }),
299
- ]),
300
- ]));
301
- const homeEntry = tree.entry("home");
302
- const layoutEntry = homeEntry.parent;
303
- expect(layoutEntry.parallel).toHaveLength(1);
304
- expect(layoutEntry.parallel[0].type).toBe("parallel");
305
- // Parallel slot names are on the layout entry's parallel array
306
- const parallelHandler = layoutEntry.parallel[0].handler;
307
- const slotNames = Object.keys(parallelHandler);
308
- expect(slotNames).toContain("@sidebar");
309
- expect(slotNames).toContain("@main");
310
- });
311
- // -------------------------------------------------------------------------
312
- // Error & NotFound boundaries
313
- // -------------------------------------------------------------------------
314
- it("detects error boundary on a route", () => {
315
- const tree = buildRouteTree(urls(({ path, errorBoundary }) => [
316
- path("/", HomePage, { name: "home" }, () => [
317
- errorBoundary(ErrorFallback),
318
- ]),
319
- ]));
320
- expect(tree.hasErrorBoundary("home")).toBe(true);
321
- });
322
- it("detects not-found boundary on a layout", () => {
323
- const tree = buildRouteTree(urls(({ path, layout, notFoundBoundary }) => [
324
- layout(RootLayout, () => [
325
- notFoundBoundary(NotFoundFallback),
326
- path("/", HomePage, { name: "home" }),
327
- ]),
328
- ]));
329
- const homeEntry = tree.entry("home");
330
- const layoutEntry = homeEntry.parent;
331
- expect(layoutEntry.notFoundBoundary).toHaveLength(1);
332
- });
333
- // -------------------------------------------------------------------------
334
- // Loading
335
- // -------------------------------------------------------------------------
336
- it("detects loading component on a route", () => {
337
- const tree = buildRouteTree(urls(({ path, loading }) => [
338
- path("/", HomePage, { name: "home" }, () => [
339
- loading(LoadingSpinner),
340
- ]),
341
- ]));
342
- expect(tree.hasLoading("home")).toBe(true);
343
- });
344
- it("route without loading returns false", () => {
345
- const tree = buildRouteTree(urls(({ path }) => [
346
- path("/", HomePage, { name: "home" }),
347
- ]));
348
- expect(tree.hasLoading("home")).toBe(false);
349
- });
350
- // -------------------------------------------------------------------------
351
- // Deeply nested layouts — segment hierarchy
352
- // -------------------------------------------------------------------------
353
- it("deeply nested layouts produce correct segment hierarchy", () => {
354
- const NavLayout = (_jsx("div", { children: "nav" }));
355
- const ContentLayout = (_jsx("div", { children: "content" }));
356
- const SettingsLayout = (_jsx("div", { children: "settings" }));
357
- const SettingsGeneral = (_jsx("div", { children: "settings-general" }));
358
- const SettingsSecurity = (_jsx("div", { children: "settings-security" }));
359
- const tree = buildRouteTree(urls(({ path, layout, middleware }) => [
360
- layout(RootLayout, () => [
361
- middleware(logMiddleware),
362
- layout(NavLayout, () => [
363
- layout(ContentLayout, () => [
364
- path("/", HomePage, { name: "home" }),
365
- layout(SettingsLayout, () => [
366
- middleware(authMiddleware),
367
- path("/settings", SettingsGeneral, { name: "settings.general" }),
368
- path("/settings/security", SettingsSecurity, { name: "settings.security" }),
369
- ]),
370
- ]),
371
- ]),
372
- ]),
373
- ]));
374
- // 4 layouts deep: synthetic root > RootLayout > NavLayout > ContentLayout > SettingsLayout
375
- const segPath = tree.segmentPath("settings.general");
376
- expect(segPath.map((s) => s.type)).toEqual([
377
- "layout", "layout", "layout", "layout", "layout", "route",
378
- ]);
379
- expect(segPath.map((s) => s.id)).toEqual([
380
- "M0L0", // synthetic root
381
- "M0L0L0", // RootLayout
382
- "M0L0L0L0", // NavLayout
383
- "M0L0L0L0L0", // ContentLayout
384
- "M0L0L0L0L0L0", // SettingsLayout
385
- "M0L0L0L0L0L0R0", // settings.general
386
- ]);
387
- // Security is R1 under SettingsLayout
388
- expect(tree.segmentId("settings.security")).toBe("M0L0L0L0L0L0R1");
389
- // Home is under ContentLayout directly (not SettingsLayout)
390
- const homePath = tree.segmentPath("home");
391
- expect(homePath).toHaveLength(5); // synthetic + Root + Nav + Content + route
392
- expect(homePath[3].id).toBe("M0L0L0L0L0"); // ContentLayout
393
- expect(homePath[4].id).toBe("M0L0L0L0L0R0"); // home (R0 before SettingsLayout takes L0)
394
- // Middleware chain: settings gets both logMw (root) and authMw (settings layout)
395
- const settingsChain = tree.middlewareChain("settings.general");
396
- expect(settingsChain).toEqual([
397
- { segmentId: "M0L0L0", count: 1 }, // logMw on RootLayout
398
- { segmentId: "M0L0L0L0L0L0", count: 1 }, // authMw on SettingsLayout
399
- ]);
400
- // Home only gets logMw
401
- expect(tree.middlewareChain("home")).toEqual([
402
- { segmentId: "M0L0L0", count: 1 },
403
- ]);
404
- });
405
- // -------------------------------------------------------------------------
406
- // Cache segments
407
- // -------------------------------------------------------------------------
408
- it("cache() wrapping children creates a C segment in the hierarchy", () => {
409
- const CachedPage = (_jsx("div", { children: "cached" }));
410
- const UncachedPage = (_jsx("div", { children: "uncached" }));
411
- const tree = buildRouteTree(urls(({ path, layout, cache }) => [
412
- layout(RootLayout, () => [
413
- path("/uncached", UncachedPage, { name: "uncached" }),
414
- cache({ ttl: 60 }, () => [
415
- path("/cached", CachedPage, { name: "cached" }),
416
- ]),
417
- ]),
418
- ]));
419
- // Both routes exist
420
- expect(tree.routes()).toEqual({
421
- uncached: "/uncached",
422
- cached: "/cached",
423
- });
424
- // Uncached route sits directly under RootLayout
425
- const uncachedPath = tree.segmentPath("uncached");
426
- expect(uncachedPath.map((s) => s.type)).toEqual(["layout", "layout", "route"]);
427
- // Cached route goes through a cache segment
428
- const cachedEntry = tree.entry("cached");
429
- expect(cachedEntry.parent.type).toBe("cache");
430
- expect(cachedEntry.parent.cache).toBeDefined();
431
- expect(cachedEntry.parent.cache.options).toEqual({ ttl: 60 });
432
- const cachedPath = tree.segmentPath("cached");
433
- expect(cachedPath.map((s) => s.type)).toEqual([
434
- "layout", "layout", "cache", "route",
435
- ]);
436
- // C segment gets a C prefix in the shortCode
437
- expect(cachedEntry.parent.shortCode).toMatch(/^M0L0L0C/);
438
- });
439
- it("nested cache segments with different TTLs", () => {
440
- const ListPage = (_jsx("div", { children: "list" }));
441
- const DetailPage = (_jsx("div", { children: "detail" }));
442
- const AdminPage = (_jsx("div", { children: "admin" }));
443
- const tree = buildRouteTree(urls(({ path, layout, cache }) => [
444
- layout(RootLayout, () => [
445
- cache({ ttl: 60 }, () => [
446
- path("/products", ListPage, { name: "products" }),
447
- cache({ ttl: 3600 }, () => [
448
- path("/products/:id", DetailPage, { name: "product.detail" }),
449
- ]),
450
- ]),
451
- cache(false, () => [
452
- path("/admin", AdminPage, { name: "admin" }),
453
- ]),
454
- ]),
455
- ]));
456
- // Products has outer cache (ttl: 60)
457
- const productsEntry = tree.entry("products");
458
- expect(productsEntry.parent.type).toBe("cache");
459
- expect(productsEntry.parent.cache.options).toEqual({ ttl: 60 });
460
- // Product detail has inner cache (ttl: 3600), parent is the outer cache
461
- const detailEntry = tree.entry("product.detail");
462
- expect(detailEntry.parent.type).toBe("cache");
463
- expect(detailEntry.parent.cache.options).toEqual({ ttl: 3600 });
464
- expect(detailEntry.parent.parent.type).toBe("cache");
465
- expect(detailEntry.parent.parent.cache.options).toEqual({ ttl: 60 });
466
- // Segment path has two cache levels
467
- const detailPath = tree.segmentPath("product.detail");
468
- const types = detailPath.map((s) => s.type);
469
- expect(types).toEqual(["layout", "layout", "cache", "cache", "route"]);
470
- // Admin has cache disabled (false)
471
- const adminEntry = tree.entry("admin");
472
- expect(adminEntry.parent.type).toBe("cache");
473
- expect(adminEntry.parent.cache.options).toBe(false);
474
- });
475
- // -------------------------------------------------------------------------
476
- // Parallel slots with loaders and loading
477
- // -------------------------------------------------------------------------
478
- it("parallel slots with loaders and loading", () => {
479
- const FeedContent = (_jsx("div", { children: "feed" }));
480
- const TrendingSidebar = (_jsx("div", { children: "trending" }));
481
- const FeedLoader = createLoader(async () => ({ items: [] }));
482
- const tree = buildRouteTree(urls(({ path, layout, parallel, loader, loading }) => [
483
- layout(RootLayout, () => [
484
- path("/feed", HomePage, { name: "feed" }),
485
- parallel({ "@sidebar": TrendingSidebar, "@content": FeedContent }, () => [
486
- loader(FeedLoader),
487
- loading(LoadingSpinner),
488
- ]),
489
- ]),
490
- ]));
491
- const feedEntry = tree.entry("feed");
492
- const layoutEntry = feedEntry.parent;
493
- // Parallel slot is on the layout
494
- expect(layoutEntry.parallel).toHaveLength(1);
495
- const parallelEntry = layoutEntry.parallel[0];
496
- expect(parallelEntry.type).toBe("parallel");
497
- // Parallel has its own loader and loading
498
- expect(parallelEntry.loader).toHaveLength(1);
499
- expect(parallelEntry.loader[0].loader).toBe(FeedLoader);
500
- expect(parallelEntry.loading).toBe(LoadingSpinner);
501
- // Slot names
502
- const handler = parallelEntry.handler;
503
- expect(Object.keys(handler)).toEqual(expect.arrayContaining(["@sidebar", "@content"]));
504
- // Parallel gets a P prefix shortCode
505
- expect(parallelEntry.shortCode).toMatch(/^M0L0L0P/);
506
- });
507
- // -------------------------------------------------------------------------
508
- // Include inside layout — segments inherit correctly
509
- // -------------------------------------------------------------------------
510
- it("include() inside a layout inherits the layout parent", () => {
511
- const apiPatterns = urls(({ path, loader }) => [
512
- path("/", (_jsx("div", { children: "api-index" })), { name: "index" }),
513
- path("/:id", (_jsx("div", { children: "api-detail" })), { name: "detail" }, () => [
514
- loader(PostLoader),
515
- ]),
516
- ]);
517
- const tree = buildRouteTree(urls(({ path, layout, include, middleware }) => [
518
- layout(RootLayout, () => [
519
- middleware(authMiddleware),
520
- path("/", HomePage, { name: "home" }),
521
- layout(AuthLayout, () => [
522
- include("/api/v1", apiPatterns, { name: "api" }),
523
- ]),
524
- ]),
525
- ]));
526
- // Included routes get prefixed names and patterns
527
- expect(tree.routes()).toEqual({
528
- home: "/",
529
- "api.index": "/api/v1",
530
- "api.detail": "/api/v1/:id",
531
- });
532
- // Matching works with full prefixed paths
533
- expect(tree.match("/api/v1").routeKey).toBe("api.index");
534
- expect(tree.match("/api/v1/42").params).toEqual({ id: "42" });
535
- // Lazy includes capture the parent at include() call time (AuthLayout).
536
- // The segment path for included routes starts from that captured parent.
537
- const detailEntry = tree.entry("api.detail");
538
- expect(detailEntry.parent.type).toBe("layout"); // AuthLayout
539
- expect(detailEntry.parent.shortCode).toBe("M0L0L0L0");
540
- // API detail has a loader
541
- expect(tree.hasLoaders("api.detail")).toBe(true);
542
- expect(tree.hasLoaders("api.index")).toBe(false);
543
- // Middleware: authMw is on RootLayout (M0L0L0), which is an ancestor
544
- // of AuthLayout. Since lazy includes capture AuthLayout as parent,
545
- // the middleware chain traverses from AuthLayout upward.
546
- const chain = tree.middlewareChain("api.detail");
547
- // authMw on RootLayout must be reachable through the parent chain
548
- expect(chain).toEqual([
549
- { segmentId: "M0L0L0", count: 1 },
550
- ]);
551
- // AuthLayout's parent must NOT be null — it must point to RootLayout
552
- // so the middleware chain is intact
553
- const authLayout = detailEntry.parent;
554
- expect(authLayout.parent).not.toBeNull();
555
- expect(authLayout.parent.shortCode).toBe("M0L0L0");
556
- });
557
- it("layout with middleware and only include children preserves middleware chain", () => {
558
- const blogPatterns = urls(({ path }) => [
559
- path("/", BlogIndex, { name: "index" }),
560
- path("/:slug", BlogPost, { name: "post" }),
561
- ]);
562
- const tree = buildRouteTree(urls(({ path, layout, include, middleware }) => [
563
- layout(RootLayout, () => [
564
- middleware(logMiddleware),
565
- path("/", HomePage, { name: "home" }),
566
- layout(AuthLayout, () => [
567
- middleware(authMiddleware),
568
- include("/blog", blogPatterns, { name: "blog" }),
569
- ]),
570
- ]),
571
- ]));
572
- // Routes include both direct and included routes
573
- expect(tree.routeNames()).toEqual(expect.arrayContaining(["home", "blog.index", "blog.post"]));
574
- // AuthLayout must NOT be orphaned — it has include children with routes
575
- const postEntry = tree.entry("blog.post");
576
- expect(postEntry.parent.type).toBe("layout"); // AuthLayout
577
- expect(postEntry.parent.parent).not.toBeNull(); // parent chain intact
578
- expect(postEntry.parent.middleware).toHaveLength(1);
579
- expect(postEntry.parent.middleware[0]).toBe(authMiddleware);
580
- // Full middleware chain: logMw (RootLayout) + authMw (AuthLayout)
581
- const chain = tree.middlewareChain("blog.post");
582
- expect(chain).toEqual([
583
- { segmentId: "M0L0L0", count: 1 }, // logMw on RootLayout
584
- { segmentId: "M0L0L0L0", count: 1 }, // authMw on AuthLayout
585
- ]);
586
- // Home route only gets logMw (not under AuthLayout)
587
- const homeChain = tree.middlewareChain("home");
588
- expect(homeChain).toEqual([
589
- { segmentId: "M0L0L0", count: 1 },
590
- ]);
591
- });
592
- // -------------------------------------------------------------------------
593
- // Orphan layouts — layouts without routes that wrap siblings
594
- // -------------------------------------------------------------------------
595
- it("orphan layout attaches to parent's layout array", () => {
596
- const WrapperLayout = (_jsx("div", { children: "wrapper" }));
597
- const tree = buildRouteTree(urls(({ path, layout, middleware }) => [
598
- layout(RootLayout, () => [
599
- layout(WrapperLayout, () => [
600
- middleware(authMiddleware),
601
- ]),
602
- path("/", HomePage, { name: "home" }),
603
- path("/about", AboutPage, { name: "about" }),
604
- ]),
605
- ]));
606
- // Routes still register correctly
607
- expect(tree.routes()).toEqual({ home: "/", about: "/about" });
608
- // The orphan layout (WrapperLayout) is stored in RootLayout's layout array
609
- const homeEntry = tree.entry("home");
610
- const rootLayout = homeEntry.parent;
611
- expect(rootLayout.type).toBe("layout");
612
- expect(rootLayout.layout).toHaveLength(1);
613
- const orphan = rootLayout.layout[0];
614
- expect(orphan.type).toBe("layout");
615
- // Orphan layouts have their parent cleared to prevent duplicate processing
616
- expect(orphan.parent).toBeNull();
617
- // But they carry their middleware
618
- expect(orphan.middleware).toHaveLength(1);
619
- expect(orphan.middleware[0]).toBe(authMiddleware);
620
- });
621
- it("orphan layout with loading attaches loading to the layout entry", () => {
622
- const WrapperLayout = (_jsx("div", { children: "wrapper" }));
623
- const tree = buildRouteTree(urls(({ path, layout, loading }) => [
624
- layout(RootLayout, () => [
625
- layout(WrapperLayout, () => [
626
- loading(LoadingSpinner),
627
- ]),
628
- path("/", HomePage, { name: "home" }),
629
- ]),
630
- ]));
631
- const homeEntry = tree.entry("home");
632
- const rootLayout = homeEntry.parent;
633
- const orphan = rootLayout.layout[0];
634
- expect(orphan.loading).toBe(LoadingSpinner);
635
- });
636
- it("orphan layout containing another orphan layout throws", () => {
637
- const Wrapper1 = (_jsx("div", { children: "w1" }));
638
- const Wrapper2 = (_jsx("div", { children: "w2" }));
639
- expect(() => buildRouteTree(urls(({ path, layout, middleware, loading }) => [
640
- layout(RootLayout, () => [
641
- layout(Wrapper1, () => [
642
- middleware(logMiddleware),
643
- layout(Wrapper2, () => [
644
- middleware(authMiddleware),
645
- loading(LoadingSpinner),
646
- ]),
647
- ]),
648
- path("/", HomePage, { name: "home" }),
649
- ]),
650
- ]))).toThrow("orphan layout cannot contain other layouts as children");
651
- });
652
- it("sibling orphan layouts stack as composable wrappers", () => {
653
- const Wrapper1 = (_jsx("div", { children: "w1" }));
654
- const Wrapper2 = (_jsx("div", { children: "w2" }));
655
- const tree = buildRouteTree(urls(({ path, layout, middleware, loading }) => [
656
- layout(RootLayout, () => [
657
- layout(Wrapper1, () => [
658
- middleware(logMiddleware),
659
- ]),
660
- layout(Wrapper2, () => [
661
- middleware(authMiddleware),
662
- loading(LoadingSpinner),
663
- ]),
664
- path("/", HomePage, { name: "home" }),
665
- ]),
666
- ]));
667
- expect(tree.routes()).toEqual({ home: "/" });
668
- const homeEntry = tree.entry("home");
669
- const rootLayout = homeEntry.parent;
670
- // Both wrappers are sibling orphan layouts on RootLayout
671
- expect(rootLayout.layout).toHaveLength(2);
672
- const wrapper1 = rootLayout.layout[0];
673
- const wrapper2 = rootLayout.layout[1];
674
- expect(wrapper1.type).toBe("layout");
675
- expect(wrapper2.type).toBe("layout");
676
- expect(wrapper1.parent).toBeNull();
677
- expect(wrapper2.parent).toBeNull();
678
- expect(wrapper1.middleware).toHaveLength(1);
679
- expect(wrapper1.middleware[0]).toBe(logMiddleware);
680
- expect(wrapper1.shortCode).toBe("M0L0L0L0");
681
- expect(wrapper2.middleware).toHaveLength(1);
682
- expect(wrapper2.middleware[0]).toBe(authMiddleware);
683
- expect(wrapper2.loading).toBe(LoadingSpinner);
684
- expect(wrapper2.shortCode).toBe("M0L0L0L1");
685
- expect(homeEntry.shortCode).toBe("M0L0L0R0");
686
- });
687
- it("orphan cache attaches to parent and wraps subsequent siblings", () => {
688
- const tree = buildRouteTree(urls(({ path, layout, cache }) => [
689
- layout(RootLayout, () => [
690
- cache({ ttl: 300 }),
691
- path("/", HomePage, { name: "home" }),
692
- path("/about", AboutPage, { name: "about" }),
693
- ]),
694
- ]));
695
- // Routes register correctly
696
- expect(tree.routes()).toEqual({ home: "/", about: "/about" });
697
- // With orphan cache(), the cache becomes the new parent for siblings
698
- // so routes attach under the cache segment
699
- const homeEntry = tree.entry("home");
700
- expect(homeEntry.parent.type).toBe("cache");
701
- expect(homeEntry.parent.cache.options).toEqual({ ttl: 300 });
702
- // Cache is a child of RootLayout
703
- const cacheParent = homeEntry.parent.parent;
704
- // Orphan cache has parent cleared (like orphan layout)
705
- // but the segment path still shows the hierarchy
706
- const homePath = tree.segmentPath("home");
707
- expect(homePath.map((s) => s.type)).toContain("cache");
708
- });
709
- // -------------------------------------------------------------------------
710
- // Invalid configurations — must error at definition time
711
- // -------------------------------------------------------------------------
712
- it("layout inside parallel throws", () => {
713
- expect(() => {
714
- buildRouteTree(urls(({ path, layout, parallel }) => [
715
- layout(RootLayout, () => [
716
- path("/", HomePage, { name: "home" }),
717
- // @ts-expect-error layout is not a valid parallel use item
718
- parallel({ "@sidebar": Sidebar }, () => [
719
- layout(AuthLayout, () => [
720
- // layout inside parallel is not allowed
721
- ]),
722
- ]),
723
- ]),
724
- ]));
725
- }).toThrow(/layout\(\) cannot be used inside parallel/);
726
- });
727
- it("orphan layout inside parallel throws", () => {
728
- expect(() => {
729
- buildRouteTree(urls(({ path, layout, parallel }) => [
730
- layout(RootLayout, () => [
731
- path("/", HomePage, { name: "home" }),
732
- // @ts-expect-error layout is not a valid parallel use item
733
- parallel({ "@sidebar": Sidebar }, () => [
734
- layout(AuthLayout),
735
- ]),
736
- ]),
737
- ]));
738
- }).toThrow(/layout\(\) cannot be used inside parallel/);
739
- });
740
- it("when() outside intercept throws", () => {
741
- expect(() => {
742
- buildRouteTree(urls(({ path, layout, when }) => [
743
- layout(RootLayout, () => [
744
- path("/", HomePage, { name: "home" }),
745
- // @ts-expect-error when is not a valid layout use item
746
- when(() => true),
747
- ]),
748
- ]));
749
- }).toThrow(/when\(\) can only be used inside intercept/);
750
- });
751
- it("duplicate route names throw", () => {
752
- expect(() => {
753
- buildRouteTree(urls(({ path }) => [
754
- path("/", HomePage, { name: "home" }),
755
- path("/other", AboutPage, { name: "home" }),
756
- ]));
757
- }).toThrow(/Duplicate route name: home/);
758
- });
759
- it("parallel inside parallel throws", () => {
760
- expect(() => {
761
- buildRouteTree(urls(({ path, layout, parallel }) => [
762
- layout(RootLayout, () => [
763
- path("/", HomePage, { name: "home" }),
764
- // @ts-expect-error parallel is not a valid parallel use item
765
- parallel({ "@sidebar": Sidebar }, () => [
766
- parallel({ "@inner": MainContent }),
767
- ]),
768
- ]),
769
- ]));
770
- }).toThrow(/parallel\(\) cannot be nested inside another parallel/);
771
- });
772
- it("intercept inside parallel throws", () => {
773
- expect(() => {
774
- buildRouteTree(urls(({ path, layout, parallel, intercept }) => [
775
- layout(RootLayout, () => [
776
- path("/", HomePage, { name: "home" }),
777
- path("/detail", AboutPage, { name: "detail" }),
778
- // @ts-expect-error intercept is not a valid parallel use item
779
- parallel({ "@sidebar": Sidebar }, () => [
780
- intercept("@modal", "detail", ProductModal),
781
- ]),
782
- ]),
783
- ]));
784
- }).toThrow(/intercept\(\) cannot be used inside parallel/);
785
- });
786
- it("path inside parallel throws", () => {
787
- expect(() => {
788
- buildRouteTree(urls(({ path, layout, parallel }) => [
789
- layout(RootLayout, () => [
790
- // @ts-expect-error path is not a valid parallel use item
791
- parallel({ "@sidebar": Sidebar }, () => [
792
- path("/nested", HomePage, { name: "nested" }),
793
- ]),
794
- ]),
795
- ]));
796
- }).toThrow(/path\(\) cannot be used inside parallel/);
797
- });
798
- it("path inside path throws", () => {
799
- expect(() => {
800
- buildRouteTree(urls(({ path, layout }) => [
801
- layout(RootLayout, () => [
802
- // @ts-expect-error path is not a valid route use item
803
- path("/parent", HomePage, { name: "parent" }, () => [
804
- path("/child", AboutPage, { name: "child" }),
805
- ]),
806
- ]),
807
- ]));
808
- }).toThrow(/path\(\) cannot be nested inside another path/);
809
- });
810
- it("path inside layout inside path throws", () => {
811
- expect(() => {
812
- buildRouteTree(urls(({ path, layout }) => [
813
- layout(RootLayout, () => [
814
- path("/parent", HomePage, { name: "parent" }, () => [
815
- layout(AuthLayout, () => [
816
- path("/child", AboutPage, { name: "child" }),
817
- ]),
818
- ]),
819
- ]),
820
- ]));
821
- }).toThrow(/path\(\) cannot be nested inside another path/);
822
- });
823
- it("path inside cache inside layout inside path throws", () => {
824
- expect(() => {
825
- buildRouteTree(urls(({ path, layout, cache }) => [
826
- layout(RootLayout, () => [
827
- path("/parent", HomePage, { name: "parent" }, () => [
828
- layout(AuthLayout, () => [
829
- cache({ ttl: 60 }, () => [
830
- path("/child", AboutPage, { name: "child" }),
831
- ]),
832
- ]),
833
- ]),
834
- ]),
835
- ]));
836
- }).toThrow(/path\(\) cannot be nested inside another path/);
837
- });
838
- // -------------------------------------------------------------------------
839
- // Combined: complex app with cache, parallel, nested layouts, include
840
- // -------------------------------------------------------------------------
841
- it("inspects a full app route tree", () => {
842
- const blogPatterns = urls(({ path, loader }) => [
843
- path("/", BlogIndex, { name: "index" }),
844
- path("/:slug", BlogPost, { name: "post" }, () => [
845
- loader(PostLoader),
846
- ]),
847
- ]);
848
- const tree = buildRouteTree(urls(({ path, layout, include, middleware, errorBoundary, loading }) => [
849
- layout(RootLayout, () => [
850
- middleware(logMiddleware),
851
- errorBoundary(ErrorFallback),
852
- path("/", HomePage, { name: "home" }),
853
- layout(AuthLayout, () => [
854
- middleware(authMiddleware),
855
- path("/dashboard", Dashboard, { name: "dashboard" }, () => [
856
- loading(LoadingSpinner),
857
- ]),
858
- ]),
859
- include("/blog", blogPatterns, { name: "blog" }),
860
- ]),
861
- ]));
862
- // Route patterns
863
- expect(tree.routeNames()).toContain("home");
864
- expect(tree.routeNames()).toContain("dashboard");
865
- expect(tree.routeNames()).toContain("blog.index");
866
- expect(tree.routeNames()).toContain("blog.post");
867
- // Matching
868
- expect(tree.match("/").routeKey).toBe("home");
869
- expect(tree.match("/dashboard").routeKey).toBe("dashboard");
870
- expect(tree.match("/blog").routeKey).toBe("blog.index");
871
- expect(tree.match("/blog/hello").params).toEqual({ slug: "hello" });
872
- // Middleware chain: dashboard goes through root + auth layouts
873
- const dashChain = tree.middlewareChain("dashboard");
874
- expect(dashChain).toHaveLength(2);
875
- // Home only goes through root layout
876
- const homeChain = tree.middlewareChain("home");
877
- expect(homeChain).toHaveLength(1);
878
- // Blog post has a loader
879
- expect(tree.hasLoaders("blog.post")).toBe(true);
880
- expect(tree.hasLoaders("blog.index")).toBe(false);
881
- // Dashboard has loading
882
- expect(tree.hasLoading("dashboard")).toBe(true);
883
- // Root layout has error boundary
884
- const homeEntry = tree.entry("home");
885
- expect(homeEntry.parent.errorBoundary).toHaveLength(1);
886
- // Debug output
887
- const debug = tree.debug();
888
- expect(debug).toContain("home:");
889
- expect(debug).toContain("dashboard:");
890
- });
891
- it("path with nested layouts carrying loading, loaders, and parallel", () => {
892
- const InnerLayout = (_jsx("div", { children: "inner" }));
893
- const DeepLayout = (_jsx("div", { children: "deep" }));
894
- const ComplexPage = (_jsx("div", { children: "complex" }));
895
- const PanelA = (_jsx("div", { children: "panel-a" }));
896
- const PanelB = (_jsx("div", { children: "panel-b" }));
897
- const InnerLoading = (_jsx("div", { children: "inner-loading" }));
898
- const ComplexLoader = createLoader(async () => ({ data: "complex" }));
899
- const DeepLoader = createLoader(async () => ({ nested: true }));
900
- const tree = buildRouteTree(urls(({ path, layout, loader, loading, parallel, middleware }) => [
901
- layout(RootLayout, () => [
902
- middleware(logMiddleware),
903
- path("/complex-extra", ComplexPage, { name: "complex.very" }, () => [
904
- loader(ComplexLoader),
905
- loading(LoadingSpinner),
906
- layout(InnerLayout, () => [
907
- loading(InnerLoading),
908
- loader(DeepLoader),
909
- parallel({ "@panelA": PanelA, "@panelB": PanelB }),
910
- ]),
911
- layout(DeepLayout, () => [
912
- middleware(authMiddleware),
913
- ]),
914
- ]),
915
- ]),
916
- ]));
917
- // Route registers correctly
918
- expect(tree.routes()).toEqual({ "complex.very": "/complex-extra" });
919
- expect(tree.match("/complex-extra").routeKey).toBe("complex.very");
920
- // Route entry itself
921
- const entry = tree.entry("complex.very");
922
- expect(entry.type).toBe("route");
923
- expect(entry.parent.type).toBe("layout"); // RootLayout
924
- // Route has its own loader and loading
925
- expect(entry.loader).toHaveLength(1);
926
- expect(entry.loader[0].loader).toBe(ComplexLoader);
927
- expect(entry.loading).toBe(LoadingSpinner);
928
- // Both orphan layouts are siblings on the route's layout array
929
- expect(entry.layout).toHaveLength(2);
930
- const innerLayout = entry.layout[0];
931
- const deepLayout = entry.layout[1];
932
- expect(innerLayout.type).toBe("layout");
933
- expect(deepLayout.type).toBe("layout");
934
- // InnerLayout carries its own loading and loader
935
- expect(innerLayout.loading).toBe(InnerLoading);
936
- expect(innerLayout.loader).toHaveLength(1);
937
- expect(innerLayout.loader[0].loader).toBe(DeepLoader);
938
- // InnerLayout has parallel slots
939
- expect(innerLayout.parallel).toHaveLength(1);
940
- const parallelEntry = innerLayout.parallel[0];
941
- expect(parallelEntry.type).toBe("parallel");
942
- const slots = parallelEntry.handler;
943
- expect(Object.keys(slots)).toEqual(expect.arrayContaining(["@panelA", "@panelB"]));
944
- // DeepLayout carries middleware (no nested orphan layouts)
945
- expect(innerLayout.layout).toHaveLength(0);
946
- expect(deepLayout.middleware).toHaveLength(1);
947
- expect(deepLayout.middleware[0]).toBe(authMiddleware);
948
- // Segment IDs: route is under RootLayout
949
- expect(tree.segmentId("complex.very")).toBe("M0L0L0R0");
950
- // Both layouts get L shortCodes directly under the route
951
- expect(innerLayout.shortCode).toBe("M0L0L0R0L0");
952
- expect(deepLayout.shortCode).toBe("M0L0L0R0L1");
953
- expect(parallelEntry.shortCode).toBe("M0L0L0R0L0P0");
954
- // Middleware chain for the route: only logMw from RootLayout
955
- // (authMw is on DeepLayout which wraps inside the route, not in parent chain)
956
- const chain = tree.middlewareChain("complex.very");
957
- expect(chain).toEqual([
958
- { segmentId: "M0L0L0", count: 1 },
959
- ]);
960
- });
961
- it("complex app: cache + parallel + nested layouts + intercept", () => {
962
- const NavLayout = (_jsx("div", { children: "nav" }));
963
- const ListPage = (_jsx("div", { children: "list" }));
964
- const DetailPage = (_jsx("div", { children: "detail" }));
965
- const ModalView = (_jsx("div", { children: "modal" }));
966
- const SidebarNav = (_jsx("div", { children: "sidebar-nav" }));
967
- const DetailLoader = createLoader(async () => ({ item: {} }));
968
- const ListLoader = createLoader(async () => ({ items: [] }));
969
- const tree = buildRouteTree(urls(({ path, layout, cache, parallel, intercept, when, middleware, loader, loading, errorBoundary }) => [
970
- layout(RootLayout, () => [
971
- middleware(logMiddleware),
972
- errorBoundary(ErrorFallback),
973
- layout(NavLayout, () => [
974
- parallel({ "@sidebar": SidebarNav }),
975
- cache({ ttl: 120 }, () => [
976
- path("/items", ListPage, { name: "items" }, () => [
977
- loader(ListLoader),
978
- loading(LoadingSpinner),
979
- ]),
980
- path("/items/:id", DetailPage, { name: "item.detail" }, () => [
981
- loader(DetailLoader),
982
- loading(LoadingSpinner),
983
- ]),
984
- intercept("@drawer", "item.detail", ModalView, () => [
985
- when((ctx) => ctx.from.pathname.startsWith("/items")),
986
- loader(DetailLoader),
987
- ]),
988
- ]),
989
- path("/", HomePage, { name: "home" }),
990
- ]),
991
- ]),
992
- ]));
993
- // All routes registered
994
- expect(tree.routeNames()).toEqual(expect.arrayContaining(["home", "items", "item.detail"]));
995
- // Matching
996
- expect(tree.match("/").routeKey).toBe("home");
997
- expect(tree.match("/items").routeKey).toBe("items");
998
- expect(tree.match("/items/abc").params).toEqual({ id: "abc" });
999
- // Segment hierarchy for items: synthetic > Root > Nav > Cache > route
1000
- const itemsPath = tree.segmentPath("items");
1001
- const itemsTypes = itemsPath.map((s) => s.type);
1002
- expect(itemsTypes).toEqual(["layout", "layout", "layout", "cache", "route"]);
1003
- // Home is NOT inside the cache segment
1004
- const homePath = tree.segmentPath("home");
1005
- const homeTypes = homePath.map((s) => s.type);
1006
- expect(homeTypes).toEqual(["layout", "layout", "layout", "route"]);
1007
- // Cache segment properties
1008
- const itemsEntry = tree.entry("items");
1009
- expect(itemsEntry.parent.type).toBe("cache");
1010
- expect(itemsEntry.parent.cache.options).toEqual({ ttl: 120 });
1011
- // Loaders on items and item.detail
1012
- expect(tree.hasLoaders("items")).toBe(true);
1013
- expect(tree.loaders("items")[0].loader).toBe(ListLoader);
1014
- expect(tree.hasLoaders("item.detail")).toBe(true);
1015
- expect(tree.loaders("item.detail")[0].loader).toBe(DetailLoader);
1016
- // Loading on both
1017
- expect(tree.hasLoading("items")).toBe(true);
1018
- expect(tree.hasLoading("item.detail")).toBe(true);
1019
- // Home has no loader or loading
1020
- expect(tree.hasLoaders("home")).toBe(false);
1021
- expect(tree.hasLoading("home")).toBe(false);
1022
- // Middleware: all routes get logMw from RootLayout
1023
- expect(tree.middlewareChain("items")).toEqual([
1024
- { segmentId: "M0L0L0", count: 1 },
1025
- ]);
1026
- expect(tree.middlewareChain("home")).toEqual([
1027
- { segmentId: "M0L0L0", count: 1 },
1028
- ]);
1029
- // Error boundary on RootLayout propagates
1030
- expect(itemsEntry.parent.parent.parent.errorBoundary).toHaveLength(1);
1031
- // Parallel sidebar on NavLayout
1032
- const homeEntry = tree.entry("home");
1033
- const navLayout = homeEntry.parent;
1034
- expect(navLayout.type).toBe("layout"); // NavLayout
1035
- expect(navLayout.parallel).toHaveLength(1);
1036
- const sidebarSlot = navLayout.parallel[0];
1037
- expect(sidebarSlot.type).toBe("parallel");
1038
- const sidebarHandler = sidebarSlot.handler;
1039
- expect(Object.keys(sidebarHandler)).toContain("@sidebar");
1040
- // Intercept on cache segment's parent (NavLayout holds the cache which holds the intercept)
1041
- // Intercepts are on the entry where intercept() is called — inside cache() children
1042
- const cacheEntry = itemsEntry.parent;
1043
- expect(cacheEntry.intercept).toHaveLength(1);
1044
- expect(cacheEntry.intercept[0].slotName).toBe("@drawer");
1045
- expect(cacheEntry.intercept[0].routeName).toBe("item.detail");
1046
- expect(cacheEntry.intercept[0].when).toHaveLength(1);
1047
- expect(cacheEntry.intercept[0].loader).toHaveLength(1);
1048
- expect(cacheEntry.intercept[0].loader[0].loader).toBe(DetailLoader);
1049
- });
1050
- });
1051
- //# sourceMappingURL=router-integration.test.js.map