@rangojs/router 0.0.0-experimental.60 → 0.0.0-experimental.60c5dbde

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 (889) hide show
  1. package/README.md +61 -8
  2. package/dist/bin/rango.js +2 -1
  3. package/dist/vite/index.js +448 -179
  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/segment-reconciler.ts +72 -2
  24. package/src/build/generate-manifest.ts +3 -6
  25. package/src/build/route-trie.ts +50 -24
  26. package/src/build/route-types/scan-filter.ts +8 -1
  27. package/src/client.tsx +5 -66
  28. package/src/handle.ts +40 -0
  29. package/src/index.rsc.ts +3 -1
  30. package/src/index.ts +46 -6
  31. package/src/prerender/store.ts +5 -4
  32. package/src/prerender.ts +138 -77
  33. package/src/reverse.ts +6 -1
  34. package/src/route-definition/dsl-helpers.ts +194 -32
  35. package/src/route-definition/helpers-types.ts +61 -14
  36. package/src/route-definition/index.ts +3 -0
  37. package/src/route-definition/resolve-handler-use.ts +149 -0
  38. package/src/route-types.ts +11 -0
  39. package/src/router/content-negotiation.ts +100 -1
  40. package/src/router/handler-context.ts +26 -6
  41. package/src/router/loader-resolution.ts +147 -19
  42. package/src/router/match-api.ts +124 -189
  43. package/src/router/match-middleware/cache-lookup.ts +24 -7
  44. package/src/router/match-middleware/segment-resolution.ts +53 -0
  45. package/src/router/match-result.ts +82 -4
  46. package/src/router/navigation-snapshot.ts +182 -0
  47. package/src/router/prerender-match.ts +108 -8
  48. package/src/router/preview-match.ts +30 -102
  49. package/src/router/request-classification.ts +310 -0
  50. package/src/router/route-snapshot.ts +245 -0
  51. package/src/router/router-interfaces.ts +11 -0
  52. package/src/router/segment-resolution/fresh.ts +59 -2
  53. package/src/router/segment-resolution/revalidation.ts +79 -6
  54. package/src/router.ts +13 -1
  55. package/src/rsc/handler.ts +468 -377
  56. package/src/rsc/loader-fetch.ts +23 -3
  57. package/src/rsc/progressive-enhancement.ts +10 -2
  58. package/src/rsc/rsc-rendering.ts +5 -1
  59. package/src/rsc/server-action.ts +6 -0
  60. package/src/rsc/ssr-setup.ts +1 -1
  61. package/src/rsc/types.ts +1 -0
  62. package/src/segment-content-promise.ts +38 -0
  63. package/src/segment-system.tsx +25 -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/rango.ts +2 -1
  85. package/src/vite/router-discovery.ts +178 -37
  86. package/src/vite/utils/prerender-utils.ts +37 -5
  87. package/dist/__internal.d.ts +0 -83
  88. package/dist/__internal.d.ts.map +0 -1
  89. package/dist/__internal.js +0 -19
  90. package/dist/__internal.js.map +0 -1
  91. package/dist/__mocks__/version.d.ts +0 -7
  92. package/dist/__mocks__/version.d.ts.map +0 -1
  93. package/dist/__mocks__/version.js +0 -7
  94. package/dist/__mocks__/version.js.map +0 -1
  95. package/dist/__tests__/client-href.test.d.ts +0 -2
  96. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  97. package/dist/__tests__/client-href.test.js +0 -74
  98. package/dist/__tests__/client-href.test.js.map +0 -1
  99. package/dist/__tests__/component-utils.test.d.ts +0 -2
  100. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  101. package/dist/__tests__/component-utils.test.js +0 -51
  102. package/dist/__tests__/component-utils.test.js.map +0 -1
  103. package/dist/__tests__/event-controller.test.d.ts +0 -2
  104. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  105. package/dist/__tests__/event-controller.test.js +0 -538
  106. package/dist/__tests__/event-controller.test.js.map +0 -1
  107. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  108. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  109. package/dist/__tests__/helpers/route-tree.js +0 -374
  110. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  111. package/dist/__tests__/match-result.test.d.ts +0 -2
  112. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  113. package/dist/__tests__/match-result.test.js +0 -154
  114. package/dist/__tests__/match-result.test.js.map +0 -1
  115. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  116. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  117. package/dist/__tests__/navigation-store.test.js +0 -440
  118. package/dist/__tests__/navigation-store.test.js.map +0 -1
  119. package/dist/__tests__/partial-update.test.d.ts +0 -2
  120. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  121. package/dist/__tests__/partial-update.test.js +0 -1009
  122. package/dist/__tests__/partial-update.test.js.map +0 -1
  123. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  124. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  125. package/dist/__tests__/reverse-types.test.js +0 -656
  126. package/dist/__tests__/reverse-types.test.js.map +0 -1
  127. package/dist/__tests__/route-definition.test.d.ts +0 -2
  128. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  129. package/dist/__tests__/route-definition.test.js +0 -55
  130. package/dist/__tests__/route-definition.test.js.map +0 -1
  131. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  132. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  133. package/dist/__tests__/router-helpers.test.js +0 -377
  134. package/dist/__tests__/router-helpers.test.js.map +0 -1
  135. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  136. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  137. package/dist/__tests__/router-integration-2.test.js +0 -426
  138. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  139. package/dist/__tests__/router-integration.test.d.ts +0 -2
  140. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  141. package/dist/__tests__/router-integration.test.js +0 -1051
  142. package/dist/__tests__/router-integration.test.js.map +0 -1
  143. package/dist/__tests__/search-params.test.d.ts +0 -5
  144. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  145. package/dist/__tests__/search-params.test.js +0 -306
  146. package/dist/__tests__/search-params.test.js.map +0 -1
  147. package/dist/__tests__/segment-system.test.d.ts +0 -2
  148. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  149. package/dist/__tests__/segment-system.test.js +0 -627
  150. package/dist/__tests__/segment-system.test.js.map +0 -1
  151. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  152. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  153. package/dist/__tests__/static-handler-types.test.js +0 -63
  154. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  155. package/dist/__tests__/urls.test.d.ts +0 -2
  156. package/dist/__tests__/urls.test.d.ts.map +0 -1
  157. package/dist/__tests__/urls.test.js +0 -421
  158. package/dist/__tests__/urls.test.js.map +0 -1
  159. package/dist/__tests__/use-mount.test.d.ts +0 -2
  160. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  161. package/dist/__tests__/use-mount.test.js +0 -35
  162. package/dist/__tests__/use-mount.test.js.map +0 -1
  163. package/dist/bin/rango.d.ts +0 -2
  164. package/dist/bin/rango.d.ts.map +0 -1
  165. package/dist/bin/rango.js.map +0 -1
  166. package/dist/browser/event-controller.d.ts +0 -191
  167. package/dist/browser/event-controller.d.ts.map +0 -1
  168. package/dist/browser/event-controller.js +0 -559
  169. package/dist/browser/event-controller.js.map +0 -1
  170. package/dist/browser/index.d.ts +0 -2
  171. package/dist/browser/index.d.ts.map +0 -1
  172. package/dist/browser/index.js +0 -14
  173. package/dist/browser/index.js.map +0 -1
  174. package/dist/browser/link-interceptor.d.ts +0 -38
  175. package/dist/browser/link-interceptor.d.ts.map +0 -1
  176. package/dist/browser/link-interceptor.js +0 -99
  177. package/dist/browser/link-interceptor.js.map +0 -1
  178. package/dist/browser/logging.d.ts +0 -10
  179. package/dist/browser/logging.d.ts.map +0 -1
  180. package/dist/browser/logging.js +0 -29
  181. package/dist/browser/logging.js.map +0 -1
  182. package/dist/browser/lru-cache.d.ts +0 -17
  183. package/dist/browser/lru-cache.d.ts.map +0 -1
  184. package/dist/browser/lru-cache.js +0 -50
  185. package/dist/browser/lru-cache.js.map +0 -1
  186. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  187. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  188. package/dist/browser/merge-segment-loaders.js +0 -102
  189. package/dist/browser/merge-segment-loaders.js.map +0 -1
  190. package/dist/browser/navigation-bridge.d.ts +0 -102
  191. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  192. package/dist/browser/navigation-bridge.js +0 -708
  193. package/dist/browser/navigation-bridge.js.map +0 -1
  194. package/dist/browser/navigation-client.d.ts +0 -25
  195. package/dist/browser/navigation-client.d.ts.map +0 -1
  196. package/dist/browser/navigation-client.js +0 -157
  197. package/dist/browser/navigation-client.js.map +0 -1
  198. package/dist/browser/navigation-store.d.ts +0 -101
  199. package/dist/browser/navigation-store.d.ts.map +0 -1
  200. package/dist/browser/navigation-store.js +0 -625
  201. package/dist/browser/navigation-store.js.map +0 -1
  202. package/dist/browser/partial-update.d.ts +0 -75
  203. package/dist/browser/partial-update.d.ts.map +0 -1
  204. package/dist/browser/partial-update.js +0 -426
  205. package/dist/browser/partial-update.js.map +0 -1
  206. package/dist/browser/react/Link.d.ts +0 -86
  207. package/dist/browser/react/Link.d.ts.map +0 -1
  208. package/dist/browser/react/Link.js +0 -128
  209. package/dist/browser/react/Link.js.map +0 -1
  210. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  211. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  212. package/dist/browser/react/NavigationProvider.js +0 -216
  213. package/dist/browser/react/NavigationProvider.js.map +0 -1
  214. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  215. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  216. package/dist/browser/react/ScrollRestoration.js +0 -57
  217. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  218. package/dist/browser/react/context.d.ts +0 -46
  219. package/dist/browser/react/context.d.ts.map +0 -1
  220. package/dist/browser/react/context.js +0 -10
  221. package/dist/browser/react/context.js.map +0 -1
  222. package/dist/browser/react/index.d.ts +0 -11
  223. package/dist/browser/react/index.d.ts.map +0 -1
  224. package/dist/browser/react/index.js +0 -22
  225. package/dist/browser/react/index.js.map +0 -1
  226. package/dist/browser/react/location-state-shared.d.ts +0 -63
  227. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  228. package/dist/browser/react/location-state-shared.js +0 -81
  229. package/dist/browser/react/location-state-shared.js.map +0 -1
  230. package/dist/browser/react/location-state.d.ts +0 -23
  231. package/dist/browser/react/location-state.d.ts.map +0 -1
  232. package/dist/browser/react/location-state.js +0 -29
  233. package/dist/browser/react/location-state.js.map +0 -1
  234. package/dist/browser/react/mount-context.d.ts +0 -24
  235. package/dist/browser/react/mount-context.d.ts.map +0 -1
  236. package/dist/browser/react/mount-context.js +0 -24
  237. package/dist/browser/react/mount-context.js.map +0 -1
  238. package/dist/browser/react/use-action.d.ts +0 -64
  239. package/dist/browser/react/use-action.d.ts.map +0 -1
  240. package/dist/browser/react/use-action.js +0 -134
  241. package/dist/browser/react/use-action.js.map +0 -1
  242. package/dist/browser/react/use-client-cache.d.ts +0 -41
  243. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  244. package/dist/browser/react/use-client-cache.js +0 -39
  245. package/dist/browser/react/use-client-cache.js.map +0 -1
  246. package/dist/browser/react/use-handle.d.ts +0 -31
  247. package/dist/browser/react/use-handle.d.ts.map +0 -1
  248. package/dist/browser/react/use-handle.js +0 -144
  249. package/dist/browser/react/use-handle.js.map +0 -1
  250. package/dist/browser/react/use-href.d.ts +0 -33
  251. package/dist/browser/react/use-href.d.ts.map +0 -1
  252. package/dist/browser/react/use-href.js +0 -39
  253. package/dist/browser/react/use-href.js.map +0 -1
  254. package/dist/browser/react/use-link-status.d.ts +0 -37
  255. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  256. package/dist/browser/react/use-link-status.js +0 -99
  257. package/dist/browser/react/use-link-status.js.map +0 -1
  258. package/dist/browser/react/use-mount.d.ts +0 -25
  259. package/dist/browser/react/use-mount.d.ts.map +0 -1
  260. package/dist/browser/react/use-mount.js +0 -30
  261. package/dist/browser/react/use-mount.js.map +0 -1
  262. package/dist/browser/react/use-navigation.d.ts +0 -27
  263. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  264. package/dist/browser/react/use-navigation.js +0 -87
  265. package/dist/browser/react/use-navigation.js.map +0 -1
  266. package/dist/browser/react/use-segments.d.ts +0 -38
  267. package/dist/browser/react/use-segments.d.ts.map +0 -1
  268. package/dist/browser/react/use-segments.js +0 -130
  269. package/dist/browser/react/use-segments.js.map +0 -1
  270. package/dist/browser/request-controller.d.ts +0 -26
  271. package/dist/browser/request-controller.d.ts.map +0 -1
  272. package/dist/browser/request-controller.js +0 -147
  273. package/dist/browser/request-controller.js.map +0 -1
  274. package/dist/browser/rsc-router.d.ts +0 -129
  275. package/dist/browser/rsc-router.d.ts.map +0 -1
  276. package/dist/browser/rsc-router.js +0 -195
  277. package/dist/browser/rsc-router.js.map +0 -1
  278. package/dist/browser/scroll-restoration.d.ts +0 -93
  279. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  280. package/dist/browser/scroll-restoration.js +0 -321
  281. package/dist/browser/scroll-restoration.js.map +0 -1
  282. package/dist/browser/segment-structure-assert.d.ts +0 -17
  283. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  284. package/dist/browser/segment-structure-assert.js +0 -59
  285. package/dist/browser/segment-structure-assert.js.map +0 -1
  286. package/dist/browser/server-action-bridge.d.ts +0 -26
  287. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  288. package/dist/browser/server-action-bridge.js +0 -668
  289. package/dist/browser/server-action-bridge.js.map +0 -1
  290. package/dist/browser/shallow.d.ts +0 -12
  291. package/dist/browser/shallow.d.ts.map +0 -1
  292. package/dist/browser/shallow.js +0 -34
  293. package/dist/browser/shallow.js.map +0 -1
  294. package/dist/browser/types.d.ts +0 -369
  295. package/dist/browser/types.d.ts.map +0 -1
  296. package/dist/browser/types.js +0 -2
  297. package/dist/browser/types.js.map +0 -1
  298. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  299. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  300. package/dist/build/__tests__/generate-cli.test.js +0 -237
  301. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  302. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  303. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  304. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  305. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  306. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  307. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  308. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  309. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  310. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  311. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  312. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  313. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  314. package/dist/build/generate-manifest.d.ts +0 -81
  315. package/dist/build/generate-manifest.d.ts.map +0 -1
  316. package/dist/build/generate-manifest.js +0 -276
  317. package/dist/build/generate-manifest.js.map +0 -1
  318. package/dist/build/generate-route-types.d.ts +0 -115
  319. package/dist/build/generate-route-types.d.ts.map +0 -1
  320. package/dist/build/generate-route-types.js +0 -740
  321. package/dist/build/generate-route-types.js.map +0 -1
  322. package/dist/build/index.d.ts +0 -21
  323. package/dist/build/index.d.ts.map +0 -1
  324. package/dist/build/index.js +0 -21
  325. package/dist/build/index.js.map +0 -1
  326. package/dist/build/route-trie.d.ts +0 -71
  327. package/dist/build/route-trie.d.ts.map +0 -1
  328. package/dist/build/route-trie.js +0 -175
  329. package/dist/build/route-trie.js.map +0 -1
  330. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  331. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  332. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  333. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  334. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  335. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  336. package/dist/cache/__tests__/document-cache.test.js +0 -345
  337. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  338. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  339. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  340. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  341. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  342. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  343. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  344. package/dist/cache/__tests__/memory-store.test.js +0 -367
  345. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  346. package/dist/cache/cache-scope.d.ts +0 -102
  347. package/dist/cache/cache-scope.d.ts.map +0 -1
  348. package/dist/cache/cache-scope.js +0 -440
  349. package/dist/cache/cache-scope.js.map +0 -1
  350. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  351. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  352. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  353. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  354. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  355. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  356. package/dist/cache/cf/cf-cache-store.js +0 -242
  357. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  358. package/dist/cache/cf/index.d.ts +0 -14
  359. package/dist/cache/cf/index.d.ts.map +0 -1
  360. package/dist/cache/cf/index.js +0 -17
  361. package/dist/cache/cf/index.js.map +0 -1
  362. package/dist/cache/document-cache.d.ts +0 -64
  363. package/dist/cache/document-cache.d.ts.map +0 -1
  364. package/dist/cache/document-cache.js +0 -228
  365. package/dist/cache/document-cache.js.map +0 -1
  366. package/dist/cache/index.d.ts +0 -19
  367. package/dist/cache/index.d.ts.map +0 -1
  368. package/dist/cache/index.js +0 -21
  369. package/dist/cache/index.js.map +0 -1
  370. package/dist/cache/memory-segment-store.d.ts +0 -110
  371. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  372. package/dist/cache/memory-segment-store.js +0 -117
  373. package/dist/cache/memory-segment-store.js.map +0 -1
  374. package/dist/cache/memory-store.d.ts +0 -41
  375. package/dist/cache/memory-store.d.ts.map +0 -1
  376. package/dist/cache/memory-store.js +0 -191
  377. package/dist/cache/memory-store.js.map +0 -1
  378. package/dist/cache/types.d.ts +0 -317
  379. package/dist/cache/types.d.ts.map +0 -1
  380. package/dist/cache/types.js +0 -12
  381. package/dist/cache/types.js.map +0 -1
  382. package/dist/client.d.ts +0 -248
  383. package/dist/client.d.ts.map +0 -1
  384. package/dist/client.js +0 -367
  385. package/dist/client.js.map +0 -1
  386. package/dist/client.rsc.d.ts +0 -26
  387. package/dist/client.rsc.d.ts.map +0 -1
  388. package/dist/client.rsc.js +0 -46
  389. package/dist/client.rsc.js.map +0 -1
  390. package/dist/component-utils.d.ts +0 -36
  391. package/dist/component-utils.d.ts.map +0 -1
  392. package/dist/component-utils.js +0 -61
  393. package/dist/component-utils.js.map +0 -1
  394. package/dist/components/DefaultDocument.d.ts +0 -13
  395. package/dist/components/DefaultDocument.d.ts.map +0 -1
  396. package/dist/components/DefaultDocument.js +0 -15
  397. package/dist/components/DefaultDocument.js.map +0 -1
  398. package/dist/debug.d.ts +0 -58
  399. package/dist/debug.d.ts.map +0 -1
  400. package/dist/debug.js +0 -157
  401. package/dist/debug.js.map +0 -1
  402. package/dist/default-error-boundary.d.ts +0 -11
  403. package/dist/default-error-boundary.d.ts.map +0 -1
  404. package/dist/default-error-boundary.js +0 -45
  405. package/dist/default-error-boundary.js.map +0 -1
  406. package/dist/deps/browser.d.ts +0 -2
  407. package/dist/deps/browser.d.ts.map +0 -1
  408. package/dist/deps/browser.js +0 -3
  409. package/dist/deps/browser.js.map +0 -1
  410. package/dist/deps/html-stream-client.d.ts +0 -2
  411. package/dist/deps/html-stream-client.d.ts.map +0 -1
  412. package/dist/deps/html-stream-client.js +0 -3
  413. package/dist/deps/html-stream-client.js.map +0 -1
  414. package/dist/deps/html-stream-server.d.ts +0 -2
  415. package/dist/deps/html-stream-server.d.ts.map +0 -1
  416. package/dist/deps/html-stream-server.js +0 -3
  417. package/dist/deps/html-stream-server.js.map +0 -1
  418. package/dist/deps/rsc.d.ts +0 -2
  419. package/dist/deps/rsc.d.ts.map +0 -1
  420. package/dist/deps/rsc.js +0 -4
  421. package/dist/deps/rsc.js.map +0 -1
  422. package/dist/deps/ssr.d.ts +0 -2
  423. package/dist/deps/ssr.d.ts.map +0 -1
  424. package/dist/deps/ssr.js +0 -3
  425. package/dist/deps/ssr.js.map +0 -1
  426. package/dist/errors.d.ts +0 -174
  427. package/dist/errors.d.ts.map +0 -1
  428. package/dist/errors.js +0 -241
  429. package/dist/errors.js.map +0 -1
  430. package/dist/handle.d.ts +0 -78
  431. package/dist/handle.d.ts.map +0 -1
  432. package/dist/handle.js +0 -82
  433. package/dist/handle.js.map +0 -1
  434. package/dist/handles/MetaTags.d.ts +0 -14
  435. package/dist/handles/MetaTags.d.ts.map +0 -1
  436. package/dist/handles/MetaTags.js +0 -136
  437. package/dist/handles/MetaTags.js.map +0 -1
  438. package/dist/handles/index.d.ts +0 -6
  439. package/dist/handles/index.d.ts.map +0 -1
  440. package/dist/handles/index.js +0 -6
  441. package/dist/handles/index.js.map +0 -1
  442. package/dist/handles/meta.d.ts +0 -39
  443. package/dist/handles/meta.d.ts.map +0 -1
  444. package/dist/handles/meta.js +0 -202
  445. package/dist/handles/meta.js.map +0 -1
  446. package/dist/host/__tests__/errors.test.d.ts +0 -2
  447. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  448. package/dist/host/__tests__/errors.test.js +0 -76
  449. package/dist/host/__tests__/errors.test.js.map +0 -1
  450. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  451. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  452. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  453. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  454. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  455. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  456. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  457. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  458. package/dist/host/__tests__/router.test.d.ts +0 -2
  459. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  460. package/dist/host/__tests__/router.test.js +0 -241
  461. package/dist/host/__tests__/router.test.js.map +0 -1
  462. package/dist/host/__tests__/testing.test.d.ts +0 -2
  463. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  464. package/dist/host/__tests__/testing.test.js +0 -64
  465. package/dist/host/__tests__/testing.test.js.map +0 -1
  466. package/dist/host/__tests__/utils.test.d.ts +0 -2
  467. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  468. package/dist/host/__tests__/utils.test.js +0 -29
  469. package/dist/host/__tests__/utils.test.js.map +0 -1
  470. package/dist/host/cookie-handler.d.ts +0 -34
  471. package/dist/host/cookie-handler.d.ts.map +0 -1
  472. package/dist/host/cookie-handler.js +0 -124
  473. package/dist/host/cookie-handler.js.map +0 -1
  474. package/dist/host/errors.d.ts +0 -56
  475. package/dist/host/errors.d.ts.map +0 -1
  476. package/dist/host/errors.js +0 -79
  477. package/dist/host/errors.js.map +0 -1
  478. package/dist/host/index.d.ts +0 -29
  479. package/dist/host/index.d.ts.map +0 -1
  480. package/dist/host/index.js +0 -32
  481. package/dist/host/index.js.map +0 -1
  482. package/dist/host/pattern-matcher.d.ts +0 -36
  483. package/dist/host/pattern-matcher.d.ts.map +0 -1
  484. package/dist/host/pattern-matcher.js +0 -172
  485. package/dist/host/pattern-matcher.js.map +0 -1
  486. package/dist/host/router.d.ts +0 -26
  487. package/dist/host/router.d.ts.map +0 -1
  488. package/dist/host/router.js +0 -218
  489. package/dist/host/router.js.map +0 -1
  490. package/dist/host/testing.d.ts +0 -36
  491. package/dist/host/testing.d.ts.map +0 -1
  492. package/dist/host/testing.js +0 -55
  493. package/dist/host/testing.js.map +0 -1
  494. package/dist/host/types.d.ts +0 -115
  495. package/dist/host/types.d.ts.map +0 -1
  496. package/dist/host/types.js +0 -7
  497. package/dist/host/types.js.map +0 -1
  498. package/dist/host/utils.d.ts +0 -21
  499. package/dist/host/utils.d.ts.map +0 -1
  500. package/dist/host/utils.js +0 -23
  501. package/dist/host/utils.js.map +0 -1
  502. package/dist/href-client.d.ts +0 -131
  503. package/dist/href-client.d.ts.map +0 -1
  504. package/dist/href-client.js +0 -64
  505. package/dist/href-client.js.map +0 -1
  506. package/dist/href-context.d.ts +0 -29
  507. package/dist/href-context.d.ts.map +0 -1
  508. package/dist/href-context.js +0 -21
  509. package/dist/href-context.js.map +0 -1
  510. package/dist/index.d.ts +0 -73
  511. package/dist/index.d.ts.map +0 -1
  512. package/dist/index.js +0 -91
  513. package/dist/index.js.map +0 -1
  514. package/dist/index.rsc.d.ts +0 -32
  515. package/dist/index.rsc.d.ts.map +0 -1
  516. package/dist/index.rsc.js +0 -40
  517. package/dist/index.rsc.js.map +0 -1
  518. package/dist/internal-debug.d.ts +0 -2
  519. package/dist/internal-debug.d.ts.map +0 -1
  520. package/dist/internal-debug.js +0 -5
  521. package/dist/internal-debug.js.map +0 -1
  522. package/dist/loader.d.ts +0 -14
  523. package/dist/loader.d.ts.map +0 -1
  524. package/dist/loader.js +0 -20
  525. package/dist/loader.js.map +0 -1
  526. package/dist/loader.rsc.d.ts +0 -19
  527. package/dist/loader.rsc.d.ts.map +0 -1
  528. package/dist/loader.rsc.js +0 -99
  529. package/dist/loader.rsc.js.map +0 -1
  530. package/dist/network-error-thrower.d.ts +0 -17
  531. package/dist/network-error-thrower.d.ts.map +0 -1
  532. package/dist/network-error-thrower.js +0 -14
  533. package/dist/network-error-thrower.js.map +0 -1
  534. package/dist/outlet-context.d.ts +0 -13
  535. package/dist/outlet-context.d.ts.map +0 -1
  536. package/dist/outlet-context.js +0 -3
  537. package/dist/outlet-context.js.map +0 -1
  538. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  539. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  540. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  541. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  542. package/dist/prerender/param-hash.d.ts +0 -16
  543. package/dist/prerender/param-hash.d.ts.map +0 -1
  544. package/dist/prerender/param-hash.js +0 -36
  545. package/dist/prerender/param-hash.js.map +0 -1
  546. package/dist/prerender/store.d.ts +0 -38
  547. package/dist/prerender/store.d.ts.map +0 -1
  548. package/dist/prerender/store.js +0 -61
  549. package/dist/prerender/store.js.map +0 -1
  550. package/dist/prerender.d.ts +0 -66
  551. package/dist/prerender.d.ts.map +0 -1
  552. package/dist/prerender.js +0 -57
  553. package/dist/prerender.js.map +0 -1
  554. package/dist/reverse.d.ts +0 -196
  555. package/dist/reverse.d.ts.map +0 -1
  556. package/dist/reverse.js +0 -78
  557. package/dist/reverse.js.map +0 -1
  558. package/dist/root-error-boundary.d.ts +0 -33
  559. package/dist/root-error-boundary.d.ts.map +0 -1
  560. package/dist/root-error-boundary.js +0 -165
  561. package/dist/root-error-boundary.js.map +0 -1
  562. package/dist/route-content-wrapper.d.ts +0 -46
  563. package/dist/route-content-wrapper.d.ts.map +0 -1
  564. package/dist/route-content-wrapper.js +0 -77
  565. package/dist/route-content-wrapper.js.map +0 -1
  566. package/dist/route-definition.d.ts +0 -421
  567. package/dist/route-definition.d.ts.map +0 -1
  568. package/dist/route-definition.js +0 -868
  569. package/dist/route-definition.js.map +0 -1
  570. package/dist/route-map-builder.d.ts +0 -155
  571. package/dist/route-map-builder.d.ts.map +0 -1
  572. package/dist/route-map-builder.js +0 -237
  573. package/dist/route-map-builder.js.map +0 -1
  574. package/dist/route-types.d.ts +0 -165
  575. package/dist/route-types.d.ts.map +0 -1
  576. package/dist/route-types.js +0 -7
  577. package/dist/route-types.js.map +0 -1
  578. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  579. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  580. package/dist/router/__tests__/handler-context.test.js +0 -65
  581. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  582. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  583. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  584. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  585. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  586. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  587. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  588. package/dist/router/__tests__/match-context.test.js +0 -92
  589. package/dist/router/__tests__/match-context.test.js.map +0 -1
  590. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  591. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  592. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  593. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  594. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  595. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  596. package/dist/router/__tests__/match-result.test.js +0 -457
  597. package/dist/router/__tests__/match-result.test.js.map +0 -1
  598. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  599. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  600. package/dist/router/__tests__/on-error.test.js +0 -678
  601. package/dist/router/__tests__/on-error.test.js.map +0 -1
  602. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  603. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  604. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  605. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  606. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  607. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  608. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  609. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  610. package/dist/router/error-handling.d.ts +0 -77
  611. package/dist/router/error-handling.d.ts.map +0 -1
  612. package/dist/router/error-handling.js +0 -202
  613. package/dist/router/error-handling.js.map +0 -1
  614. package/dist/router/handler-context.d.ts +0 -20
  615. package/dist/router/handler-context.d.ts.map +0 -1
  616. package/dist/router/handler-context.js +0 -198
  617. package/dist/router/handler-context.js.map +0 -1
  618. package/dist/router/intercept-resolution.d.ts +0 -66
  619. package/dist/router/intercept-resolution.d.ts.map +0 -1
  620. package/dist/router/intercept-resolution.js +0 -246
  621. package/dist/router/intercept-resolution.js.map +0 -1
  622. package/dist/router/loader-resolution.d.ts +0 -64
  623. package/dist/router/loader-resolution.d.ts.map +0 -1
  624. package/dist/router/loader-resolution.js +0 -284
  625. package/dist/router/loader-resolution.js.map +0 -1
  626. package/dist/router/logging.d.ts +0 -15
  627. package/dist/router/logging.d.ts.map +0 -1
  628. package/dist/router/logging.js +0 -99
  629. package/dist/router/logging.js.map +0 -1
  630. package/dist/router/manifest.d.ts +0 -22
  631. package/dist/router/manifest.d.ts.map +0 -1
  632. package/dist/router/manifest.js +0 -181
  633. package/dist/router/manifest.js.map +0 -1
  634. package/dist/router/match-api.d.ts +0 -35
  635. package/dist/router/match-api.d.ts.map +0 -1
  636. package/dist/router/match-api.js +0 -406
  637. package/dist/router/match-api.js.map +0 -1
  638. package/dist/router/match-context.d.ts +0 -206
  639. package/dist/router/match-context.d.ts.map +0 -1
  640. package/dist/router/match-context.js +0 -17
  641. package/dist/router/match-context.js.map +0 -1
  642. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  643. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  644. package/dist/router/match-middleware/background-revalidation.js +0 -75
  645. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  646. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  647. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  648. package/dist/router/match-middleware/cache-lookup.js +0 -257
  649. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  650. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  651. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  652. package/dist/router/match-middleware/cache-store.js +0 -108
  653. package/dist/router/match-middleware/cache-store.js.map +0 -1
  654. package/dist/router/match-middleware/index.d.ts +0 -81
  655. package/dist/router/match-middleware/index.d.ts.map +0 -1
  656. package/dist/router/match-middleware/index.js +0 -80
  657. package/dist/router/match-middleware/index.js.map +0 -1
  658. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  659. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  660. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  661. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  662. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  663. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  664. package/dist/router/match-middleware/segment-resolution.js +0 -53
  665. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  666. package/dist/router/match-pipelines.d.ts +0 -147
  667. package/dist/router/match-pipelines.d.ts.map +0 -1
  668. package/dist/router/match-pipelines.js +0 -82
  669. package/dist/router/match-pipelines.js.map +0 -1
  670. package/dist/router/match-result.d.ts +0 -126
  671. package/dist/router/match-result.d.ts.map +0 -1
  672. package/dist/router/match-result.js +0 -93
  673. package/dist/router/match-result.js.map +0 -1
  674. package/dist/router/metrics.d.ts +0 -20
  675. package/dist/router/metrics.d.ts.map +0 -1
  676. package/dist/router/metrics.js +0 -47
  677. package/dist/router/metrics.js.map +0 -1
  678. package/dist/router/middleware.d.ts +0 -249
  679. package/dist/router/middleware.d.ts.map +0 -1
  680. package/dist/router/middleware.js +0 -434
  681. package/dist/router/middleware.js.map +0 -1
  682. package/dist/router/middleware.test.d.ts +0 -2
  683. package/dist/router/middleware.test.d.ts.map +0 -1
  684. package/dist/router/middleware.test.js +0 -816
  685. package/dist/router/middleware.test.js.map +0 -1
  686. package/dist/router/pattern-matching.d.ts +0 -149
  687. package/dist/router/pattern-matching.d.ts.map +0 -1
  688. package/dist/router/pattern-matching.js +0 -349
  689. package/dist/router/pattern-matching.js.map +0 -1
  690. package/dist/router/revalidation.d.ts +0 -44
  691. package/dist/router/revalidation.d.ts.map +0 -1
  692. package/dist/router/revalidation.js +0 -147
  693. package/dist/router/revalidation.js.map +0 -1
  694. package/dist/router/router-context.d.ts +0 -135
  695. package/dist/router/router-context.d.ts.map +0 -1
  696. package/dist/router/router-context.js +0 -36
  697. package/dist/router/router-context.js.map +0 -1
  698. package/dist/router/segment-resolution.d.ts +0 -127
  699. package/dist/router/segment-resolution.d.ts.map +0 -1
  700. package/dist/router/segment-resolution.js +0 -919
  701. package/dist/router/segment-resolution.js.map +0 -1
  702. package/dist/router/trie-matching.d.ts +0 -40
  703. package/dist/router/trie-matching.d.ts.map +0 -1
  704. package/dist/router/trie-matching.js +0 -127
  705. package/dist/router/trie-matching.js.map +0 -1
  706. package/dist/router/types.d.ts +0 -136
  707. package/dist/router/types.d.ts.map +0 -1
  708. package/dist/router/types.js +0 -7
  709. package/dist/router/types.js.map +0 -1
  710. package/dist/router.d.ts +0 -753
  711. package/dist/router.d.ts.map +0 -1
  712. package/dist/router.gen.d.ts +0 -6
  713. package/dist/router.gen.d.ts.map +0 -1
  714. package/dist/router.gen.js +0 -6
  715. package/dist/router.gen.js.map +0 -1
  716. package/dist/router.js +0 -1304
  717. package/dist/router.js.map +0 -1
  718. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  719. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  720. package/dist/rsc/__tests__/helpers.test.js +0 -140
  721. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  722. package/dist/rsc/handler.d.ts +0 -45
  723. package/dist/rsc/handler.d.ts.map +0 -1
  724. package/dist/rsc/handler.js +0 -1172
  725. package/dist/rsc/handler.js.map +0 -1
  726. package/dist/rsc/helpers.d.ts +0 -16
  727. package/dist/rsc/helpers.d.ts.map +0 -1
  728. package/dist/rsc/helpers.js +0 -55
  729. package/dist/rsc/helpers.js.map +0 -1
  730. package/dist/rsc/index.d.ts +0 -22
  731. package/dist/rsc/index.d.ts.map +0 -1
  732. package/dist/rsc/index.js +0 -23
  733. package/dist/rsc/index.js.map +0 -1
  734. package/dist/rsc/nonce.d.ts +0 -9
  735. package/dist/rsc/nonce.d.ts.map +0 -1
  736. package/dist/rsc/nonce.js +0 -18
  737. package/dist/rsc/nonce.js.map +0 -1
  738. package/dist/rsc/types.d.ts +0 -206
  739. package/dist/rsc/types.d.ts.map +0 -1
  740. package/dist/rsc/types.js +0 -8
  741. package/dist/rsc/types.js.map +0 -1
  742. package/dist/search-params.d.ts +0 -103
  743. package/dist/search-params.d.ts.map +0 -1
  744. package/dist/search-params.js +0 -74
  745. package/dist/search-params.js.map +0 -1
  746. package/dist/segment-system.d.ts +0 -75
  747. package/dist/segment-system.d.ts.map +0 -1
  748. package/dist/segment-system.js +0 -336
  749. package/dist/segment-system.js.map +0 -1
  750. package/dist/server/context.d.ts +0 -245
  751. package/dist/server/context.d.ts.map +0 -1
  752. package/dist/server/context.js +0 -197
  753. package/dist/server/context.js.map +0 -1
  754. package/dist/server/fetchable-loader-store.d.ts +0 -18
  755. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  756. package/dist/server/fetchable-loader-store.js +0 -18
  757. package/dist/server/fetchable-loader-store.js.map +0 -1
  758. package/dist/server/handle-store.d.ts +0 -85
  759. package/dist/server/handle-store.d.ts.map +0 -1
  760. package/dist/server/handle-store.js +0 -142
  761. package/dist/server/handle-store.js.map +0 -1
  762. package/dist/server/loader-registry.d.ts +0 -55
  763. package/dist/server/loader-registry.d.ts.map +0 -1
  764. package/dist/server/loader-registry.js +0 -132
  765. package/dist/server/loader-registry.js.map +0 -1
  766. package/dist/server/request-context.d.ts +0 -226
  767. package/dist/server/request-context.d.ts.map +0 -1
  768. package/dist/server/request-context.js +0 -290
  769. package/dist/server/request-context.js.map +0 -1
  770. package/dist/server/root-layout.d.ts +0 -4
  771. package/dist/server/root-layout.d.ts.map +0 -1
  772. package/dist/server/root-layout.js +0 -5
  773. package/dist/server/root-layout.js.map +0 -1
  774. package/dist/server.d.ts +0 -15
  775. package/dist/server.d.ts.map +0 -1
  776. package/dist/server.js +0 -20
  777. package/dist/server.js.map +0 -1
  778. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  779. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  780. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  781. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  782. package/dist/ssr/index.d.ts +0 -98
  783. package/dist/ssr/index.d.ts.map +0 -1
  784. package/dist/ssr/index.js +0 -158
  785. package/dist/ssr/index.js.map +0 -1
  786. package/dist/static-handler.d.ts +0 -50
  787. package/dist/static-handler.d.ts.map +0 -1
  788. package/dist/static-handler.gen.d.ts +0 -5
  789. package/dist/static-handler.gen.d.ts.map +0 -1
  790. package/dist/static-handler.gen.js +0 -5
  791. package/dist/static-handler.gen.js.map +0 -1
  792. package/dist/static-handler.js +0 -29
  793. package/dist/static-handler.js.map +0 -1
  794. package/dist/theme/ThemeProvider.d.ts +0 -20
  795. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  796. package/dist/theme/ThemeProvider.js +0 -240
  797. package/dist/theme/ThemeProvider.js.map +0 -1
  798. package/dist/theme/ThemeScript.d.ts +0 -48
  799. package/dist/theme/ThemeScript.d.ts.map +0 -1
  800. package/dist/theme/ThemeScript.js +0 -13
  801. package/dist/theme/ThemeScript.js.map +0 -1
  802. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  803. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  804. package/dist/theme/__tests__/theme.test.js +0 -103
  805. package/dist/theme/__tests__/theme.test.js.map +0 -1
  806. package/dist/theme/constants.d.ts +0 -29
  807. package/dist/theme/constants.d.ts.map +0 -1
  808. package/dist/theme/constants.js +0 -48
  809. package/dist/theme/constants.js.map +0 -1
  810. package/dist/theme/index.d.ts +0 -31
  811. package/dist/theme/index.d.ts.map +0 -1
  812. package/dist/theme/index.js +0 -36
  813. package/dist/theme/index.js.map +0 -1
  814. package/dist/theme/theme-context.d.ts +0 -40
  815. package/dist/theme/theme-context.d.ts.map +0 -1
  816. package/dist/theme/theme-context.js +0 -60
  817. package/dist/theme/theme-context.js.map +0 -1
  818. package/dist/theme/theme-script.d.ts +0 -27
  819. package/dist/theme/theme-script.d.ts.map +0 -1
  820. package/dist/theme/theme-script.js +0 -147
  821. package/dist/theme/theme-script.js.map +0 -1
  822. package/dist/theme/types.d.ts +0 -163
  823. package/dist/theme/types.d.ts.map +0 -1
  824. package/dist/theme/types.js +0 -11
  825. package/dist/theme/types.js.map +0 -1
  826. package/dist/theme/use-theme.d.ts +0 -12
  827. package/dist/theme/use-theme.d.ts.map +0 -1
  828. package/dist/theme/use-theme.js +0 -40
  829. package/dist/theme/use-theme.js.map +0 -1
  830. package/dist/types.d.ts +0 -1479
  831. package/dist/types.d.ts.map +0 -1
  832. package/dist/types.js +0 -10
  833. package/dist/types.js.map +0 -1
  834. package/dist/urls.d.ts +0 -441
  835. package/dist/urls.d.ts.map +0 -1
  836. package/dist/urls.gen.d.ts +0 -8
  837. package/dist/urls.gen.d.ts.map +0 -1
  838. package/dist/urls.gen.js +0 -8
  839. package/dist/urls.gen.js.map +0 -1
  840. package/dist/urls.js +0 -443
  841. package/dist/urls.js.map +0 -1
  842. package/dist/use-loader.d.ts +0 -127
  843. package/dist/use-loader.d.ts.map +0 -1
  844. package/dist/use-loader.js +0 -237
  845. package/dist/use-loader.js.map +0 -1
  846. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  847. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  848. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  849. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  850. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  851. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  852. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  853. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  854. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  855. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  856. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  857. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  858. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  859. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  860. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  861. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  862. package/dist/vite/ast-handler-extract.d.ts +0 -49
  863. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  864. package/dist/vite/ast-handler-extract.js +0 -249
  865. package/dist/vite/ast-handler-extract.js.map +0 -1
  866. package/dist/vite/expose-action-id.d.ts +0 -19
  867. package/dist/vite/expose-action-id.d.ts.map +0 -1
  868. package/dist/vite/expose-action-id.js +0 -250
  869. package/dist/vite/expose-action-id.js.map +0 -1
  870. package/dist/vite/expose-id-utils.d.ts +0 -69
  871. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  872. package/dist/vite/expose-id-utils.js +0 -289
  873. package/dist/vite/expose-id-utils.js.map +0 -1
  874. package/dist/vite/expose-internal-ids.d.ts +0 -22
  875. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  876. package/dist/vite/expose-internal-ids.js +0 -886
  877. package/dist/vite/expose-internal-ids.js.map +0 -1
  878. package/dist/vite/index.d.ts +0 -149
  879. package/dist/vite/index.d.ts.map +0 -1
  880. package/dist/vite/index.js.map +0 -1
  881. package/dist/vite/index.named-routes.gen.ts +0 -103
  882. package/dist/vite/package-resolution.d.ts +0 -43
  883. package/dist/vite/package-resolution.d.ts.map +0 -1
  884. package/dist/vite/package-resolution.js +0 -112
  885. package/dist/vite/package-resolution.js.map +0 -1
  886. package/dist/vite/virtual-entries.d.ts +0 -25
  887. package/dist/vite/virtual-entries.d.ts.map +0 -1
  888. package/dist/vite/virtual-entries.js +0 -110
  889. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1,627 +0,0 @@
