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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (890) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +2 -1
  3. package/dist/vite/index.js +507 -192
  4. package/package.json +3 -3
  5. package/skills/handler-use/SKILL.md +362 -0
  6. package/skills/intercept/SKILL.md +20 -0
  7. package/skills/layout/SKILL.md +22 -0
  8. package/skills/middleware/SKILL.md +32 -3
  9. package/skills/migrate-nextjs/SKILL.md +560 -0
  10. package/skills/migrate-react-router/SKILL.md +764 -0
  11. package/skills/parallel/SKILL.md +59 -0
  12. package/skills/prerender/SKILL.md +110 -68
  13. package/skills/rango/SKILL.md +24 -22
  14. package/skills/route/SKILL.md +24 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/navigation-bridge.ts +7 -1
  17. package/src/browser/navigation-client.ts +34 -6
  18. package/src/browser/partial-update.ts +5 -0
  19. package/src/browser/prefetch/cache.ts +16 -6
  20. package/src/browser/prefetch/fetch.ts +60 -4
  21. package/src/browser/react/Link.tsx +25 -2
  22. package/src/browser/react/use-handle.ts +9 -58
  23. package/src/browser/scroll-restoration.ts +10 -8
  24. package/src/browser/segment-reconciler.ts +26 -0
  25. package/src/build/generate-manifest.ts +3 -6
  26. package/src/build/route-trie.ts +50 -24
  27. package/src/build/route-types/scan-filter.ts +8 -1
  28. package/src/client.tsx +2 -56
  29. package/src/handle.ts +40 -0
  30. package/src/index.rsc.ts +3 -1
  31. package/src/index.ts +46 -6
  32. package/src/prerender/store.ts +5 -4
  33. package/src/prerender.ts +138 -77
  34. package/src/reverse.ts +25 -1
  35. package/src/route-definition/dsl-helpers.ts +194 -32
  36. package/src/route-definition/helpers-types.ts +61 -14
  37. package/src/route-definition/index.ts +3 -0
  38. package/src/route-definition/resolve-handler-use.ts +149 -0
  39. package/src/route-types.ts +11 -0
  40. package/src/router/content-negotiation.ts +100 -1
  41. package/src/router/handler-context.ts +46 -6
  42. package/src/router/loader-resolution.ts +147 -19
  43. package/src/router/match-api.ts +124 -189
  44. package/src/router/match-middleware/cache-lookup.ts +24 -7
  45. package/src/router/match-middleware/segment-resolution.ts +53 -0
  46. package/src/router/match-result.ts +82 -4
  47. package/src/router/navigation-snapshot.ts +182 -0
  48. package/src/router/prerender-match.ts +108 -8
  49. package/src/router/preview-match.ts +30 -102
  50. package/src/router/request-classification.ts +310 -0
  51. package/src/router/route-snapshot.ts +245 -0
  52. package/src/router/router-interfaces.ts +11 -0
  53. package/src/router/segment-resolution/fresh.ts +59 -2
  54. package/src/router/segment-resolution/revalidation.ts +79 -6
  55. package/src/router.ts +13 -1
  56. package/src/rsc/handler.ts +468 -377
  57. package/src/rsc/loader-fetch.ts +23 -3
  58. package/src/rsc/progressive-enhancement.ts +10 -2
  59. package/src/rsc/rsc-rendering.ts +5 -1
  60. package/src/rsc/server-action.ts +6 -0
  61. package/src/rsc/ssr-setup.ts +1 -1
  62. package/src/rsc/types.ts +1 -0
  63. package/src/segment-system.tsx +45 -11
  64. package/src/server/context.ts +14 -1
  65. package/src/server/handle-store.ts +19 -0
  66. package/src/server/request-context.ts +125 -3
  67. package/src/static-handler.ts +18 -6
  68. package/src/types/handler-context.ts +12 -2
  69. package/src/types/loader-types.ts +32 -4
  70. package/src/types/route-entry.ts +1 -1
  71. package/src/types/segments.ts +4 -0
  72. package/src/urls/path-helper-types.ts +39 -6
  73. package/src/urls/path-helper.ts +47 -12
  74. package/src/urls/response-types.ts +16 -6
  75. package/src/use-loader.tsx +77 -5
  76. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  77. package/src/vite/discovery/prerender-collection.ts +128 -74
  78. package/src/vite/discovery/state.ts +13 -4
  79. package/src/vite/index.ts +4 -0
  80. package/src/vite/plugin-types.ts +60 -5
  81. package/src/vite/plugins/expose-id-utils.ts +12 -0
  82. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  83. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  84. package/src/vite/plugins/refresh-cmd.ts +88 -26
  85. package/src/vite/rango.ts +2 -1
  86. package/src/vite/router-discovery.ts +178 -37
  87. package/src/vite/utils/prerender-utils.ts +37 -5
  88. package/dist/__internal.d.ts +0 -83
  89. package/dist/__internal.d.ts.map +0 -1
  90. package/dist/__internal.js +0 -19
  91. package/dist/__internal.js.map +0 -1
  92. package/dist/__mocks__/version.d.ts +0 -7
  93. package/dist/__mocks__/version.d.ts.map +0 -1
  94. package/dist/__mocks__/version.js +0 -7
  95. package/dist/__mocks__/version.js.map +0 -1
  96. package/dist/__tests__/client-href.test.d.ts +0 -2
  97. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  98. package/dist/__tests__/client-href.test.js +0 -74
  99. package/dist/__tests__/client-href.test.js.map +0 -1
  100. package/dist/__tests__/component-utils.test.d.ts +0 -2
  101. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  102. package/dist/__tests__/component-utils.test.js +0 -51
  103. package/dist/__tests__/component-utils.test.js.map +0 -1
  104. package/dist/__tests__/event-controller.test.d.ts +0 -2
  105. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  106. package/dist/__tests__/event-controller.test.js +0 -538
  107. package/dist/__tests__/event-controller.test.js.map +0 -1
  108. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  109. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  110. package/dist/__tests__/helpers/route-tree.js +0 -374
  111. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  112. package/dist/__tests__/match-result.test.d.ts +0 -2
  113. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  114. package/dist/__tests__/match-result.test.js +0 -154
  115. package/dist/__tests__/match-result.test.js.map +0 -1
  116. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  117. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  118. package/dist/__tests__/navigation-store.test.js +0 -440
  119. package/dist/__tests__/navigation-store.test.js.map +0 -1
  120. package/dist/__tests__/partial-update.test.d.ts +0 -2
  121. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  122. package/dist/__tests__/partial-update.test.js +0 -1009
  123. package/dist/__tests__/partial-update.test.js.map +0 -1
  124. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  125. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  126. package/dist/__tests__/reverse-types.test.js +0 -656
  127. package/dist/__tests__/reverse-types.test.js.map +0 -1
  128. package/dist/__tests__/route-definition.test.d.ts +0 -2
  129. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  130. package/dist/__tests__/route-definition.test.js +0 -55
  131. package/dist/__tests__/route-definition.test.js.map +0 -1
  132. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  133. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  134. package/dist/__tests__/router-helpers.test.js +0 -377
  135. package/dist/__tests__/router-helpers.test.js.map +0 -1
  136. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  137. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  138. package/dist/__tests__/router-integration-2.test.js +0 -426
  139. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  140. package/dist/__tests__/router-integration.test.d.ts +0 -2
  141. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  142. package/dist/__tests__/router-integration.test.js +0 -1051
  143. package/dist/__tests__/router-integration.test.js.map +0 -1
  144. package/dist/__tests__/search-params.test.d.ts +0 -5
  145. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  146. package/dist/__tests__/search-params.test.js +0 -306
  147. package/dist/__tests__/search-params.test.js.map +0 -1
  148. package/dist/__tests__/segment-system.test.d.ts +0 -2
  149. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  150. package/dist/__tests__/segment-system.test.js +0 -627
  151. package/dist/__tests__/segment-system.test.js.map +0 -1
  152. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  153. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  154. package/dist/__tests__/static-handler-types.test.js +0 -63
  155. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  156. package/dist/__tests__/urls.test.d.ts +0 -2
  157. package/dist/__tests__/urls.test.d.ts.map +0 -1
  158. package/dist/__tests__/urls.test.js +0 -421
  159. package/dist/__tests__/urls.test.js.map +0 -1
  160. package/dist/__tests__/use-mount.test.d.ts +0 -2
  161. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  162. package/dist/__tests__/use-mount.test.js +0 -35
  163. package/dist/__tests__/use-mount.test.js.map +0 -1
  164. package/dist/bin/rango.d.ts +0 -2
  165. package/dist/bin/rango.d.ts.map +0 -1
  166. package/dist/bin/rango.js.map +0 -1
  167. package/dist/browser/event-controller.d.ts +0 -191
  168. package/dist/browser/event-controller.d.ts.map +0 -1
  169. package/dist/browser/event-controller.js +0 -559
  170. package/dist/browser/event-controller.js.map +0 -1
  171. package/dist/browser/index.d.ts +0 -2
  172. package/dist/browser/index.d.ts.map +0 -1
  173. package/dist/browser/index.js +0 -14
  174. package/dist/browser/index.js.map +0 -1
  175. package/dist/browser/link-interceptor.d.ts +0 -38
  176. package/dist/browser/link-interceptor.d.ts.map +0 -1
  177. package/dist/browser/link-interceptor.js +0 -99
  178. package/dist/browser/link-interceptor.js.map +0 -1
  179. package/dist/browser/logging.d.ts +0 -10
  180. package/dist/browser/logging.d.ts.map +0 -1
  181. package/dist/browser/logging.js +0 -29
  182. package/dist/browser/logging.js.map +0 -1
  183. package/dist/browser/lru-cache.d.ts +0 -17
  184. package/dist/browser/lru-cache.d.ts.map +0 -1
  185. package/dist/browser/lru-cache.js +0 -50
  186. package/dist/browser/lru-cache.js.map +0 -1
  187. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  188. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  189. package/dist/browser/merge-segment-loaders.js +0 -102
  190. package/dist/browser/merge-segment-loaders.js.map +0 -1
  191. package/dist/browser/navigation-bridge.d.ts +0 -102
  192. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  193. package/dist/browser/navigation-bridge.js +0 -708
  194. package/dist/browser/navigation-bridge.js.map +0 -1
  195. package/dist/browser/navigation-client.d.ts +0 -25
  196. package/dist/browser/navigation-client.d.ts.map +0 -1
  197. package/dist/browser/navigation-client.js +0 -157
  198. package/dist/browser/navigation-client.js.map +0 -1
  199. package/dist/browser/navigation-store.d.ts +0 -101
  200. package/dist/browser/navigation-store.d.ts.map +0 -1
  201. package/dist/browser/navigation-store.js +0 -625
  202. package/dist/browser/navigation-store.js.map +0 -1
  203. package/dist/browser/partial-update.d.ts +0 -75
  204. package/dist/browser/partial-update.d.ts.map +0 -1
  205. package/dist/browser/partial-update.js +0 -426
  206. package/dist/browser/partial-update.js.map +0 -1
  207. package/dist/browser/react/Link.d.ts +0 -86
  208. package/dist/browser/react/Link.d.ts.map +0 -1
  209. package/dist/browser/react/Link.js +0 -128
  210. package/dist/browser/react/Link.js.map +0 -1
  211. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  212. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  213. package/dist/browser/react/NavigationProvider.js +0 -216
  214. package/dist/browser/react/NavigationProvider.js.map +0 -1
  215. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  216. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  217. package/dist/browser/react/ScrollRestoration.js +0 -57
  218. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  219. package/dist/browser/react/context.d.ts +0 -46
  220. package/dist/browser/react/context.d.ts.map +0 -1
  221. package/dist/browser/react/context.js +0 -10
  222. package/dist/browser/react/context.js.map +0 -1
  223. package/dist/browser/react/index.d.ts +0 -11
  224. package/dist/browser/react/index.d.ts.map +0 -1
  225. package/dist/browser/react/index.js +0 -22
  226. package/dist/browser/react/index.js.map +0 -1
  227. package/dist/browser/react/location-state-shared.d.ts +0 -63
  228. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  229. package/dist/browser/react/location-state-shared.js +0 -81
  230. package/dist/browser/react/location-state-shared.js.map +0 -1
  231. package/dist/browser/react/location-state.d.ts +0 -23
  232. package/dist/browser/react/location-state.d.ts.map +0 -1
  233. package/dist/browser/react/location-state.js +0 -29
  234. package/dist/browser/react/location-state.js.map +0 -1
  235. package/dist/browser/react/mount-context.d.ts +0 -24
  236. package/dist/browser/react/mount-context.d.ts.map +0 -1
  237. package/dist/browser/react/mount-context.js +0 -24
  238. package/dist/browser/react/mount-context.js.map +0 -1
  239. package/dist/browser/react/use-action.d.ts +0 -64
  240. package/dist/browser/react/use-action.d.ts.map +0 -1
  241. package/dist/browser/react/use-action.js +0 -134
  242. package/dist/browser/react/use-action.js.map +0 -1
  243. package/dist/browser/react/use-client-cache.d.ts +0 -41
  244. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  245. package/dist/browser/react/use-client-cache.js +0 -39
  246. package/dist/browser/react/use-client-cache.js.map +0 -1
  247. package/dist/browser/react/use-handle.d.ts +0 -31
  248. package/dist/browser/react/use-handle.d.ts.map +0 -1
  249. package/dist/browser/react/use-handle.js +0 -144
  250. package/dist/browser/react/use-handle.js.map +0 -1
  251. package/dist/browser/react/use-href.d.ts +0 -33
  252. package/dist/browser/react/use-href.d.ts.map +0 -1
  253. package/dist/browser/react/use-href.js +0 -39
  254. package/dist/browser/react/use-href.js.map +0 -1
  255. package/dist/browser/react/use-link-status.d.ts +0 -37
  256. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  257. package/dist/browser/react/use-link-status.js +0 -99
  258. package/dist/browser/react/use-link-status.js.map +0 -1
  259. package/dist/browser/react/use-mount.d.ts +0 -25
  260. package/dist/browser/react/use-mount.d.ts.map +0 -1
  261. package/dist/browser/react/use-mount.js +0 -30
  262. package/dist/browser/react/use-mount.js.map +0 -1
  263. package/dist/browser/react/use-navigation.d.ts +0 -27
  264. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  265. package/dist/browser/react/use-navigation.js +0 -87
  266. package/dist/browser/react/use-navigation.js.map +0 -1
  267. package/dist/browser/react/use-segments.d.ts +0 -38
  268. package/dist/browser/react/use-segments.d.ts.map +0 -1
  269. package/dist/browser/react/use-segments.js +0 -130
  270. package/dist/browser/react/use-segments.js.map +0 -1
  271. package/dist/browser/request-controller.d.ts +0 -26
  272. package/dist/browser/request-controller.d.ts.map +0 -1
  273. package/dist/browser/request-controller.js +0 -147
  274. package/dist/browser/request-controller.js.map +0 -1
  275. package/dist/browser/rsc-router.d.ts +0 -129
  276. package/dist/browser/rsc-router.d.ts.map +0 -1
  277. package/dist/browser/rsc-router.js +0 -195
  278. package/dist/browser/rsc-router.js.map +0 -1
  279. package/dist/browser/scroll-restoration.d.ts +0 -93
  280. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  281. package/dist/browser/scroll-restoration.js +0 -321
  282. package/dist/browser/scroll-restoration.js.map +0 -1
  283. package/dist/browser/segment-structure-assert.d.ts +0 -17
  284. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  285. package/dist/browser/segment-structure-assert.js +0 -59
  286. package/dist/browser/segment-structure-assert.js.map +0 -1
  287. package/dist/browser/server-action-bridge.d.ts +0 -26
  288. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  289. package/dist/browser/server-action-bridge.js +0 -668
  290. package/dist/browser/server-action-bridge.js.map +0 -1
  291. package/dist/browser/shallow.d.ts +0 -12
  292. package/dist/browser/shallow.d.ts.map +0 -1
  293. package/dist/browser/shallow.js +0 -34
  294. package/dist/browser/shallow.js.map +0 -1
  295. package/dist/browser/types.d.ts +0 -369
  296. package/dist/browser/types.d.ts.map +0 -1
  297. package/dist/browser/types.js +0 -2
  298. package/dist/browser/types.js.map +0 -1
  299. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  300. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  301. package/dist/build/__tests__/generate-cli.test.js +0 -237
  302. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  303. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  304. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  305. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  306. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  307. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  308. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  309. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  310. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  311. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  312. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  313. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  314. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  315. package/dist/build/generate-manifest.d.ts +0 -81
  316. package/dist/build/generate-manifest.d.ts.map +0 -1
  317. package/dist/build/generate-manifest.js +0 -276
  318. package/dist/build/generate-manifest.js.map +0 -1
  319. package/dist/build/generate-route-types.d.ts +0 -115
  320. package/dist/build/generate-route-types.d.ts.map +0 -1
  321. package/dist/build/generate-route-types.js +0 -740
  322. package/dist/build/generate-route-types.js.map +0 -1
  323. package/dist/build/index.d.ts +0 -21
  324. package/dist/build/index.d.ts.map +0 -1
  325. package/dist/build/index.js +0 -21
  326. package/dist/build/index.js.map +0 -1
  327. package/dist/build/route-trie.d.ts +0 -71
  328. package/dist/build/route-trie.d.ts.map +0 -1
  329. package/dist/build/route-trie.js +0 -175
  330. package/dist/build/route-trie.js.map +0 -1
  331. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  332. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  333. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  334. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  335. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  336. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  337. package/dist/cache/__tests__/document-cache.test.js +0 -345
  338. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  339. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  340. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  341. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  342. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  343. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  344. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  345. package/dist/cache/__tests__/memory-store.test.js +0 -367
  346. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  347. package/dist/cache/cache-scope.d.ts +0 -102
  348. package/dist/cache/cache-scope.d.ts.map +0 -1
  349. package/dist/cache/cache-scope.js +0 -440
  350. package/dist/cache/cache-scope.js.map +0 -1
  351. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  352. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  353. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  354. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  355. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  356. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  357. package/dist/cache/cf/cf-cache-store.js +0 -242
  358. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  359. package/dist/cache/cf/index.d.ts +0 -14
  360. package/dist/cache/cf/index.d.ts.map +0 -1
  361. package/dist/cache/cf/index.js +0 -17
  362. package/dist/cache/cf/index.js.map +0 -1
  363. package/dist/cache/document-cache.d.ts +0 -64
  364. package/dist/cache/document-cache.d.ts.map +0 -1
  365. package/dist/cache/document-cache.js +0 -228
  366. package/dist/cache/document-cache.js.map +0 -1
  367. package/dist/cache/index.d.ts +0 -19
  368. package/dist/cache/index.d.ts.map +0 -1
  369. package/dist/cache/index.js +0 -21
  370. package/dist/cache/index.js.map +0 -1
  371. package/dist/cache/memory-segment-store.d.ts +0 -110
  372. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  373. package/dist/cache/memory-segment-store.js +0 -117
  374. package/dist/cache/memory-segment-store.js.map +0 -1
  375. package/dist/cache/memory-store.d.ts +0 -41
  376. package/dist/cache/memory-store.d.ts.map +0 -1
  377. package/dist/cache/memory-store.js +0 -191
  378. package/dist/cache/memory-store.js.map +0 -1
  379. package/dist/cache/types.d.ts +0 -317
  380. package/dist/cache/types.d.ts.map +0 -1
  381. package/dist/cache/types.js +0 -12
  382. package/dist/cache/types.js.map +0 -1
  383. package/dist/client.d.ts +0 -248
  384. package/dist/client.d.ts.map +0 -1
  385. package/dist/client.js +0 -367
  386. package/dist/client.js.map +0 -1
  387. package/dist/client.rsc.d.ts +0 -26
  388. package/dist/client.rsc.d.ts.map +0 -1
  389. package/dist/client.rsc.js +0 -46
  390. package/dist/client.rsc.js.map +0 -1
  391. package/dist/component-utils.d.ts +0 -36
  392. package/dist/component-utils.d.ts.map +0 -1
  393. package/dist/component-utils.js +0 -61
  394. package/dist/component-utils.js.map +0 -1
  395. package/dist/components/DefaultDocument.d.ts +0 -13
  396. package/dist/components/DefaultDocument.d.ts.map +0 -1
  397. package/dist/components/DefaultDocument.js +0 -15
  398. package/dist/components/DefaultDocument.js.map +0 -1
  399. package/dist/debug.d.ts +0 -58
  400. package/dist/debug.d.ts.map +0 -1
  401. package/dist/debug.js +0 -157
  402. package/dist/debug.js.map +0 -1
  403. package/dist/default-error-boundary.d.ts +0 -11
  404. package/dist/default-error-boundary.d.ts.map +0 -1
  405. package/dist/default-error-boundary.js +0 -45
  406. package/dist/default-error-boundary.js.map +0 -1
  407. package/dist/deps/browser.d.ts +0 -2
  408. package/dist/deps/browser.d.ts.map +0 -1
  409. package/dist/deps/browser.js +0 -3
  410. package/dist/deps/browser.js.map +0 -1
  411. package/dist/deps/html-stream-client.d.ts +0 -2
  412. package/dist/deps/html-stream-client.d.ts.map +0 -1
  413. package/dist/deps/html-stream-client.js +0 -3
  414. package/dist/deps/html-stream-client.js.map +0 -1
  415. package/dist/deps/html-stream-server.d.ts +0 -2
  416. package/dist/deps/html-stream-server.d.ts.map +0 -1
  417. package/dist/deps/html-stream-server.js +0 -3
  418. package/dist/deps/html-stream-server.js.map +0 -1
  419. package/dist/deps/rsc.d.ts +0 -2
  420. package/dist/deps/rsc.d.ts.map +0 -1
  421. package/dist/deps/rsc.js +0 -4
  422. package/dist/deps/rsc.js.map +0 -1
  423. package/dist/deps/ssr.d.ts +0 -2
  424. package/dist/deps/ssr.d.ts.map +0 -1
  425. package/dist/deps/ssr.js +0 -3
  426. package/dist/deps/ssr.js.map +0 -1
  427. package/dist/errors.d.ts +0 -174
  428. package/dist/errors.d.ts.map +0 -1
  429. package/dist/errors.js +0 -241
  430. package/dist/errors.js.map +0 -1
  431. package/dist/handle.d.ts +0 -78
  432. package/dist/handle.d.ts.map +0 -1
  433. package/dist/handle.js +0 -82
  434. package/dist/handle.js.map +0 -1
  435. package/dist/handles/MetaTags.d.ts +0 -14
  436. package/dist/handles/MetaTags.d.ts.map +0 -1
  437. package/dist/handles/MetaTags.js +0 -136
  438. package/dist/handles/MetaTags.js.map +0 -1
  439. package/dist/handles/index.d.ts +0 -6
  440. package/dist/handles/index.d.ts.map +0 -1
  441. package/dist/handles/index.js +0 -6
  442. package/dist/handles/index.js.map +0 -1
  443. package/dist/handles/meta.d.ts +0 -39
  444. package/dist/handles/meta.d.ts.map +0 -1
  445. package/dist/handles/meta.js +0 -202
  446. package/dist/handles/meta.js.map +0 -1
  447. package/dist/host/__tests__/errors.test.d.ts +0 -2
  448. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  449. package/dist/host/__tests__/errors.test.js +0 -76
  450. package/dist/host/__tests__/errors.test.js.map +0 -1
  451. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  452. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  453. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  454. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  455. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  456. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  457. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  458. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  459. package/dist/host/__tests__/router.test.d.ts +0 -2
  460. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  461. package/dist/host/__tests__/router.test.js +0 -241
  462. package/dist/host/__tests__/router.test.js.map +0 -1
  463. package/dist/host/__tests__/testing.test.d.ts +0 -2
  464. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  465. package/dist/host/__tests__/testing.test.js +0 -64
  466. package/dist/host/__tests__/testing.test.js.map +0 -1
  467. package/dist/host/__tests__/utils.test.d.ts +0 -2
  468. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  469. package/dist/host/__tests__/utils.test.js +0 -29
  470. package/dist/host/__tests__/utils.test.js.map +0 -1
  471. package/dist/host/cookie-handler.d.ts +0 -34
  472. package/dist/host/cookie-handler.d.ts.map +0 -1
  473. package/dist/host/cookie-handler.js +0 -124
  474. package/dist/host/cookie-handler.js.map +0 -1
  475. package/dist/host/errors.d.ts +0 -56
  476. package/dist/host/errors.d.ts.map +0 -1
  477. package/dist/host/errors.js +0 -79
  478. package/dist/host/errors.js.map +0 -1
  479. package/dist/host/index.d.ts +0 -29
  480. package/dist/host/index.d.ts.map +0 -1
  481. package/dist/host/index.js +0 -32
  482. package/dist/host/index.js.map +0 -1
  483. package/dist/host/pattern-matcher.d.ts +0 -36
  484. package/dist/host/pattern-matcher.d.ts.map +0 -1
  485. package/dist/host/pattern-matcher.js +0 -172
  486. package/dist/host/pattern-matcher.js.map +0 -1
  487. package/dist/host/router.d.ts +0 -26
  488. package/dist/host/router.d.ts.map +0 -1
  489. package/dist/host/router.js +0 -218
  490. package/dist/host/router.js.map +0 -1
  491. package/dist/host/testing.d.ts +0 -36
  492. package/dist/host/testing.d.ts.map +0 -1
  493. package/dist/host/testing.js +0 -55
  494. package/dist/host/testing.js.map +0 -1
  495. package/dist/host/types.d.ts +0 -115
  496. package/dist/host/types.d.ts.map +0 -1
  497. package/dist/host/types.js +0 -7
  498. package/dist/host/types.js.map +0 -1
  499. package/dist/host/utils.d.ts +0 -21
  500. package/dist/host/utils.d.ts.map +0 -1
  501. package/dist/host/utils.js +0 -23
  502. package/dist/host/utils.js.map +0 -1
  503. package/dist/href-client.d.ts +0 -131
  504. package/dist/href-client.d.ts.map +0 -1
  505. package/dist/href-client.js +0 -64
  506. package/dist/href-client.js.map +0 -1
  507. package/dist/href-context.d.ts +0 -29
  508. package/dist/href-context.d.ts.map +0 -1
  509. package/dist/href-context.js +0 -21
  510. package/dist/href-context.js.map +0 -1
  511. package/dist/index.d.ts +0 -73
  512. package/dist/index.d.ts.map +0 -1
  513. package/dist/index.js +0 -91
  514. package/dist/index.js.map +0 -1
  515. package/dist/index.rsc.d.ts +0 -32
  516. package/dist/index.rsc.d.ts.map +0 -1
  517. package/dist/index.rsc.js +0 -40
  518. package/dist/index.rsc.js.map +0 -1
  519. package/dist/internal-debug.d.ts +0 -2
  520. package/dist/internal-debug.d.ts.map +0 -1
  521. package/dist/internal-debug.js +0 -5
  522. package/dist/internal-debug.js.map +0 -1
  523. package/dist/loader.d.ts +0 -14
  524. package/dist/loader.d.ts.map +0 -1
  525. package/dist/loader.js +0 -20
  526. package/dist/loader.js.map +0 -1
  527. package/dist/loader.rsc.d.ts +0 -19
  528. package/dist/loader.rsc.d.ts.map +0 -1
  529. package/dist/loader.rsc.js +0 -99
  530. package/dist/loader.rsc.js.map +0 -1
  531. package/dist/network-error-thrower.d.ts +0 -17
  532. package/dist/network-error-thrower.d.ts.map +0 -1
  533. package/dist/network-error-thrower.js +0 -14
  534. package/dist/network-error-thrower.js.map +0 -1
  535. package/dist/outlet-context.d.ts +0 -13
  536. package/dist/outlet-context.d.ts.map +0 -1
  537. package/dist/outlet-context.js +0 -3
  538. package/dist/outlet-context.js.map +0 -1
  539. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  540. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  541. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  542. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  543. package/dist/prerender/param-hash.d.ts +0 -16
  544. package/dist/prerender/param-hash.d.ts.map +0 -1
  545. package/dist/prerender/param-hash.js +0 -36
  546. package/dist/prerender/param-hash.js.map +0 -1
  547. package/dist/prerender/store.d.ts +0 -38
  548. package/dist/prerender/store.d.ts.map +0 -1
  549. package/dist/prerender/store.js +0 -61
  550. package/dist/prerender/store.js.map +0 -1
  551. package/dist/prerender.d.ts +0 -66
  552. package/dist/prerender.d.ts.map +0 -1
  553. package/dist/prerender.js +0 -57
  554. package/dist/prerender.js.map +0 -1
  555. package/dist/reverse.d.ts +0 -196
  556. package/dist/reverse.d.ts.map +0 -1
  557. package/dist/reverse.js +0 -78
  558. package/dist/reverse.js.map +0 -1
  559. package/dist/root-error-boundary.d.ts +0 -33
  560. package/dist/root-error-boundary.d.ts.map +0 -1
  561. package/dist/root-error-boundary.js +0 -165
  562. package/dist/root-error-boundary.js.map +0 -1
  563. package/dist/route-content-wrapper.d.ts +0 -46
  564. package/dist/route-content-wrapper.d.ts.map +0 -1
  565. package/dist/route-content-wrapper.js +0 -77
  566. package/dist/route-content-wrapper.js.map +0 -1
  567. package/dist/route-definition.d.ts +0 -421
  568. package/dist/route-definition.d.ts.map +0 -1
  569. package/dist/route-definition.js +0 -868
  570. package/dist/route-definition.js.map +0 -1
  571. package/dist/route-map-builder.d.ts +0 -155
  572. package/dist/route-map-builder.d.ts.map +0 -1
  573. package/dist/route-map-builder.js +0 -237
  574. package/dist/route-map-builder.js.map +0 -1
  575. package/dist/route-types.d.ts +0 -165
  576. package/dist/route-types.d.ts.map +0 -1
  577. package/dist/route-types.js +0 -7
  578. package/dist/route-types.js.map +0 -1
  579. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  580. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  581. package/dist/router/__tests__/handler-context.test.js +0 -65
  582. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  583. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  584. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  585. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  586. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  587. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  588. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  589. package/dist/router/__tests__/match-context.test.js +0 -92
  590. package/dist/router/__tests__/match-context.test.js.map +0 -1
  591. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  592. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  593. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  594. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  595. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  596. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  597. package/dist/router/__tests__/match-result.test.js +0 -457
  598. package/dist/router/__tests__/match-result.test.js.map +0 -1
  599. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  600. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  601. package/dist/router/__tests__/on-error.test.js +0 -678
  602. package/dist/router/__tests__/on-error.test.js.map +0 -1
  603. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  604. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  605. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  606. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  607. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  608. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  609. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  610. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  611. package/dist/router/error-handling.d.ts +0 -77
  612. package/dist/router/error-handling.d.ts.map +0 -1
  613. package/dist/router/error-handling.js +0 -202
  614. package/dist/router/error-handling.js.map +0 -1
  615. package/dist/router/handler-context.d.ts +0 -20
  616. package/dist/router/handler-context.d.ts.map +0 -1
  617. package/dist/router/handler-context.js +0 -198
  618. package/dist/router/handler-context.js.map +0 -1
  619. package/dist/router/intercept-resolution.d.ts +0 -66
  620. package/dist/router/intercept-resolution.d.ts.map +0 -1
  621. package/dist/router/intercept-resolution.js +0 -246
  622. package/dist/router/intercept-resolution.js.map +0 -1
  623. package/dist/router/loader-resolution.d.ts +0 -64
  624. package/dist/router/loader-resolution.d.ts.map +0 -1
  625. package/dist/router/loader-resolution.js +0 -284
  626. package/dist/router/loader-resolution.js.map +0 -1
  627. package/dist/router/logging.d.ts +0 -15
  628. package/dist/router/logging.d.ts.map +0 -1
  629. package/dist/router/logging.js +0 -99
  630. package/dist/router/logging.js.map +0 -1
  631. package/dist/router/manifest.d.ts +0 -22
  632. package/dist/router/manifest.d.ts.map +0 -1
  633. package/dist/router/manifest.js +0 -181
  634. package/dist/router/manifest.js.map +0 -1
  635. package/dist/router/match-api.d.ts +0 -35
  636. package/dist/router/match-api.d.ts.map +0 -1
  637. package/dist/router/match-api.js +0 -406
  638. package/dist/router/match-api.js.map +0 -1
  639. package/dist/router/match-context.d.ts +0 -206
  640. package/dist/router/match-context.d.ts.map +0 -1
  641. package/dist/router/match-context.js +0 -17
  642. package/dist/router/match-context.js.map +0 -1
  643. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  644. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  645. package/dist/router/match-middleware/background-revalidation.js +0 -75
  646. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  647. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  648. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  649. package/dist/router/match-middleware/cache-lookup.js +0 -257
  650. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  651. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  652. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  653. package/dist/router/match-middleware/cache-store.js +0 -108
  654. package/dist/router/match-middleware/cache-store.js.map +0 -1
  655. package/dist/router/match-middleware/index.d.ts +0 -81
  656. package/dist/router/match-middleware/index.d.ts.map +0 -1
  657. package/dist/router/match-middleware/index.js +0 -80
  658. package/dist/router/match-middleware/index.js.map +0 -1
  659. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  660. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  661. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  662. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  663. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  664. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  665. package/dist/router/match-middleware/segment-resolution.js +0 -53
  666. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  667. package/dist/router/match-pipelines.d.ts +0 -147
  668. package/dist/router/match-pipelines.d.ts.map +0 -1
  669. package/dist/router/match-pipelines.js +0 -82
  670. package/dist/router/match-pipelines.js.map +0 -1
  671. package/dist/router/match-result.d.ts +0 -126
  672. package/dist/router/match-result.d.ts.map +0 -1
  673. package/dist/router/match-result.js +0 -93
  674. package/dist/router/match-result.js.map +0 -1
  675. package/dist/router/metrics.d.ts +0 -20
  676. package/dist/router/metrics.d.ts.map +0 -1
  677. package/dist/router/metrics.js +0 -47
  678. package/dist/router/metrics.js.map +0 -1
  679. package/dist/router/middleware.d.ts +0 -249
  680. package/dist/router/middleware.d.ts.map +0 -1
  681. package/dist/router/middleware.js +0 -434
  682. package/dist/router/middleware.js.map +0 -1
  683. package/dist/router/middleware.test.d.ts +0 -2
  684. package/dist/router/middleware.test.d.ts.map +0 -1
  685. package/dist/router/middleware.test.js +0 -816
  686. package/dist/router/middleware.test.js.map +0 -1
  687. package/dist/router/pattern-matching.d.ts +0 -149
  688. package/dist/router/pattern-matching.d.ts.map +0 -1
  689. package/dist/router/pattern-matching.js +0 -349
  690. package/dist/router/pattern-matching.js.map +0 -1
  691. package/dist/router/revalidation.d.ts +0 -44
  692. package/dist/router/revalidation.d.ts.map +0 -1
  693. package/dist/router/revalidation.js +0 -147
  694. package/dist/router/revalidation.js.map +0 -1
  695. package/dist/router/router-context.d.ts +0 -135
  696. package/dist/router/router-context.d.ts.map +0 -1
  697. package/dist/router/router-context.js +0 -36
  698. package/dist/router/router-context.js.map +0 -1
  699. package/dist/router/segment-resolution.d.ts +0 -127
  700. package/dist/router/segment-resolution.d.ts.map +0 -1
  701. package/dist/router/segment-resolution.js +0 -919
  702. package/dist/router/segment-resolution.js.map +0 -1
  703. package/dist/router/trie-matching.d.ts +0 -40
  704. package/dist/router/trie-matching.d.ts.map +0 -1
  705. package/dist/router/trie-matching.js +0 -127
  706. package/dist/router/trie-matching.js.map +0 -1
  707. package/dist/router/types.d.ts +0 -136
  708. package/dist/router/types.d.ts.map +0 -1
  709. package/dist/router/types.js +0 -7
  710. package/dist/router/types.js.map +0 -1
  711. package/dist/router.d.ts +0 -753
  712. package/dist/router.d.ts.map +0 -1
  713. package/dist/router.gen.d.ts +0 -6
  714. package/dist/router.gen.d.ts.map +0 -1
  715. package/dist/router.gen.js +0 -6
  716. package/dist/router.gen.js.map +0 -1
  717. package/dist/router.js +0 -1304
  718. package/dist/router.js.map +0 -1
  719. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  720. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  721. package/dist/rsc/__tests__/helpers.test.js +0 -140
  722. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  723. package/dist/rsc/handler.d.ts +0 -45
  724. package/dist/rsc/handler.d.ts.map +0 -1
  725. package/dist/rsc/handler.js +0 -1172
  726. package/dist/rsc/handler.js.map +0 -1
  727. package/dist/rsc/helpers.d.ts +0 -16
  728. package/dist/rsc/helpers.d.ts.map +0 -1
  729. package/dist/rsc/helpers.js +0 -55
  730. package/dist/rsc/helpers.js.map +0 -1
  731. package/dist/rsc/index.d.ts +0 -22
  732. package/dist/rsc/index.d.ts.map +0 -1
  733. package/dist/rsc/index.js +0 -23
  734. package/dist/rsc/index.js.map +0 -1
  735. package/dist/rsc/nonce.d.ts +0 -9
  736. package/dist/rsc/nonce.d.ts.map +0 -1
  737. package/dist/rsc/nonce.js +0 -18
  738. package/dist/rsc/nonce.js.map +0 -1
  739. package/dist/rsc/types.d.ts +0 -206
  740. package/dist/rsc/types.d.ts.map +0 -1
  741. package/dist/rsc/types.js +0 -8
  742. package/dist/rsc/types.js.map +0 -1
  743. package/dist/search-params.d.ts +0 -103
  744. package/dist/search-params.d.ts.map +0 -1
  745. package/dist/search-params.js +0 -74
  746. package/dist/search-params.js.map +0 -1
  747. package/dist/segment-system.d.ts +0 -75
  748. package/dist/segment-system.d.ts.map +0 -1
  749. package/dist/segment-system.js +0 -336
  750. package/dist/segment-system.js.map +0 -1
  751. package/dist/server/context.d.ts +0 -245
  752. package/dist/server/context.d.ts.map +0 -1
  753. package/dist/server/context.js +0 -197
  754. package/dist/server/context.js.map +0 -1
  755. package/dist/server/fetchable-loader-store.d.ts +0 -18
  756. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  757. package/dist/server/fetchable-loader-store.js +0 -18
  758. package/dist/server/fetchable-loader-store.js.map +0 -1
  759. package/dist/server/handle-store.d.ts +0 -85
  760. package/dist/server/handle-store.d.ts.map +0 -1
  761. package/dist/server/handle-store.js +0 -142
  762. package/dist/server/handle-store.js.map +0 -1
  763. package/dist/server/loader-registry.d.ts +0 -55
  764. package/dist/server/loader-registry.d.ts.map +0 -1
  765. package/dist/server/loader-registry.js +0 -132
  766. package/dist/server/loader-registry.js.map +0 -1
  767. package/dist/server/request-context.d.ts +0 -226
  768. package/dist/server/request-context.d.ts.map +0 -1
  769. package/dist/server/request-context.js +0 -290
  770. package/dist/server/request-context.js.map +0 -1
  771. package/dist/server/root-layout.d.ts +0 -4
  772. package/dist/server/root-layout.d.ts.map +0 -1
  773. package/dist/server/root-layout.js +0 -5
  774. package/dist/server/root-layout.js.map +0 -1
  775. package/dist/server.d.ts +0 -15
  776. package/dist/server.d.ts.map +0 -1
  777. package/dist/server.js +0 -20
  778. package/dist/server.js.map +0 -1
  779. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  780. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  781. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  782. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  783. package/dist/ssr/index.d.ts +0 -98
  784. package/dist/ssr/index.d.ts.map +0 -1
  785. package/dist/ssr/index.js +0 -158
  786. package/dist/ssr/index.js.map +0 -1
  787. package/dist/static-handler.d.ts +0 -50
  788. package/dist/static-handler.d.ts.map +0 -1
  789. package/dist/static-handler.gen.d.ts +0 -5
  790. package/dist/static-handler.gen.d.ts.map +0 -1
  791. package/dist/static-handler.gen.js +0 -5
  792. package/dist/static-handler.gen.js.map +0 -1
  793. package/dist/static-handler.js +0 -29
  794. package/dist/static-handler.js.map +0 -1
  795. package/dist/theme/ThemeProvider.d.ts +0 -20
  796. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  797. package/dist/theme/ThemeProvider.js +0 -240
  798. package/dist/theme/ThemeProvider.js.map +0 -1
  799. package/dist/theme/ThemeScript.d.ts +0 -48
  800. package/dist/theme/ThemeScript.d.ts.map +0 -1
  801. package/dist/theme/ThemeScript.js +0 -13
  802. package/dist/theme/ThemeScript.js.map +0 -1
  803. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  804. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  805. package/dist/theme/__tests__/theme.test.js +0 -103
  806. package/dist/theme/__tests__/theme.test.js.map +0 -1
  807. package/dist/theme/constants.d.ts +0 -29
  808. package/dist/theme/constants.d.ts.map +0 -1
  809. package/dist/theme/constants.js +0 -48
  810. package/dist/theme/constants.js.map +0 -1
  811. package/dist/theme/index.d.ts +0 -31
  812. package/dist/theme/index.d.ts.map +0 -1
  813. package/dist/theme/index.js +0 -36
  814. package/dist/theme/index.js.map +0 -1
  815. package/dist/theme/theme-context.d.ts +0 -40
  816. package/dist/theme/theme-context.d.ts.map +0 -1
  817. package/dist/theme/theme-context.js +0 -60
  818. package/dist/theme/theme-context.js.map +0 -1
  819. package/dist/theme/theme-script.d.ts +0 -27
  820. package/dist/theme/theme-script.d.ts.map +0 -1
  821. package/dist/theme/theme-script.js +0 -147
  822. package/dist/theme/theme-script.js.map +0 -1
  823. package/dist/theme/types.d.ts +0 -163
  824. package/dist/theme/types.d.ts.map +0 -1
  825. package/dist/theme/types.js +0 -11
  826. package/dist/theme/types.js.map +0 -1
  827. package/dist/theme/use-theme.d.ts +0 -12
  828. package/dist/theme/use-theme.d.ts.map +0 -1
  829. package/dist/theme/use-theme.js +0 -40
  830. package/dist/theme/use-theme.js.map +0 -1
  831. package/dist/types.d.ts +0 -1479
  832. package/dist/types.d.ts.map +0 -1
  833. package/dist/types.js +0 -10
  834. package/dist/types.js.map +0 -1
  835. package/dist/urls.d.ts +0 -441
  836. package/dist/urls.d.ts.map +0 -1
  837. package/dist/urls.gen.d.ts +0 -8
  838. package/dist/urls.gen.d.ts.map +0 -1
  839. package/dist/urls.gen.js +0 -8
  840. package/dist/urls.gen.js.map +0 -1
  841. package/dist/urls.js +0 -443
  842. package/dist/urls.js.map +0 -1
  843. package/dist/use-loader.d.ts +0 -127
  844. package/dist/use-loader.d.ts.map +0 -1
  845. package/dist/use-loader.js +0 -237
  846. package/dist/use-loader.js.map +0 -1
  847. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  848. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  849. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  850. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  851. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  852. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  853. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  854. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  855. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  856. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  857. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  858. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  859. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  860. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  861. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  862. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  863. package/dist/vite/ast-handler-extract.d.ts +0 -49
  864. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  865. package/dist/vite/ast-handler-extract.js +0 -249
  866. package/dist/vite/ast-handler-extract.js.map +0 -1
  867. package/dist/vite/expose-action-id.d.ts +0 -19
  868. package/dist/vite/expose-action-id.d.ts.map +0 -1
  869. package/dist/vite/expose-action-id.js +0 -250
  870. package/dist/vite/expose-action-id.js.map +0 -1
  871. package/dist/vite/expose-id-utils.d.ts +0 -69
  872. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  873. package/dist/vite/expose-id-utils.js +0 -289
  874. package/dist/vite/expose-id-utils.js.map +0 -1
  875. package/dist/vite/expose-internal-ids.d.ts +0 -22
  876. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  877. package/dist/vite/expose-internal-ids.js +0 -886
  878. package/dist/vite/expose-internal-ids.js.map +0 -1
  879. package/dist/vite/index.d.ts +0 -149
  880. package/dist/vite/index.d.ts.map +0 -1
  881. package/dist/vite/index.js.map +0 -1
  882. package/dist/vite/index.named-routes.gen.ts +0 -103
  883. package/dist/vite/package-resolution.d.ts +0 -43
  884. package/dist/vite/package-resolution.d.ts.map +0 -1
  885. package/dist/vite/package-resolution.js +0 -112
  886. package/dist/vite/package-resolution.js.map +0 -1
  887. package/dist/vite/virtual-entries.d.ts +0 -25
  888. package/dist/vite/virtual-entries.d.ts.map +0 -1
  889. package/dist/vite/virtual-entries.js +0 -110
  890. package/dist/vite/virtual-entries.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rangojs/router",
