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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (889) hide show
  1. package/README.md +61 -8
  2. package/dist/bin/rango.js +2 -1
  3. package/dist/vite/index.js +448 -179
  4. package/package.json +3 -3
  5. package/skills/handler-use/SKILL.md +362 -0
  6. package/skills/intercept/SKILL.md +20 -0
  7. package/skills/layout/SKILL.md +22 -0
  8. package/skills/middleware/SKILL.md +32 -3
  9. package/skills/migrate-nextjs/SKILL.md +560 -0
  10. package/skills/migrate-react-router/SKILL.md +764 -0
  11. package/skills/parallel/SKILL.md +59 -0
  12. package/skills/prerender/SKILL.md +110 -68
  13. package/skills/rango/SKILL.md +24 -22
  14. package/skills/route/SKILL.md +24 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/navigation-bridge.ts +7 -1
  17. package/src/browser/navigation-client.ts +34 -6
  18. package/src/browser/partial-update.ts +5 -0
  19. package/src/browser/prefetch/cache.ts +16 -6
  20. package/src/browser/prefetch/fetch.ts +60 -4
  21. package/src/browser/react/Link.tsx +25 -2
  22. package/src/browser/react/use-handle.ts +9 -58
  23. package/src/browser/segment-reconciler.ts +72 -2
  24. package/src/build/generate-manifest.ts +3 -6
  25. package/src/build/route-trie.ts +50 -24
  26. package/src/build/route-types/scan-filter.ts +8 -1
  27. package/src/client.tsx +5 -66
  28. package/src/handle.ts +40 -0
  29. package/src/index.rsc.ts +3 -1
  30. package/src/index.ts +46 -6
  31. package/src/prerender/store.ts +5 -4
  32. package/src/prerender.ts +138 -77
  33. package/src/reverse.ts +6 -1
  34. package/src/route-definition/dsl-helpers.ts +194 -32
  35. package/src/route-definition/helpers-types.ts +61 -14
  36. package/src/route-definition/index.ts +3 -0
  37. package/src/route-definition/resolve-handler-use.ts +149 -0
  38. package/src/route-types.ts +11 -0
  39. package/src/router/content-negotiation.ts +100 -1
  40. package/src/router/handler-context.ts +26 -6
  41. package/src/router/loader-resolution.ts +147 -19
  42. package/src/router/match-api.ts +124 -189
  43. package/src/router/match-middleware/cache-lookup.ts +24 -7
  44. package/src/router/match-middleware/segment-resolution.ts +53 -0
  45. package/src/router/match-result.ts +82 -4
  46. package/src/router/navigation-snapshot.ts +182 -0
  47. package/src/router/prerender-match.ts +108 -8
  48. package/src/router/preview-match.ts +30 -102
  49. package/src/router/request-classification.ts +310 -0
  50. package/src/router/route-snapshot.ts +245 -0
  51. package/src/router/router-interfaces.ts +11 -0
  52. package/src/router/segment-resolution/fresh.ts +59 -2
  53. package/src/router/segment-resolution/revalidation.ts +79 -6
  54. package/src/router.ts +13 -1
  55. package/src/rsc/handler.ts +468 -377
  56. package/src/rsc/loader-fetch.ts +23 -3
  57. package/src/rsc/progressive-enhancement.ts +10 -2
  58. package/src/rsc/rsc-rendering.ts +5 -1
  59. package/src/rsc/server-action.ts +6 -0
  60. package/src/rsc/ssr-setup.ts +1 -1
  61. package/src/rsc/types.ts +1 -0
  62. package/src/segment-content-promise.ts +38 -0
  63. package/src/segment-system.tsx +25 -11
  64. package/src/server/context.ts +14 -1
  65. package/src/server/handle-store.ts +19 -0
  66. package/src/server/request-context.ts +125 -3
  67. package/src/static-handler.ts +18 -6
  68. package/src/types/handler-context.ts +12 -2
  69. package/src/types/loader-types.ts +32 -4
  70. package/src/types/route-entry.ts +1 -1
  71. package/src/types/segments.ts +4 -0
  72. package/src/urls/path-helper-types.ts +39 -6
  73. package/src/urls/path-helper.ts +47 -12
  74. package/src/urls/response-types.ts +16 -6
  75. package/src/use-loader.tsx +77 -5
  76. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  77. package/src/vite/discovery/prerender-collection.ts +128 -74
  78. package/src/vite/discovery/state.ts +13 -4
  79. package/src/vite/index.ts +4 -0
  80. package/src/vite/plugin-types.ts +60 -5
  81. package/src/vite/plugins/expose-id-utils.ts +12 -0
  82. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  83. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  84. package/src/vite/rango.ts +2 -1
  85. package/src/vite/router-discovery.ts +178 -37
  86. package/src/vite/utils/prerender-utils.ts +37 -5
  87. package/dist/__internal.d.ts +0 -83
  88. package/dist/__internal.d.ts.map +0 -1
  89. package/dist/__internal.js +0 -19
  90. package/dist/__internal.js.map +0 -1
  91. package/dist/__mocks__/version.d.ts +0 -7
  92. package/dist/__mocks__/version.d.ts.map +0 -1
  93. package/dist/__mocks__/version.js +0 -7
  94. package/dist/__mocks__/version.js.map +0 -1
  95. package/dist/__tests__/client-href.test.d.ts +0 -2
  96. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  97. package/dist/__tests__/client-href.test.js +0 -74
  98. package/dist/__tests__/client-href.test.js.map +0 -1
  99. package/dist/__tests__/component-utils.test.d.ts +0 -2
  100. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  101. package/dist/__tests__/component-utils.test.js +0 -51
  102. package/dist/__tests__/component-utils.test.js.map +0 -1
  103. package/dist/__tests__/event-controller.test.d.ts +0 -2
  104. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  105. package/dist/__tests__/event-controller.test.js +0 -538
  106. package/dist/__tests__/event-controller.test.js.map +0 -1
  107. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  108. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  109. package/dist/__tests__/helpers/route-tree.js +0 -374
  110. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  111. package/dist/__tests__/match-result.test.d.ts +0 -2
  112. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  113. package/dist/__tests__/match-result.test.js +0 -154
  114. package/dist/__tests__/match-result.test.js.map +0 -1
  115. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  116. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  117. package/dist/__tests__/navigation-store.test.js +0 -440
  118. package/dist/__tests__/navigation-store.test.js.map +0 -1
  119. package/dist/__tests__/partial-update.test.d.ts +0 -2
  120. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  121. package/dist/__tests__/partial-update.test.js +0 -1009
  122. package/dist/__tests__/partial-update.test.js.map +0 -1
  123. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  124. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  125. package/dist/__tests__/reverse-types.test.js +0 -656
  126. package/dist/__tests__/reverse-types.test.js.map +0 -1
  127. package/dist/__tests__/route-definition.test.d.ts +0 -2
  128. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  129. package/dist/__tests__/route-definition.test.js +0 -55
  130. package/dist/__tests__/route-definition.test.js.map +0 -1
  131. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  132. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  133. package/dist/__tests__/router-helpers.test.js +0 -377
  134. package/dist/__tests__/router-helpers.test.js.map +0 -1
  135. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  136. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  137. package/dist/__tests__/router-integration-2.test.js +0 -426
  138. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  139. package/dist/__tests__/router-integration.test.d.ts +0 -2
  140. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  141. package/dist/__tests__/router-integration.test.js +0 -1051
  142. package/dist/__tests__/router-integration.test.js.map +0 -1
  143. package/dist/__tests__/search-params.test.d.ts +0 -5
  144. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  145. package/dist/__tests__/search-params.test.js +0 -306
  146. package/dist/__tests__/search-params.test.js.map +0 -1
  147. package/dist/__tests__/segment-system.test.d.ts +0 -2
  148. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  149. package/dist/__tests__/segment-system.test.js +0 -627
  150. package/dist/__tests__/segment-system.test.js.map +0 -1
  151. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  152. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  153. package/dist/__tests__/static-handler-types.test.js +0 -63
  154. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  155. package/dist/__tests__/urls.test.d.ts +0 -2
  156. package/dist/__tests__/urls.test.d.ts.map +0 -1
  157. package/dist/__tests__/urls.test.js +0 -421
  158. package/dist/__tests__/urls.test.js.map +0 -1
  159. package/dist/__tests__/use-mount.test.d.ts +0 -2
  160. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  161. package/dist/__tests__/use-mount.test.js +0 -35
  162. package/dist/__tests__/use-mount.test.js.map +0 -1
  163. package/dist/bin/rango.d.ts +0 -2
  164. package/dist/bin/rango.d.ts.map +0 -1
  165. package/dist/bin/rango.js.map +0 -1
  166. package/dist/browser/event-controller.d.ts +0 -191
  167. package/dist/browser/event-controller.d.ts.map +0 -1
  168. package/dist/browser/event-controller.js +0 -559
  169. package/dist/browser/event-controller.js.map +0 -1
  170. package/dist/browser/index.d.ts +0 -2
  171. package/dist/browser/index.d.ts.map +0 -1
  172. package/dist/browser/index.js +0 -14
  173. package/dist/browser/index.js.map +0 -1
  174. package/dist/browser/link-interceptor.d.ts +0 -38
  175. package/dist/browser/link-interceptor.d.ts.map +0 -1
  176. package/dist/browser/link-interceptor.js +0 -99
  177. package/dist/browser/link-interceptor.js.map +0 -1
  178. package/dist/browser/logging.d.ts +0 -10
  179. package/dist/browser/logging.d.ts.map +0 -1
  180. package/dist/browser/logging.js +0 -29
  181. package/dist/browser/logging.js.map +0 -1
  182. package/dist/browser/lru-cache.d.ts +0 -17
  183. package/dist/browser/lru-cache.d.ts.map +0 -1
  184. package/dist/browser/lru-cache.js +0 -50
  185. package/dist/browser/lru-cache.js.map +0 -1
  186. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  187. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  188. package/dist/browser/merge-segment-loaders.js +0 -102
  189. package/dist/browser/merge-segment-loaders.js.map +0 -1
  190. package/dist/browser/navigation-bridge.d.ts +0 -102
  191. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  192. package/dist/browser/navigation-bridge.js +0 -708
  193. package/dist/browser/navigation-bridge.js.map +0 -1
  194. package/dist/browser/navigation-client.d.ts +0 -25
  195. package/dist/browser/navigation-client.d.ts.map +0 -1
  196. package/dist/browser/navigation-client.js +0 -157
  197. package/dist/browser/navigation-client.js.map +0 -1
  198. package/dist/browser/navigation-store.d.ts +0 -101
  199. package/dist/browser/navigation-store.d.ts.map +0 -1
  200. package/dist/browser/navigation-store.js +0 -625
  201. package/dist/browser/navigation-store.js.map +0 -1
  202. package/dist/browser/partial-update.d.ts +0 -75
  203. package/dist/browser/partial-update.d.ts.map +0 -1
  204. package/dist/browser/partial-update.js +0 -426
  205. package/dist/browser/partial-update.js.map +0 -1
  206. package/dist/browser/react/Link.d.ts +0 -86
  207. package/dist/browser/react/Link.d.ts.map +0 -1
  208. package/dist/browser/react/Link.js +0 -128
  209. package/dist/browser/react/Link.js.map +0 -1
  210. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  211. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  212. package/dist/browser/react/NavigationProvider.js +0 -216
  213. package/dist/browser/react/NavigationProvider.js.map +0 -1
  214. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  215. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  216. package/dist/browser/react/ScrollRestoration.js +0 -57
  217. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  218. package/dist/browser/react/context.d.ts +0 -46
  219. package/dist/browser/react/context.d.ts.map +0 -1
  220. package/dist/browser/react/context.js +0 -10
  221. package/dist/browser/react/context.js.map +0 -1
  222. package/dist/browser/react/index.d.ts +0 -11
  223. package/dist/browser/react/index.d.ts.map +0 -1
  224. package/dist/browser/react/index.js +0 -22
  225. package/dist/browser/react/index.js.map +0 -1
  226. package/dist/browser/react/location-state-shared.d.ts +0 -63
  227. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  228. package/dist/browser/react/location-state-shared.js +0 -81
  229. package/dist/browser/react/location-state-shared.js.map +0 -1
  230. package/dist/browser/react/location-state.d.ts +0 -23
  231. package/dist/browser/react/location-state.d.ts.map +0 -1
  232. package/dist/browser/react/location-state.js +0 -29
  233. package/dist/browser/react/location-state.js.map +0 -1
  234. package/dist/browser/react/mount-context.d.ts +0 -24
  235. package/dist/browser/react/mount-context.d.ts.map +0 -1
  236. package/dist/browser/react/mount-context.js +0 -24
  237. package/dist/browser/react/mount-context.js.map +0 -1
  238. package/dist/browser/react/use-action.d.ts +0 -64
  239. package/dist/browser/react/use-action.d.ts.map +0 -1
  240. package/dist/browser/react/use-action.js +0 -134
  241. package/dist/browser/react/use-action.js.map +0 -1
  242. package/dist/browser/react/use-client-cache.d.ts +0 -41
  243. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  244. package/dist/browser/react/use-client-cache.js +0 -39
  245. package/dist/browser/react/use-client-cache.js.map +0 -1
  246. package/dist/browser/react/use-handle.d.ts +0 -31
  247. package/dist/browser/react/use-handle.d.ts.map +0 -1
  248. package/dist/browser/react/use-handle.js +0 -144
  249. package/dist/browser/react/use-handle.js.map +0 -1
  250. package/dist/browser/react/use-href.d.ts +0 -33
  251. package/dist/browser/react/use-href.d.ts.map +0 -1
  252. package/dist/browser/react/use-href.js +0 -39
  253. package/dist/browser/react/use-href.js.map +0 -1
  254. package/dist/browser/react/use-link-status.d.ts +0 -37
  255. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  256. package/dist/browser/react/use-link-status.js +0 -99
  257. package/dist/browser/react/use-link-status.js.map +0 -1
  258. package/dist/browser/react/use-mount.d.ts +0 -25
  259. package/dist/browser/react/use-mount.d.ts.map +0 -1
  260. package/dist/browser/react/use-mount.js +0 -30
  261. package/dist/browser/react/use-mount.js.map +0 -1
  262. package/dist/browser/react/use-navigation.d.ts +0 -27
  263. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  264. package/dist/browser/react/use-navigation.js +0 -87
  265. package/dist/browser/react/use-navigation.js.map +0 -1
  266. package/dist/browser/react/use-segments.d.ts +0 -38
  267. package/dist/browser/react/use-segments.d.ts.map +0 -1
  268. package/dist/browser/react/use-segments.js +0 -130
  269. package/dist/browser/react/use-segments.js.map +0 -1
  270. package/dist/browser/request-controller.d.ts +0 -26
  271. package/dist/browser/request-controller.d.ts.map +0 -1
  272. package/dist/browser/request-controller.js +0 -147
  273. package/dist/browser/request-controller.js.map +0 -1
  274. package/dist/browser/rsc-router.d.ts +0 -129
  275. package/dist/browser/rsc-router.d.ts.map +0 -1
  276. package/dist/browser/rsc-router.js +0 -195
  277. package/dist/browser/rsc-router.js.map +0 -1
  278. package/dist/browser/scroll-restoration.d.ts +0 -93
  279. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  280. package/dist/browser/scroll-restoration.js +0 -321
  281. package/dist/browser/scroll-restoration.js.map +0 -1
  282. package/dist/browser/segment-structure-assert.d.ts +0 -17
  283. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  284. package/dist/browser/segment-structure-assert.js +0 -59
  285. package/dist/browser/segment-structure-assert.js.map +0 -1
  286. package/dist/browser/server-action-bridge.d.ts +0 -26
  287. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  288. package/dist/browser/server-action-bridge.js +0 -668
  289. package/dist/browser/server-action-bridge.js.map +0 -1
  290. package/dist/browser/shallow.d.ts +0 -12
  291. package/dist/browser/shallow.d.ts.map +0 -1
  292. package/dist/browser/shallow.js +0 -34
  293. package/dist/browser/shallow.js.map +0 -1
  294. package/dist/browser/types.d.ts +0 -369
  295. package/dist/browser/types.d.ts.map +0 -1
  296. package/dist/browser/types.js +0 -2
  297. package/dist/browser/types.js.map +0 -1
  298. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  299. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  300. package/dist/build/__tests__/generate-cli.test.js +0 -237
  301. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  302. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  303. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  304. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  305. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  306. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  307. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  308. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  309. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  310. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  311. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  312. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  313. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  314. package/dist/build/generate-manifest.d.ts +0 -81
  315. package/dist/build/generate-manifest.d.ts.map +0 -1
  316. package/dist/build/generate-manifest.js +0 -276
  317. package/dist/build/generate-manifest.js.map +0 -1
  318. package/dist/build/generate-route-types.d.ts +0 -115
  319. package/dist/build/generate-route-types.d.ts.map +0 -1
  320. package/dist/build/generate-route-types.js +0 -740
  321. package/dist/build/generate-route-types.js.map +0 -1
  322. package/dist/build/index.d.ts +0 -21
  323. package/dist/build/index.d.ts.map +0 -1
  324. package/dist/build/index.js +0 -21
  325. package/dist/build/index.js.map +0 -1
  326. package/dist/build/route-trie.d.ts +0 -71
  327. package/dist/build/route-trie.d.ts.map +0 -1
  328. package/dist/build/route-trie.js +0 -175
  329. package/dist/build/route-trie.js.map +0 -1
  330. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  331. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  332. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  333. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  334. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  335. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  336. package/dist/cache/__tests__/document-cache.test.js +0 -345
  337. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  338. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  339. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  340. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  341. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  342. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  343. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  344. package/dist/cache/__tests__/memory-store.test.js +0 -367
  345. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  346. package/dist/cache/cache-scope.d.ts +0 -102
  347. package/dist/cache/cache-scope.d.ts.map +0 -1
  348. package/dist/cache/cache-scope.js +0 -440
  349. package/dist/cache/cache-scope.js.map +0 -1
  350. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  351. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  352. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  353. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  354. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  355. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  356. package/dist/cache/cf/cf-cache-store.js +0 -242
  357. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  358. package/dist/cache/cf/index.d.ts +0 -14
  359. package/dist/cache/cf/index.d.ts.map +0 -1
  360. package/dist/cache/cf/index.js +0 -17
  361. package/dist/cache/cf/index.js.map +0 -1
  362. package/dist/cache/document-cache.d.ts +0 -64
  363. package/dist/cache/document-cache.d.ts.map +0 -1
  364. package/dist/cache/document-cache.js +0 -228
  365. package/dist/cache/document-cache.js.map +0 -1
  366. package/dist/cache/index.d.ts +0 -19
  367. package/dist/cache/index.d.ts.map +0 -1
  368. package/dist/cache/index.js +0 -21
  369. package/dist/cache/index.js.map +0 -1
  370. package/dist/cache/memory-segment-store.d.ts +0 -110
  371. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  372. package/dist/cache/memory-segment-store.js +0 -117
  373. package/dist/cache/memory-segment-store.js.map +0 -1
  374. package/dist/cache/memory-store.d.ts +0 -41
  375. package/dist/cache/memory-store.d.ts.map +0 -1
  376. package/dist/cache/memory-store.js +0 -191
  377. package/dist/cache/memory-store.js.map +0 -1
  378. package/dist/cache/types.d.ts +0 -317
  379. package/dist/cache/types.d.ts.map +0 -1
  380. package/dist/cache/types.js +0 -12
  381. package/dist/cache/types.js.map +0 -1
  382. package/dist/client.d.ts +0 -248
  383. package/dist/client.d.ts.map +0 -1
  384. package/dist/client.js +0 -367
  385. package/dist/client.js.map +0 -1
  386. package/dist/client.rsc.d.ts +0 -26
  387. package/dist/client.rsc.d.ts.map +0 -1
  388. package/dist/client.rsc.js +0 -46
  389. package/dist/client.rsc.js.map +0 -1
  390. package/dist/component-utils.d.ts +0 -36
  391. package/dist/component-utils.d.ts.map +0 -1
  392. package/dist/component-utils.js +0 -61
  393. package/dist/component-utils.js.map +0 -1
  394. package/dist/components/DefaultDocument.d.ts +0 -13
  395. package/dist/components/DefaultDocument.d.ts.map +0 -1
  396. package/dist/components/DefaultDocument.js +0 -15
  397. package/dist/components/DefaultDocument.js.map +0 -1
  398. package/dist/debug.d.ts +0 -58
  399. package/dist/debug.d.ts.map +0 -1
  400. package/dist/debug.js +0 -157
  401. package/dist/debug.js.map +0 -1
  402. package/dist/default-error-boundary.d.ts +0 -11
  403. package/dist/default-error-boundary.d.ts.map +0 -1
  404. package/dist/default-error-boundary.js +0 -45
  405. package/dist/default-error-boundary.js.map +0 -1
  406. package/dist/deps/browser.d.ts +0 -2
  407. package/dist/deps/browser.d.ts.map +0 -1
  408. package/dist/deps/browser.js +0 -3
  409. package/dist/deps/browser.js.map +0 -1
  410. package/dist/deps/html-stream-client.d.ts +0 -2
  411. package/dist/deps/html-stream-client.d.ts.map +0 -1
  412. package/dist/deps/html-stream-client.js +0 -3
  413. package/dist/deps/html-stream-client.js.map +0 -1
  414. package/dist/deps/html-stream-server.d.ts +0 -2
  415. package/dist/deps/html-stream-server.d.ts.map +0 -1
  416. package/dist/deps/html-stream-server.js +0 -3
  417. package/dist/deps/html-stream-server.js.map +0 -1
  418. package/dist/deps/rsc.d.ts +0 -2
  419. package/dist/deps/rsc.d.ts.map +0 -1
  420. package/dist/deps/rsc.js +0 -4
  421. package/dist/deps/rsc.js.map +0 -1
  422. package/dist/deps/ssr.d.ts +0 -2
  423. package/dist/deps/ssr.d.ts.map +0 -1
  424. package/dist/deps/ssr.js +0 -3
  425. package/dist/deps/ssr.js.map +0 -1
  426. package/dist/errors.d.ts +0 -174
  427. package/dist/errors.d.ts.map +0 -1
  428. package/dist/errors.js +0 -241
  429. package/dist/errors.js.map +0 -1
  430. package/dist/handle.d.ts +0 -78
  431. package/dist/handle.d.ts.map +0 -1
  432. package/dist/handle.js +0 -82
  433. package/dist/handle.js.map +0 -1
  434. package/dist/handles/MetaTags.d.ts +0 -14
  435. package/dist/handles/MetaTags.d.ts.map +0 -1
  436. package/dist/handles/MetaTags.js +0 -136
  437. package/dist/handles/MetaTags.js.map +0 -1
  438. package/dist/handles/index.d.ts +0 -6
  439. package/dist/handles/index.d.ts.map +0 -1
  440. package/dist/handles/index.js +0 -6
  441. package/dist/handles/index.js.map +0 -1
  442. package/dist/handles/meta.d.ts +0 -39
  443. package/dist/handles/meta.d.ts.map +0 -1
  444. package/dist/handles/meta.js +0 -202
  445. package/dist/handles/meta.js.map +0 -1
  446. package/dist/host/__tests__/errors.test.d.ts +0 -2
  447. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  448. package/dist/host/__tests__/errors.test.js +0 -76
  449. package/dist/host/__tests__/errors.test.js.map +0 -1
  450. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  451. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  452. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  453. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  454. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  455. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  456. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  457. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  458. package/dist/host/__tests__/router.test.d.ts +0 -2
  459. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  460. package/dist/host/__tests__/router.test.js +0 -241
  461. package/dist/host/__tests__/router.test.js.map +0 -1
  462. package/dist/host/__tests__/testing.test.d.ts +0 -2
  463. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  464. package/dist/host/__tests__/testing.test.js +0 -64
  465. package/dist/host/__tests__/testing.test.js.map +0 -1
  466. package/dist/host/__tests__/utils.test.d.ts +0 -2
  467. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  468. package/dist/host/__tests__/utils.test.js +0 -29
  469. package/dist/host/__tests__/utils.test.js.map +0 -1
  470. package/dist/host/cookie-handler.d.ts +0 -34
  471. package/dist/host/cookie-handler.d.ts.map +0 -1
  472. package/dist/host/cookie-handler.js +0 -124
  473. package/dist/host/cookie-handler.js.map +0 -1
  474. package/dist/host/errors.d.ts +0 -56
  475. package/dist/host/errors.d.ts.map +0 -1
  476. package/dist/host/errors.js +0 -79
  477. package/dist/host/errors.js.map +0 -1
  478. package/dist/host/index.d.ts +0 -29
  479. package/dist/host/index.d.ts.map +0 -1
  480. package/dist/host/index.js +0 -32
  481. package/dist/host/index.js.map +0 -1
  482. package/dist/host/pattern-matcher.d.ts +0 -36
  483. package/dist/host/pattern-matcher.d.ts.map +0 -1
  484. package/dist/host/pattern-matcher.js +0 -172
  485. package/dist/host/pattern-matcher.js.map +0 -1
  486. package/dist/host/router.d.ts +0 -26
  487. package/dist/host/router.d.ts.map +0 -1
  488. package/dist/host/router.js +0 -218
  489. package/dist/host/router.js.map +0 -1
  490. package/dist/host/testing.d.ts +0 -36
  491. package/dist/host/testing.d.ts.map +0 -1
  492. package/dist/host/testing.js +0 -55
  493. package/dist/host/testing.js.map +0 -1
  494. package/dist/host/types.d.ts +0 -115
  495. package/dist/host/types.d.ts.map +0 -1
  496. package/dist/host/types.js +0 -7
  497. package/dist/host/types.js.map +0 -1
  498. package/dist/host/utils.d.ts +0 -21
  499. package/dist/host/utils.d.ts.map +0 -1
  500. package/dist/host/utils.js +0 -23
  501. package/dist/host/utils.js.map +0 -1
  502. package/dist/href-client.d.ts +0 -131
  503. package/dist/href-client.d.ts.map +0 -1
  504. package/dist/href-client.js +0 -64
  505. package/dist/href-client.js.map +0 -1
  506. package/dist/href-context.d.ts +0 -29
  507. package/dist/href-context.d.ts.map +0 -1
  508. package/dist/href-context.js +0 -21
  509. package/dist/href-context.js.map +0 -1
  510. package/dist/index.d.ts +0 -73
  511. package/dist/index.d.ts.map +0 -1
  512. package/dist/index.js +0 -91
  513. package/dist/index.js.map +0 -1
  514. package/dist/index.rsc.d.ts +0 -32
  515. package/dist/index.rsc.d.ts.map +0 -1
  516. package/dist/index.rsc.js +0 -40
  517. package/dist/index.rsc.js.map +0 -1
  518. package/dist/internal-debug.d.ts +0 -2
  519. package/dist/internal-debug.d.ts.map +0 -1
  520. package/dist/internal-debug.js +0 -5
  521. package/dist/internal-debug.js.map +0 -1
  522. package/dist/loader.d.ts +0 -14
  523. package/dist/loader.d.ts.map +0 -1
  524. package/dist/loader.js +0 -20
  525. package/dist/loader.js.map +0 -1
  526. package/dist/loader.rsc.d.ts +0 -19
  527. package/dist/loader.rsc.d.ts.map +0 -1
  528. package/dist/loader.rsc.js +0 -99
  529. package/dist/loader.rsc.js.map +0 -1
  530. package/dist/network-error-thrower.d.ts +0 -17
  531. package/dist/network-error-thrower.d.ts.map +0 -1
  532. package/dist/network-error-thrower.js +0 -14
  533. package/dist/network-error-thrower.js.map +0 -1
  534. package/dist/outlet-context.d.ts +0 -13
  535. package/dist/outlet-context.d.ts.map +0 -1
  536. package/dist/outlet-context.js +0 -3
  537. package/dist/outlet-context.js.map +0 -1
  538. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  539. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  540. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  541. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  542. package/dist/prerender/param-hash.d.ts +0 -16
  543. package/dist/prerender/param-hash.d.ts.map +0 -1
  544. package/dist/prerender/param-hash.js +0 -36
  545. package/dist/prerender/param-hash.js.map +0 -1
  546. package/dist/prerender/store.d.ts +0 -38
  547. package/dist/prerender/store.d.ts.map +0 -1
  548. package/dist/prerender/store.js +0 -61
  549. package/dist/prerender/store.js.map +0 -1
  550. package/dist/prerender.d.ts +0 -66
  551. package/dist/prerender.d.ts.map +0 -1
  552. package/dist/prerender.js +0 -57
  553. package/dist/prerender.js.map +0 -1
  554. package/dist/reverse.d.ts +0 -196
  555. package/dist/reverse.d.ts.map +0 -1
  556. package/dist/reverse.js +0 -78
  557. package/dist/reverse.js.map +0 -1
  558. package/dist/root-error-boundary.d.ts +0 -33
  559. package/dist/root-error-boundary.d.ts.map +0 -1
  560. package/dist/root-error-boundary.js +0 -165
  561. package/dist/root-error-boundary.js.map +0 -1
  562. package/dist/route-content-wrapper.d.ts +0 -46
  563. package/dist/route-content-wrapper.d.ts.map +0 -1
  564. package/dist/route-content-wrapper.js +0 -77
  565. package/dist/route-content-wrapper.js.map +0 -1
  566. package/dist/route-definition.d.ts +0 -421
  567. package/dist/route-definition.d.ts.map +0 -1
  568. package/dist/route-definition.js +0 -868
  569. package/dist/route-definition.js.map +0 -1
  570. package/dist/route-map-builder.d.ts +0 -155
  571. package/dist/route-map-builder.d.ts.map +0 -1
  572. package/dist/route-map-builder.js +0 -237
  573. package/dist/route-map-builder.js.map +0 -1
  574. package/dist/route-types.d.ts +0 -165
  575. package/dist/route-types.d.ts.map +0 -1
  576. package/dist/route-types.js +0 -7
  577. package/dist/route-types.js.map +0 -1
  578. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  579. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  580. package/dist/router/__tests__/handler-context.test.js +0 -65
  581. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  582. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  583. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  584. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  585. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  586. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  587. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  588. package/dist/router/__tests__/match-context.test.js +0 -92
  589. package/dist/router/__tests__/match-context.test.js.map +0 -1
  590. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  591. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  592. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  593. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  594. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  595. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  596. package/dist/router/__tests__/match-result.test.js +0 -457
  597. package/dist/router/__tests__/match-result.test.js.map +0 -1
  598. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  599. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  600. package/dist/router/__tests__/on-error.test.js +0 -678
  601. package/dist/router/__tests__/on-error.test.js.map +0 -1
  602. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  603. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  604. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  605. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  606. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  607. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  608. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  609. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  610. package/dist/router/error-handling.d.ts +0 -77
  611. package/dist/router/error-handling.d.ts.map +0 -1
  612. package/dist/router/error-handling.js +0 -202
  613. package/dist/router/error-handling.js.map +0 -1
  614. package/dist/router/handler-context.d.ts +0 -20
  615. package/dist/router/handler-context.d.ts.map +0 -1
  616. package/dist/router/handler-context.js +0 -198
  617. package/dist/router/handler-context.js.map +0 -1
  618. package/dist/router/intercept-resolution.d.ts +0 -66
  619. package/dist/router/intercept-resolution.d.ts.map +0 -1
  620. package/dist/router/intercept-resolution.js +0 -246
  621. package/dist/router/intercept-resolution.js.map +0 -1
  622. package/dist/router/loader-resolution.d.ts +0 -64
  623. package/dist/router/loader-resolution.d.ts.map +0 -1
  624. package/dist/router/loader-resolution.js +0 -284
  625. package/dist/router/loader-resolution.js.map +0 -1
  626. package/dist/router/logging.d.ts +0 -15
  627. package/dist/router/logging.d.ts.map +0 -1
  628. package/dist/router/logging.js +0 -99
  629. package/dist/router/logging.js.map +0 -1
  630. package/dist/router/manifest.d.ts +0 -22
  631. package/dist/router/manifest.d.ts.map +0 -1
  632. package/dist/router/manifest.js +0 -181
  633. package/dist/router/manifest.js.map +0 -1
  634. package/dist/router/match-api.d.ts +0 -35
  635. package/dist/router/match-api.d.ts.map +0 -1
  636. package/dist/router/match-api.js +0 -406
  637. package/dist/router/match-api.js.map +0 -1
  638. package/dist/router/match-context.d.ts +0 -206
  639. package/dist/router/match-context.d.ts.map +0 -1
  640. package/dist/router/match-context.js +0 -17
  641. package/dist/router/match-context.js.map +0 -1
  642. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  643. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  644. package/dist/router/match-middleware/background-revalidation.js +0 -75
  645. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  646. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  647. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  648. package/dist/router/match-middleware/cache-lookup.js +0 -257
  649. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  650. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  651. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  652. package/dist/router/match-middleware/cache-store.js +0 -108
  653. package/dist/router/match-middleware/cache-store.js.map +0 -1
  654. package/dist/router/match-middleware/index.d.ts +0 -81
  655. package/dist/router/match-middleware/index.d.ts.map +0 -1
  656. package/dist/router/match-middleware/index.js +0 -80
  657. package/dist/router/match-middleware/index.js.map +0 -1
  658. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  659. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  660. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  661. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  662. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  663. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  664. package/dist/router/match-middleware/segment-resolution.js +0 -53
  665. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  666. package/dist/router/match-pipelines.d.ts +0 -147
  667. package/dist/router/match-pipelines.d.ts.map +0 -1
  668. package/dist/router/match-pipelines.js +0 -82
  669. package/dist/router/match-pipelines.js.map +0 -1
  670. package/dist/router/match-result.d.ts +0 -126
  671. package/dist/router/match-result.d.ts.map +0 -1
  672. package/dist/router/match-result.js +0 -93
  673. package/dist/router/match-result.js.map +0 -1
  674. package/dist/router/metrics.d.ts +0 -20
  675. package/dist/router/metrics.d.ts.map +0 -1
  676. package/dist/router/metrics.js +0 -47
  677. package/dist/router/metrics.js.map +0 -1
  678. package/dist/router/middleware.d.ts +0 -249
  679. package/dist/router/middleware.d.ts.map +0 -1
  680. package/dist/router/middleware.js +0 -434
  681. package/dist/router/middleware.js.map +0 -1
  682. package/dist/router/middleware.test.d.ts +0 -2
  683. package/dist/router/middleware.test.d.ts.map +0 -1
  684. package/dist/router/middleware.test.js +0 -816
  685. package/dist/router/middleware.test.js.map +0 -1
  686. package/dist/router/pattern-matching.d.ts +0 -149
  687. package/dist/router/pattern-matching.d.ts.map +0 -1
  688. package/dist/router/pattern-matching.js +0 -349
  689. package/dist/router/pattern-matching.js.map +0 -1
  690. package/dist/router/revalidation.d.ts +0 -44
  691. package/dist/router/revalidation.d.ts.map +0 -1
  692. package/dist/router/revalidation.js +0 -147
  693. package/dist/router/revalidation.js.map +0 -1
  694. package/dist/router/router-context.d.ts +0 -135
  695. package/dist/router/router-context.d.ts.map +0 -1
  696. package/dist/router/router-context.js +0 -36
  697. package/dist/router/router-context.js.map +0 -1
  698. package/dist/router/segment-resolution.d.ts +0 -127
  699. package/dist/router/segment-resolution.d.ts.map +0 -1
  700. package/dist/router/segment-resolution.js +0 -919
  701. package/dist/router/segment-resolution.js.map +0 -1
  702. package/dist/router/trie-matching.d.ts +0 -40
  703. package/dist/router/trie-matching.d.ts.map +0 -1
  704. package/dist/router/trie-matching.js +0 -127
  705. package/dist/router/trie-matching.js.map +0 -1
  706. package/dist/router/types.d.ts +0 -136
  707. package/dist/router/types.d.ts.map +0 -1
  708. package/dist/router/types.js +0 -7
  709. package/dist/router/types.js.map +0 -1
  710. package/dist/router.d.ts +0 -753
  711. package/dist/router.d.ts.map +0 -1
  712. package/dist/router.gen.d.ts +0 -6
  713. package/dist/router.gen.d.ts.map +0 -1
  714. package/dist/router.gen.js +0 -6
  715. package/dist/router.gen.js.map +0 -1
  716. package/dist/router.js +0 -1304
  717. package/dist/router.js.map +0 -1
  718. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  719. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  720. package/dist/rsc/__tests__/helpers.test.js +0 -140
  721. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  722. package/dist/rsc/handler.d.ts +0 -45
  723. package/dist/rsc/handler.d.ts.map +0 -1
  724. package/dist/rsc/handler.js +0 -1172
  725. package/dist/rsc/handler.js.map +0 -1
  726. package/dist/rsc/helpers.d.ts +0 -16
  727. package/dist/rsc/helpers.d.ts.map +0 -1
  728. package/dist/rsc/helpers.js +0 -55
  729. package/dist/rsc/helpers.js.map +0 -1
  730. package/dist/rsc/index.d.ts +0 -22
  731. package/dist/rsc/index.d.ts.map +0 -1
  732. package/dist/rsc/index.js +0 -23
  733. package/dist/rsc/index.js.map +0 -1
  734. package/dist/rsc/nonce.d.ts +0 -9
  735. package/dist/rsc/nonce.d.ts.map +0 -1
  736. package/dist/rsc/nonce.js +0 -18
  737. package/dist/rsc/nonce.js.map +0 -1
  738. package/dist/rsc/types.d.ts +0 -206
  739. package/dist/rsc/types.d.ts.map +0 -1
  740. package/dist/rsc/types.js +0 -8
  741. package/dist/rsc/types.js.map +0 -1
  742. package/dist/search-params.d.ts +0 -103
  743. package/dist/search-params.d.ts.map +0 -1
  744. package/dist/search-params.js +0 -74
  745. package/dist/search-params.js.map +0 -1
  746. package/dist/segment-system.d.ts +0 -75
  747. package/dist/segment-system.d.ts.map +0 -1
  748. package/dist/segment-system.js +0 -336
  749. package/dist/segment-system.js.map +0 -1
  750. package/dist/server/context.d.ts +0 -245
  751. package/dist/server/context.d.ts.map +0 -1
  752. package/dist/server/context.js +0 -197
  753. package/dist/server/context.js.map +0 -1
  754. package/dist/server/fetchable-loader-store.d.ts +0 -18
  755. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  756. package/dist/server/fetchable-loader-store.js +0 -18
  757. package/dist/server/fetchable-loader-store.js.map +0 -1
  758. package/dist/server/handle-store.d.ts +0 -85
  759. package/dist/server/handle-store.d.ts.map +0 -1
  760. package/dist/server/handle-store.js +0 -142
  761. package/dist/server/handle-store.js.map +0 -1
  762. package/dist/server/loader-registry.d.ts +0 -55
  763. package/dist/server/loader-registry.d.ts.map +0 -1
  764. package/dist/server/loader-registry.js +0 -132
  765. package/dist/server/loader-registry.js.map +0 -1
  766. package/dist/server/request-context.d.ts +0 -226
  767. package/dist/server/request-context.d.ts.map +0 -1
  768. package/dist/server/request-context.js +0 -290
  769. package/dist/server/request-context.js.map +0 -1
  770. package/dist/server/root-layout.d.ts +0 -4
  771. package/dist/server/root-layout.d.ts.map +0 -1
  772. package/dist/server/root-layout.js +0 -5
  773. package/dist/server/root-layout.js.map +0 -1
  774. package/dist/server.d.ts +0 -15
  775. package/dist/server.d.ts.map +0 -1
  776. package/dist/server.js +0 -20
  777. package/dist/server.js.map +0 -1
  778. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  779. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  780. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  781. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  782. package/dist/ssr/index.d.ts +0 -98
  783. package/dist/ssr/index.d.ts.map +0 -1
  784. package/dist/ssr/index.js +0 -158
  785. package/dist/ssr/index.js.map +0 -1
  786. package/dist/static-handler.d.ts +0 -50
  787. package/dist/static-handler.d.ts.map +0 -1
  788. package/dist/static-handler.gen.d.ts +0 -5
  789. package/dist/static-handler.gen.d.ts.map +0 -1
  790. package/dist/static-handler.gen.js +0 -5
  791. package/dist/static-handler.gen.js.map +0 -1
  792. package/dist/static-handler.js +0 -29
  793. package/dist/static-handler.js.map +0 -1
  794. package/dist/theme/ThemeProvider.d.ts +0 -20
  795. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  796. package/dist/theme/ThemeProvider.js +0 -240
  797. package/dist/theme/ThemeProvider.js.map +0 -1
  798. package/dist/theme/ThemeScript.d.ts +0 -48
  799. package/dist/theme/ThemeScript.d.ts.map +0 -1
  800. package/dist/theme/ThemeScript.js +0 -13
  801. package/dist/theme/ThemeScript.js.map +0 -1
  802. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  803. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  804. package/dist/theme/__tests__/theme.test.js +0 -103
  805. package/dist/theme/__tests__/theme.test.js.map +0 -1
  806. package/dist/theme/constants.d.ts +0 -29
  807. package/dist/theme/constants.d.ts.map +0 -1
  808. package/dist/theme/constants.js +0 -48
  809. package/dist/theme/constants.js.map +0 -1
  810. package/dist/theme/index.d.ts +0 -31
  811. package/dist/theme/index.d.ts.map +0 -1
  812. package/dist/theme/index.js +0 -36
  813. package/dist/theme/index.js.map +0 -1
  814. package/dist/theme/theme-context.d.ts +0 -40
  815. package/dist/theme/theme-context.d.ts.map +0 -1
  816. package/dist/theme/theme-context.js +0 -60
  817. package/dist/theme/theme-context.js.map +0 -1
  818. package/dist/theme/theme-script.d.ts +0 -27
  819. package/dist/theme/theme-script.d.ts.map +0 -1
  820. package/dist/theme/theme-script.js +0 -147
  821. package/dist/theme/theme-script.js.map +0 -1
  822. package/dist/theme/types.d.ts +0 -163
  823. package/dist/theme/types.d.ts.map +0 -1
  824. package/dist/theme/types.js +0 -11
  825. package/dist/theme/types.js.map +0 -1
  826. package/dist/theme/use-theme.d.ts +0 -12
  827. package/dist/theme/use-theme.d.ts.map +0 -1
  828. package/dist/theme/use-theme.js +0 -40
  829. package/dist/theme/use-theme.js.map +0 -1
  830. package/dist/types.d.ts +0 -1479
  831. package/dist/types.d.ts.map +0 -1
  832. package/dist/types.js +0 -10
  833. package/dist/types.js.map +0 -1
  834. package/dist/urls.d.ts +0 -441
  835. package/dist/urls.d.ts.map +0 -1
  836. package/dist/urls.gen.d.ts +0 -8
  837. package/dist/urls.gen.d.ts.map +0 -1
  838. package/dist/urls.gen.js +0 -8
  839. package/dist/urls.gen.js.map +0 -1
  840. package/dist/urls.js +0 -443
  841. package/dist/urls.js.map +0 -1
  842. package/dist/use-loader.d.ts +0 -127
  843. package/dist/use-loader.d.ts.map +0 -1
  844. package/dist/use-loader.js +0 -237
  845. package/dist/use-loader.js.map +0 -1
  846. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  847. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  848. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  849. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  850. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  851. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  852. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  853. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  854. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  855. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  856. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  857. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  858. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  859. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  860. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  861. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  862. package/dist/vite/ast-handler-extract.d.ts +0 -49
  863. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  864. package/dist/vite/ast-handler-extract.js +0 -249
  865. package/dist/vite/ast-handler-extract.js.map +0 -1
  866. package/dist/vite/expose-action-id.d.ts +0 -19
  867. package/dist/vite/expose-action-id.d.ts.map +0 -1
  868. package/dist/vite/expose-action-id.js +0 -250
  869. package/dist/vite/expose-action-id.js.map +0 -1
  870. package/dist/vite/expose-id-utils.d.ts +0 -69
  871. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  872. package/dist/vite/expose-id-utils.js +0 -289
  873. package/dist/vite/expose-id-utils.js.map +0 -1
  874. package/dist/vite/expose-internal-ids.d.ts +0 -22
  875. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  876. package/dist/vite/expose-internal-ids.js +0 -886
  877. package/dist/vite/expose-internal-ids.js.map +0 -1
  878. package/dist/vite/index.d.ts +0 -149
  879. package/dist/vite/index.d.ts.map +0 -1
  880. package/dist/vite/index.js.map +0 -1
  881. package/dist/vite/index.named-routes.gen.ts +0 -103
  882. package/dist/vite/package-resolution.d.ts +0 -43
  883. package/dist/vite/package-resolution.d.ts.map +0 -1
  884. package/dist/vite/package-resolution.js +0 -112
  885. package/dist/vite/package-resolution.js.map +0 -1
  886. package/dist/vite/virtual-entries.d.ts +0 -25
  887. package/dist/vite/virtual-entries.d.ts.map +0 -1
  888. package/dist/vite/virtual-entries.js +0 -110
  889. package/dist/vite/virtual-entries.js.map +0 -1