1
- import { describe, it, expect, vi } from "vitest";
2
- import { createElement } from "react";
3
- // Sentinel components for identification in the element tree
4
- function MockOutletProvider(props) {
5
- return props.children;
6
- }
7
- function MockLoaderBoundary(props) {
8
- return props.children;
9
- }
10
- function MockRouteContentWrapper(props) {
11
- return null;
12
- }
13
- function MockMountContextProvider(props) {
14
- return props.children;
15
- }
16
- function MockRootErrorBoundary(props) {
17
- return props.children;
18
- }
19
- vi.mock("../client.js", () => ({
20
- OutletProvider: MockOutletProvider,
21
- }));
22
- vi.mock("../browser/react/mount-context.js", () => ({
23
- MountContextProvider: MockMountContextProvider,
24
- }));
25
- vi.mock("../route-content-wrapper.js", () => ({
26
- RouteContentWrapper: MockRouteContentWrapper,
27
- LoaderBoundary: MockLoaderBoundary,
28
- }));
29
- vi.mock("../root-error-boundary.js", () => ({
30
- RootErrorBoundary: MockRootErrorBoundary,
31
- }));
32
- import { renderSegments } from "../segment-system";
33
- // Helper to create a minimal segment
34
- function seg(overrides) {
35
- return {
36
- namespace: "",
37
- index: 0,
38
- component: createElement("div", null, `component-${overrides.id}`),
39
- ...overrides,
40
- };
41
- }
42
- function toTreeNode(node) {
43
- if (!node || typeof node !== "object")
44
- return null;
45
- const el = node;
46
- if (!el.type)
47
- return null;
48
- const typeName = typeof el.type === "string"
49
- ? el.type
50
- : el.type.name || "Anonymous";
51
- const children = [];
52
- // Walk both `children` and `content` props since layouts pass inner
53
- // content via the `content` prop to OutletProvider
54
- for (const prop of ["children", "content"]) {
55
- const val = el.props?.[prop];
56
- if (!val)
57
- continue;
58
- if (Array.isArray(val)) {
59
- for (const child of val) {
60
- const n = toTreeNode(child);
61
- if (n)
62
- children.push(n);
63
- }
64
- }
65
- else {
66
- const n = toTreeNode(val);
67
- if (n)
68
- children.push(n);
69
- }
70
- }
71
- return { type: el.type, typeName, props: el.props || {}, children };
72
- }
73
- // Find all nodes matching a component type in the tree
74
- function findAll(tree, fn) {
75
- if (!tree)
76
- return [];
77
- const results = [];
78
- if (tree.type === fn)
79
- results.push(tree);
80
- for (const child of tree.children) {
81
- results.push(...findAll(child, fn));
82
- }
83
- return results;
84
- }
85
- // Find first node matching a component type
86
- function findFirst(tree, fn) {
87
- if (!tree)
88
- return null;
89
- if (tree.type === fn)
90
- return tree;
91
- for (const child of tree.children) {
92
- const found = findFirst(child, fn);
93
- if (found)
94
- return found;
95
- }
96
- return null;
97
- }
98
- // Collect all nodes of a type in order (depth-first)
99
- function collectByType(tree, fn) {
100
- return findAll(tree, fn);
101
- }
102
- describe("segment-system", () => {
103
- describe("renderSegments", () => {
104
- describe("basic tree structure", () => {
105
- it("renders a single route segment with OutletProvider", async () => {
106
- const segments = [
107
- seg({ id: "R0", type: "route" }),
108
- ];
109
- const result = await renderSegments(segments);
110
- const tree = toTreeNode(result);
111
- // Root is RootErrorBoundary
112
- expect(tree.type).toBe(MockRootErrorBoundary);
113
- // Inside is an OutletProvider for the route
114
- const outlets = collectByType(tree, MockOutletProvider);
115
- expect(outlets).toHaveLength(1);
116
- expect(outlets[0].props.segment.id).toBe("R0");
117
- expect(outlets[0].props.content).toBeNull(); // route has no outlet content
118
- });
119
- it("nests layout around route (layout receives route as outlet content)", async () => {
120
- const segments = [
121
- seg({ id: "L0", type: "layout" }),
122
- seg({ id: "L0R0", type: "route" }),
123
- ];
124
- const result = await renderSegments(segments);
125
- const tree = toTreeNode(result);
126
- const outlets = collectByType(tree, MockOutletProvider);
127
- // Two OutletProviders
128
- expect(outlets).toHaveLength(2);
129
- // Outer (layout) wraps inner (route)
130
- // The outermost outlet should be the layout
131
- const outerOutlet = outlets[0];
132
- expect(outerOutlet.props.segment.id).toBe("L0");
133
- // Layout's content prop is the route's OutletProvider
134
- expect(outerOutlet.props.content).not.toBeNull();
135
- });
136
- it("nests multiple layouts (root -> inner -> route)", async () => {
137
- const segments = [
138
- seg({ id: "L0", type: "layout" }),
139
- seg({ id: "L0L0", type: "layout" }),
140
- seg({ id: "L0L0R0", type: "route" }),
141
- ];
142
- const result = await renderSegments(segments);
143
- const tree = toTreeNode(result);
144
- const outlets = collectByType(tree, MockOutletProvider);
145
- expect(outlets).toHaveLength(3);
146
- // Outermost is root layout L0
147
- expect(outlets[0].props.segment.id).toBe("L0");
148
- });
149
- it("always wraps with RootErrorBoundary", async () => {
150
- const segments = [
151
- seg({ id: "R0", type: "route" }),
152
- ];
153
- const result = await renderSegments(segments);
154
- const tree = toTreeNode(result);
155
- expect(tree.type).toBe(MockRootErrorBoundary);
156
- });
157
- });
158
- describe("tree structure based on loading property", () => {
159
- it("uses OutletProvider directly when loading is undefined", async () => {
160
- const segments = [
161
- seg({ id: "R0", type: "route", loading: undefined }),
162
- ];
163
- const result = await renderSegments(segments);
164
- const tree = toTreeNode(result);
165
- expect(collectByType(tree, MockOutletProvider)).toHaveLength(1);
166
- expect(collectByType(tree, MockLoaderBoundary)).toHaveLength(0);
167
- expect(collectByType(tree, MockRouteContentWrapper)).toHaveLength(0);
168
- });
169
- it("uses OutletProvider directly when loading is null", async () => {
170
- const segments = [
171
- seg({ id: "R0", type: "route", loading: null }),
172
- ];
173
- const result = await renderSegments(segments);
174
- const tree = toTreeNode(result);
175
- expect(collectByType(tree, MockOutletProvider)).toHaveLength(1);
176
- expect(collectByType(tree, MockLoaderBoundary)).toHaveLength(0);
177
- });
178
- it("uses LoaderBoundary when loading is false (defined but falsy)", async () => {
179
- const segments = [
180
- seg({ id: "R0", type: "route", loading: false }),
181
- ];
182
- const result = await renderSegments(segments);
183
- const tree = toTreeNode(result);
184
- // loading is false: not null, not undefined, so enters LoaderBoundary path
185
- expect(collectByType(tree, MockLoaderBoundary)).toHaveLength(1);
186
- });
187
- it("uses LoaderBoundary + RouteContentWrapper when loading is a ReactNode", async () => {
188
- const loadingSkeleton = createElement("div", null, "Loading...");
189
- const segments = [
190
- seg({ id: "R0", type: "route", loading: loadingSkeleton }),
191
- ];
192
- const result = await renderSegments(segments);
193
- const tree = toTreeNode(result);
194
- expect(collectByType(tree, MockLoaderBoundary)).toHaveLength(1);
195
- // RouteContentWrapper used as the children of LoaderBoundary
196
- expect(collectByType(tree, MockRouteContentWrapper)).toHaveLength(1);
197
- });
198
- it("uses OutletProvider with awaited data when loaders exist but no loading", async () => {
199
- const segments = [
200
- seg({ id: "R0", type: "route" }),
201
- seg({
202
- id: "R0D0.data",
203
- type: "loader",
204
- loaderId: "my-loader",
205
- loaderData: { value: 42 },
206
- }),
207
- ];
208
- const result = await renderSegments(segments);
209
- const tree = toTreeNode(result);
210
- // No LoaderBoundary because loading is undefined
211
- expect(collectByType(tree, MockLoaderBoundary)).toHaveLength(0);
212
- // Uses OutletProvider with loaderData injected
213
- const outlets = collectByType(tree, MockOutletProvider);
214
- expect(outlets).toHaveLength(1);
215
- expect(outlets[0].props.loaderData).toEqual({ "my-loader": { value: 42 } });
216
- });
217
- });
218
- describe("key generation", () => {
219
- it("uses segment ID as key when no params", async () => {
220
- const segments = [
221
- seg({ id: "R0", type: "route" }),
222
- ];
223
- const result = await renderSegments(segments);
224
- const tree = toTreeNode(result);
225
- const outlet = findFirst(tree, MockOutletProvider);
226
- // Key for route without params is just the ID
227
- expect(result.props.children.key).toBeDefined();
228
- });
229
- it("includes sorted params in key for route segments", async () => {
230
- const segments = [
231
- seg({
232
- id: "R0",
233
- type: "route",
234
- params: { slug: "hello", category: "tech" },
235
- }),
236
- ];
237
- const result = await renderSegments(segments);
238
- const tree = toTreeNode(result);
239
- const outlets = collectByType(tree, MockOutletProvider);
240
- // Params are sorted alphabetically in key
241
- expect(outlets[0].props.segment.params).toEqual({
242
- slug: "hello",
243
- category: "tech",
244
- });
245
- });
246
- it("excludes params from key for non-belongsToRoute layouts", async () => {
247
- // Layout that is shared (not belongsToRoute) should use just ID as key
248
- const segments = [
249
- seg({
250
- id: "L0",
251
- type: "layout",
252
- belongsToRoute: false,
253
- params: { slug: "hello" },
254
- }),
255
- seg({ id: "L0R0", type: "route" }),
256
- ];
257
- // Should not throw - params are excluded from key for shared layouts
258
- await renderSegments(segments);
259
- });
260
- });
261
- describe("parallel segment grouping", () => {
262
- it("attaches parallel segments to correct parent by ID prefix", async () => {
263
- const segments = [
264
- seg({ id: "L0", type: "layout" }),
265
- seg({ id: "L0R0", type: "route" }),
266
- seg({
267
- id: "L0.@sidebar",
268
- type: "parallel",
269
- slot: "@sidebar",
270
- }),
271
- ];
272
- const result = await renderSegments(segments);
273
- const tree = toTreeNode(result);
274
- const outlets = collectByType(tree, MockOutletProvider);
275
- // Layout L0 should have the parallel segment
276
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
277
- expect(layoutOutlet.props.parallel).toHaveLength(1);
278
- expect(layoutOutlet.props.parallel[0].slot).toBe("@sidebar");
279
- // Route should NOT have parallels
280
- const routeOutlet = outlets.find((o) => o.props.segment.id === "L0R0");
281
- expect(routeOutlet.props.parallel).toEqual([]);
282
- });
283
- it("groups multiple parallels under same parent", async () => {
284
- const segments = [
285
- seg({ id: "L0", type: "layout" }),
286
- seg({ id: "L0R0", type: "route" }),
287
- seg({ id: "L0.@sidebar", type: "parallel", slot: "@sidebar" }),
288
- seg({ id: "L0.@modal", type: "parallel", slot: "@modal" }),
289
- ];
290
- const result = await renderSegments(segments);
291
- const tree = toTreeNode(result);
292
- const outlets = collectByType(tree, MockOutletProvider);
293
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
294
- expect(layoutOutlet.props.parallel).toHaveLength(2);
295
- expect(layoutOutlet.props.parallel.map((p) => p.slot).sort()).toEqual(["@modal", "@sidebar"]);
296
- });
297
- });
298
- describe("loader segment grouping", () => {
299
- it("groups loader segments by parent ID and passes data to OutletProvider", async () => {
300
- const segments = [
301
- seg({ id: "L0", type: "layout" }),
302
- seg({ id: "L0R0", type: "route" }),
303
- seg({
304
- id: "L0D0.products",
305
- type: "loader",
306
- loaderId: "products-loader",
307
- loaderData: { products: ["a", "b"] },
308
- }),
309
- ];
310
- const result = await renderSegments(segments);
311
- const tree = toTreeNode(result);
312
- const outlets = collectByType(tree, MockOutletProvider);
313
- // Layout L0 gets the loader data (parent of "L0D0.products" is "L0")
314
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
315
- expect(layoutOutlet.props.loaderData).toEqual({
316
- "products-loader": { products: ["a", "b"] },
317
- });
318
- });
319
- it("resolves LoaderDataResult success wrapper", async () => {
320
- const segments = [
321
- seg({ id: "R0", type: "route" }),
322
- seg({
323
- id: "R0D0.data",
324
- type: "loader",
325
- loaderId: "my-loader",
326
- loaderData: {
327
- __loaderResult: true,
328
- ok: true,
329
- data: { value: 42 },
330
- },
331
- }),
332
- ];
333
- const result = await renderSegments(segments);
334
- const tree = toTreeNode(result);
335
- const outlets = collectByType(tree, MockOutletProvider);
336
- // Should unwrap LoaderDataResult to get the inner data
337
- expect(outlets[0].props.loaderData).toEqual({ "my-loader": { value: 42 } });
338
- });
339
- it("renders error fallback for LoaderDataResult with error+fallback", async () => {
340
- const errorFallback = createElement("div", null, "Error occurred");
341
- const segments = [
342
- seg({ id: "R0", type: "route" }),
343
- seg({
344
- id: "R0D0.data",
345
- type: "loader",
346
- loaderId: "my-loader",
347
- loaderData: {
348
- __loaderResult: true,
349
- ok: false,
350
- error: { message: "Failed" },
351
- fallback: errorFallback,
352
- },
353
- }),
354
- ];
355
- const result = await renderSegments(segments);
356
- const tree = toTreeNode(result);
357
- const outlets = collectByType(tree, MockOutletProvider);
358
- // The OutletProvider children should be the error fallback
359
- expect(outlets[0].props.children).toBe(errorFallback);
360
- });
361
- it("throws for LoaderDataResult with error but no fallback", async () => {
362
- const segments = [
363
- seg({ id: "R0", type: "route" }),
364
- seg({
365
- id: "R0D0.data",
366
- type: "loader",
367
- loaderId: "my-loader",
368
- loaderData: {
369
- __loaderResult: true,
370
- ok: false,
371
- error: { message: "Loader failed" },
372
- },
373
- }),
374
- ];
375
- await expect(renderSegments(segments)).rejects.toThrow("Loader failed");
376
- });
377
- });
378
- describe("segment ordering", () => {
379
- it("sorts segments by ID length regardless of input order", async () => {
380
- // Provide in wrong order
381
- const segments = [
382
- seg({ id: "L0L0R0", type: "route" }),
383
- seg({ id: "L0", type: "layout" }),
384
- seg({ id: "L0L0", type: "layout" }),
385
- ];
386
- const result = await renderSegments(segments);
387
- const tree = toTreeNode(result);
388
- const outlets = collectByType(tree, MockOutletProvider);
389
- expect(outlets).toHaveLength(3);
390
- // Outermost is root layout (L0)
391
- expect(outlets[0].props.segment.id).toBe("L0");
392
- });
393
- });
394
- describe("isAction behavior", () => {
395
- it("awaits component promises when isAction is true", async () => {
396
- const resolvedComponent = createElement("div", null, "resolved");
397
- const componentPromise = Promise.resolve(resolvedComponent);
398
- const segments = [
399
- seg({ id: "R0", type: "route", component: componentPromise }),
400
- ];
401
- const result = await renderSegments(segments, { isAction: true });
402
- const tree = toTreeNode(result);
403
- const outlets = collectByType(tree, MockOutletProvider);
404
- // Component should be resolved, not wrapped in RouteContentWrapper
405
- expect(outlets).toHaveLength(1);
406
- expect(collectByType(tree, MockRouteContentWrapper)).toHaveLength(0);
407
- });
408
- it("pre-resolves loader promises when isAction is true", async () => {
409
- const loadingSkeleton = createElement("div", null, "Loading...");
410
- const segments = [
411
- seg({ id: "R0", type: "route", loading: loadingSkeleton }),
412
- seg({
413
- id: "R0D0.data",
414
- type: "loader",
415
- loaderId: "test",
416
- loaderData: Promise.resolve({ count: 5 }),
417
- }),
418
- ];
419
- const result = await renderSegments(segments, { isAction: true });
420
- const tree = toTreeNode(result);
421
- const boundaries = collectByType(tree, MockLoaderBoundary);
422
- expect(boundaries).toHaveLength(1);
423
- // When isAction, the promise should be pre-resolved to an array
424
- expect(Array.isArray(boundaries[0].props.loaderDataPromise)).toBe(true);
425
- });
426
- });
427
- describe("forceAwait behavior", () => {
428
- it("pre-resolves loader promises when forceAwait is true", async () => {
429
- const loadingSkeleton = createElement("div", null, "Loading...");
430
- const segments = [
431
- seg({ id: "R0", type: "route", loading: loadingSkeleton }),
432
- seg({
433
- id: "R0D0.data",
434
- type: "loader",
435
- loaderId: "test",
436
- loaderData: Promise.resolve({ count: 5 }),
437
- }),
438
- ];
439
- const result = await renderSegments(segments, { forceAwait: true });
440
- const tree = toTreeNode(result);
441
- const boundaries = collectByType(tree, MockLoaderBoundary);
442
- expect(boundaries).toHaveLength(1);
443
- expect(Array.isArray(boundaries[0].props.loaderDataPromise)).toBe(true);
444
- });
445
- });
446
- describe("intercept segments", () => {
447
- it("injects intercept parallel segments into parent parallel group", async () => {
448
- const segments = [
449
- seg({ id: "L0", type: "layout" }),
450
- seg({ id: "L0R0", type: "route" }),
451
- ];
452
- const interceptSegments = [
453
- seg({
454
- id: "L0.@modal",
455
- type: "parallel",
456
- slot: "@modal",
457
- }),
458
- ];
459
- const result = await renderSegments(segments, { interceptSegments });
460
- const tree = toTreeNode(result);
461
- const outlets = collectByType(tree, MockOutletProvider);
462
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
463
- expect(layoutOutlet.props.parallel).toHaveLength(1);
464
- expect(layoutOutlet.props.parallel[0].slot).toBe("@modal");
465
- });
466
- it("injects intercept loader segments into parent loader group", async () => {
467
- const segments = [
468
- seg({ id: "L0", type: "layout" }),
469
- seg({ id: "L0R0", type: "route" }),
470
- ];
471
- const interceptSegments = [
472
- seg({
473
- id: "L0D0.modal-data",
474
- type: "loader",
475
- loaderId: "modal-loader",
476
- loaderData: { modal: true },
477
- }),
478
- ];
479
- const result = await renderSegments(segments, { interceptSegments });
480
- const tree = toTreeNode(result);
481
- const outlets = collectByType(tree, MockOutletProvider);
482
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
483
- expect(layoutOutlet.props.loaderData).toEqual({
484
- "modal-loader": { modal: true },
485
- });
486
- });
487
- });
488
- describe("rootLayout wrapping", () => {
489
- it("wraps tree with rootLayout when provided", async () => {
490
- const RootLayout = ({ children }) => createElement("div", null, children);
491
- const segments = [
492
- seg({ id: "R0", type: "route" }),
493
- ];
494
- const result = await renderSegments(segments, {
495
- rootLayout: RootLayout,
496
- });
497
- const tree = toTreeNode(result);
498
- // Root should be the RootLayout, not RootErrorBoundary
499
- expect(tree.type).toBe(RootLayout);
500
- // RootErrorBoundary should be inside
501
- const errorBoundary = findFirst(tree, MockRootErrorBoundary);
502
- expect(errorBoundary).not.toBeNull();
503
- });
504
- it("does not wrap with rootLayout when not provided", async () => {
505
- const segments = [
506
- seg({ id: "R0", type: "route" }),
507
- ];
508
- const result = await renderSegments(segments);
509
- const tree = toTreeNode(result);
510
- expect(tree.type).toBe(MockRootErrorBoundary);
511
- });
512
- });
513
- describe("MountContextProvider wrapping", () => {
514
- it("wraps segment with MountContextProvider when mountPath is set", async () => {
515
- const segments = [
516
- seg({ id: "R0", type: "route", mountPath: "/shop" }),
517
- ];
518
- const result = await renderSegments(segments);
519
- const tree = toTreeNode(result);
520
- const mounts = collectByType(tree, MockMountContextProvider);
521
- expect(mounts).toHaveLength(1);
522
- expect(mounts[0].props.value).toBe("/shop");
523
- });
524
- it("does not wrap when mountPath is undefined", async () => {
525
- const segments = [
526
- seg({ id: "R0", type: "route" }),
527
- ];
528
- const result = await renderSegments(segments);
529
- const tree = toTreeNode(result);
530
- const mounts = collectByType(tree, MockMountContextProvider);
531
- expect(mounts).toHaveLength(0);
532
- });
533
- it("wraps all segment types with MountContextProvider", async () => {
534
- const segments = [
535
- seg({ id: "L0", type: "layout", mountPath: "/shop" }),
536
- seg({ id: "L0R0", type: "route", mountPath: "/shop" }),
537
- ];
538
- const result = await renderSegments(segments);
539
- const tree = toTreeNode(result);
540
- const mounts = collectByType(tree, MockMountContextProvider);
541
- expect(mounts).toHaveLength(2);
542
- });
543
- });
544
- describe("error and notFound segments", () => {
545
- it("renders error segments in the tree", async () => {
546
- const segments = [
547
- seg({ id: "L0", type: "layout" }),
548
- seg({
549
- id: "L0E0",
550
- type: "error",
551
- component: createElement("div", null, "Error fallback"),
552
- error: {
553
- name: "Error",
554
- message: "Something broke",
555
- segmentId: "R0",
556
- segmentType: "route",
557
- },
558
- }),
559
- ];
560
- const result = await renderSegments(segments);
561
- const tree = toTreeNode(result);
562
- const outlets = collectByType(tree, MockOutletProvider);
563
- // Should have outlets for both layout and error segment
564
- expect(outlets).toHaveLength(2);
565
- const errorOutlet = outlets.find((o) => o.props.segment.type === "error");
566
- expect(errorOutlet).toBeDefined();
567
- });
568
- it("renders notFound segments in the tree", async () => {
569
- const segments = [
570
- seg({ id: "L0", type: "layout" }),
571
- seg({
572
- id: "L0NF0",
573
- type: "notFound",
574
- component: createElement("div", null, "Not found"),
575
- notFoundInfo: {
576
- message: "Page not found",
577
- segmentId: "R0",
578
- segmentType: "route",
579
- },
580
- }),
581
- ];
582
- const result = await renderSegments(segments);
583
- const tree = toTreeNode(result);
584
- const outlets = collectByType(tree, MockOutletProvider);
585
- expect(outlets).toHaveLength(2);
586
- const notFoundOutlet = outlets.find((o) => o.props.segment.type === "notFound");
587
- expect(notFoundOutlet).toBeDefined();
588
- });
589
- });
590
- describe("empty segments", () => {
591
- it("returns RootErrorBoundary wrapping null for empty segments", async () => {
592
- const result = await renderSegments([]);
593
- const tree = toTreeNode(result);
594
- expect(tree.type).toBe(MockRootErrorBoundary);
595
- });
596
- });
597
- describe("parallel segment loaders", () => {
598
- it("includes loaders from parallel segments in parent loader list", async () => {
599
- const segments = [
600
- seg({ id: "L0", type: "layout" }),
601
- seg({ id: "L0R0", type: "route" }),
602
- seg({
603
- id: "L0.@sidebar",
604
- type: "parallel",
605
- slot: "@sidebar",
606
- }),
607
- seg({
608
- id: "L0.@sidebarD0.data",
609
- type: "loader",
610
- loaderId: "sidebar-loader",
611
- loaderData: { sidebar: true },
612
- }),
613
- ];
614
- const result = await renderSegments(segments);
615
- const tree = toTreeNode(result);
616
- const outlets = collectByType(tree, MockOutletProvider);
617
- // The layout should have sidebar loader data accessible
618
- // (loaders from parallels are merged into parent's loaders)
619
- const layoutOutlet = outlets.find((o) => o.props.segment.id === "L0");
620
- // The sidebar loader is grouped under the parallel "L0.@sidebar"
621
- // which is a child of L0, so it gets included in L0's loaders
622
- expect(layoutOutlet.props.loaderData).toBeDefined();
623
- });
624
- });
625
- });
626
- });
627
- //# sourceMappingURL=segment-system.test.js.map