@rangojs/router 0.0.0-experimental.65 → 0.0.0-experimental.655f3c16

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 (852) hide show
  1. package/dist/vite/index.js +253 -81
  2. package/package.json +3 -3
  3. package/skills/handler-use/SKILL.md +362 -0
  4. package/skills/intercept/SKILL.md +20 -0
  5. package/skills/layout/SKILL.md +22 -0
  6. package/skills/middleware/SKILL.md +32 -3
  7. package/skills/migrate-nextjs/SKILL.md +560 -0
  8. package/skills/migrate-react-router/SKILL.md +764 -0
  9. package/skills/parallel/SKILL.md +59 -0
  10. package/skills/rango/SKILL.md +24 -22
  11. package/skills/route/SKILL.md +24 -0
  12. package/src/browser/navigation-bridge.ts +7 -1
  13. package/src/browser/navigation-client.ts +34 -6
  14. package/src/browser/partial-update.ts +5 -0
  15. package/src/browser/prefetch/cache.ts +16 -6
  16. package/src/browser/prefetch/fetch.ts +60 -4
  17. package/src/browser/react/Link.tsx +25 -2
  18. package/src/browser/segment-reconciler.ts +81 -15
  19. package/src/build/route-trie.ts +50 -24
  20. package/src/client.tsx +3 -10
  21. package/src/index.ts +41 -9
  22. package/src/reverse.ts +4 -1
  23. package/src/route-definition/dsl-helpers.ts +159 -20
  24. package/src/route-definition/helpers-types.ts +57 -13
  25. package/src/router/handler-context.ts +4 -1
  26. package/src/router/loader-resolution.ts +70 -47
  27. package/src/router/match-middleware/cache-lookup.ts +10 -5
  28. package/src/router/match-middleware/segment-resolution.ts +1 -1
  29. package/src/router/match-result.ts +82 -4
  30. package/src/router/segment-resolution/fresh.ts +5 -0
  31. package/src/router/segment-resolution/revalidation.ts +7 -1
  32. package/src/rsc/handler.ts +13 -5
  33. package/src/rsc/loader-fetch.ts +23 -3
  34. package/src/rsc/progressive-enhancement.ts +10 -2
  35. package/src/rsc/rsc-rendering.ts +5 -1
  36. package/src/rsc/server-action.ts +6 -0
  37. package/src/rsc/types.ts +1 -0
  38. package/src/segment-content-promise.ts +38 -0
  39. package/src/segment-system.tsx +25 -11
  40. package/src/server/handle-store.ts +19 -0
  41. package/src/server/request-context.ts +30 -2
  42. package/src/types/segments.ts +4 -0
  43. package/src/urls/path-helper-types.ts +30 -4
  44. package/src/use-loader.tsx +4 -1
  45. package/src/vite/discovery/prerender-collection.ts +124 -83
  46. package/src/vite/plugins/expose-id-utils.ts +12 -0
  47. package/src/vite/plugins/expose-internal-ids.ts +213 -2
  48. package/src/vite/utils/prerender-utils.ts +20 -6
  49. package/dist/__internal.d.ts +0 -83
  50. package/dist/__internal.d.ts.map +0 -1
  51. package/dist/__internal.js +0 -19
  52. package/dist/__internal.js.map +0 -1
  53. package/dist/__mocks__/version.d.ts +0 -7
  54. package/dist/__mocks__/version.d.ts.map +0 -1
  55. package/dist/__mocks__/version.js +0 -7
  56. package/dist/__mocks__/version.js.map +0 -1
  57. package/dist/__tests__/client-href.test.d.ts +0 -2
  58. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  59. package/dist/__tests__/client-href.test.js +0 -74
  60. package/dist/__tests__/client-href.test.js.map +0 -1
  61. package/dist/__tests__/component-utils.test.d.ts +0 -2
  62. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  63. package/dist/__tests__/component-utils.test.js +0 -51
  64. package/dist/__tests__/component-utils.test.js.map +0 -1
  65. package/dist/__tests__/event-controller.test.d.ts +0 -2
  66. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  67. package/dist/__tests__/event-controller.test.js +0 -538
  68. package/dist/__tests__/event-controller.test.js.map +0 -1
  69. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  70. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  71. package/dist/__tests__/helpers/route-tree.js +0 -374
  72. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  73. package/dist/__tests__/match-result.test.d.ts +0 -2
  74. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  75. package/dist/__tests__/match-result.test.js +0 -154
  76. package/dist/__tests__/match-result.test.js.map +0 -1
  77. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  78. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  79. package/dist/__tests__/navigation-store.test.js +0 -440
  80. package/dist/__tests__/navigation-store.test.js.map +0 -1
  81. package/dist/__tests__/partial-update.test.d.ts +0 -2
  82. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  83. package/dist/__tests__/partial-update.test.js +0 -1009
  84. package/dist/__tests__/partial-update.test.js.map +0 -1
  85. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  86. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  87. package/dist/__tests__/reverse-types.test.js +0 -656
  88. package/dist/__tests__/reverse-types.test.js.map +0 -1
  89. package/dist/__tests__/route-definition.test.d.ts +0 -2
  90. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  91. package/dist/__tests__/route-definition.test.js +0 -55
  92. package/dist/__tests__/route-definition.test.js.map +0 -1
  93. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  94. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  95. package/dist/__tests__/router-helpers.test.js +0 -377
  96. package/dist/__tests__/router-helpers.test.js.map +0 -1
  97. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  98. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  99. package/dist/__tests__/router-integration-2.test.js +0 -426
  100. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  101. package/dist/__tests__/router-integration.test.d.ts +0 -2
  102. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  103. package/dist/__tests__/router-integration.test.js +0 -1051
  104. package/dist/__tests__/router-integration.test.js.map +0 -1
  105. package/dist/__tests__/search-params.test.d.ts +0 -5
  106. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  107. package/dist/__tests__/search-params.test.js +0 -306
  108. package/dist/__tests__/search-params.test.js.map +0 -1
  109. package/dist/__tests__/segment-system.test.d.ts +0 -2
  110. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  111. package/dist/__tests__/segment-system.test.js +0 -627
  112. package/dist/__tests__/segment-system.test.js.map +0 -1
  113. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  114. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  115. package/dist/__tests__/static-handler-types.test.js +0 -63
  116. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  117. package/dist/__tests__/urls.test.d.ts +0 -2
  118. package/dist/__tests__/urls.test.d.ts.map +0 -1
  119. package/dist/__tests__/urls.test.js +0 -421
  120. package/dist/__tests__/urls.test.js.map +0 -1
  121. package/dist/__tests__/use-mount.test.d.ts +0 -2
  122. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  123. package/dist/__tests__/use-mount.test.js +0 -35
  124. package/dist/__tests__/use-mount.test.js.map +0 -1
  125. package/dist/bin/rango.d.ts +0 -2
  126. package/dist/bin/rango.d.ts.map +0 -1
  127. package/dist/bin/rango.js.map +0 -1
  128. package/dist/browser/event-controller.d.ts +0 -191
  129. package/dist/browser/event-controller.d.ts.map +0 -1
  130. package/dist/browser/event-controller.js +0 -559
  131. package/dist/browser/event-controller.js.map +0 -1
  132. package/dist/browser/index.d.ts +0 -2
  133. package/dist/browser/index.d.ts.map +0 -1
  134. package/dist/browser/index.js +0 -14
  135. package/dist/browser/index.js.map +0 -1
  136. package/dist/browser/link-interceptor.d.ts +0 -38
  137. package/dist/browser/link-interceptor.d.ts.map +0 -1
  138. package/dist/browser/link-interceptor.js +0 -99
  139. package/dist/browser/link-interceptor.js.map +0 -1
  140. package/dist/browser/logging.d.ts +0 -10
  141. package/dist/browser/logging.d.ts.map +0 -1
  142. package/dist/browser/logging.js +0 -29
  143. package/dist/browser/logging.js.map +0 -1
  144. package/dist/browser/lru-cache.d.ts +0 -17
  145. package/dist/browser/lru-cache.d.ts.map +0 -1
  146. package/dist/browser/lru-cache.js +0 -50
  147. package/dist/browser/lru-cache.js.map +0 -1
  148. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  149. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  150. package/dist/browser/merge-segment-loaders.js +0 -102
  151. package/dist/browser/merge-segment-loaders.js.map +0 -1
  152. package/dist/browser/navigation-bridge.d.ts +0 -102
  153. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  154. package/dist/browser/navigation-bridge.js +0 -708
  155. package/dist/browser/navigation-bridge.js.map +0 -1
  156. package/dist/browser/navigation-client.d.ts +0 -25
  157. package/dist/browser/navigation-client.d.ts.map +0 -1
  158. package/dist/browser/navigation-client.js +0 -157
  159. package/dist/browser/navigation-client.js.map +0 -1
  160. package/dist/browser/navigation-store.d.ts +0 -101
  161. package/dist/browser/navigation-store.d.ts.map +0 -1
  162. package/dist/browser/navigation-store.js +0 -625
  163. package/dist/browser/navigation-store.js.map +0 -1
  164. package/dist/browser/partial-update.d.ts +0 -75
  165. package/dist/browser/partial-update.d.ts.map +0 -1
  166. package/dist/browser/partial-update.js +0 -426
  167. package/dist/browser/partial-update.js.map +0 -1
  168. package/dist/browser/react/Link.d.ts +0 -86
  169. package/dist/browser/react/Link.d.ts.map +0 -1
  170. package/dist/browser/react/Link.js +0 -128
  171. package/dist/browser/react/Link.js.map +0 -1
  172. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  173. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  174. package/dist/browser/react/NavigationProvider.js +0 -216
  175. package/dist/browser/react/NavigationProvider.js.map +0 -1
  176. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  177. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  178. package/dist/browser/react/ScrollRestoration.js +0 -57
  179. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  180. package/dist/browser/react/context.d.ts +0 -46
  181. package/dist/browser/react/context.d.ts.map +0 -1
  182. package/dist/browser/react/context.js +0 -10
  183. package/dist/browser/react/context.js.map +0 -1
  184. package/dist/browser/react/index.d.ts +0 -11
  185. package/dist/browser/react/index.d.ts.map +0 -1
  186. package/dist/browser/react/index.js +0 -22
  187. package/dist/browser/react/index.js.map +0 -1
  188. package/dist/browser/react/location-state-shared.d.ts +0 -63
  189. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  190. package/dist/browser/react/location-state-shared.js +0 -81
  191. package/dist/browser/react/location-state-shared.js.map +0 -1
  192. package/dist/browser/react/location-state.d.ts +0 -23
  193. package/dist/browser/react/location-state.d.ts.map +0 -1
  194. package/dist/browser/react/location-state.js +0 -29
  195. package/dist/browser/react/location-state.js.map +0 -1
  196. package/dist/browser/react/mount-context.d.ts +0 -24
  197. package/dist/browser/react/mount-context.d.ts.map +0 -1
  198. package/dist/browser/react/mount-context.js +0 -24
  199. package/dist/browser/react/mount-context.js.map +0 -1
  200. package/dist/browser/react/use-action.d.ts +0 -64
  201. package/dist/browser/react/use-action.d.ts.map +0 -1
  202. package/dist/browser/react/use-action.js +0 -134
  203. package/dist/browser/react/use-action.js.map +0 -1
  204. package/dist/browser/react/use-client-cache.d.ts +0 -41
  205. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  206. package/dist/browser/react/use-client-cache.js +0 -39
  207. package/dist/browser/react/use-client-cache.js.map +0 -1
  208. package/dist/browser/react/use-handle.d.ts +0 -31
  209. package/dist/browser/react/use-handle.d.ts.map +0 -1
  210. package/dist/browser/react/use-handle.js +0 -144
  211. package/dist/browser/react/use-handle.js.map +0 -1
  212. package/dist/browser/react/use-href.d.ts +0 -33
  213. package/dist/browser/react/use-href.d.ts.map +0 -1
  214. package/dist/browser/react/use-href.js +0 -39
  215. package/dist/browser/react/use-href.js.map +0 -1
  216. package/dist/browser/react/use-link-status.d.ts +0 -37
  217. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  218. package/dist/browser/react/use-link-status.js +0 -99
  219. package/dist/browser/react/use-link-status.js.map +0 -1
  220. package/dist/browser/react/use-mount.d.ts +0 -25
  221. package/dist/browser/react/use-mount.d.ts.map +0 -1
  222. package/dist/browser/react/use-mount.js +0 -30
  223. package/dist/browser/react/use-mount.js.map +0 -1
  224. package/dist/browser/react/use-navigation.d.ts +0 -27
  225. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  226. package/dist/browser/react/use-navigation.js +0 -87
  227. package/dist/browser/react/use-navigation.js.map +0 -1
  228. package/dist/browser/react/use-segments.d.ts +0 -38
  229. package/dist/browser/react/use-segments.d.ts.map +0 -1
  230. package/dist/browser/react/use-segments.js +0 -130
  231. package/dist/browser/react/use-segments.js.map +0 -1
  232. package/dist/browser/request-controller.d.ts +0 -26
  233. package/dist/browser/request-controller.d.ts.map +0 -1
  234. package/dist/browser/request-controller.js +0 -147
  235. package/dist/browser/request-controller.js.map +0 -1
  236. package/dist/browser/rsc-router.d.ts +0 -129
  237. package/dist/browser/rsc-router.d.ts.map +0 -1
  238. package/dist/browser/rsc-router.js +0 -195
  239. package/dist/browser/rsc-router.js.map +0 -1
  240. package/dist/browser/scroll-restoration.d.ts +0 -93
  241. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  242. package/dist/browser/scroll-restoration.js +0 -321
  243. package/dist/browser/scroll-restoration.js.map +0 -1
  244. package/dist/browser/segment-structure-assert.d.ts +0 -17
  245. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  246. package/dist/browser/segment-structure-assert.js +0 -59
  247. package/dist/browser/segment-structure-assert.js.map +0 -1
  248. package/dist/browser/server-action-bridge.d.ts +0 -26
  249. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  250. package/dist/browser/server-action-bridge.js +0 -668
  251. package/dist/browser/server-action-bridge.js.map +0 -1
  252. package/dist/browser/shallow.d.ts +0 -12
  253. package/dist/browser/shallow.d.ts.map +0 -1
  254. package/dist/browser/shallow.js +0 -34
  255. package/dist/browser/shallow.js.map +0 -1
  256. package/dist/browser/types.d.ts +0 -369
  257. package/dist/browser/types.d.ts.map +0 -1
  258. package/dist/browser/types.js +0 -2
  259. package/dist/browser/types.js.map +0 -1
  260. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  261. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  262. package/dist/build/__tests__/generate-cli.test.js +0 -237
  263. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  264. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  265. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  266. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  267. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  268. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  269. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  270. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  271. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  272. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  273. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  274. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  275. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  276. package/dist/build/generate-manifest.d.ts +0 -81
  277. package/dist/build/generate-manifest.d.ts.map +0 -1
  278. package/dist/build/generate-manifest.js +0 -276
  279. package/dist/build/generate-manifest.js.map +0 -1
  280. package/dist/build/generate-route-types.d.ts +0 -115
  281. package/dist/build/generate-route-types.d.ts.map +0 -1
  282. package/dist/build/generate-route-types.js +0 -740
  283. package/dist/build/generate-route-types.js.map +0 -1
  284. package/dist/build/index.d.ts +0 -21
  285. package/dist/build/index.d.ts.map +0 -1
  286. package/dist/build/index.js +0 -21
  287. package/dist/build/index.js.map +0 -1
  288. package/dist/build/route-trie.d.ts +0 -71
  289. package/dist/build/route-trie.d.ts.map +0 -1
  290. package/dist/build/route-trie.js +0 -175
  291. package/dist/build/route-trie.js.map +0 -1
  292. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  293. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  294. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  295. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  296. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  297. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  298. package/dist/cache/__tests__/document-cache.test.js +0 -345
  299. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  300. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  301. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  302. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  303. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  304. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  305. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  306. package/dist/cache/__tests__/memory-store.test.js +0 -367
  307. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  308. package/dist/cache/cache-scope.d.ts +0 -102
  309. package/dist/cache/cache-scope.d.ts.map +0 -1
  310. package/dist/cache/cache-scope.js +0 -440
  311. package/dist/cache/cache-scope.js.map +0 -1
  312. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  313. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  314. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  315. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  316. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  317. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  318. package/dist/cache/cf/cf-cache-store.js +0 -242
  319. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  320. package/dist/cache/cf/index.d.ts +0 -14
  321. package/dist/cache/cf/index.d.ts.map +0 -1
  322. package/dist/cache/cf/index.js +0 -17
  323. package/dist/cache/cf/index.js.map +0 -1
  324. package/dist/cache/document-cache.d.ts +0 -64
  325. package/dist/cache/document-cache.d.ts.map +0 -1
  326. package/dist/cache/document-cache.js +0 -228
  327. package/dist/cache/document-cache.js.map +0 -1
  328. package/dist/cache/index.d.ts +0 -19
  329. package/dist/cache/index.d.ts.map +0 -1
  330. package/dist/cache/index.js +0 -21
  331. package/dist/cache/index.js.map +0 -1
  332. package/dist/cache/memory-segment-store.d.ts +0 -110
  333. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  334. package/dist/cache/memory-segment-store.js +0 -117
  335. package/dist/cache/memory-segment-store.js.map +0 -1
  336. package/dist/cache/memory-store.d.ts +0 -41
  337. package/dist/cache/memory-store.d.ts.map +0 -1
  338. package/dist/cache/memory-store.js +0 -191
  339. package/dist/cache/memory-store.js.map +0 -1
  340. package/dist/cache/types.d.ts +0 -317
  341. package/dist/cache/types.d.ts.map +0 -1
  342. package/dist/cache/types.js +0 -12
  343. package/dist/cache/types.js.map +0 -1
  344. package/dist/client.d.ts +0 -248
  345. package/dist/client.d.ts.map +0 -1
  346. package/dist/client.js +0 -367
  347. package/dist/client.js.map +0 -1
  348. package/dist/client.rsc.d.ts +0 -26
  349. package/dist/client.rsc.d.ts.map +0 -1
  350. package/dist/client.rsc.js +0 -46
  351. package/dist/client.rsc.js.map +0 -1
  352. package/dist/component-utils.d.ts +0 -36
  353. package/dist/component-utils.d.ts.map +0 -1
  354. package/dist/component-utils.js +0 -61
  355. package/dist/component-utils.js.map +0 -1
  356. package/dist/components/DefaultDocument.d.ts +0 -13
  357. package/dist/components/DefaultDocument.d.ts.map +0 -1
  358. package/dist/components/DefaultDocument.js +0 -15
  359. package/dist/components/DefaultDocument.js.map +0 -1
  360. package/dist/debug.d.ts +0 -58
  361. package/dist/debug.d.ts.map +0 -1
  362. package/dist/debug.js +0 -157
  363. package/dist/debug.js.map +0 -1
  364. package/dist/default-error-boundary.d.ts +0 -11
  365. package/dist/default-error-boundary.d.ts.map +0 -1
  366. package/dist/default-error-boundary.js +0 -45
  367. package/dist/default-error-boundary.js.map +0 -1
  368. package/dist/deps/browser.d.ts +0 -2
  369. package/dist/deps/browser.d.ts.map +0 -1
  370. package/dist/deps/browser.js +0 -3
  371. package/dist/deps/browser.js.map +0 -1
  372. package/dist/deps/html-stream-client.d.ts +0 -2
  373. package/dist/deps/html-stream-client.d.ts.map +0 -1
  374. package/dist/deps/html-stream-client.js +0 -3
  375. package/dist/deps/html-stream-client.js.map +0 -1
  376. package/dist/deps/html-stream-server.d.ts +0 -2
  377. package/dist/deps/html-stream-server.d.ts.map +0 -1
  378. package/dist/deps/html-stream-server.js +0 -3
  379. package/dist/deps/html-stream-server.js.map +0 -1
  380. package/dist/deps/rsc.d.ts +0 -2
  381. package/dist/deps/rsc.d.ts.map +0 -1
  382. package/dist/deps/rsc.js +0 -4
  383. package/dist/deps/rsc.js.map +0 -1
  384. package/dist/deps/ssr.d.ts +0 -2
  385. package/dist/deps/ssr.d.ts.map +0 -1
  386. package/dist/deps/ssr.js +0 -3
  387. package/dist/deps/ssr.js.map +0 -1
  388. package/dist/errors.d.ts +0 -174
  389. package/dist/errors.d.ts.map +0 -1
  390. package/dist/errors.js +0 -241
  391. package/dist/errors.js.map +0 -1
  392. package/dist/handle.d.ts +0 -78
  393. package/dist/handle.d.ts.map +0 -1
  394. package/dist/handle.js +0 -82
  395. package/dist/handle.js.map +0 -1
  396. package/dist/handles/MetaTags.d.ts +0 -14
  397. package/dist/handles/MetaTags.d.ts.map +0 -1
  398. package/dist/handles/MetaTags.js +0 -136
  399. package/dist/handles/MetaTags.js.map +0 -1
  400. package/dist/handles/index.d.ts +0 -6
  401. package/dist/handles/index.d.ts.map +0 -1
  402. package/dist/handles/index.js +0 -6
  403. package/dist/handles/index.js.map +0 -1
  404. package/dist/handles/meta.d.ts +0 -39
  405. package/dist/handles/meta.d.ts.map +0 -1
  406. package/dist/handles/meta.js +0 -202
  407. package/dist/handles/meta.js.map +0 -1
  408. package/dist/host/__tests__/errors.test.d.ts +0 -2
  409. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  410. package/dist/host/__tests__/errors.test.js +0 -76
  411. package/dist/host/__tests__/errors.test.js.map +0 -1
  412. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  413. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  414. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  415. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  416. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  417. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  418. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  419. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  420. package/dist/host/__tests__/router.test.d.ts +0 -2
  421. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  422. package/dist/host/__tests__/router.test.js +0 -241
  423. package/dist/host/__tests__/router.test.js.map +0 -1
  424. package/dist/host/__tests__/testing.test.d.ts +0 -2
  425. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  426. package/dist/host/__tests__/testing.test.js +0 -64
  427. package/dist/host/__tests__/testing.test.js.map +0 -1
  428. package/dist/host/__tests__/utils.test.d.ts +0 -2
  429. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  430. package/dist/host/__tests__/utils.test.js +0 -29
  431. package/dist/host/__tests__/utils.test.js.map +0 -1
  432. package/dist/host/cookie-handler.d.ts +0 -34
  433. package/dist/host/cookie-handler.d.ts.map +0 -1
  434. package/dist/host/cookie-handler.js +0 -124
  435. package/dist/host/cookie-handler.js.map +0 -1
  436. package/dist/host/errors.d.ts +0 -56
  437. package/dist/host/errors.d.ts.map +0 -1
  438. package/dist/host/errors.js +0 -79
  439. package/dist/host/errors.js.map +0 -1
  440. package/dist/host/index.d.ts +0 -29
  441. package/dist/host/index.d.ts.map +0 -1
  442. package/dist/host/index.js +0 -32
  443. package/dist/host/index.js.map +0 -1
  444. package/dist/host/pattern-matcher.d.ts +0 -36
  445. package/dist/host/pattern-matcher.d.ts.map +0 -1
  446. package/dist/host/pattern-matcher.js +0 -172
  447. package/dist/host/pattern-matcher.js.map +0 -1
  448. package/dist/host/router.d.ts +0 -26
  449. package/dist/host/router.d.ts.map +0 -1
  450. package/dist/host/router.js +0 -218
  451. package/dist/host/router.js.map +0 -1
  452. package/dist/host/testing.d.ts +0 -36
  453. package/dist/host/testing.d.ts.map +0 -1
  454. package/dist/host/testing.js +0 -55
  455. package/dist/host/testing.js.map +0 -1
  456. package/dist/host/types.d.ts +0 -115
  457. package/dist/host/types.d.ts.map +0 -1
  458. package/dist/host/types.js +0 -7
  459. package/dist/host/types.js.map +0 -1
  460. package/dist/host/utils.d.ts +0 -21
  461. package/dist/host/utils.d.ts.map +0 -1
  462. package/dist/host/utils.js +0 -23
  463. package/dist/host/utils.js.map +0 -1
  464. package/dist/href-client.d.ts +0 -131
  465. package/dist/href-client.d.ts.map +0 -1
  466. package/dist/href-client.js +0 -64
  467. package/dist/href-client.js.map +0 -1
  468. package/dist/href-context.d.ts +0 -29
  469. package/dist/href-context.d.ts.map +0 -1
  470. package/dist/href-context.js +0 -21
  471. package/dist/href-context.js.map +0 -1
  472. package/dist/index.d.ts +0 -73
  473. package/dist/index.d.ts.map +0 -1
  474. package/dist/index.js +0 -91
  475. package/dist/index.js.map +0 -1
  476. package/dist/index.rsc.d.ts +0 -32
  477. package/dist/index.rsc.d.ts.map +0 -1
  478. package/dist/index.rsc.js +0 -40
  479. package/dist/index.rsc.js.map +0 -1
  480. package/dist/internal-debug.d.ts +0 -2
  481. package/dist/internal-debug.d.ts.map +0 -1
  482. package/dist/internal-debug.js +0 -5
  483. package/dist/internal-debug.js.map +0 -1
  484. package/dist/loader.d.ts +0 -14
  485. package/dist/loader.d.ts.map +0 -1
  486. package/dist/loader.js +0 -20
  487. package/dist/loader.js.map +0 -1
  488. package/dist/loader.rsc.d.ts +0 -19
  489. package/dist/loader.rsc.d.ts.map +0 -1
  490. package/dist/loader.rsc.js +0 -99
  491. package/dist/loader.rsc.js.map +0 -1
  492. package/dist/network-error-thrower.d.ts +0 -17
  493. package/dist/network-error-thrower.d.ts.map +0 -1
  494. package/dist/network-error-thrower.js +0 -14
  495. package/dist/network-error-thrower.js.map +0 -1
  496. package/dist/outlet-context.d.ts +0 -13
  497. package/dist/outlet-context.d.ts.map +0 -1
  498. package/dist/outlet-context.js +0 -3
  499. package/dist/outlet-context.js.map +0 -1
  500. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  501. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  502. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  503. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  504. package/dist/prerender/param-hash.d.ts +0 -16
  505. package/dist/prerender/param-hash.d.ts.map +0 -1
  506. package/dist/prerender/param-hash.js +0 -36
  507. package/dist/prerender/param-hash.js.map +0 -1
  508. package/dist/prerender/store.d.ts +0 -38
  509. package/dist/prerender/store.d.ts.map +0 -1
  510. package/dist/prerender/store.js +0 -61
  511. package/dist/prerender/store.js.map +0 -1
  512. package/dist/prerender.d.ts +0 -66
  513. package/dist/prerender.d.ts.map +0 -1
  514. package/dist/prerender.js +0 -57
  515. package/dist/prerender.js.map +0 -1
  516. package/dist/reverse.d.ts +0 -196
  517. package/dist/reverse.d.ts.map +0 -1
  518. package/dist/reverse.js +0 -78
  519. package/dist/reverse.js.map +0 -1
  520. package/dist/root-error-boundary.d.ts +0 -33
  521. package/dist/root-error-boundary.d.ts.map +0 -1
  522. package/dist/root-error-boundary.js +0 -165
  523. package/dist/root-error-boundary.js.map +0 -1
  524. package/dist/route-content-wrapper.d.ts +0 -46
  525. package/dist/route-content-wrapper.d.ts.map +0 -1
  526. package/dist/route-content-wrapper.js +0 -77
  527. package/dist/route-content-wrapper.js.map +0 -1
  528. package/dist/route-definition.d.ts +0 -421
  529. package/dist/route-definition.d.ts.map +0 -1
  530. package/dist/route-definition.js +0 -868
  531. package/dist/route-definition.js.map +0 -1
  532. package/dist/route-map-builder.d.ts +0 -155
  533. package/dist/route-map-builder.d.ts.map +0 -1
  534. package/dist/route-map-builder.js +0 -237
  535. package/dist/route-map-builder.js.map +0 -1
  536. package/dist/route-types.d.ts +0 -165
  537. package/dist/route-types.d.ts.map +0 -1
  538. package/dist/route-types.js +0 -7
  539. package/dist/route-types.js.map +0 -1
  540. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  541. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  542. package/dist/router/__tests__/handler-context.test.js +0 -65
  543. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  544. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  545. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  546. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  547. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  548. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  549. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  550. package/dist/router/__tests__/match-context.test.js +0 -92
  551. package/dist/router/__tests__/match-context.test.js.map +0 -1
  552. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  553. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  554. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  555. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  556. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  557. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  558. package/dist/router/__tests__/match-result.test.js +0 -457
  559. package/dist/router/__tests__/match-result.test.js.map +0 -1
  560. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  561. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  562. package/dist/router/__tests__/on-error.test.js +0 -678
  563. package/dist/router/__tests__/on-error.test.js.map +0 -1
  564. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  565. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  566. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  567. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  568. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  569. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  570. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  571. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  572. package/dist/router/error-handling.d.ts +0 -77
  573. package/dist/router/error-handling.d.ts.map +0 -1
  574. package/dist/router/error-handling.js +0 -202
  575. package/dist/router/error-handling.js.map +0 -1
  576. package/dist/router/handler-context.d.ts +0 -20
  577. package/dist/router/handler-context.d.ts.map +0 -1
  578. package/dist/router/handler-context.js +0 -198
  579. package/dist/router/handler-context.js.map +0 -1
  580. package/dist/router/intercept-resolution.d.ts +0 -66
  581. package/dist/router/intercept-resolution.d.ts.map +0 -1
  582. package/dist/router/intercept-resolution.js +0 -246
  583. package/dist/router/intercept-resolution.js.map +0 -1
  584. package/dist/router/loader-resolution.d.ts +0 -64
  585. package/dist/router/loader-resolution.d.ts.map +0 -1
  586. package/dist/router/loader-resolution.js +0 -284
  587. package/dist/router/loader-resolution.js.map +0 -1
  588. package/dist/router/logging.d.ts +0 -15
  589. package/dist/router/logging.d.ts.map +0 -1
  590. package/dist/router/logging.js +0 -99
  591. package/dist/router/logging.js.map +0 -1
  592. package/dist/router/manifest.d.ts +0 -22
  593. package/dist/router/manifest.d.ts.map +0 -1
  594. package/dist/router/manifest.js +0 -181
  595. package/dist/router/manifest.js.map +0 -1
  596. package/dist/router/match-api.d.ts +0 -35
  597. package/dist/router/match-api.d.ts.map +0 -1
  598. package/dist/router/match-api.js +0 -406
  599. package/dist/router/match-api.js.map +0 -1
  600. package/dist/router/match-context.d.ts +0 -206
  601. package/dist/router/match-context.d.ts.map +0 -1
  602. package/dist/router/match-context.js +0 -17
  603. package/dist/router/match-context.js.map +0 -1
  604. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  605. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  606. package/dist/router/match-middleware/background-revalidation.js +0 -75
  607. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  608. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  609. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  610. package/dist/router/match-middleware/cache-lookup.js +0 -257
  611. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  612. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  613. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  614. package/dist/router/match-middleware/cache-store.js +0 -108
  615. package/dist/router/match-middleware/cache-store.js.map +0 -1
  616. package/dist/router/match-middleware/index.d.ts +0 -81
  617. package/dist/router/match-middleware/index.d.ts.map +0 -1
  618. package/dist/router/match-middleware/index.js +0 -80
  619. package/dist/router/match-middleware/index.js.map +0 -1
  620. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  621. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  622. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  623. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  624. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  625. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  626. package/dist/router/match-middleware/segment-resolution.js +0 -53
  627. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  628. package/dist/router/match-pipelines.d.ts +0 -147
  629. package/dist/router/match-pipelines.d.ts.map +0 -1
  630. package/dist/router/match-pipelines.js +0 -82
  631. package/dist/router/match-pipelines.js.map +0 -1
  632. package/dist/router/match-result.d.ts +0 -126
  633. package/dist/router/match-result.d.ts.map +0 -1
  634. package/dist/router/match-result.js +0 -93
  635. package/dist/router/match-result.js.map +0 -1
  636. package/dist/router/metrics.d.ts +0 -20
  637. package/dist/router/metrics.d.ts.map +0 -1
  638. package/dist/router/metrics.js +0 -47
  639. package/dist/router/metrics.js.map +0 -1
  640. package/dist/router/middleware.d.ts +0 -249
  641. package/dist/router/middleware.d.ts.map +0 -1
  642. package/dist/router/middleware.js +0 -434
  643. package/dist/router/middleware.js.map +0 -1
  644. package/dist/router/middleware.test.d.ts +0 -2
  645. package/dist/router/middleware.test.d.ts.map +0 -1
  646. package/dist/router/middleware.test.js +0 -816
  647. package/dist/router/middleware.test.js.map +0 -1
  648. package/dist/router/pattern-matching.d.ts +0 -149
  649. package/dist/router/pattern-matching.d.ts.map +0 -1
  650. package/dist/router/pattern-matching.js +0 -349
  651. package/dist/router/pattern-matching.js.map +0 -1
  652. package/dist/router/revalidation.d.ts +0 -44
  653. package/dist/router/revalidation.d.ts.map +0 -1
  654. package/dist/router/revalidation.js +0 -147
  655. package/dist/router/revalidation.js.map +0 -1
  656. package/dist/router/router-context.d.ts +0 -135
  657. package/dist/router/router-context.d.ts.map +0 -1
  658. package/dist/router/router-context.js +0 -36
  659. package/dist/router/router-context.js.map +0 -1
  660. package/dist/router/segment-resolution.d.ts +0 -127
  661. package/dist/router/segment-resolution.d.ts.map +0 -1
  662. package/dist/router/segment-resolution.js +0 -919
  663. package/dist/router/segment-resolution.js.map +0 -1
  664. package/dist/router/trie-matching.d.ts +0 -40
  665. package/dist/router/trie-matching.d.ts.map +0 -1
  666. package/dist/router/trie-matching.js +0 -127
  667. package/dist/router/trie-matching.js.map +0 -1
  668. package/dist/router/types.d.ts +0 -136
  669. package/dist/router/types.d.ts.map +0 -1
  670. package/dist/router/types.js +0 -7
  671. package/dist/router/types.js.map +0 -1
  672. package/dist/router.d.ts +0 -753
  673. package/dist/router.d.ts.map +0 -1
  674. package/dist/router.gen.d.ts +0 -6
  675. package/dist/router.gen.d.ts.map +0 -1
  676. package/dist/router.gen.js +0 -6
  677. package/dist/router.gen.js.map +0 -1
  678. package/dist/router.js +0 -1304
  679. package/dist/router.js.map +0 -1
  680. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  681. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  682. package/dist/rsc/__tests__/helpers.test.js +0 -140
  683. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  684. package/dist/rsc/handler.d.ts +0 -45
  685. package/dist/rsc/handler.d.ts.map +0 -1
  686. package/dist/rsc/handler.js +0 -1172
  687. package/dist/rsc/handler.js.map +0 -1
  688. package/dist/rsc/helpers.d.ts +0 -16
  689. package/dist/rsc/helpers.d.ts.map +0 -1
  690. package/dist/rsc/helpers.js +0 -55
  691. package/dist/rsc/helpers.js.map +0 -1
  692. package/dist/rsc/index.d.ts +0 -22
  693. package/dist/rsc/index.d.ts.map +0 -1
  694. package/dist/rsc/index.js +0 -23
  695. package/dist/rsc/index.js.map +0 -1
  696. package/dist/rsc/nonce.d.ts +0 -9
  697. package/dist/rsc/nonce.d.ts.map +0 -1
  698. package/dist/rsc/nonce.js +0 -18
  699. package/dist/rsc/nonce.js.map +0 -1
  700. package/dist/rsc/types.d.ts +0 -206
  701. package/dist/rsc/types.d.ts.map +0 -1
  702. package/dist/rsc/types.js +0 -8
  703. package/dist/rsc/types.js.map +0 -1
  704. package/dist/search-params.d.ts +0 -103
  705. package/dist/search-params.d.ts.map +0 -1
  706. package/dist/search-params.js +0 -74
  707. package/dist/search-params.js.map +0 -1
  708. package/dist/segment-system.d.ts +0 -75
  709. package/dist/segment-system.d.ts.map +0 -1
  710. package/dist/segment-system.js +0 -336
  711. package/dist/segment-system.js.map +0 -1
  712. package/dist/server/context.d.ts +0 -245
  713. package/dist/server/context.d.ts.map +0 -1
  714. package/dist/server/context.js +0 -197
  715. package/dist/server/context.js.map +0 -1
  716. package/dist/server/fetchable-loader-store.d.ts +0 -18
  717. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  718. package/dist/server/fetchable-loader-store.js +0 -18
  719. package/dist/server/fetchable-loader-store.js.map +0 -1
  720. package/dist/server/handle-store.d.ts +0 -85
  721. package/dist/server/handle-store.d.ts.map +0 -1
  722. package/dist/server/handle-store.js +0 -142
  723. package/dist/server/handle-store.js.map +0 -1
  724. package/dist/server/loader-registry.d.ts +0 -55
  725. package/dist/server/loader-registry.d.ts.map +0 -1
  726. package/dist/server/loader-registry.js +0 -132
  727. package/dist/server/loader-registry.js.map +0 -1
  728. package/dist/server/request-context.d.ts +0 -226
  729. package/dist/server/request-context.d.ts.map +0 -1
  730. package/dist/server/request-context.js +0 -290
  731. package/dist/server/request-context.js.map +0 -1
  732. package/dist/server/root-layout.d.ts +0 -4
  733. package/dist/server/root-layout.d.ts.map +0 -1
  734. package/dist/server/root-layout.js +0 -5
  735. package/dist/server/root-layout.js.map +0 -1
  736. package/dist/server.d.ts +0 -15
  737. package/dist/server.d.ts.map +0 -1
  738. package/dist/server.js +0 -20
  739. package/dist/server.js.map +0 -1
  740. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  741. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  742. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  743. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  744. package/dist/ssr/index.d.ts +0 -98
  745. package/dist/ssr/index.d.ts.map +0 -1
  746. package/dist/ssr/index.js +0 -158
  747. package/dist/ssr/index.js.map +0 -1
  748. package/dist/static-handler.d.ts +0 -50
  749. package/dist/static-handler.d.ts.map +0 -1
  750. package/dist/static-handler.gen.d.ts +0 -5
  751. package/dist/static-handler.gen.d.ts.map +0 -1
  752. package/dist/static-handler.gen.js +0 -5
  753. package/dist/static-handler.gen.js.map +0 -1
  754. package/dist/static-handler.js +0 -29
  755. package/dist/static-handler.js.map +0 -1
  756. package/dist/theme/ThemeProvider.d.ts +0 -20
  757. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  758. package/dist/theme/ThemeProvider.js +0 -240
  759. package/dist/theme/ThemeProvider.js.map +0 -1
  760. package/dist/theme/ThemeScript.d.ts +0 -48
  761. package/dist/theme/ThemeScript.d.ts.map +0 -1
  762. package/dist/theme/ThemeScript.js +0 -13
  763. package/dist/theme/ThemeScript.js.map +0 -1
  764. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  765. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  766. package/dist/theme/__tests__/theme.test.js +0 -103
  767. package/dist/theme/__tests__/theme.test.js.map +0 -1
  768. package/dist/theme/constants.d.ts +0 -29
  769. package/dist/theme/constants.d.ts.map +0 -1
  770. package/dist/theme/constants.js +0 -48
  771. package/dist/theme/constants.js.map +0 -1
  772. package/dist/theme/index.d.ts +0 -31
  773. package/dist/theme/index.d.ts.map +0 -1
  774. package/dist/theme/index.js +0 -36
  775. package/dist/theme/index.js.map +0 -1
  776. package/dist/theme/theme-context.d.ts +0 -40
  777. package/dist/theme/theme-context.d.ts.map +0 -1
  778. package/dist/theme/theme-context.js +0 -60
  779. package/dist/theme/theme-context.js.map +0 -1
  780. package/dist/theme/theme-script.d.ts +0 -27
  781. package/dist/theme/theme-script.d.ts.map +0 -1
  782. package/dist/theme/theme-script.js +0 -147
  783. package/dist/theme/theme-script.js.map +0 -1
  784. package/dist/theme/types.d.ts +0 -163
  785. package/dist/theme/types.d.ts.map +0 -1
  786. package/dist/theme/types.js +0 -11
  787. package/dist/theme/types.js.map +0 -1
  788. package/dist/theme/use-theme.d.ts +0 -12
  789. package/dist/theme/use-theme.d.ts.map +0 -1
  790. package/dist/theme/use-theme.js +0 -40
  791. package/dist/theme/use-theme.js.map +0 -1
  792. package/dist/types.d.ts +0 -1479
  793. package/dist/types.d.ts.map +0 -1
  794. package/dist/types.js +0 -10
  795. package/dist/types.js.map +0 -1
  796. package/dist/urls.d.ts +0 -441
  797. package/dist/urls.d.ts.map +0 -1
  798. package/dist/urls.gen.d.ts +0 -8
  799. package/dist/urls.gen.d.ts.map +0 -1
  800. package/dist/urls.gen.js +0 -8
  801. package/dist/urls.gen.js.map +0 -1
  802. package/dist/urls.js +0 -443
  803. package/dist/urls.js.map +0 -1
  804. package/dist/use-loader.d.ts +0 -127
  805. package/dist/use-loader.d.ts.map +0 -1
  806. package/dist/use-loader.js +0 -237
  807. package/dist/use-loader.js.map +0 -1
  808. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  809. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  810. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  811. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  812. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  813. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  814. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  815. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  816. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  817. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  818. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  819. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  820. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  821. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  822. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  823. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  824. package/dist/vite/ast-handler-extract.d.ts +0 -49
  825. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  826. package/dist/vite/ast-handler-extract.js +0 -249
  827. package/dist/vite/ast-handler-extract.js.map +0 -1
  828. package/dist/vite/expose-action-id.d.ts +0 -19
  829. package/dist/vite/expose-action-id.d.ts.map +0 -1
  830. package/dist/vite/expose-action-id.js +0 -250
  831. package/dist/vite/expose-action-id.js.map +0 -1
  832. package/dist/vite/expose-id-utils.d.ts +0 -69
  833. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  834. package/dist/vite/expose-id-utils.js +0 -289
  835. package/dist/vite/expose-id-utils.js.map +0 -1
  836. package/dist/vite/expose-internal-ids.d.ts +0 -22
  837. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  838. package/dist/vite/expose-internal-ids.js +0 -886
  839. package/dist/vite/expose-internal-ids.js.map +0 -1
  840. package/dist/vite/index.d.ts +0 -149
  841. package/dist/vite/index.d.ts.map +0 -1
  842. package/dist/vite/index.js.bak +0 -5448
  843. package/dist/vite/index.js.map +0 -1
  844. package/dist/vite/index.named-routes.gen.ts +0 -103
  845. package/dist/vite/package-resolution.d.ts +0 -43
  846. package/dist/vite/package-resolution.d.ts.map +0 -1
  847. package/dist/vite/package-resolution.js +0 -112
  848. package/dist/vite/package-resolution.js.map +0 -1
  849. package/dist/vite/virtual-entries.d.ts +0 -25
  850. package/dist/vite/virtual-entries.d.ts.map +0 -1
  851. package/dist/vite/virtual-entries.js +0 -110
  852. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1,740 +0,0 @@