3
- "version": "0.0.0-experimental.0b3f4e91",
3
+ "version": "0.0.0-experimental.0c4f94c2",
4
4
  "description": "Django-inspired RSC router with composable URL patterns",
5
5
  "keywords": [
6
6
  "react",
@@ -142,7 +142,7 @@
142
142
  "test:unit:watch": "vitest"
143
143
  },
144
144
  "dependencies": {
145
- "@vitejs/plugin-rsc": "^0.5.19",
145
+ "@vitejs/plugin-rsc": "^0.5.23",
146
146
  "magic-string": "^0.30.17",
147
147
  "picomatch": "^4.0.3",
148
148
  "rsc-html-stream": "^0.0.7"
@@ -162,7 +162,7 @@
162
162
  },
163
163
  "peerDependencies": {
164
164
  "@cloudflare/vite-plugin": "^1.25.0",
165
- "@vitejs/plugin-rsc": "^0.5.14",
165
+ "@vitejs/plugin-rsc": "^0.5.23",
166
166
  "react": "^18.0.0 || ^19.0.0",
167
167
  "vite": "^7.3.0"
168
168
  },
@@ -0,0 +1,362 @@
1
+ ---
2
+ name: handler-use
3
+ description: Attach default loaders, middleware, parallels, and other use items directly to handlers via handler.use, and compose them with explicit use() at mount sites
4
+ argument-hint: "[handler]"
5
+ ---
6
+
7
+ # Handler-Attached `.use`
8
+
9
+ A handler function (or branded `Static`/`Prerender`/`Passthrough` definition) can carry its own defaults via a `.use` callback that returns an array of `use` items (loader, middleware, parallel, intercept, layout, loading, etc.). The mount-site DSL (`path()`, `layout()`, `parallel()`, `intercept()`) merges those defaults with any explicit `use()` callback supplied at the registration site.
10
+
11
+ This lets handlers be **self-contained, reusable units** — a page brings its own loader, a layout brings its own middleware, a parallel slot brings its own data + skeleton — without forcing every caller to wire the same items at every mount site.
12
+
13
+ Canonical implementation reference:
14
+ [src/route-definition/resolve-handler-use.ts](../../src/route-definition/resolve-handler-use.ts)
15
+
16
+ ## Defining a handler with `.use`
17
+
18
+ Attach `.use` to the function (or to the branded definition for `Static()`/`Prerender()`/`Passthrough()`):
19
+
20
+ ```typescript
21
+ import {
22
+ loader,
23
+ middleware,
24
+ loading,
25
+ createLoader,
26
+ type Handler,
27
+ } from "@rangojs/router";
28
+
29
+ export const ProductLoader = createLoader(async (ctx) =>
30
+ fetchProduct(ctx.params.slug),
31
+ );
32
+
33
+ const ProductPage: Handler<"/product/:slug"> = async (ctx) => {
34
+ const product = await ctx.use(ProductLoader);
35
+ return <ProductView product={product} />;
36
+ };
37
+
38
+ ProductPage.use = () => [
39
+ loader(ProductLoader),
40
+ loading(<ProductSkeleton />),
41
+ middleware(async (ctx, next) => {
42
+ await next();
43
+ ctx.header("Cache-Control", "private, max-age=60");
44
+ }),
45
+ ];
46
+ ```
47
+
48
+ Now `ProductPage` carries its loader, loading state, and response-header middleware regardless of where it is mounted.
49
+
50
+ ## Allowed items per mount site
51
+
52
+ `handler.use()` is the same callback shape regardless of where the handler runs, but the runtime validates that the items it returns are valid for the mount site. Driven by `MOUNT_SITE_ALLOWED_TYPES` in [resolve-handler-use.ts](../../src/route-definition/resolve-handler-use.ts):
53
+
54
+ | Mount site | Allowed item types |
55
+ | ------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------- |
56
+ | `path()` / `route()` | `layout`, `parallel`, `intercept`, `middleware`, `revalidate`, `loader`, `loading`, `errorBoundary`, `notFoundBoundary`, `cache`, `transition` |
57
+ | `layout()` | All of the above, plus `route`, `include` |
58
+ | `parallel()` (per slot) | `revalidate`, `loader`, `loading`, `errorBoundary`, `notFoundBoundary`, `transition` |
59
+ | `intercept()` | `middleware`, `revalidate`, `loader`, `loading`, `errorBoundary`, `notFoundBoundary`, `layout`, `route`, `when`, `transition` |
60
+ | Response routes (`path.json()`, `path.text()`, …) | `middleware`, `cache` |
61
+
62
+ If `handler.use()` returns a disallowed item for a mount site, registration throws:
63
+
64
+ ```
65
+ handler.use() returned middleware() which is not valid inside parallel().
66
+ Allowed types: revalidate, loader, loading, errorBoundary, notFoundBoundary, transition.
67
+ ```
68
+
69
+ The narrowest contract is `parallel()` — slots cannot bring their own middleware or layout; only data, loading, error/notFound boundaries, revalidation, and transitions.
70
+
71
+ ## Composition with explicit `use()`
72
+
73
+ Every mount site that takes a `use` callback merges in this order:
74
+
75
+ 1. **`handler.use()` items first** — the handler's defaults.
76
+ 2. **Explicit `use()` items second** — overrides specified at the mount site.
77
+
78
+ Items of the same kind from the explicit `use()` follow the existing override rules of that item type. The most important ones for composition:
79
+
80
+ - **`loading()`** — last definition wins, so explicit `loading()` replaces the handler's default.
81
+ - **`parallel({ "@slot": … })`** — the last `parallel()` call wins per slot name. Other slots from earlier calls are preserved (see `skills/parallel`).
82
+ - **`loader()`, `middleware()`, etc.** — accumulate; both the handler's and the explicit ones run.
83
+
84
+ Skip the boilerplate: if neither `handler.use` nor explicit `use()` is provided, no merge happens.
85
+
86
+ ```typescript
87
+ // Handler brings a loader + a (placeholder) loading; explicit use replaces loading.
88
+ const SidebarSlot: Handler = async (ctx) => {
89
+ const data = await ctx.use(SidebarLoader);
90
+ return <Sidebar data={data} />;
91
+ };
92
+ SidebarSlot.use = () => [
93
+ loader(SidebarLoader),
94
+ loading(<DefaultSidebarSkeleton />),
95
+ ];
96
+
97
+ parallel({ "@sidebar": SidebarSlot }, () => [
98
+ // Replaces the default skeleton; SidebarLoader from handler.use still runs.
99
+ loading(<SiteSpecificSidebarSkeleton />),
100
+ ]);
101
+ ```
102
+
103
+ ## Composable parallel slots (the main pay-off)
104
+
105
+ The parallel slot site is where `handler.use` shines. A slot handler that owns its data/loading lets a layout declare **just** the slot names — every loader, skeleton, and revalidation contract travels with the slot itself.
106
+
107
+ ### Without `handler.use` (every caller wires it up)
108
+
109
+ ```typescript
110
+ layout(<DashboardLayout />, () => [
111
+ parallel({ "@cart": CartSummary }, () => [
112
+ loader(CartLoader),
113
+ loading(<CartSkeleton />),
114
+ revalidate(revalidateCartData),
115
+ ]),
116
+ parallel({ "@notifs": NotificationPanel }, () => [
117
+ loader(NotificationsLoader),
118
+ loading(<NotifsSkeleton />),
119
+ revalidate(revalidateNotifs),
120
+ ]),
121
+ path("/dashboard", DashboardIndex, { name: "dashboard.index" }),
122
+ ]);
123
+ ```
124
+
125
+ Every layout that wants `@cart` must repeat the same loader/loading/revalidate triplet.
126
+
127
+ ### With `handler.use` (slot owns its dependencies)
128
+
129
+ ```typescript
130
+ const CartSummary: Handler = async (ctx) => {
131
+ const cart = await ctx.use(CartLoader);
132
+ return <CartSummaryView cart={cart} />;
133
+ };
134
+ CartSummary.use = () => [
135
+ loader(CartLoader),
136
+ loading(<CartSkeleton />),
137
+ revalidate(revalidateCartData),
138
+ ];
139
+
140
+ const NotificationPanel: Handler = async (ctx) => {
141
+ const items = await ctx.use(NotificationsLoader);
142
+ return <NotificationsView items={items} />;
143
+ };
144
+ NotificationPanel.use = () => [
145
+ loader(NotificationsLoader),
146
+ loading(<NotifsSkeleton />),
147
+ revalidate(revalidateNotifs),
148
+ ];
149
+
150
+ // Mount sites become declarative — no per-call data wiring.
151
+ layout(<DashboardLayout />, () => [
152
+ parallel({ "@cart": CartSummary, "@notifs": NotificationPanel }),
153
+ path("/dashboard", DashboardIndex, { name: "dashboard.index" }),
154
+ ]);
155
+
156
+ layout(<AccountLayout />, () => [
157
+ // Same slot, same defaults, zero re-wiring.
158
+ parallel({ "@cart": CartSummary }),
159
+ path("/account", AccountIndex, { name: "account.index" }),
160
+ ]);
161
+ ```
162
+
163
+ Each slot handler is now a portable, self-contained unit. Different layouts can use the same slot without copying data plumbing.
164
+
165
+ ### Streaming behavior is per-slot
166
+
167
+ A slot's `loading()` (whether from `handler.use` or explicit) makes that slot an independent streaming unit — its loader does not block the parent layout. Two slot handlers with their own loading skeletons stream independently.
168
+
169
+ ```typescript
170
+ parallel({
171
+ "@cart": CartSummary, // handler.use loading() → streams independently
172
+ "@cartBadge": CartBadge, // no loading() anywhere → awaited before paint
173
+ });
174
+ ```
175
+
176
+ ### Two scopes for explicit `use` at the mount site: shared (broadcast) and slot-local
177
+
178
+ `parallel()` accepts an explicit `use()` callback that **broadcasts** to every slot in the call ([dsl-helpers.ts](../../src/route-definition/dsl-helpers.ts)). That's the right behavior for the items the parallel allow-list permits and that accumulate (`loader`, `revalidate`, `errorBoundary`, `notFoundBoundary`, `transition`) — every slot gets them. (Note: `middleware` is not allowed inside `parallel()`; see the allowed-types table above.)
179
+
180
+ For single-assignment items like `loading()`, broadcasting overwrites every slot's `handler.use` default. Pass a **slot descriptor** `{ handler, use }` instead: items in the descriptor's `use` apply only to that slot.
181
+
182
+ ```typescript
183
+ parallel({
184
+ "@meta": MetaSlot,
185
+ "@sidebar": {
186
+ handler: SidebarSlot,
187
+ use: () => [loading(<SidebarSkeleton />)], // ← only @sidebar
188
+ },
189
+ });
190
+ ```
191
+
192
+ Per-slot merge order is **handler.use → shared use → slot-local use** (narrowest scope wins for last-write-wins items like `loading()`):
193
+
194
+ ```typescript
195
+ parallel(
196
+ {
197
+ "@cart": {
198
+ handler: Cart,
199
+ use: () => [loading(<CartSkeleton />)], // wins for @cart
200
+ },
201
+ "@notifs": Notifs, // gets <BroadcastSkeleton />
202
+ },
203
+ () => [
204
+ loader(SharedAnalyticsLoader), // accumulates on every slot
205
+ loading(<BroadcastSkeleton />), // applies to slots without slot-local
206
+ ],
207
+ );
208
+ ```
209
+
210
+ Use the descriptor's `use` for `loading(false)` too — opting one slot out of streaming without affecting siblings:
211
+
212
+ ```typescript
213
+ parallel(
214
+ {
215
+ "@cart": { handler: Cart, use: () => [loading(false)] }, // @cart awaits
216
+ "@notifs": Notifs, // @notifs still streams with broadcast skeleton
217
+ },
218
+ () => [loading(<BroadcastSkeleton />)],
219
+ );
220
+ ```
221
+
222
+ Rule of thumb: shared `use` is for items that legitimately apply to every slot. Slot-local `use` is for per-slot precision — especially `loading()` and `loading(false)`.
223
+
224
+ ### Replacing a whole slot from a parent's `handler.use`
225
+
226
+ A handler can publish a default `parallel({...})` set via its `.use`, and the mount site can replace any individual slot by re-declaring it. Last `parallel()` per slot name wins (see `skills/parallel` § Slot Override Semantics).
227
+
228
+ ```typescript
229
+ const ProductPage: Handler<"/product/:slug"> = (ctx) => (
230
+ <article>
231
+ <ProductHero slug={ctx.params.slug} />
232
+ <ParallelOutlet name="@related" />
233
+ <ParallelOutlet name="@reviews" />
234
+ </article>
235
+ );
236
+ ProductPage.use = () => [
237
+ parallel({
238
+ "@related": DefaultRelatedProducts,
239
+ "@reviews": DefaultReviews,
240
+ }),
241
+ ];
242
+
243
+ path("/product/:slug", ProductPage, { name: "product" }, () => [
244
+ // Override @related only; @reviews keeps the default from handler.use.
245
+ parallel({ "@related": SiteSpecificRelated }),
246
+ ]);
247
+ ```
248
+
249
+ ## Other mount sites
250
+
251
+ ### Pages (`path()`)
252
+
253
+ Page handlers can carry middleware, loaders, error boundaries, parallel slots, etc. — anything from the `path` row of the table above.
254
+
255
+ ```typescript
256
+ const CheckoutPage: Handler<"/checkout"> = async (ctx) => { /* … */ };
257
+ CheckoutPage.use = () => [
258
+ middleware(requireAuth),
259
+ loader(CartLoader),
260
+ errorBoundary(<CheckoutError />),
261
+ notFoundBoundary(<CheckoutNotFound />),
262
+ ];
263
+ ```
264
+
265
+ ### Layouts (`layout()`)
266
+
267
+ Layout handlers can carry middleware that runs for every child route, plus default parallels, includes, etc.
268
+
269
+ ```typescript
270
+ const AdminLayout: Handler = (ctx) => {
271
+ const user = ctx.get(CurrentUser);
272
+ return <Admin user={user} />;
273
+ };
274
+ AdminLayout.use = () => [
275
+ middleware(requireAdmin),
276
+ parallel({ "@adminNotifs": AdminNotifsSlot }),
277
+ ];
278
+ ```
279
+
280
+ ### Intercepts (`intercept()`)
281
+
282
+ Intercept handlers can carry their own middleware chain, loaders, and even nested layouts/routes for the modal shell.
283
+
284
+ ```typescript
285
+ const QuickViewModal: Handler = async (ctx) => {
286
+ const product = await ctx.use(ProductLoader);
287
+ return <QuickView product={product} />;
288
+ };
289
+ QuickViewModal.use = () => [
290
+ loader(ProductLoader),
291
+ loading(<QuickViewSkeleton />),
292
+ layout(<ModalChrome />),
293
+ ];
294
+ ```
295
+
296
+ ## `loading()` is a single-assignment item — scope it correctly
297
+
298
+ Most `use` items accumulate when merged: `handler.use` `middleware()` runs _and_ explicit `middleware()` runs; both `loader()` registrations apply. `loading()` is different — it mutates `entry.loading` directly, last call wins ([dsl-helpers.ts `loadingFn`](../../src/route-definition/dsl-helpers.ts)).
299
+
300
+ For pages, layouts, and intercepts that's straightforward: explicit `loading()` at the mount site replaces any `loading()` from `handler.use`. The merge order is `handler.use → explicit`, so the explicit one is the last writer and wins.
301
+
302
+ For parallel slots, the shared `parallel(..., () => [...])` callback is **broadcast** to every slot in the call. A single `loading()` placed there lands on every slot, overwriting each slot's `handler.use` default. To scope `loading()` to one slot, use the **slot descriptor** form:
303
+
304
+ ```typescript
305
+ const Cart: Handler = async (ctx) => { /* … */ };
306
+ Cart.use = () => [loader(CartLoader), loading(<CartSkeleton />)];
307
+
308
+ const Notifs: Handler = async (ctx) => { /* … */ };
309
+ Notifs.use = () => [loader(NotifsLoader), loading(<NotifsSkeleton />)];
310
+
311
+ // ✅ @cart gets a custom skeleton; @notifs keeps its handler.use default.
312
+ parallel({
313
+ "@cart": {
314
+ handler: Cart,
315
+ use: () => [loading(<CustomCartSkeleton />)],
316
+ },
317
+ "@notifs": Notifs,
318
+ });
319
+
320
+ // ✅ Opt one slot out of streaming while siblings still stream the broadcast.
321
+ parallel(
322
+ {
323
+ "@cart": { handler: Cart, use: () => [loading(false)] },
324
+ "@notifs": Notifs,
325
+ },
326
+ () => [loading(<BroadcastSkeleton />)],
327
+ );
328
+ ```
329
+
330
+ Per-slot merge order is **handler.use → shared use → slot-local use**. Slot-local is the narrowest scope, so it wins for last-write-wins items like `loading()`. Items that accumulate within the parallel allow-list (`loader`, `revalidate`, `errorBoundary`, `notFoundBoundary`, `transition`) compose across all three layers regardless.
331
+
332
+ Other things to keep in mind about `loading()`:
333
+
334
+ - Any `loading()` (regardless of source) makes the segment a streaming unit. A handler that includes `loading()` in its `.use` opts every mount site into streaming by default. To opt back out, pass `loading(false)` at the mount site (`loading: false` handling in [match-middleware/segment-resolution.ts](../../src/router/match-middleware/segment-resolution.ts)) — use the slot descriptor form for parallel slots so the opt-out doesn't broadcast.
335
+
336
+ Rule of thumb: only put `loading()` in `handler.use` if you genuinely want every mount site to stream by default. Use the slot descriptor's `use` for any per-slot intent at a `parallel()` call.
337
+
338
+ ## Edge cases & gotchas
339
+
340
+ - **ReactNode handlers cannot have `.use`.** A bare JSX element passed as a handler (e.g., `path("/about", <About />)`) has no function to attach properties to. Pass a function or branded definition instead.
341
+ - **Branded handlers** — `Static()`, `Prerender()`, and `Passthrough()` are positional constructors (not object-arg). Construct first, then attach `.use` to the returned definition:
342
+
343
+ ```typescript
344
+ const ProductPage = Prerender(async (ctx) => {
345
+ const product = await fetchProduct(ctx.params.slug);
346
+ return <ProductView product={product} />;
347
+ });
348
+ ProductPage.use = () => [loader(ProductLoader)];
349
+ ```
350
+
351
+ - **Items can be flat or nested arrays.** `handler.use()` results are flattened with `.flat(3)` before validation, so factory helpers that return arrays inline work the same as in regular `use()` callbacks.
352
+ - **Validation runs at registration / first match**, not at handler definition. A handler doesn't know its mount site at definition time — the same handler used in a `path()` and an `intercept()` is validated against each mount's allowed-types set when registered.
353
+ - **No silent shadowing.** If a disallowed item slips through (e.g., a layout factory returning `cache()` from a slot's `handler.use`), the runtime throws with the offending type and mount site named.
354
+
355
+ ## Cross-references
356
+
357
+ - `skills/route` — `path()` mount site basics
358
+ - `skills/layout` — `layout()` mount site basics
359
+ - `skills/parallel` — parallel slot semantics, slot override rules, streaming behavior
360
+ - `skills/intercept` — intercept mount site basics
361
+ - `skills/loader` — defining `createLoader` and reading via `ctx.use()`
362
+ - `skills/middleware` — middleware semantics and ordering
@@ -311,3 +311,23 @@ export const shopPatterns = urls(({
311
311
  ]),
312
312
  ]);