@@ -2,7 +2,12 @@ import type { Plugin, ResolvedConfig } from "vite";
2
2
  import { parseAst } from "vite";
3
3
  import MagicString from "magic-string";
4
4
  import path from "node:path";
5
- import { normalizePath, hashId, detectImports } from "./expose-id-utils.js";
5
+ import {
6
+ normalizePath,
7
+ hashId,
8
+ makeStubId,
9
+ detectImports,
10
+ } from "./expose-id-utils.js";
6
11
  import {
7
12
  transformInlineHandlers,
8
13
  type VirtualHandlerEntry,
@@ -23,6 +28,7 @@ import {
23
28
  getImportedFnNames,
24
29
  collectCreateExportBindings,
25
30
  buildUnsupportedShapeWarning,
31
+ isExportOnlyFile,
26
32
  } from "./expose-ids/export-analysis.js";
27
33
  import {
28
34
  hasCreateLoaderImport,
@@ -34,6 +40,7 @@ import {
34
40
  transformLocationState,
35
41
  generateWholeFileStubs,
36
42
  generateExprStubs,
43
+ stubHandlerExprs,
37
44
  transformHandlerIds,
38
45
  } from "./expose-ids/handler-transform.js";
39
46
 
@@ -385,7 +392,9 @@ ${lazyImports.join(",\n")}
385
392
  if (stubResult) return stubResult;
386
393
  }
387
394
 
388
- // --- PrerenderHandler: non-RSC stub replacement ---
395
+ // --- PrerenderHandler: non-RSC whole-file stub replacement ---
396
+ // When ALL exports are Prerender() calls, replace the entire file.
397
+ // Mixed-export files are handled in the unified pipeline below.
389
398
  if (hasPrerenderHandlerCode && !isRscEnv) {
390
399
  const fnNames = getFnNames(PRERENDER_CONFIG.fnName);
391
400
  const bindings = getBindings(code, fnNames);
@@ -397,16 +406,6 @@ ${lazyImports.join(",\n")}
397
406
  isBuild,
398
407
  );
399
408
  if (wholeFile) return wholeFile;
400
-
401
- const exprStubs = generateExprStubs(
402
- PRERENDER_CONFIG,
403
- bindings,
404
- code,
405
- filePath,
406
- id,
407
- isBuild,
408
- );
409
- if (exprStubs) return exprStubs;
410
409
  }