1
- import { readFileSync, writeFileSync, existsSync, readdirSync, unlinkSync } from "node:fs";
2
- import { join, dirname, resolve, relative, basename as pathBasename } from "node:path";
3
- // @ts-ignore -- picomatch ships no .d.ts; types are trivial
4
- import picomatch from "picomatch";
5
- import ts from "typescript";
6
- // ---------------------------------------------------------------------------
7
- // AST helpers
8
- // ---------------------------------------------------------------------------
9
- function getStringValue(node) {
10
- if (ts.isStringLiteral(node))
11
- return node.text;
12
- if (ts.isNoSubstitutionTemplateLiteral(node))
13
- return node.text;
14
- return null;
15
- }
16
- function extractObjectStringProperties(node) {
17
- const result = {};
18
- for (const prop of node.properties) {
19
- if (!ts.isPropertyAssignment(prop))
20
- continue;
21
- const key = ts.isIdentifier(prop.name) ? prop.name.text
22
- : ts.isStringLiteral(prop.name) ? prop.name.text
23
- : null;
24
- if (!key)
25
- continue;
26
- const val = getStringValue(prop.initializer);
27
- if (val !== null)
28
- result[key] = val;
29
- }
30
- return result;
31
- }
32
- // ---------------------------------------------------------------------------
33
- // Param extraction from route patterns
34
- // ---------------------------------------------------------------------------
35
- /**
36
- * Extract typed params from a route pattern string.
37
- * Matches `:paramName` and `:paramName?` (optional).
38
- * Custom regex constraints like `:id(\d+)` are ignored for type purposes.
39
- */
40
- export function extractParamsFromPattern(pattern) {
41
- const params = {};
42
- const regex = /:([a-zA-Z_$][\w$]*)(?:\([^)]+\))?(\?)?/g;
43
- let match;
44
- while ((match = regex.exec(pattern)) !== null) {
45
- params[match[1]] = match[2] ? "string?" : "string";
46
- }
47
- return Object.keys(params).length > 0 ? params : undefined;
48
- }
49
- // ---------------------------------------------------------------------------
50
- // Shared route entry formatter
51
- // ---------------------------------------------------------------------------
52
- /**
53
- * Format a single route entry for codegen output.
54
- * Routes without search remain plain strings (params are extracted from
55
- * the pattern at the type level by ExtractParams).
56
- * Routes with search become objects with path and search fields.
57
- */
58
- export function formatRouteEntry(key, pattern, _params, search) {
59
- const hasSearch = search && Object.keys(search).length > 0;
60
- if (!hasSearch) {
61
- return ` ${key}: "${pattern}",`;
62
- }
63
- const searchBody = Object.entries(search)
64
- .map(([k, v]) => `${k}: "${v}"`)
65
- .join(", ");
66
- return ` ${key}: { path: "${pattern}", search: { ${searchBody} } },`;
67
- }
68
- // ---------------------------------------------------------------------------
69
- // AST-based route extraction
70
- // ---------------------------------------------------------------------------
71
- /**
72
- * Extract route definitions from source code by walking the TypeScript AST.
73
- * Finds path() and path.json(), path.md(), etc. call expressions and extracts
74
- * the pattern, name, params, and optional search schema from each.
75
- * Skips unnamed paths (no { name: "..." }).
76
- */
77
- export function extractRoutesFromSource(code) {
78
- const sourceFile = ts.createSourceFile("input.tsx", code, ts.ScriptTarget.Latest, true, ts.ScriptKind.TSX);
79
- const routes = [];
80
- function visit(node) {
81
- if (ts.isCallExpression(node)) {
82
- const callee = node.expression;
83
- const isPath = (ts.isIdentifier(callee) && callee.text === "path") ||
84
- (ts.isPropertyAccessExpression(callee) &&
85
- ts.isIdentifier(callee.expression) && callee.expression.text === "path");
86
- if (isPath && node.arguments.length >= 1) {
87
- const route = extractRouteFromCallExpression(node);
88
- if (route)
89
- routes.push(route);
90
- }
91
- }
92
- ts.forEachChild(node, visit);
93
- }
94
- visit(sourceFile);
95
- return routes;
96
- }
97
- function extractRouteFromCallExpression(node) {
98
- const patternNode = node.arguments[0];
99
- const pattern = getStringValue(patternNode);
100
- if (pattern === null)
101
- return null;
102
- let name = null;
103
- let search;
104
- for (let i = 1; i < node.arguments.length; i++) {
105
- const arg = node.arguments[i];
106
- if (ts.isObjectLiteralExpression(arg)) {
107
- for (const prop of arg.properties) {
108
- if (!ts.isPropertyAssignment(prop))
109
- continue;
110
- const propName = ts.isIdentifier(prop.name) ? prop.name.text : null;
111
- if (propName === "name") {
112
- name = getStringValue(prop.initializer);
113
- }
114
- else if (propName === "search" && ts.isObjectLiteralExpression(prop.initializer)) {
115
- search = extractObjectStringProperties(prop.initializer);
116
- }
117
- }
118
- }
119
- }
120
- if (!name)
121
- return null;
122
- const params = extractParamsFromPattern(pattern);
123
- return {
124
- name,
125
- pattern,
126
- ...(params ? { params } : {}),
127
- ...(search && Object.keys(search).length > 0 ? { search } : {}),
128
- };
129
- }
130
- // ---------------------------------------------------------------------------
131
- // Code generation
132
- // ---------------------------------------------------------------------------
133
- /**
134
- * Generate a per-module types file from extracted routes.
135
- * Output has zero imports, preventing circular references.
136
- */
137
- export function generatePerModuleTypesSource(routes) {
138
- const valid = routes.filter(({ name }) => {
139
- if (!name || /["'\\`\n\r]/.test(name)) {
140
- console.warn(`[rsc-router] Skipping route with invalid name: ${JSON.stringify(name)}`);
141
- return false;
142
- }
143
- return true;
144
- });
145
- // Deduplicate by name (first definition wins — primary route before variants)
146
- const deduped = new Map();
147
- for (const { name, pattern, params, search } of valid) {
148
- if (deduped.has(name)) {
149
- console.warn(`[rsc-router] Duplicate route name "${name}" — keeping first definition`);
150
- continue;
151
- }
152
- deduped.set(name, { pattern, params, search });
153
- }
154
- const sorted = [...deduped.entries()]
155
- .sort(([a], [b]) => a.localeCompare(b));
156
- const body = sorted
157
- .map(([name, { pattern, params, search }]) => {
158
- const key = /^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(name) ? name : `"${name}"`;
159
- return formatRouteEntry(key, pattern, params, search);
160
- })
161
- .join("\n");
162
- return `// Auto-generated by @rangojs/router - do not edit\nexport const routes = {\n${body}\n} as const;\nexport type routes = typeof routes;\n`;
163
- }
164
- /**
165
- * Generates a .ts file that augments RSCRouter.GeneratedRouteMap
166
- * with route name -> pattern mappings. This enables Handler<"routeName">
167
- * without circular references since the file has no imports from the app.
168
- */
169
- export function generateRouteTypesSource(routeManifest, searchSchemas) {
170
- const entries = Object.entries(routeManifest).sort(([a], [b]) => a.localeCompare(b));
171
- const objectBody = entries
172
- .map(([name, pattern]) => {
173
- const key = /^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(name) ? name : `"${name}"`;
174
- const params = extractParamsFromPattern(pattern);
175
- const search = searchSchemas?.[name];
176
- return formatRouteEntry(key, pattern, params, search);
177
- })
178
- .join("\n");
179
- return `// Auto-generated by @rangojs/router - do not edit
180
- export const NamedRoutes = {
181
- ${objectBody}
182
- } as const;
183
-
184
- declare global {
185
- namespace RSCRouter {
186
- interface GeneratedRouteMap extends Readonly<typeof NamedRoutes> {}
187
- }
188
- }
189
- `;
190
- }
191
- /** Default exclude patterns for route type scanning. */
192
- export const DEFAULT_EXCLUDE_PATTERNS = [
193
- "**/__tests__/**",
194
- "**/__mocks__/**",
195
- "**/dist/**",
196
- "**/coverage/**",
197
- "**/*.test.{ts,tsx}",
198
- "**/*.spec.{ts,tsx}",
199
- ];
200
- /**
201
- * Compile include/exclude glob patterns into a single predicate.
202
- * Paths are made root-relative before matching.
203
- * Returns undefined when no filtering is needed (no include, default exclude).
204
- */
205
- export function createScanFilter(root, opts) {
206
- const { include, exclude } = opts;
207
- const hasInclude = include && include.length > 0;
208
- const hasCustomExclude = exclude !== undefined;
209
- if (!hasInclude && !hasCustomExclude)
210
- return undefined;
211
- const effectiveExclude = exclude ?? DEFAULT_EXCLUDE_PATTERNS;
212
- const includeMatcher = hasInclude ? picomatch(include) : null;
213
- const excludeMatcher = effectiveExclude.length > 0 ? picomatch(effectiveExclude) : null;
214
- return (absolutePath) => {
215
- const rel = relative(root, absolutePath);
216
- if (excludeMatcher && excludeMatcher(rel))
217
- return false;
218
- if (includeMatcher)
219
- return includeMatcher(rel);
220
- return true;
221
- };
222
- }
223
- /**
224
- * Recursively find .ts/.tsx files under a directory, skipping node_modules
225
- * and .gen. files.
226
- */
227
- export function findTsFiles(dir, filter) {
228
- const results = [];
229
- let entries;
230
- try {
231
- entries = readdirSync(dir, { withFileTypes: true });
232
- }
233
- catch (err) {
234
- console.warn(`[rsc-router] Failed to scan directory ${dir}: ${err.message}`);
235
- return results;
236
- }
237
- for (const entry of entries) {
238
- const fullPath = join(dir, entry.name);
239
- if (entry.isDirectory()) {
240
- if (entry.name === "node_modules" || entry.name.startsWith("."))
241
- continue;
242
- results.push(...findTsFiles(fullPath, filter));
243
- }
244
- else if ((entry.name.endsWith(".ts") || entry.name.endsWith(".tsx")) &&
245
- !entry.name.includes(".gen.")) {
246
- if (filter && !filter(fullPath))
247
- continue;
248
- results.push(fullPath);
249
- }
250
- }
251
- return results;
252
- }
253
- /**
254
- * Generate per-module route type files by statically parsing url module source.
255
- * Scans for files containing `urls(` and writes a sibling `.gen.ts` with the
256
- * extracted route name/pattern pairs. Only writes when content has changed.
257
- */
258
- export function writePerModuleRouteTypes(root, filter) {
259
- const files = findTsFiles(root, filter);
260
- for (const filePath of files) {
261
- writePerModuleRouteTypesForFile(filePath);
262
- }
263
- }
264
- /**
265
- * Find all variable names assigned to urls() calls in source code.
266
- * e.g. `export const patterns = urls(...)` → ["patterns"]
267
- */
268
- function findUrlsVariableNames(code) {
269
- const sourceFile = ts.createSourceFile("input.tsx", code, ts.ScriptTarget.Latest, true, ts.ScriptKind.TSX);
270
- const names = [];
271
- function visit(node) {
272
- if (ts.isVariableDeclaration(node) &&
273
- ts.isIdentifier(node.name) &&
274
- node.initializer &&
275
- ts.isCallExpression(node.initializer)) {
276
- const callee = node.initializer.expression;
277
- if (ts.isIdentifier(callee) && callee.text === "urls") {
278
- names.push(node.name.text);
279
- }
280
- }
281
- ts.forEachChild(node, visit);
282
- }
283
- visit(sourceFile);
284
- return names;
285
- }
286
- /**
287
- * Generate per-module route types for a single url module file.
288
- * Follows include() calls recursively to produce the full route tree.
289
- * No-ops if the file doesn't contain `urls(` or has no named routes.
290
- */
291
- export function writePerModuleRouteTypesForFile(filePath) {
292
- try {
293
- const source = readFileSync(filePath, "utf-8");
294
- if (!source.includes("urls("))
295
- return;
296
- const varNames = findUrlsVariableNames(source);
297
- let routes;
298
- if (varNames.length > 0) {
299
- // Follow includes recursively via the combined route map builder.
300
- // The visited set in buildCombinedRouteMapWithSearch prevents infinite loops.
301
- routes = [];
302
- for (const varName of varNames) {
303
- const { routes: routeMap, searchSchemas } = buildCombinedRouteMapWithSearch(filePath, varName);
304
- for (const [name, pattern] of Object.entries(routeMap)) {
305
- const params = extractParamsFromPattern(pattern);
306
- routes.push({
307
- name,
308
- pattern,
309
- ...(params ? { params } : {}),
310
- ...(searchSchemas[name] ? { search: searchSchemas[name] } : {}),
311
- });
312
- }
313
- }
314
- }
315
- else {
316
- // Fallback: no urls() variable found, extract path() calls directly
317
- routes = extractRoutesFromSource(source);
318
- }
319
- if (routes.length === 0)
320
- return;
321
- const genPath = filePath.replace(/\.(tsx?)$/, ".gen.ts");
322
- const genSource = generatePerModuleTypesSource(routes);
323
- const existing = existsSync(genPath) ? readFileSync(genPath, "utf-8") : null;
324
- if (existing !== genSource) {
325
- writeFileSync(genPath, genSource);
326
- console.log(`[rsc-router] Generated route types -> ${genPath}`);
327
- }
328
- }
329
- catch (err) {
330
- console.warn(`[rsc-router] Failed to generate route types for ${filePath}: ${err.message}`);
331
- }
332
- }
333
- // ---------------------------------------------------------------------------
334
- // AST-based include() parsing
335
- // ---------------------------------------------------------------------------
336
- /**
337
- * Extract include() calls from source code by walking the TypeScript AST.
338
- * Returns the path prefix, variable name, and optional name prefix for each.
339
- */
340
- export function extractIncludesFromSource(code) {
341
- const sourceFile = ts.createSourceFile("input.tsx", code, ts.ScriptTarget.Latest, true, ts.ScriptKind.TSX);
342
- const results = [];
343
- function visit(node) {
344
- if (ts.isCallExpression(node)) {
345
- const callee = node.expression;
346
- if (ts.isIdentifier(callee) && callee.text === "include") {
347
- const result = extractIncludeFromCallExpression(node);
348
- if (result)
349
- results.push(result);
350
- }
351
- }
352
- ts.forEachChild(node, visit);
353
- }
354
- visit(sourceFile);
355
- return results;
356
- }
357
- function extractIncludeFromCallExpression(node) {
358
- if (node.arguments.length < 2)
359
- return null;
360
- const pathPrefix = getStringValue(node.arguments[0]);
361
- if (pathPrefix === null)
362
- return null;
363
- const secondArg = node.arguments[1];
364
- if (!ts.isIdentifier(secondArg))
365
- return null;
366
- const variableName = secondArg.text;
367
- let namePrefix = null;
368
- if (node.arguments.length >= 3) {
369
- const thirdArg = node.arguments[2];
370
- if (ts.isObjectLiteralExpression(thirdArg)) {
371
- for (const prop of thirdArg.properties) {
372
- if (!ts.isPropertyAssignment(prop))
373
- continue;
374
- const propName = ts.isIdentifier(prop.name) ? prop.name.text : null;
375
- if (propName === "name") {
376
- namePrefix = getStringValue(prop.initializer);
377
- }
378
- }
379
- }
380
- }
381
- return { pathPrefix, variableName, namePrefix };
382
- }
383
- // ---------------------------------------------------------------------------
384
- // Import resolution
385
- // ---------------------------------------------------------------------------
386
- /**
387
- * Find the import statement for a local variable name.
388
- * Returns the import specifier and the exported name from the source module.
389
- */
390
- function resolveImportedVariable(code, localName) {
391
- const importRegex = /import\s*\{([^}]+)\}\s*from\s*["']([^"']+)["']/g;
392
- let match;
393
- while ((match = importRegex.exec(code)) !== null) {
394
- const imports = match[1];
395
- const specifier = match[2];
396
- const parts = imports
397
- .split(",")
398
- .map((s) => s.trim())
399
- .filter(Boolean);
400
- for (const part of parts) {
401
- const asMatch = part.match(/^(\w+)\s+as\s+(\w+)$/);
402
- if (asMatch && asMatch[2] === localName)
403
- return { specifier, exportedName: asMatch[1] };
404
- if (part === localName)
405
- return { specifier, exportedName: localName };
406
- }
407
- }
408
- return null;
409
- }
410
- /**
411
- * Resolve an import specifier relative to the importing file.
412
- * Strips .js/.mjs extensions and tries .ts/.tsx candidates.
413
- */
414
- function resolveImportPath(importSpec, fromFile) {
415
- if (!importSpec.startsWith("."))
416
- return null;
417
- const dir = dirname(fromFile);
418
- let base = importSpec;
419
- if (base.endsWith(".js"))
420
- base = base.slice(0, -3);
421
- else if (base.endsWith(".mjs"))
422
- base = base.slice(0, -4);
423
- const candidates = [
424
- resolve(dir, base + ".ts"),
425
- resolve(dir, base + ".tsx"),
426
- resolve(dir, base + "/index.ts"),
427
- resolve(dir, base + "/index.tsx"),
428
- ];
429
- for (const candidate of candidates) {
430
- if (existsSync(candidate))
431
- return candidate;
432
- }
433
- return null;
434
- }
435
- // ---------------------------------------------------------------------------
436
- // urls() block extraction for same-file variables
437
- // ---------------------------------------------------------------------------
438
- /**
439
- * Extract the source of a specific `const varName = urls(...)` call using
440
- * the TypeScript AST. Returns the full text of the urls() call expression.
441
- */
442
- function extractUrlsBlockForVariable(code, varName) {
443
- const sourceFile = ts.createSourceFile("input.tsx", code, ts.ScriptTarget.Latest, true, ts.ScriptKind.TSX);
444
- let result = null;
445
- function visit(node) {
446
- if (result)
447
- return;
448
- if (ts.isVariableDeclaration(node) &&
449
- ts.isIdentifier(node.name) &&
450
- node.name.text === varName &&
451
- node.initializer &&
452
- ts.isCallExpression(node.initializer)) {
453
- const callee = node.initializer.expression;
454
- if (ts.isIdentifier(callee) && callee.text === "urls") {
455
- result = node.initializer.getText(sourceFile);
456
- return;
457
- }
458
- }
459
- ts.forEachChild(node, visit);
460
- }
461
- visit(sourceFile);
462
- return result;
463
- }
464
- // ---------------------------------------------------------------------------
465
- // Combined route map building
466
- // ---------------------------------------------------------------------------
467
- /**
468
- * Recursively build a route map from a urls module file.
469
- * Extracts local path() routes and follows include() calls to sub-modules.
470
- * Handles both imported and same-file variables.
471
- */
472
- export function buildCombinedRouteMap(filePath, variableName, visited) {
473
- visited = visited ?? new Set();
474
- const realPath = resolve(filePath);
475
- const key = variableName ? `${realPath}:${variableName}` : realPath;
476
- if (visited.has(key)) {
477
- console.warn(`[rsc-router] Circular include detected, skipping: ${key}`);
478
- return {};
479
- }
480
- visited.add(key);
481
- let source;
482
- try {
483
- source = readFileSync(realPath, "utf-8");
484
- }
485
- catch {
486
- return {};
487
- }
488
- // If a specific variable is requested, extract just its urls() block
489
- let block;
490
- if (variableName) {
491
- const extracted = extractUrlsBlockForVariable(source, variableName);
492
- if (!extracted)
493
- return {};
494
- block = extracted;
495
- }
496
- else {
497
- block = source;
498
- }
499
- return buildRouteMapFromBlock(block, source, realPath, visited);
500
- }
501
- function buildRouteMapFromBlock(block, fullSource, filePath, visited, searchSchemasOut) {
502
- const routeMap = {};
503
- // Extract local path() routes
504
- const localRoutes = extractRoutesFromSource(block);
505
- for (const { name, pattern, search } of localRoutes) {
506
- routeMap[name] = pattern;
507
- if (search && searchSchemasOut) {
508
- searchSchemasOut[name] = search;
509
- }
510
- }
511
- // Extract include() calls
512
- const includes = extractIncludesFromSource(block);
513
- for (const { pathPrefix, variableName, namePrefix } of includes) {
514
- let childResult;
515
- // Try import resolution first
516
- const imported = resolveImportedVariable(fullSource, variableName);
517
- if (imported) {
518
- const targetFile = resolveImportPath(imported.specifier, filePath);
519
- if (!targetFile)
520
- continue;
521
- childResult = buildCombinedRouteMapWithSearch(targetFile, imported.exportedName, visited);
522
- }
523
- else {
524
- // Same-file variable
525
- childResult = buildCombinedRouteMapWithSearch(filePath, variableName, visited);
526
- }
527
- // Apply prefixes
528
- for (const [name, pattern] of Object.entries(childResult.routes)) {
529
- const prefixedName = namePrefix ? `${namePrefix}.${name}` : name;
530
- let prefixedPattern;
531
- if (pattern === "/") {
532
- prefixedPattern = pathPrefix || "/";
533
- }
534
- else if (pathPrefix.endsWith("/") && pattern.startsWith("/")) {
535
- prefixedPattern = pathPrefix + pattern.slice(1);
536
- }
537
- else {
538
- prefixedPattern = pathPrefix + pattern;
539
- }
540
- routeMap[prefixedName] = prefixedPattern;
541
- // Propagate search schemas with prefix
542
- if (childResult.searchSchemas[name] && searchSchemasOut) {
543
- searchSchemasOut[prefixedName] = childResult.searchSchemas[name];
544
- }
545
- }
546
- }
547
- return routeMap;
548
- }
549
- /**
550
- * Build route map and search schemas together.
551
- * Internal helper used by the include resolution path.
552
- */
553
- function buildCombinedRouteMapWithSearch(filePath, variableName, visited) {
554
- visited = visited ?? new Set();
555
- const realPath = resolve(filePath);
556
- const key = variableName ? `${realPath}:${variableName}` : realPath;
557
- if (visited.has(key)) {
558
- console.warn(`[rsc-router] Circular include detected, skipping: ${key}`);
559
- return { routes: {}, searchSchemas: {} };
560
- }
561
- visited.add(key);
562
- let source;
563
- try {
564
- source = readFileSync(realPath, "utf-8");
565
- }
566
- catch {
567
- return { routes: {}, searchSchemas: {} };
568
- }
569
- let block;
570
- if (variableName) {
571
- const extracted = extractUrlsBlockForVariable(source, variableName);
572
- if (!extracted)
573
- return { routes: {}, searchSchemas: {} };
574
- block = extracted;
575
- }
576
- else {
577
- block = source;
578
- }
579
- const searchSchemas = {};
580
- const routes = buildRouteMapFromBlock(block, source, realPath, visited, searchSchemas);
581
- return { routes, searchSchemas };
582
- }
583
- // ---------------------------------------------------------------------------
584
- // Router file URL extraction
585
- // ---------------------------------------------------------------------------
586
- /**
587
- * Extract the url patterns variable from a router file.
588
- * Looks for patterns like:
589
- * .routes(variableName)
590
- * urls: variableName
591
- * Returns the local variable name and optional import info.
592
- */
593
- function extractUrlsVariableFromRouter(code) {
594
- // Pattern 1: .routes(variableName) where variableName is an identifier (not a string)
595
- const routesCallMatch = code.match(/\.routes\s*\(\s*([a-zA-Z_$][\w$]*)\s*\)/);
596
- if (routesCallMatch)
597
- return routesCallMatch[1];
598
- // Pattern 2: urls: variableName in createRouter options
599
- const urlsOptionMatch = code.match(/urls\s*:\s*([a-zA-Z_$][\w$]*)/);
600
- if (urlsOptionMatch)
601
- return urlsOptionMatch[1];
602
- return null;
603
- }
604
- /**
605
- * Resolve routes and search schemas from a router source file by following the
606
- * variable passed to `.routes(...)` or `urls: ...` in createRouter options.
607
- */
608
- export function buildCombinedRouteMapForRouterFile(routerFilePath) {
609
- let routerSource;
610
- try {
611
- routerSource = readFileSync(routerFilePath, "utf-8");
612
- }
613
- catch {
614
- return { routes: {}, searchSchemas: {} };
615
- }
616
- const urlsVarName = extractUrlsVariableFromRouter(routerSource);
617
- if (!urlsVarName) {
618
- return { routes: {}, searchSchemas: {} };
619
- }
620
- const imported = resolveImportedVariable(routerSource, urlsVarName);
621
- if (imported) {
622
- const targetFile = resolveImportPath(imported.specifier, routerFilePath);
623
- if (!targetFile) {
624
- return { routes: {}, searchSchemas: {} };
625
- }
626
- return buildCombinedRouteMapWithSearch(targetFile, imported.exportedName);
627
- }
628
- return buildCombinedRouteMapWithSearch(routerFilePath, urlsVarName);
629
- }
630
- // ---------------------------------------------------------------------------
631
- // Per-router named-routes.gen.ts writer
632
- // ---------------------------------------------------------------------------
633
- /**
634
- * Scan for files containing createRouter() and return their paths.
635
- * Call once at startup; the result can be reused on subsequent watcher triggers.
636
- */
637
- export function findRouterFiles(root, filter) {
638
- const files = findTsFiles(root, filter);
639
- const result = [];
640
- for (const filePath of files) {
641
- if (filePath.includes(".gen."))
642
- continue;
643
- try {
644
- const source = readFileSync(filePath, "utf-8");
645
- if (/\bcreateRouter\s*[<(]/.test(source)) {
646
- result.push(filePath);
647
- }
648
- }
649
- catch {
650
- continue;
651
- }
652
- }
653
- return result;
654
- }
655
- /**
656
- * Generate per-router named-routes.gen.ts files from known router file paths.
657
- * Re-reads each router file and resolves url patterns via static source parsing.
658
- *
659
- * Pass `knownRouterFiles` from a previous `findRouterFiles()` call to skip the
660
- * full directory scan. If omitted, falls back to scanning (startup path).
661
- */
662
- /**
663
- * Write named-routes.gen.ts files from static source parsing.
664
- * Dev-only: provides initial .gen.ts files for IDE types before runtime
665
- * discovery runs. Must NOT be called during production builds — runtime
666
- * discovery in buildStart produces the definitive file.
667
- */
668
- export function writeCombinedRouteTypes(root, knownRouterFiles, opts) {
669
- // Delete old combined named-routes.gen.ts if it exists (stale from older versions)
670
- try {
671
- const oldCombinedPath = join(root, "src", "named-routes.gen.ts");
672
- if (existsSync(oldCombinedPath)) {
673
- unlinkSync(oldCombinedPath);
674
- console.log(`[rsc-router] Removed stale combined route types: ${oldCombinedPath}`);
675
- }
676
- }
677
- catch { }
678
- const routerFilePaths = knownRouterFiles ?? findRouterFiles(root);
679
- if (routerFilePaths.length === 0)
680
- return;
681
- for (const routerFilePath of routerFilePaths) {
682
- let routerSource;
683
- try {
684
- routerSource = readFileSync(routerFilePath, "utf-8");
685
- }
686
- catch {
687
- continue;
688
- }
689
- // Extract the urls variable name from .routes(varName) or urls: varName
690
- const urlsVarName = extractUrlsVariableFromRouter(routerSource);
691
- if (!urlsVarName)
692
- continue;
693
- // Resolve the variable to its source module
694
- let result;
695
- const imported = resolveImportedVariable(routerSource, urlsVarName);
696
- if (imported) {
697
- // Variable is imported from another module
698
- const targetFile = resolveImportPath(imported.specifier, routerFilePath);
699
- if (!targetFile)
700
- continue;
701
- result = buildCombinedRouteMapWithSearch(targetFile, imported.exportedName);
702
- }
703
- else {
704
- // Variable is defined in the same file
705
- result = buildCombinedRouteMapWithSearch(routerFilePath, urlsVarName);
706
- }
707
- const routerBasename = pathBasename(routerFilePath).replace(/\.(tsx?|jsx?)$/, "");
708
- const outPath = join(dirname(routerFilePath), `${routerBasename}.named-routes.gen.ts`);
709
- const existing = existsSync(outPath) ? readFileSync(outPath, "utf-8") : null;
710
- // When the static parser can't extract routes (e.g. callback-style urls()),
711
- // write an empty placeholder so the build-time transform's injected import
712
- // resolves. Runtime discovery will overwrite this with the real routes.
713
- if (Object.keys(result.routes).length === 0) {
714
- if (!existing) {
715
- const emptySource = generateRouteTypesSource({});
716
- writeFileSync(outPath, emptySource);
717
- }
718
- continue;
719
- }
720
- const hasSearchSchemas = Object.keys(result.searchSchemas).length > 0;
721
- const source = generateRouteTypesSource(result.routes, hasSearchSchemas ? result.searchSchemas : undefined);
722
- if (existing !== source) {
723
- // On initial dev startup, don't overwrite a file from runtime discovery
724
- // (which has all dynamic routes) with a smaller set from the static
725
- // parser. The static parser can't see routes generated by Array.from()
726
- // or other dynamic code. During HMR (file watcher), always write so
727
- // newly added routes appear immediately.
728
- if (opts?.preserveIfLarger && existing) {
729
- const existingCount = (existing.match(/^\s+["a-zA-Z_$][^:]*:\s*["{]/gm) || []).length;
730
- const newCount = Object.keys(result.routes).length;
731
- if (existingCount > newCount) {
732
- continue;
733
- }
734
- }
735
- writeFileSync(outPath, source);
736
- console.log(`[rsc-router] Generated route types (${Object.keys(result.routes).length} routes) -> ${outPath}`);
737
- }
738
- }
739
- }
740
- //# sourceMappingURL=generate-route-types.js.map