313
313
  ```
314
+
315
+ ## Handler-attached `.use`
316
+
317
+ Intercept handlers can carry their own middleware, loaders, loading state, error/notFound boundaries, and even nested `layout`/`route`/`when` defaults via `.use` — useful for self-contained modal components that travel with their own data and chrome.
318
+
319
+ ```typescript
320
+ const QuickViewModal: Handler = async (ctx) => {
321
+ const product = await ctx.use(ProductLoader);
322
+ return <QuickView product={product} />;
323
+ };
324
+ QuickViewModal.use = () => [
325
+ loader(ProductLoader),
326
+ loading(<QuickViewSkeleton />),
327
+ layout(<ModalChrome />),
328
+ ];
329
+
330
+ intercept("@modal", "product", QuickViewModal);
331
+ ```
332
+
333
+ Explicit `use()` at the mount site merges with `handler.use` (handler defaults first, explicit second). See [skills/handler-use](../handler-use/SKILL.md) for merge order and the per-mount-site allowed-types table.
@@ -308,3 +308,25 @@ export const shopPatterns = urls(({ path, layout, parallel, loader, revalidate }
308
308
  ]),
309
309
  ]);
310
310
  ```
311
+
312
+ ## Handler-attached `.use`
313
+
314
+ Layout handlers can carry their own middleware, default parallels, and includes via `.use` so a layout becomes a self-contained unit reusable across mount sites.
315
+
316
+ ```typescript
317
+ const AdminLayout: Handler = (ctx) => {
318
+ const user = ctx.get(CurrentUser);
319
+ return <Admin user={user} />;
320
+ };
321
+ AdminLayout.use = () => [
322
+ middleware(requireAdmin),
323
+ parallel({ "@adminNotifs": AdminNotifsSlot }),
324
+ ];
325
+
326
+ // Mount site declares structure only; defaults travel with the layout.
327
+ layout(AdminLayout, () => [
328
+ path("/admin", AdminIndex, { name: "admin.index" }),
329
+ ]);
330
+ ```
331
+
332
+ Allowed item types in a layout's `.use` mirror the layout `use()` callback (the broadest set). Explicit `use()` at the mount site merges with `handler.use` (handler defaults first, explicit second). See [skills/handler-use](../handler-use/SKILL.md) for merge order and per-mount-site allowed types.
@@ -137,17 +137,46 @@ export const urlpatterns = urls(({ path, layout, middleware }) => [
137
137
  ## Middleware with Multiple Handlers
138
138
 
139
139
  ```typescript
140
- // Spread multiple middleware from a single export
140
+ // Group multiple middleware in an array
141
141
  export const shopMiddleware = [loggerMiddleware, mockAuthMiddleware];
142
142
 
143
- // In routes
143
+ // In routes — pass the array directly
144
144
  layout(<ShopLayout />, () => [
145
- middleware(...shopMiddleware),
145
+ middleware(shopMiddleware),
146
146
 
147
147
  path("/shop", ShopIndex, { name: "shop" }),
148
148
  ])
149
149
  ```
150
150
 
151
+ ## Wrapping Middleware (Scoped to Children)
152
+
153
+ Use the wrapping form to scope middleware to a subset of routes without
154
+ introducing a visible layout:
155
+
156
+ ```typescript
157
+ urls(({ path, middleware }) => [
158
+ // authMw only applies to /admin and /admin/settings
159
+ middleware(authMw, () => [
160
+ path("/admin", AdminPage, { name: "admin" }),
161
+ path("/admin/settings", SettingsPage, { name: "settings" }),
162
+ ]),
163
+
164
+ // Public route — no authMw
165
+ path("/", HomePage, { name: "home" }),
166
+ ]);
167
+ ```
168
+
169
+ Multiple middleware with wrapping:
170
+
171
+ ```typescript
172
+ middleware([authMw, loggingMw], () => [
173
+ path("/admin", AdminPage, { name: "admin" }),
174
+ ]);
175
+ ```
176
+
177
+ This creates a transparent layout (`<Outlet />`) that carries the middleware.
178
+ The middleware does not affect sibling routes outside the callback.
179
+
151
180
  ## Middleware Context
152
181
 
153
182
  ```typescript