411
410
 
412
411
  // --- PrerenderHandler: RSC build module tracking ---
@@ -467,7 +466,8 @@ ${lazyImports.join(",\n")}
467
466
  }
468
467
  }
469
468
 
470
- // --- StaticHandler: non-RSC stub replacement ---
469
+ // --- StaticHandler: non-RSC whole-file stub replacement ---
470
+ // When ALL exports are Static() calls, replace the entire file.
471
471
  if (hasStaticHandlerCode && !isRscEnv) {
472
472
  const fnNames = getFnNames(STATIC_CONFIG.fnName);
473
473
  const bindings = getBindings(code, fnNames);
@@ -479,16 +479,212 @@ ${lazyImports.join(",\n")}
479
479
  isBuild,
480
480
  );
481
481
  if (wholeFile) return wholeFile;
482
+ }
482
483
 
483
- const exprStubs = generateExprStubs(
484
- STATIC_CONFIG,
485
- bindings,
486
- code,
487
- filePath,
488
- id,
489
- isBuild,
490
- );
491
- if (exprStubs) return exprStubs;
484
+ // --- Mixed-type whole-file stub replacement (non-RSC) ---
485
+ // When the individual whole-file checks above fail (each only checks
486
+ // one type), the file has mixed exports (e.g. createLoader + Prerender).
487
+ // Gather ALL stub-safe bindings and check if they cover every export.
488
+ // If yes, replace the entire file with stubs — this strips server-only
489
+ // imports (node:fs, DB clients, etc.) that would crash in the browser.
490
+ //
491
+ // Only applies when the file contains Prerender/Static (the handler
492
+ // types that bring server-only code). Files with only loaders, handles,
493
+ // or locationState are handled correctly by the unified pipeline below.
494
+ //
495
+ // Loader, Prerender, and Static exports become plain { __brand, $$id }
496
+ // stubs. createHandle and createLocationState need their create*()
497
+ // functions to execute (collect registration / __rsc_ls_key), so their
498
+ // call expressions are preserved with only a @rangojs/router import.
499
+ // This strips all server-only imports while keeping the correct
500
+ // client contract for every export type.
501
+ if (!isRscEnv && (hasPrerenderHandlerCode || hasStaticHandlerCode)) {
502
+ const prerenderFnNames = hasPrerenderHandlerCode
503
+ ? getFnNames(PRERENDER_CONFIG.fnName)
504
+ : [];
505
+ const staticFnNames = hasStaticHandlerCode
506
+ ? getFnNames(STATIC_CONFIG.fnName)
507
+ : [];
508
+ const loaderFnNames = hasLoaderCode ? getFnNames("createLoader") : [];
509
+ const handleFnNames = hasHandleCode ? getFnNames("createHandle") : [];
510
+ const lsFnNames = hasLocationStateCode
511
+ ? getFnNames("createLocationState")
512
+ : [];
513
+
514
+ // Collect ALL recognized bindings to check export coverage
515
+ const allBindings: CreateExportBinding[] = [];
516
+ for (const fnNames of [
517
+ prerenderFnNames,
518
+ staticFnNames,
519
+ loaderFnNames,
520
+ handleFnNames,
521
+ lsFnNames,
522
+ ]) {
523
+ if (fnNames.length > 0) {
524
+ allBindings.push(...getBindings(code, fnNames));
525
+ }
526
+ }
527
+
528
+ // Check if preserved createHandle/createLocationState calls
529
+ // reference non-exported locals (e.g. helper functions, constants).
530
+ // If so, the whole-file stub would strip those locals, breaking
531
+ // the call. Fall through to the unified pipeline instead.
532
+ let canStubWholeFile =
533
+ allBindings.length > 0 && isExportOnlyFile(code, allBindings);
534
+
535
+ if (
536
+ canStubWholeFile &&
537
+ (handleFnNames.length > 0 || lsFnNames.length > 0)
538
+ ) {
539
+ const exportedLocals = new Set(allBindings.map((b) => b.localName));
540
+ // Collect bindings that would be stripped by whole-file replacement:
541
+ // local declarations and imported bindings from non-@rangojs/router
542
+ // modules. This is a regex-based heuristic — it intentionally skips
543
+ // edge cases (class decls, destructured bindings, combined
544
+ // default+named imports) since those rarely appear in route files.
545
+ const strippedBindings: string[] = [];
546
+
547
+ // Skip React Fast Refresh temporaries (_c, _c2, ...) which are
548
+ // injected by @vitejs/plugin-react in the client environment and
549
+ // would falsely trigger the bailout.
550
+ const localDeclPattern =
551
+ /(?:^|;|\n)\s*(?:const|let|var|function)\s+(\w+)/g;
552
+ let declMatch: RegExpExecArray | null;
553
+ while ((declMatch = localDeclPattern.exec(code)) !== null) {
554
+ const name = declMatch[1];
555
+ if (!exportedLocals.has(name) && !/^_c\d*$/.test(name)) {
556
+ strippedBindings.push(name);
557
+ }
558
+ }
559
+
560
+ const importPattern =
561
+ /import\s*\{([^}]*)\}\s*from\s*["'](?!@rangojs\/router)[^"']*["']/g;
562
+ let importMatch: RegExpExecArray | null;
563
+ while ((importMatch = importPattern.exec(code)) !== null) {
564
+ for (const spec of importMatch[1].split(",")) {
565
+ const m = spec
566
+ .trim()
567
+ .match(/^[A-Za-z_$][\w$]*(?:\s+as\s+([A-Za-z_$][\w$]*))?$/);
568
+ if (m) strippedBindings.push(m[1] || m[0].trim().split(/\s/)[0]);
569
+ }
570
+ }
571
+ const defaultImportPattern =
572
+ /import\s+([A-Za-z_$][\w$]*)\s+from\s*["'](?!@rangojs\/router)[^"']*["']/g;
573
+ while ((importMatch = defaultImportPattern.exec(code)) !== null) {
574
+ strippedBindings.push(importMatch[1]);
575
+ }
576
+ const nsImportPattern =
577
+ /import\s+\*\s+as\s+([A-Za-z_$][\w$]*)\s+from\s*["'](?!@rangojs\/router)[^"']*["']/g;
578
+ while ((importMatch = nsImportPattern.exec(code)) !== null) {
579
+ strippedBindings.push(importMatch[1]);
580
+ }
581
+
582
+ if (strippedBindings.length > 0) {
583
+ const preservedBindings = allBindings.filter((b) => {
584
+ const fc = code.slice(b.callExprStart, b.callOpenParenPos + 1);
585
+ return (
586
+ handleFnNames.some((n) => fc.includes(n)) ||
587
+ lsFnNames.some((n) => fc.includes(n))
588
+ );
589
+ });
590
+ const strippedRe = new RegExp(
591
+ `\\b(?:${strippedBindings.join("|")})\\b`,
592
+ );
593
+ canStubWholeFile = !preservedBindings.some((b) => {
594
+ const expr = code.slice(b.callExprStart, b.callCloseParenPos + 1);
595
+ return strippedRe.test(expr);
596
+ });
597
+ }
598
+ }
599
+
600
+ if (canStubWholeFile) {
601
+ const lines: string[] = [];
602
+ const neededImports: string[] = [];
603
+ if (handleFnNames.length > 0) neededImports.push("createHandle");
604
+ if (lsFnNames.length > 0) neededImports.push("createLocationState");
605
+ if (neededImports.length > 0) {
606
+ lines.push(
607
+ `import { ${neededImports.join(", ")} } from "@rangojs/router";`,
608
+ );
609
+ }
610
+
611
+ for (const binding of allBindings) {
612
+ const fnCall = code.slice(
613
+ binding.callExprStart,
614
+ binding.callOpenParenPos + 1,
615
+ );
616
+ const isHandle = handleFnNames.some((n) => fnCall.includes(n));
617
+ const isLocationState = lsFnNames.some((n) => fnCall.includes(n));
618
+
619
+ // Aliases share the primary name's ID (matches server transforms).
620
+ const primaryName = binding.exportNames[0];
621
+ const stubId = makeStubId(filePath, primaryName, isBuild);
622
+
623
+ if (isHandle || isLocationState) {
624
+ // Rewrite alias to canonical name since the stub file only
625
+ // imports canonical names from @rangojs/router.
626
+ // Strip React Fast Refresh `_c = ` wrappers from args
627
+ // (e.g. `_c = (segments) => ...` → `(segments) => ...`)
628
+ const rawArgs = code
629
+ .slice(binding.callOpenParenPos + 1, binding.callCloseParenPos)
630
+ .replace(/\b_c\d*\s*=\s*/g, "");
631
+ const canonicalName = isHandle
632
+ ? "createHandle"
633
+ : "createLocationState";
634
+ const activeFnNames = isHandle ? handleFnNames : lsFnNames;
635
+
636
+ // Reconstruct the function name (handling aliases + generics)
637
+ let rawCallee = code.slice(
638
+ binding.callExprStart,
639
+ binding.callOpenParenPos,
640
+ );
641
+ for (const alias of activeFnNames) {
642
+ if (alias !== canonicalName && rawCallee.startsWith(alias)) {
643
+ rawCallee = canonicalName + rawCallee.slice(alias.length);
644
+ break;
645
+ }
646
+ }
647
+
648
+ if (isHandle) {
649
+ // createHandle checks __injectedId DURING the call, so $$id
650
+ // must be a parameter, not a post-call property assignment.
651
+ const idParam =
652
+ binding.argCount === 0
653
+ ? `undefined, "${stubId}"`
654
+ : `, "${stubId}"`;
655
+ lines.push(
656
+ `export const ${primaryName} = ${rawCallee}(${rawArgs}${idParam});`,
657
+ );
658
+ lines.push(`${primaryName}.$$id = "${stubId}";`);
659
+ } else {
660
+ lines.push(
661
+ `export const ${primaryName} = ${rawCallee}(${rawArgs});`,
662
+ );
663
+ lines.push(
664
+ `${primaryName}.__rsc_ls_key = "__rsc_ls_${stubId}";`,
665
+ );
666
+ }
667
+ for (const name of binding.exportNames.slice(1)) {
668
+ lines.push(`export const ${name} = ${primaryName};`);
669
+ }
670
+ } else {
671
+ let brand = "loader";
672
+ if (prerenderFnNames.some((n) => fnCall.includes(n))) {
673
+ brand = PRERENDER_CONFIG.brand;
674
+ } else if (staticFnNames.some((n) => fnCall.includes(n))) {
675
+ brand = STATIC_CONFIG.brand;
676
+ }
677
+ lines.push(
678
+ `export const ${primaryName} = { __brand: "${brand}", $$id: "${stubId}" };`,
679
+ );
680
+ for (const name of binding.exportNames.slice(1)) {
681
+ lines.push(`export const ${name} = ${primaryName};`);
682
+ }
683
+ }
684
+ }
685
+
686
+ return { code: lines.join("\n") + "\n", map: null };
687
+ }
492
688
  }
