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

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