493
689
 
494
690
  // --- StaticHandler: RSC build module tracking ---
@@ -535,27 +731,48 @@ ${lazyImports.join(",\n")}
535
731
  isBuild,
536
732
  ) || changed;
537
733
  }
538
- if (hasPrerenderHandlerCode && isRscEnv) {
734
+ if (hasPrerenderHandlerCode) {
539
735
  const fnNames = getFnNames(PRERENDER_CONFIG.fnName);
540
- changed =
541
- transformHandlerIds(
542
- PRERENDER_CONFIG,
543
- getBindings(code, fnNames),
544
- s,
545
- filePath,
546
- isBuild,
547
- ) || changed;
736
+ const bindings = getBindings(code, fnNames);
737
+ if (isRscEnv) {
738
+ changed =
739
+ transformHandlerIds(
740
+ PRERENDER_CONFIG,
741
+ bindings,
742
+ s,
743
+ filePath,
744
+ isBuild,
745
+ ) || changed;
746
+ } else {
747
+ // Non-RSC mixed-export file: replace Prerender() calls with stubs
748
+ // on the shared MagicString so sourcemaps stay accurate.
749
+ changed =
750
+ stubHandlerExprs(
751
+ PRERENDER_CONFIG,
752
+ bindings,
753
+ s,
754
+ filePath,
755
+ isBuild,
756
+ ) || changed;
757
+ }
548
758
  }
549
- if (hasStaticHandlerCode && isRscEnv) {
759
+ if (hasStaticHandlerCode) {
550
760
  const fnNames = getFnNames(STATIC_CONFIG.fnName);
551
- changed =
552
- transformHandlerIds(
553
- STATIC_CONFIG,
554
- getBindings(code, fnNames),
555
- s,
556
- filePath,
557
- isBuild,
558
- ) || changed;
761
+ const bindings = getBindings(code, fnNames);
762
+ if (isRscEnv) {
763
+ changed =
764
+ transformHandlerIds(
765
+ STATIC_CONFIG,
766
+ bindings,
767
+ s,
768
+ filePath,
769
+ isBuild,
770
+ ) || changed;
771
+ } else {
772
+ changed =
773
+ stubHandlerExprs(STATIC_CONFIG, bindings, s, filePath, isBuild) ||
774
+ changed;
775
+ }
559
776
  }
560
777
 
561
778
  if (!changed) return;
package/src/vite/rango.ts CHANGED
@@ -453,7 +453,8 @@ export async function rango(options?: RangoOptions): Promise<PluginOption[]> {
453
453
  createRouterDiscoveryPlugin(discoveryEntryPath, {
454
454
  routerPathRef: discoveryRouterRef,
455
455
  enableBuildPrerender: prerenderEnabled,
456
- staticRouteTypesGeneration: resolvedOptions.staticRouteTypesGeneration,
456
+ buildEnv: options?.buildEnv,
457
+ preset,
457
458
  }),
458
459
  );
459
460
 
@@ -10,6 +10,8 @@ import type { Plugin } from "vite";
10
10
  import { createServer as createViteServer } from "vite";
11
11
  import { resolve } from "node:path";
12
12
  import { readFileSync } from "node:fs";
13
+ import { createRequire } from "node:module";
14
+ import { pathToFileURL } from "node:url";
13
15
  import {
14
16
  formatNestedRouterConflictError,
15
17
  findNestedRouterConflict,
@@ -94,6 +96,105 @@ async function createTempRscServer(
94
96
  });
95
97
  }
96
98
 
99
+ // ============================================================================
100
+ // Build-Time Env Resolution
101
+ // ============================================================================
102
+
103
+ import type {
104
+ BuildEnvOption,
105
+ BuildEnvFactoryContext,
106
+ BuildEnvResult,
107
+ } from "./plugin-types.js";
108
+
109
+ /**
110
+ * Resolve the buildEnv option into a concrete { env, dispose? } result.
111
+ * Handles all four input shapes: false, "auto", factory, plain object.
112
+ */
113
+ async function resolveBuildEnv(
114
+ option: BuildEnvOption | undefined,
115
+ factoryCtx: BuildEnvFactoryContext,
116
+ ): Promise<BuildEnvResult | null> {
117
+ if (!option) return null;
118
+
119
+ if (option === "auto") {
120
+ if (factoryCtx.preset !== "cloudflare") {
121
+ throw new Error(
122
+ '[rsc-router] buildEnv: "auto" is only supported with preset: "cloudflare". ' +
123
+ "Use a factory function or plain object for other presets.",
124
+ );
125
+ }
126
+ try {
127
+ // Resolve wrangler from the user's project root (not the router package)
128
+ const userRequire = createRequire(
129
+ resolve(factoryCtx.root, "package.json"),
130
+ );
131
+ const wranglerPath = userRequire.resolve("wrangler");
132
+ const { getPlatformProxy } = (await import(
133
+ pathToFileURL(wranglerPath).href
134
+ )) as {
135
+ getPlatformProxy: (opts?: any) => Promise<any>;
136
+ };
137
+ const proxy = await getPlatformProxy();
138
+ return {
139
+ env: proxy.env as Record<string, unknown>,
140
+ dispose: proxy.dispose,
141
+ };
142
+ } catch (err: any) {
143
+ throw new Error(
144
+ '[rsc-router] buildEnv: "auto" requires wrangler to be installed.\n' +
145
+ `Install it with: pnpm add -D wrangler\n${err.message}`,
146
+ );
147
+ }
148
+ }
149
+
150
+ if (typeof option === "function") {
151
+ return await option(factoryCtx);
152
+ }
153
+
154
+ // Plain object
155
+ return { env: option };
156
+ }
157
+
158
+ /**
159
+ * Acquire build-time env bindings and store on discovery state.
160
+ * Returns true if env was acquired, false if buildEnv is disabled.
161
+ */
162
+ async function acquireBuildEnv(
163
+ s: DiscoveryState,
164
+ command: "serve" | "build",
165
+ mode: string,
166
+ ): Promise<boolean> {
167
+ const option = s.opts?.buildEnv;
168
+ if (!option) return false;
169
+
170
+ const result = await resolveBuildEnv(option, {
171
+ root: s.projectRoot,
172
+ mode,
173
+ command,
174
+ preset: s.opts?.preset ?? "node",
175
+ });
176
+ if (!result) return false;
177
+
178
+ s.resolvedBuildEnv = result.env;
179
+ s.buildEnvDispose = result.dispose ?? null;
180
+ return true;
181
+ }
182
+
183
+ /**
184
+ * Release build-time env resources and clear state.
185
+ */
186
+ async function releaseBuildEnv(s: DiscoveryState): Promise<void> {
187
+ if (s.buildEnvDispose) {
188
+ try {
189
+ await s.buildEnvDispose();
190
+ } catch (err: any) {
191
+ console.warn(`[rsc-router] buildEnv dispose failed: ${err.message}`);
192
+ }
193
+ s.buildEnvDispose = null;
194
+ }
195
+ s.resolvedBuildEnv = undefined;
196
+ }
197
+
97
198
  /**
98
199
  * Plugin that discovers router instances at dev/build time via the RSC environment.
99
200
  *
@@ -111,6 +212,8 @@ export function createRouterDiscoveryPlugin(
111
212
  opts?: PluginOptions,
112
213
  ): Plugin {
113
214
  const s = createDiscoveryState(entryPath, opts);
215
+ let viteCommand: "serve" | "build" = "build";
216
+ let viteMode = "production";
114
217
 
115
218
  return {
116
219
  name: "@rangojs/router:discovery",
@@ -121,32 +224,20 @@ export function createRouterDiscoveryPlugin(
121
224
  __RANGO_DEBUG__: JSON.stringify(!!process.env.INTERNAL_RANGO_DEBUG),
122
225
  },
123
226
  };
124
- if (opts?.enableBuildPrerender) {
125
- config.environments = {
126
- rsc: {
127
- build: {
128
- rollupOptions: {
129
- output: {
130
- manualChunks(id: string) {
131
- if (s.resolvedPrerenderModules?.has(id)) {
132
- return "__prerender-handlers";
133
- }
134
- if (s.resolvedStaticModules?.has(id)) {
135
- return "__static-handlers";
136
- }
137
- },
138
- },
139
- },
140
- },
141
- },
142
- };
143
- }
227
+ // Prerender/static handler modules are bundled naturally with the
228
+ // rest of the RSC entry. A previous design forced them into dedicated
229
+ // __prerender-handlers / __static-handlers chunks via manualChunks,
230
+ // but Rollup hoisted all shared dependencies into those chunks,
231
+ // inflating them to ~1 MB with active runtime code. Handler code is
232
+ // evicted in closeBundle regardless of which chunk it lands in.
144
233
  return config;
145
234
  },
146
235
 
147
236
  configResolved(config) {
148
237
  s.projectRoot = config.root;
149
238
  s.isBuildMode = config.command === "build";
239
+ viteCommand = config.command as "serve" | "build";
240
+ viteMode = config.mode;
150
241
  // Capture user's resolve aliases for the temp server
151
242
  s.userResolveAlias = config.resolve.alias;
152
243
  // Node preset: pick up auto-discovered router path from the config() hook.
@@ -217,12 +308,13 @@ export function createRouterDiscoveryPlugin(
217
308
  let prerenderTempServer: any = null;
218
309
  let prerenderNodeRegistry: Map<string, any> | null = null;
219
310
 
220
- // Clean up the temporary server when the dev server shuts down
311
+ // Clean up the temporary server and build env when the dev server shuts down
221
312
  server.httpServer?.on("close", () => {
222
313
  if (prerenderTempServer) {
223
314
  prerenderTempServer.close().catch(() => {});
224
315
  prerenderTempServer = null;
225
316
  }
317
+ releaseBuildEnv(s).catch(() => {});
226
318
  });
227
319
 
228
320
  async function getOrCreateTempServer(): Promise<any | null> {
@@ -262,6 +354,9 @@ export function createRouterDiscoveryPlugin(
262
354
  // Create a temp Node.js server to run runtime discovery and generate
263
355
  // named route types (static parser can't resolve factory calls).
264
356
  try {
357
+ // Acquire build-time env bindings for dev prerender
358
+ await acquireBuildEnv(s, viteCommand, viteMode);
359
+
265
360
  const tempRscEnv = await getOrCreateTempServer();
266
361
  if (tempRscEnv) {
267
362
  await discoverRouters(s, tempRscEnv);
@@ -278,6 +373,9 @@ export function createRouterDiscoveryPlugin(
278
373
  }
279
374
 
280
375
  try {
376
+ // Acquire build-time env bindings for dev prerender (Node.js path)
377
+ await acquireBuildEnv(s, viteCommand, viteMode);
378
+
281
379
  // Set the readiness gate BEFORE discovery so early requests
282
380
  // block until manifest is populated
283
381
  const serverMod = await rscEnv.runner.import(
@@ -382,9 +480,31 @@ export function createRouterDiscoveryPlugin(
382
480
  return;
383
481
  }
384
482
 
385
- // Prefer the main server's registry (Node.js preset: module runner available).
386
- // Fall back to a temp server for Cloudflare where the main RSC env uses workerd.
387
- let registry = mainRegistry;
483
+ // Import the user's entry module to force re-evaluation of any
484
+ // HMR-invalidated modules in the chain (entry router urls handlers).
485
+ // This ensures createRouter() re-runs with updated handler code before
486
+ // we read RouterRegistry. Without this, edits to prerender handler files
487
+ // produce stale content because the old router instance remains registered.
488
+ const rscEnv = (server.environments as any)?.rsc;
489
+ let registry: Map<string, any> | null = null;
490
+ if (rscEnv?.runner && s.resolvedEntryPath) {
491
+ try {
492
+ await rscEnv.runner.import(s.resolvedEntryPath);
493
+ const serverMod = await rscEnv.runner.import(
494
+ "@rangojs/router/server",
495
+ );
496
+ registry = serverMod.RouterRegistry ?? null;
497
+ } catch (err: any) {
498
+ console.warn(
499
+ `[rsc-router] Dev prerender module refresh failed: ${err.message}`,
500
+ );
501
+ res.statusCode = 500;
502
+ res.end(`Prerender handler error: ${err.message}`);
503
+ return;
504
+ }
505
+ } else {
506
+ registry = mainRegistry;
507
+ }
388
508
 
389
509
  if (!registry) {
390
510
  // No main registry: the RSC env has no module runner (Cloudflare dev).
@@ -413,6 +533,8 @@ export function createRouterDiscoveryPlugin(
413
533
  {},
414
534
  undefined,
415
535
  wantPassthrough,
536
+ s.resolvedBuildEnv,
537
+ true, // devMode: check getParams for passthrough routes
416
538
  );
417
539
  if (!result) continue;
418
540
  if (result.passthrough) continue;
@@ -601,6 +723,9 @@ export function createRouterDiscoveryPlugin(
601
723
  s.prerenderManifestEntries = null;
602
724
  s.staticManifestEntries = null;
603
725
 
726
+ // Acquire build-time env bindings if configured
727
+ await acquireBuildEnv(s, viteCommand, viteMode);
728
+
604
729
  let tempServer: any = null;
605
730
  // Signal to user-space code (e.g. reverse.ts) that build-time discovery
606
731
  // is active. Uses globalThis because the temp server's module runner
@@ -659,6 +784,7 @@ export function createRouterDiscoveryPlugin(
659
784
  if (tempServer) {
660
785
  await tempServer.close();
661
786
  }
787
+ await releaseBuildEnv(s);
662
788
  }
663
789
  },
664
790
 
@@ -719,33 +845,40 @@ export function createRouterDiscoveryPlugin(
719
845
  if (!s.resolvedPrerenderModules?.size && !s.resolvedStaticModules?.size)
720
846
  return;
721
847
 
848
+ // Clear maps at the start of each RSC generateBundle pass.
849
+ // Vite 6 multi-environment builds run RSC twice (analysis + production);
850
+ // clearing prevents stale/duplicate records from the analysis pass.
851
+ s.handlerChunkInfoMap.clear();
852
+ s.staticHandlerChunkInfoMap.clear();
853
+
722
854
  for (const [fileName, chunk] of Object.entries(bundle) as [
723
855
  string,
724
856
  any,
725
857
  ][]) {
726
858
  if (chunk.type !== "chunk") continue;
727
859
 
728
- // Prerender handlers chunk
729
- if (
730
- fileName.includes("__prerender-handlers") &&
731
- s.resolvedPrerenderModules?.size
732
- ) {
860
+ // Scan all chunks for handler exports (handlers may land in any chunk)
861
+ if (s.resolvedPrerenderModules?.size) {
733
862
  const handlers = extractHandlerExportsFromChunk(
734
863
  chunk.code,
735
864
  s.resolvedPrerenderModules,
736
865
  "Prerender",
737
- true,
866
+ false,
738
867
  );
739
868
  if (handlers.length > 0) {
740
- s.handlerChunkInfo = { fileName, exports: handlers };
869
+ const existing = s.handlerChunkInfoMap.get(fileName);
870
+ if (existing) {
871
+ existing.exports.push(...handlers);
872
+ } else {
873
+ s.handlerChunkInfoMap.set(fileName, {
874
+ fileName,
875
+ exports: handlers,
876
+ });
877
+ }
741
878
  }
742
879
  }
743
880
 
744
- // Static handlers chunk
745
- if (
746
- fileName.includes("__static-handlers") &&
747
- s.resolvedStaticModules?.size
748
- ) {
881
+ if (s.resolvedStaticModules?.size) {
749
882
  const handlers = extractHandlerExportsFromChunk(
750
883
  chunk.code,
751
884
  s.resolvedStaticModules,
@@ -753,7 +886,15 @@ export function createRouterDiscoveryPlugin(
753
886
  false,
754
887
  );
755
888
  if (handlers.length > 0) {
756
- s.staticHandlerChunkInfo = { fileName, exports: handlers };
889
+ const existing = s.staticHandlerChunkInfoMap.get(fileName);
890
+ if (existing) {
891
+ existing.exports.push(...handlers);
892
+ } else {
893
+ s.staticHandlerChunkInfoMap.set(fileName, {
894
+ fileName,
895
+ exports: handlers,
896
+ });
897
+ }
757
898
  }
758
899
  }
759
900
  }