@rangojs/router 0.0.0-experimental.0da83ed6 → 0.0.0-experimental.0e02cd4e

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 (906) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +130 -47
  3. package/dist/vite/index.js +689 -361
  4. package/package.json +2 -2
  5. package/skills/links/SKILL.md +3 -1
  6. package/skills/middleware/SKILL.md +2 -0
  7. package/skills/prerender/SKILL.md +110 -68
  8. package/skills/router-setup/SKILL.md +35 -0
  9. package/src/__internal.ts +1 -1
  10. package/src/browser/app-version.ts +14 -0
  11. package/src/browser/navigation-bridge.ts +16 -3
  12. package/src/browser/navigation-client.ts +86 -63
  13. package/src/browser/navigation-store.ts +43 -8
  14. package/src/browser/partial-update.ts +27 -5
  15. package/src/browser/prefetch/cache.ts +21 -6
  16. package/src/browser/prefetch/fetch.ts +46 -6
  17. package/src/browser/react/Link.tsx +58 -8
  18. package/src/browser/react/NavigationProvider.tsx +8 -1
  19. package/src/browser/react/context.ts +7 -2
  20. package/src/browser/react/use-handle.ts +9 -58
  21. package/src/browser/react/use-router.ts +21 -8
  22. package/src/browser/rsc-router.tsx +26 -3
  23. package/src/browser/scroll-restoration.ts +10 -8
  24. package/src/browser/server-action-bridge.ts +8 -17
  25. package/src/browser/types.ts +24 -5
  26. package/src/build/generate-manifest.ts +6 -6
  27. package/src/build/generate-route-types.ts +3 -0
  28. package/src/build/route-types/include-resolution.ts +8 -1
  29. package/src/build/route-types/router-processing.ts +211 -72
  30. package/src/build/route-types/scan-filter.ts +8 -1
  31. package/src/client.tsx +2 -56
  32. package/src/handle.ts +40 -0
  33. package/src/index.rsc.ts +3 -1
  34. package/src/index.ts +12 -0
  35. package/src/prerender/store.ts +5 -4
  36. package/src/prerender.ts +138 -77
  37. package/src/reverse.ts +22 -1
  38. package/src/route-definition/dsl-helpers.ts +42 -19
  39. package/src/route-definition/helpers-types.ts +4 -1
  40. package/src/route-definition/index.ts +3 -0
  41. package/src/route-definition/redirect.ts +9 -1
  42. package/src/route-definition/resolve-handler-use.ts +149 -0
  43. package/src/route-types.ts +11 -0
  44. package/src/router/content-negotiation.ts +100 -1
  45. package/src/router/handler-context.ts +48 -15
  46. package/src/router/intercept-resolution.ts +9 -4
  47. package/src/router/loader-resolution.ts +150 -21
  48. package/src/router/match-api.ts +124 -189
  49. package/src/router/match-middleware/cache-lookup.ts +26 -7
  50. package/src/router/match-middleware/segment-resolution.ts +53 -0
  51. package/src/router/match-result.ts +82 -4
  52. package/src/router/middleware-types.ts +0 -6
  53. package/src/router/middleware.ts +0 -3
  54. package/src/router/navigation-snapshot.ts +182 -0
  55. package/src/router/prerender-match.ts +110 -10
  56. package/src/router/preview-match.ts +30 -102
  57. package/src/router/request-classification.ts +310 -0
  58. package/src/router/route-snapshot.ts +245 -0
  59. package/src/router/router-interfaces.ts +36 -4
  60. package/src/router/router-options.ts +37 -11
  61. package/src/router/segment-resolution/fresh.ts +70 -5
  62. package/src/router/segment-resolution/revalidation.ts +87 -9
  63. package/src/router.ts +53 -5
  64. package/src/rsc/handler.ts +472 -393
  65. package/src/rsc/loader-fetch.ts +18 -3
  66. package/src/rsc/manifest-init.ts +5 -1
  67. package/src/rsc/progressive-enhancement.ts +12 -3
  68. package/src/rsc/rsc-rendering.ts +8 -2
  69. package/src/rsc/server-action.ts +8 -2
  70. package/src/rsc/ssr-setup.ts +2 -2
  71. package/src/rsc/types.ts +6 -4
  72. package/src/server/context.ts +39 -2
  73. package/src/server/handle-store.ts +19 -0
  74. package/src/server/loader-registry.ts +9 -8
  75. package/src/server/request-context.ts +132 -13
  76. package/src/ssr/index.tsx +3 -0
  77. package/src/static-handler.ts +18 -6
  78. package/src/types/cache-types.ts +4 -4
  79. package/src/types/handler-context.ts +17 -11
  80. package/src/types/loader-types.ts +32 -5
  81. package/src/types/route-entry.ts +1 -1
  82. package/src/types/segments.ts +1 -0
  83. package/src/urls/path-helper-types.ts +9 -2
  84. package/src/urls/path-helper.ts +47 -12
  85. package/src/urls/pattern-types.ts +12 -0
  86. package/src/urls/response-types.ts +16 -6
  87. package/src/use-loader.tsx +77 -5
  88. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  89. package/src/vite/discovery/discover-routers.ts +5 -1
  90. package/src/vite/discovery/prerender-collection.ts +128 -74
  91. package/src/vite/discovery/state.ts +13 -4
  92. package/src/vite/index.ts +4 -0
  93. package/src/vite/plugin-types.ts +60 -5
  94. package/src/vite/plugins/expose-id-utils.ts +12 -0
  95. package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
  96. package/src/vite/plugins/expose-internal-ids.ts +257 -40
  97. package/src/vite/plugins/performance-tracks.ts +66 -198
  98. package/src/vite/plugins/refresh-cmd.ts +88 -26
  99. package/src/vite/rango.ts +18 -5
  100. package/src/vite/router-discovery.ts +178 -37
  101. package/src/vite/utils/prerender-utils.ts +18 -0
  102. package/src/vite/utils/shared-utils.ts +3 -2
  103. package/dist/__internal.d.ts +0 -83
  104. package/dist/__internal.d.ts.map +0 -1
  105. package/dist/__internal.js +0 -19
  106. package/dist/__internal.js.map +0 -1
  107. package/dist/__mocks__/version.d.ts +0 -7
  108. package/dist/__mocks__/version.d.ts.map +0 -1
  109. package/dist/__mocks__/version.js +0 -7
  110. package/dist/__mocks__/version.js.map +0 -1
  111. package/dist/__tests__/client-href.test.d.ts +0 -2
  112. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  113. package/dist/__tests__/client-href.test.js +0 -74
  114. package/dist/__tests__/client-href.test.js.map +0 -1
  115. package/dist/__tests__/component-utils.test.d.ts +0 -2
  116. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  117. package/dist/__tests__/component-utils.test.js +0 -51
  118. package/dist/__tests__/component-utils.test.js.map +0 -1
  119. package/dist/__tests__/event-controller.test.d.ts +0 -2
  120. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  121. package/dist/__tests__/event-controller.test.js +0 -538
  122. package/dist/__tests__/event-controller.test.js.map +0 -1
  123. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  124. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  125. package/dist/__tests__/helpers/route-tree.js +0 -374
  126. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  127. package/dist/__tests__/match-result.test.d.ts +0 -2
  128. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  129. package/dist/__tests__/match-result.test.js +0 -154
  130. package/dist/__tests__/match-result.test.js.map +0 -1
  131. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  132. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  133. package/dist/__tests__/navigation-store.test.js +0 -440
  134. package/dist/__tests__/navigation-store.test.js.map +0 -1
  135. package/dist/__tests__/partial-update.test.d.ts +0 -2
  136. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  137. package/dist/__tests__/partial-update.test.js +0 -1009
  138. package/dist/__tests__/partial-update.test.js.map +0 -1
  139. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  140. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  141. package/dist/__tests__/reverse-types.test.js +0 -656
  142. package/dist/__tests__/reverse-types.test.js.map +0 -1
  143. package/dist/__tests__/route-definition.test.d.ts +0 -2
  144. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  145. package/dist/__tests__/route-definition.test.js +0 -55
  146. package/dist/__tests__/route-definition.test.js.map +0 -1
  147. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  148. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  149. package/dist/__tests__/router-helpers.test.js +0 -377
  150. package/dist/__tests__/router-helpers.test.js.map +0 -1
  151. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  152. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  153. package/dist/__tests__/router-integration-2.test.js +0 -426
  154. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  155. package/dist/__tests__/router-integration.test.d.ts +0 -2
  156. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  157. package/dist/__tests__/router-integration.test.js +0 -1051
  158. package/dist/__tests__/router-integration.test.js.map +0 -1
  159. package/dist/__tests__/search-params.test.d.ts +0 -5
  160. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  161. package/dist/__tests__/search-params.test.js +0 -306
  162. package/dist/__tests__/search-params.test.js.map +0 -1
  163. package/dist/__tests__/segment-system.test.d.ts +0 -2
  164. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  165. package/dist/__tests__/segment-system.test.js +0 -627
  166. package/dist/__tests__/segment-system.test.js.map +0 -1
  167. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  168. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  169. package/dist/__tests__/static-handler-types.test.js +0 -63
  170. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  171. package/dist/__tests__/urls.test.d.ts +0 -2
  172. package/dist/__tests__/urls.test.d.ts.map +0 -1
  173. package/dist/__tests__/urls.test.js +0 -421
  174. package/dist/__tests__/urls.test.js.map +0 -1
  175. package/dist/__tests__/use-mount.test.d.ts +0 -2
  176. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  177. package/dist/__tests__/use-mount.test.js +0 -35
  178. package/dist/__tests__/use-mount.test.js.map +0 -1
  179. package/dist/bin/rango.d.ts +0 -2
  180. package/dist/bin/rango.d.ts.map +0 -1
  181. package/dist/bin/rango.js.map +0 -1
  182. package/dist/browser/event-controller.d.ts +0 -191
  183. package/dist/browser/event-controller.d.ts.map +0 -1
  184. package/dist/browser/event-controller.js +0 -559
  185. package/dist/browser/event-controller.js.map +0 -1
  186. package/dist/browser/index.d.ts +0 -2
  187. package/dist/browser/index.d.ts.map +0 -1
  188. package/dist/browser/index.js +0 -14
  189. package/dist/browser/index.js.map +0 -1
  190. package/dist/browser/link-interceptor.d.ts +0 -38
  191. package/dist/browser/link-interceptor.d.ts.map +0 -1
  192. package/dist/browser/link-interceptor.js +0 -99
  193. package/dist/browser/link-interceptor.js.map +0 -1
  194. package/dist/browser/logging.d.ts +0 -10
  195. package/dist/browser/logging.d.ts.map +0 -1
  196. package/dist/browser/logging.js +0 -29
  197. package/dist/browser/logging.js.map +0 -1
  198. package/dist/browser/lru-cache.d.ts +0 -17
  199. package/dist/browser/lru-cache.d.ts.map +0 -1
  200. package/dist/browser/lru-cache.js +0 -50
  201. package/dist/browser/lru-cache.js.map +0 -1
  202. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  203. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  204. package/dist/browser/merge-segment-loaders.js +0 -102
  205. package/dist/browser/merge-segment-loaders.js.map +0 -1
  206. package/dist/browser/navigation-bridge.d.ts +0 -102
  207. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  208. package/dist/browser/navigation-bridge.js +0 -708
  209. package/dist/browser/navigation-bridge.js.map +0 -1
  210. package/dist/browser/navigation-client.d.ts +0 -25
  211. package/dist/browser/navigation-client.d.ts.map +0 -1
  212. package/dist/browser/navigation-client.js +0 -157
  213. package/dist/browser/navigation-client.js.map +0 -1
  214. package/dist/browser/navigation-store.d.ts +0 -101
  215. package/dist/browser/navigation-store.d.ts.map +0 -1
  216. package/dist/browser/navigation-store.js +0 -625
  217. package/dist/browser/navigation-store.js.map +0 -1
  218. package/dist/browser/partial-update.d.ts +0 -75
  219. package/dist/browser/partial-update.d.ts.map +0 -1
  220. package/dist/browser/partial-update.js +0 -426
  221. package/dist/browser/partial-update.js.map +0 -1
  222. package/dist/browser/react/Link.d.ts +0 -86
  223. package/dist/browser/react/Link.d.ts.map +0 -1
  224. package/dist/browser/react/Link.js +0 -128
  225. package/dist/browser/react/Link.js.map +0 -1
  226. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  227. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  228. package/dist/browser/react/NavigationProvider.js +0 -216
  229. package/dist/browser/react/NavigationProvider.js.map +0 -1
  230. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  231. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  232. package/dist/browser/react/ScrollRestoration.js +0 -57
  233. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  234. package/dist/browser/react/context.d.ts +0 -46
  235. package/dist/browser/react/context.d.ts.map +0 -1
  236. package/dist/browser/react/context.js +0 -10
  237. package/dist/browser/react/context.js.map +0 -1
  238. package/dist/browser/react/index.d.ts +0 -11
  239. package/dist/browser/react/index.d.ts.map +0 -1
  240. package/dist/browser/react/index.js +0 -22
  241. package/dist/browser/react/index.js.map +0 -1
  242. package/dist/browser/react/location-state-shared.d.ts +0 -63
  243. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  244. package/dist/browser/react/location-state-shared.js +0 -81
  245. package/dist/browser/react/location-state-shared.js.map +0 -1
  246. package/dist/browser/react/location-state.d.ts +0 -23
  247. package/dist/browser/react/location-state.d.ts.map +0 -1
  248. package/dist/browser/react/location-state.js +0 -29
  249. package/dist/browser/react/location-state.js.map +0 -1
  250. package/dist/browser/react/mount-context.d.ts +0 -24
  251. package/dist/browser/react/mount-context.d.ts.map +0 -1
  252. package/dist/browser/react/mount-context.js +0 -24
  253. package/dist/browser/react/mount-context.js.map +0 -1
  254. package/dist/browser/react/use-action.d.ts +0 -64
  255. package/dist/browser/react/use-action.d.ts.map +0 -1
  256. package/dist/browser/react/use-action.js +0 -134
  257. package/dist/browser/react/use-action.js.map +0 -1
  258. package/dist/browser/react/use-client-cache.d.ts +0 -41
  259. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  260. package/dist/browser/react/use-client-cache.js +0 -39
  261. package/dist/browser/react/use-client-cache.js.map +0 -1
  262. package/dist/browser/react/use-handle.d.ts +0 -31
  263. package/dist/browser/react/use-handle.d.ts.map +0 -1
  264. package/dist/browser/react/use-handle.js +0 -144
  265. package/dist/browser/react/use-handle.js.map +0 -1
  266. package/dist/browser/react/use-href.d.ts +0 -33
  267. package/dist/browser/react/use-href.d.ts.map +0 -1
  268. package/dist/browser/react/use-href.js +0 -39
  269. package/dist/browser/react/use-href.js.map +0 -1
  270. package/dist/browser/react/use-link-status.d.ts +0 -37
  271. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  272. package/dist/browser/react/use-link-status.js +0 -99
  273. package/dist/browser/react/use-link-status.js.map +0 -1
  274. package/dist/browser/react/use-mount.d.ts +0 -25
  275. package/dist/browser/react/use-mount.d.ts.map +0 -1
  276. package/dist/browser/react/use-mount.js +0 -30
  277. package/dist/browser/react/use-mount.js.map +0 -1
  278. package/dist/browser/react/use-navigation.d.ts +0 -27
  279. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  280. package/dist/browser/react/use-navigation.js +0 -87
  281. package/dist/browser/react/use-navigation.js.map +0 -1
  282. package/dist/browser/react/use-segments.d.ts +0 -38
  283. package/dist/browser/react/use-segments.d.ts.map +0 -1
  284. package/dist/browser/react/use-segments.js +0 -130
  285. package/dist/browser/react/use-segments.js.map +0 -1
  286. package/dist/browser/request-controller.d.ts +0 -26
  287. package/dist/browser/request-controller.d.ts.map +0 -1
  288. package/dist/browser/request-controller.js +0 -147
  289. package/dist/browser/request-controller.js.map +0 -1
  290. package/dist/browser/rsc-router.d.ts +0 -129
  291. package/dist/browser/rsc-router.d.ts.map +0 -1
  292. package/dist/browser/rsc-router.js +0 -195
  293. package/dist/browser/rsc-router.js.map +0 -1
  294. package/dist/browser/scroll-restoration.d.ts +0 -93
  295. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  296. package/dist/browser/scroll-restoration.js +0 -321
  297. package/dist/browser/scroll-restoration.js.map +0 -1
  298. package/dist/browser/segment-structure-assert.d.ts +0 -17
  299. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  300. package/dist/browser/segment-structure-assert.js +0 -59
  301. package/dist/browser/segment-structure-assert.js.map +0 -1
  302. package/dist/browser/server-action-bridge.d.ts +0 -26
  303. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  304. package/dist/browser/server-action-bridge.js +0 -668
  305. package/dist/browser/server-action-bridge.js.map +0 -1
  306. package/dist/browser/shallow.d.ts +0 -12
  307. package/dist/browser/shallow.d.ts.map +0 -1
  308. package/dist/browser/shallow.js +0 -34
  309. package/dist/browser/shallow.js.map +0 -1
  310. package/dist/browser/types.d.ts +0 -369
  311. package/dist/browser/types.d.ts.map +0 -1
  312. package/dist/browser/types.js +0 -2
  313. package/dist/browser/types.js.map +0 -1
  314. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  315. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  316. package/dist/build/__tests__/generate-cli.test.js +0 -237
  317. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  318. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  319. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  320. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  321. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  322. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  323. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  324. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  325. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  326. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  327. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  328. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  329. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  330. package/dist/build/generate-manifest.d.ts +0 -81
  331. package/dist/build/generate-manifest.d.ts.map +0 -1
  332. package/dist/build/generate-manifest.js +0 -276
  333. package/dist/build/generate-manifest.js.map +0 -1
  334. package/dist/build/generate-route-types.d.ts +0 -115
  335. package/dist/build/generate-route-types.d.ts.map +0 -1
  336. package/dist/build/generate-route-types.js +0 -740
  337. package/dist/build/generate-route-types.js.map +0 -1
  338. package/dist/build/index.d.ts +0 -21
  339. package/dist/build/index.d.ts.map +0 -1
  340. package/dist/build/index.js +0 -21
  341. package/dist/build/index.js.map +0 -1
  342. package/dist/build/route-trie.d.ts +0 -71
  343. package/dist/build/route-trie.d.ts.map +0 -1
  344. package/dist/build/route-trie.js +0 -175
  345. package/dist/build/route-trie.js.map +0 -1
  346. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  347. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  348. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  349. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  350. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  351. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  352. package/dist/cache/__tests__/document-cache.test.js +0 -345
  353. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  354. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  355. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  356. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  357. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  358. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  359. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  360. package/dist/cache/__tests__/memory-store.test.js +0 -367
  361. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  362. package/dist/cache/cache-scope.d.ts +0 -102
  363. package/dist/cache/cache-scope.d.ts.map +0 -1
  364. package/dist/cache/cache-scope.js +0 -440
  365. package/dist/cache/cache-scope.js.map +0 -1
  366. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  367. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  368. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  369. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  370. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  371. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  372. package/dist/cache/cf/cf-cache-store.js +0 -242
  373. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  374. package/dist/cache/cf/index.d.ts +0 -14
  375. package/dist/cache/cf/index.d.ts.map +0 -1
  376. package/dist/cache/cf/index.js +0 -17
  377. package/dist/cache/cf/index.js.map +0 -1
  378. package/dist/cache/document-cache.d.ts +0 -64
  379. package/dist/cache/document-cache.d.ts.map +0 -1
  380. package/dist/cache/document-cache.js +0 -228
  381. package/dist/cache/document-cache.js.map +0 -1
  382. package/dist/cache/index.d.ts +0 -19
  383. package/dist/cache/index.d.ts.map +0 -1
  384. package/dist/cache/index.js +0 -21
  385. package/dist/cache/index.js.map +0 -1
  386. package/dist/cache/memory-segment-store.d.ts +0 -110
  387. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  388. package/dist/cache/memory-segment-store.js +0 -117
  389. package/dist/cache/memory-segment-store.js.map +0 -1
  390. package/dist/cache/memory-store.d.ts +0 -41
  391. package/dist/cache/memory-store.d.ts.map +0 -1
  392. package/dist/cache/memory-store.js +0 -191
  393. package/dist/cache/memory-store.js.map +0 -1
  394. package/dist/cache/types.d.ts +0 -317
  395. package/dist/cache/types.d.ts.map +0 -1
  396. package/dist/cache/types.js +0 -12
  397. package/dist/cache/types.js.map +0 -1
  398. package/dist/client.d.ts +0 -248
  399. package/dist/client.d.ts.map +0 -1
  400. package/dist/client.js +0 -367
  401. package/dist/client.js.map +0 -1
  402. package/dist/client.rsc.d.ts +0 -26
  403. package/dist/client.rsc.d.ts.map +0 -1
  404. package/dist/client.rsc.js +0 -46
  405. package/dist/client.rsc.js.map +0 -1
  406. package/dist/component-utils.d.ts +0 -36
  407. package/dist/component-utils.d.ts.map +0 -1
  408. package/dist/component-utils.js +0 -61
  409. package/dist/component-utils.js.map +0 -1
  410. package/dist/components/DefaultDocument.d.ts +0 -13
  411. package/dist/components/DefaultDocument.d.ts.map +0 -1
  412. package/dist/components/DefaultDocument.js +0 -15
  413. package/dist/components/DefaultDocument.js.map +0 -1
  414. package/dist/debug.d.ts +0 -58
  415. package/dist/debug.d.ts.map +0 -1
  416. package/dist/debug.js +0 -157
  417. package/dist/debug.js.map +0 -1
  418. package/dist/default-error-boundary.d.ts +0 -11
  419. package/dist/default-error-boundary.d.ts.map +0 -1
  420. package/dist/default-error-boundary.js +0 -45
  421. package/dist/default-error-boundary.js.map +0 -1
  422. package/dist/deps/browser.d.ts +0 -2
  423. package/dist/deps/browser.d.ts.map +0 -1
  424. package/dist/deps/browser.js +0 -3
  425. package/dist/deps/browser.js.map +0 -1
  426. package/dist/deps/html-stream-client.d.ts +0 -2
  427. package/dist/deps/html-stream-client.d.ts.map +0 -1
  428. package/dist/deps/html-stream-client.js +0 -3
  429. package/dist/deps/html-stream-client.js.map +0 -1
  430. package/dist/deps/html-stream-server.d.ts +0 -2
  431. package/dist/deps/html-stream-server.d.ts.map +0 -1
  432. package/dist/deps/html-stream-server.js +0 -3
  433. package/dist/deps/html-stream-server.js.map +0 -1
  434. package/dist/deps/rsc.d.ts +0 -2
  435. package/dist/deps/rsc.d.ts.map +0 -1
  436. package/dist/deps/rsc.js +0 -4
  437. package/dist/deps/rsc.js.map +0 -1
  438. package/dist/deps/ssr.d.ts +0 -2
  439. package/dist/deps/ssr.d.ts.map +0 -1
  440. package/dist/deps/ssr.js +0 -3
  441. package/dist/deps/ssr.js.map +0 -1
  442. package/dist/errors.d.ts +0 -174
  443. package/dist/errors.d.ts.map +0 -1
  444. package/dist/errors.js +0 -241
  445. package/dist/errors.js.map +0 -1
  446. package/dist/handle.d.ts +0 -78
  447. package/dist/handle.d.ts.map +0 -1
  448. package/dist/handle.js +0 -82
  449. package/dist/handle.js.map +0 -1
  450. package/dist/handles/MetaTags.d.ts +0 -14
  451. package/dist/handles/MetaTags.d.ts.map +0 -1
  452. package/dist/handles/MetaTags.js +0 -136
  453. package/dist/handles/MetaTags.js.map +0 -1
  454. package/dist/handles/index.d.ts +0 -6
  455. package/dist/handles/index.d.ts.map +0 -1
  456. package/dist/handles/index.js +0 -6
  457. package/dist/handles/index.js.map +0 -1
  458. package/dist/handles/meta.d.ts +0 -39
  459. package/dist/handles/meta.d.ts.map +0 -1
  460. package/dist/handles/meta.js +0 -202
  461. package/dist/handles/meta.js.map +0 -1
  462. package/dist/host/__tests__/errors.test.d.ts +0 -2
  463. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  464. package/dist/host/__tests__/errors.test.js +0 -76
  465. package/dist/host/__tests__/errors.test.js.map +0 -1
  466. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  467. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  468. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  469. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  470. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  471. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  472. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  473. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  474. package/dist/host/__tests__/router.test.d.ts +0 -2
  475. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  476. package/dist/host/__tests__/router.test.js +0 -241
  477. package/dist/host/__tests__/router.test.js.map +0 -1
  478. package/dist/host/__tests__/testing.test.d.ts +0 -2
  479. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  480. package/dist/host/__tests__/testing.test.js +0 -64
  481. package/dist/host/__tests__/testing.test.js.map +0 -1
  482. package/dist/host/__tests__/utils.test.d.ts +0 -2
  483. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  484. package/dist/host/__tests__/utils.test.js +0 -29
  485. package/dist/host/__tests__/utils.test.js.map +0 -1
  486. package/dist/host/cookie-handler.d.ts +0 -34
  487. package/dist/host/cookie-handler.d.ts.map +0 -1
  488. package/dist/host/cookie-handler.js +0 -124
  489. package/dist/host/cookie-handler.js.map +0 -1
  490. package/dist/host/errors.d.ts +0 -56
  491. package/dist/host/errors.d.ts.map +0 -1
  492. package/dist/host/errors.js +0 -79
  493. package/dist/host/errors.js.map +0 -1
  494. package/dist/host/index.d.ts +0 -29
  495. package/dist/host/index.d.ts.map +0 -1
  496. package/dist/host/index.js +0 -32
  497. package/dist/host/index.js.map +0 -1
  498. package/dist/host/pattern-matcher.d.ts +0 -36
  499. package/dist/host/pattern-matcher.d.ts.map +0 -1
  500. package/dist/host/pattern-matcher.js +0 -172
  501. package/dist/host/pattern-matcher.js.map +0 -1
  502. package/dist/host/router.d.ts +0 -26
  503. package/dist/host/router.d.ts.map +0 -1
  504. package/dist/host/router.js +0 -218
  505. package/dist/host/router.js.map +0 -1
  506. package/dist/host/testing.d.ts +0 -36
  507. package/dist/host/testing.d.ts.map +0 -1
  508. package/dist/host/testing.js +0 -55
  509. package/dist/host/testing.js.map +0 -1
  510. package/dist/host/types.d.ts +0 -115
  511. package/dist/host/types.d.ts.map +0 -1
  512. package/dist/host/types.js +0 -7
  513. package/dist/host/types.js.map +0 -1
  514. package/dist/host/utils.d.ts +0 -21
  515. package/dist/host/utils.d.ts.map +0 -1
  516. package/dist/host/utils.js +0 -23
  517. package/dist/host/utils.js.map +0 -1
  518. package/dist/href-client.d.ts +0 -131
  519. package/dist/href-client.d.ts.map +0 -1
  520. package/dist/href-client.js +0 -64
  521. package/dist/href-client.js.map +0 -1
  522. package/dist/href-context.d.ts +0 -29
  523. package/dist/href-context.d.ts.map +0 -1
  524. package/dist/href-context.js +0 -21
  525. package/dist/href-context.js.map +0 -1
  526. package/dist/index.d.ts +0 -73
  527. package/dist/index.d.ts.map +0 -1
  528. package/dist/index.js +0 -91
  529. package/dist/index.js.map +0 -1
  530. package/dist/index.rsc.d.ts +0 -32
  531. package/dist/index.rsc.d.ts.map +0 -1
  532. package/dist/index.rsc.js +0 -40
  533. package/dist/index.rsc.js.map +0 -1
  534. package/dist/internal-debug.d.ts +0 -2
  535. package/dist/internal-debug.d.ts.map +0 -1
  536. package/dist/internal-debug.js +0 -5
  537. package/dist/internal-debug.js.map +0 -1
  538. package/dist/loader.d.ts +0 -14
  539. package/dist/loader.d.ts.map +0 -1
  540. package/dist/loader.js +0 -20
  541. package/dist/loader.js.map +0 -1
  542. package/dist/loader.rsc.d.ts +0 -19
  543. package/dist/loader.rsc.d.ts.map +0 -1
  544. package/dist/loader.rsc.js +0 -99
  545. package/dist/loader.rsc.js.map +0 -1
  546. package/dist/network-error-thrower.d.ts +0 -17
  547. package/dist/network-error-thrower.d.ts.map +0 -1
  548. package/dist/network-error-thrower.js +0 -14
  549. package/dist/network-error-thrower.js.map +0 -1
  550. package/dist/outlet-context.d.ts +0 -13
  551. package/dist/outlet-context.d.ts.map +0 -1
  552. package/dist/outlet-context.js +0 -3
  553. package/dist/outlet-context.js.map +0 -1
  554. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  555. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  556. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  557. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  558. package/dist/prerender/param-hash.d.ts +0 -16
  559. package/dist/prerender/param-hash.d.ts.map +0 -1
  560. package/dist/prerender/param-hash.js +0 -36
  561. package/dist/prerender/param-hash.js.map +0 -1
  562. package/dist/prerender/store.d.ts +0 -38
  563. package/dist/prerender/store.d.ts.map +0 -1
  564. package/dist/prerender/store.js +0 -61
  565. package/dist/prerender/store.js.map +0 -1
  566. package/dist/prerender.d.ts +0 -66
  567. package/dist/prerender.d.ts.map +0 -1
  568. package/dist/prerender.js +0 -57
  569. package/dist/prerender.js.map +0 -1
  570. package/dist/reverse.d.ts +0 -196
  571. package/dist/reverse.d.ts.map +0 -1
  572. package/dist/reverse.js +0 -78
  573. package/dist/reverse.js.map +0 -1
  574. package/dist/root-error-boundary.d.ts +0 -33
  575. package/dist/root-error-boundary.d.ts.map +0 -1
  576. package/dist/root-error-boundary.js +0 -165
  577. package/dist/root-error-boundary.js.map +0 -1
  578. package/dist/route-content-wrapper.d.ts +0 -46
  579. package/dist/route-content-wrapper.d.ts.map +0 -1
  580. package/dist/route-content-wrapper.js +0 -77
  581. package/dist/route-content-wrapper.js.map +0 -1
  582. package/dist/route-definition.d.ts +0 -421
  583. package/dist/route-definition.d.ts.map +0 -1
  584. package/dist/route-definition.js +0 -868
  585. package/dist/route-definition.js.map +0 -1
  586. package/dist/route-map-builder.d.ts +0 -155
  587. package/dist/route-map-builder.d.ts.map +0 -1
  588. package/dist/route-map-builder.js +0 -237
  589. package/dist/route-map-builder.js.map +0 -1
  590. package/dist/route-types.d.ts +0 -165
  591. package/dist/route-types.d.ts.map +0 -1
  592. package/dist/route-types.js +0 -7
  593. package/dist/route-types.js.map +0 -1
  594. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  595. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  596. package/dist/router/__tests__/handler-context.test.js +0 -65
  597. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  598. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  599. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  600. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  601. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  602. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  603. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  604. package/dist/router/__tests__/match-context.test.js +0 -92
  605. package/dist/router/__tests__/match-context.test.js.map +0 -1
  606. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  607. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  608. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  609. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  610. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  611. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  612. package/dist/router/__tests__/match-result.test.js +0 -457
  613. package/dist/router/__tests__/match-result.test.js.map +0 -1
  614. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  615. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  616. package/dist/router/__tests__/on-error.test.js +0 -678
  617. package/dist/router/__tests__/on-error.test.js.map +0 -1
  618. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  619. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  620. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  621. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  622. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  623. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  624. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  625. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  626. package/dist/router/error-handling.d.ts +0 -77
  627. package/dist/router/error-handling.d.ts.map +0 -1
  628. package/dist/router/error-handling.js +0 -202
  629. package/dist/router/error-handling.js.map +0 -1
  630. package/dist/router/handler-context.d.ts +0 -20
  631. package/dist/router/handler-context.d.ts.map +0 -1
  632. package/dist/router/handler-context.js +0 -198
  633. package/dist/router/handler-context.js.map +0 -1
  634. package/dist/router/intercept-resolution.d.ts +0 -66
  635. package/dist/router/intercept-resolution.d.ts.map +0 -1
  636. package/dist/router/intercept-resolution.js +0 -246
  637. package/dist/router/intercept-resolution.js.map +0 -1
  638. package/dist/router/loader-resolution.d.ts +0 -64
  639. package/dist/router/loader-resolution.d.ts.map +0 -1
  640. package/dist/router/loader-resolution.js +0 -284
  641. package/dist/router/loader-resolution.js.map +0 -1
  642. package/dist/router/logging.d.ts +0 -15
  643. package/dist/router/logging.d.ts.map +0 -1
  644. package/dist/router/logging.js +0 -99
  645. package/dist/router/logging.js.map +0 -1
  646. package/dist/router/manifest.d.ts +0 -22
  647. package/dist/router/manifest.d.ts.map +0 -1
  648. package/dist/router/manifest.js +0 -181
  649. package/dist/router/manifest.js.map +0 -1
  650. package/dist/router/match-api.d.ts +0 -35
  651. package/dist/router/match-api.d.ts.map +0 -1
  652. package/dist/router/match-api.js +0 -406
  653. package/dist/router/match-api.js.map +0 -1
  654. package/dist/router/match-context.d.ts +0 -206
  655. package/dist/router/match-context.d.ts.map +0 -1
  656. package/dist/router/match-context.js +0 -17
  657. package/dist/router/match-context.js.map +0 -1
  658. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  659. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  660. package/dist/router/match-middleware/background-revalidation.js +0 -75
  661. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  662. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  663. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  664. package/dist/router/match-middleware/cache-lookup.js +0 -257
  665. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  666. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  667. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  668. package/dist/router/match-middleware/cache-store.js +0 -108
  669. package/dist/router/match-middleware/cache-store.js.map +0 -1
  670. package/dist/router/match-middleware/index.d.ts +0 -81
  671. package/dist/router/match-middleware/index.d.ts.map +0 -1
  672. package/dist/router/match-middleware/index.js +0 -80
  673. package/dist/router/match-middleware/index.js.map +0 -1
  674. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  675. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  676. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  677. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  678. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  679. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  680. package/dist/router/match-middleware/segment-resolution.js +0 -53
  681. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  682. package/dist/router/match-pipelines.d.ts +0 -147
  683. package/dist/router/match-pipelines.d.ts.map +0 -1
  684. package/dist/router/match-pipelines.js +0 -82
  685. package/dist/router/match-pipelines.js.map +0 -1
  686. package/dist/router/match-result.d.ts +0 -126
  687. package/dist/router/match-result.d.ts.map +0 -1
  688. package/dist/router/match-result.js +0 -93
  689. package/dist/router/match-result.js.map +0 -1
  690. package/dist/router/metrics.d.ts +0 -20
  691. package/dist/router/metrics.d.ts.map +0 -1
  692. package/dist/router/metrics.js +0 -47
  693. package/dist/router/metrics.js.map +0 -1
  694. package/dist/router/middleware.d.ts +0 -249
  695. package/dist/router/middleware.d.ts.map +0 -1
  696. package/dist/router/middleware.js +0 -434
  697. package/dist/router/middleware.js.map +0 -1
  698. package/dist/router/middleware.test.d.ts +0 -2
  699. package/dist/router/middleware.test.d.ts.map +0 -1
  700. package/dist/router/middleware.test.js +0 -816
  701. package/dist/router/middleware.test.js.map +0 -1
  702. package/dist/router/pattern-matching.d.ts +0 -149
  703. package/dist/router/pattern-matching.d.ts.map +0 -1
  704. package/dist/router/pattern-matching.js +0 -349
  705. package/dist/router/pattern-matching.js.map +0 -1
  706. package/dist/router/revalidation.d.ts +0 -44
  707. package/dist/router/revalidation.d.ts.map +0 -1
  708. package/dist/router/revalidation.js +0 -147
  709. package/dist/router/revalidation.js.map +0 -1
  710. package/dist/router/router-context.d.ts +0 -135
  711. package/dist/router/router-context.d.ts.map +0 -1
  712. package/dist/router/router-context.js +0 -36
  713. package/dist/router/router-context.js.map +0 -1
  714. package/dist/router/segment-resolution.d.ts +0 -127
  715. package/dist/router/segment-resolution.d.ts.map +0 -1
  716. package/dist/router/segment-resolution.js +0 -919
  717. package/dist/router/segment-resolution.js.map +0 -1
  718. package/dist/router/trie-matching.d.ts +0 -40
  719. package/dist/router/trie-matching.d.ts.map +0 -1
  720. package/dist/router/trie-matching.js +0 -127
  721. package/dist/router/trie-matching.js.map +0 -1
  722. package/dist/router/types.d.ts +0 -136
  723. package/dist/router/types.d.ts.map +0 -1
  724. package/dist/router/types.js +0 -7
  725. package/dist/router/types.js.map +0 -1
  726. package/dist/router.d.ts +0 -753
  727. package/dist/router.d.ts.map +0 -1
  728. package/dist/router.gen.d.ts +0 -6
  729. package/dist/router.gen.d.ts.map +0 -1
  730. package/dist/router.gen.js +0 -6
  731. package/dist/router.gen.js.map +0 -1
  732. package/dist/router.js +0 -1304
  733. package/dist/router.js.map +0 -1
  734. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  735. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  736. package/dist/rsc/__tests__/helpers.test.js +0 -140
  737. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  738. package/dist/rsc/handler.d.ts +0 -45
  739. package/dist/rsc/handler.d.ts.map +0 -1
  740. package/dist/rsc/handler.js +0 -1172
  741. package/dist/rsc/handler.js.map +0 -1
  742. package/dist/rsc/helpers.d.ts +0 -16
  743. package/dist/rsc/helpers.d.ts.map +0 -1
  744. package/dist/rsc/helpers.js +0 -55
  745. package/dist/rsc/helpers.js.map +0 -1
  746. package/dist/rsc/index.d.ts +0 -22
  747. package/dist/rsc/index.d.ts.map +0 -1
  748. package/dist/rsc/index.js +0 -23
  749. package/dist/rsc/index.js.map +0 -1
  750. package/dist/rsc/nonce.d.ts +0 -9
  751. package/dist/rsc/nonce.d.ts.map +0 -1
  752. package/dist/rsc/nonce.js +0 -18
  753. package/dist/rsc/nonce.js.map +0 -1
  754. package/dist/rsc/types.d.ts +0 -206
  755. package/dist/rsc/types.d.ts.map +0 -1
  756. package/dist/rsc/types.js +0 -8
  757. package/dist/rsc/types.js.map +0 -1
  758. package/dist/search-params.d.ts +0 -103
  759. package/dist/search-params.d.ts.map +0 -1
  760. package/dist/search-params.js +0 -74
  761. package/dist/search-params.js.map +0 -1
  762. package/dist/segment-system.d.ts +0 -75
  763. package/dist/segment-system.d.ts.map +0 -1
  764. package/dist/segment-system.js +0 -336
  765. package/dist/segment-system.js.map +0 -1
  766. package/dist/server/context.d.ts +0 -245
  767. package/dist/server/context.d.ts.map +0 -1
  768. package/dist/server/context.js +0 -197
  769. package/dist/server/context.js.map +0 -1
  770. package/dist/server/fetchable-loader-store.d.ts +0 -18
  771. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  772. package/dist/server/fetchable-loader-store.js +0 -18
  773. package/dist/server/fetchable-loader-store.js.map +0 -1
  774. package/dist/server/handle-store.d.ts +0 -85
  775. package/dist/server/handle-store.d.ts.map +0 -1
  776. package/dist/server/handle-store.js +0 -142
  777. package/dist/server/handle-store.js.map +0 -1
  778. package/dist/server/loader-registry.d.ts +0 -55
  779. package/dist/server/loader-registry.d.ts.map +0 -1
  780. package/dist/server/loader-registry.js +0 -132
  781. package/dist/server/loader-registry.js.map +0 -1
  782. package/dist/server/request-context.d.ts +0 -226
  783. package/dist/server/request-context.d.ts.map +0 -1
  784. package/dist/server/request-context.js +0 -290
  785. package/dist/server/request-context.js.map +0 -1
  786. package/dist/server/root-layout.d.ts +0 -4
  787. package/dist/server/root-layout.d.ts.map +0 -1
  788. package/dist/server/root-layout.js +0 -5
  789. package/dist/server/root-layout.js.map +0 -1
  790. package/dist/server.d.ts +0 -15
  791. package/dist/server.d.ts.map +0 -1
  792. package/dist/server.js +0 -20
  793. package/dist/server.js.map +0 -1
  794. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  795. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  796. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  797. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  798. package/dist/ssr/index.d.ts +0 -98
  799. package/dist/ssr/index.d.ts.map +0 -1
  800. package/dist/ssr/index.js +0 -158
  801. package/dist/ssr/index.js.map +0 -1
  802. package/dist/static-handler.d.ts +0 -50
  803. package/dist/static-handler.d.ts.map +0 -1
  804. package/dist/static-handler.gen.d.ts +0 -5
  805. package/dist/static-handler.gen.d.ts.map +0 -1
  806. package/dist/static-handler.gen.js +0 -5
  807. package/dist/static-handler.gen.js.map +0 -1
  808. package/dist/static-handler.js +0 -29
  809. package/dist/static-handler.js.map +0 -1
  810. package/dist/theme/ThemeProvider.d.ts +0 -20
  811. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  812. package/dist/theme/ThemeProvider.js +0 -240
  813. package/dist/theme/ThemeProvider.js.map +0 -1
  814. package/dist/theme/ThemeScript.d.ts +0 -48
  815. package/dist/theme/ThemeScript.d.ts.map +0 -1
  816. package/dist/theme/ThemeScript.js +0 -13
  817. package/dist/theme/ThemeScript.js.map +0 -1
  818. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  819. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  820. package/dist/theme/__tests__/theme.test.js +0 -103
  821. package/dist/theme/__tests__/theme.test.js.map +0 -1
  822. package/dist/theme/constants.d.ts +0 -29
  823. package/dist/theme/constants.d.ts.map +0 -1
  824. package/dist/theme/constants.js +0 -48
  825. package/dist/theme/constants.js.map +0 -1
  826. package/dist/theme/index.d.ts +0 -31
  827. package/dist/theme/index.d.ts.map +0 -1
  828. package/dist/theme/index.js +0 -36
  829. package/dist/theme/index.js.map +0 -1
  830. package/dist/theme/theme-context.d.ts +0 -40
  831. package/dist/theme/theme-context.d.ts.map +0 -1
  832. package/dist/theme/theme-context.js +0 -60
  833. package/dist/theme/theme-context.js.map +0 -1
  834. package/dist/theme/theme-script.d.ts +0 -27
  835. package/dist/theme/theme-script.d.ts.map +0 -1
  836. package/dist/theme/theme-script.js +0 -147
  837. package/dist/theme/theme-script.js.map +0 -1
  838. package/dist/theme/types.d.ts +0 -163
  839. package/dist/theme/types.d.ts.map +0 -1
  840. package/dist/theme/types.js +0 -11
  841. package/dist/theme/types.js.map +0 -1
  842. package/dist/theme/use-theme.d.ts +0 -12
  843. package/dist/theme/use-theme.d.ts.map +0 -1
  844. package/dist/theme/use-theme.js +0 -40
  845. package/dist/theme/use-theme.js.map +0 -1
  846. package/dist/types.d.ts +0 -1479
  847. package/dist/types.d.ts.map +0 -1
  848. package/dist/types.js +0 -10
  849. package/dist/types.js.map +0 -1
  850. package/dist/urls.d.ts +0 -441
  851. package/dist/urls.d.ts.map +0 -1
  852. package/dist/urls.gen.d.ts +0 -8
  853. package/dist/urls.gen.d.ts.map +0 -1
  854. package/dist/urls.gen.js +0 -8
  855. package/dist/urls.gen.js.map +0 -1
  856. package/dist/urls.js +0 -443
  857. package/dist/urls.js.map +0 -1
  858. package/dist/use-loader.d.ts +0 -127
  859. package/dist/use-loader.d.ts.map +0 -1
  860. package/dist/use-loader.js +0 -237
  861. package/dist/use-loader.js.map +0 -1
  862. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  863. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  864. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  865. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  866. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  867. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  868. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  869. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  870. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  871. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  872. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  873. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  874. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  875. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  876. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  877. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  878. package/dist/vite/ast-handler-extract.d.ts +0 -49
  879. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  880. package/dist/vite/ast-handler-extract.js +0 -249
  881. package/dist/vite/ast-handler-extract.js.map +0 -1
  882. package/dist/vite/expose-action-id.d.ts +0 -19
  883. package/dist/vite/expose-action-id.d.ts.map +0 -1
  884. package/dist/vite/expose-action-id.js +0 -250
  885. package/dist/vite/expose-action-id.js.map +0 -1
  886. package/dist/vite/expose-id-utils.d.ts +0 -69
  887. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  888. package/dist/vite/expose-id-utils.js +0 -289
  889. package/dist/vite/expose-id-utils.js.map +0 -1
  890. package/dist/vite/expose-internal-ids.d.ts +0 -22
  891. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  892. package/dist/vite/expose-internal-ids.js +0 -886
  893. package/dist/vite/expose-internal-ids.js.map +0 -1
  894. package/dist/vite/index.d.ts +0 -149
  895. package/dist/vite/index.d.ts.map +0 -1
  896. package/dist/vite/index.js.map +0 -1
  897. package/dist/vite/index.named-routes.gen.ts +0 -103
  898. package/dist/vite/package-resolution.d.ts +0 -43
  899. package/dist/vite/package-resolution.d.ts.map +0 -1
  900. package/dist/vite/package-resolution.js +0 -112
  901. package/dist/vite/package-resolution.js.map +0 -1
  902. package/dist/vite/virtual-entries.d.ts +0 -25
  903. package/dist/vite/virtual-entries.d.ts.map +0 -1
  904. package/dist/vite/virtual-entries.js +0 -110
  905. package/dist/vite/virtual-entries.js.map +0 -1
  906. package/src/browser/debug-channel.ts +0 -93
@@ -1,886 +0,0 @@
1
- import { parseAst } from "vite";
2
- import MagicString from "magic-string";
3
- import path from "node:path";
4
- import { createHash } from "node:crypto";
5
- import { normalizePath, hashId, detectImports, findMatchingParen, countArgs, findStatementEnd, buildExportMap, } from "./expose-id-utils.ts";
6
- import { transformInlineHandlers, } from "./ast-handler-extract.ts";
7
- // ---------------------------------------------------------------------------
8
- // Virtual module for loader manifest
9
- // ---------------------------------------------------------------------------
10
- const VIRTUAL_LOADER_MANIFEST = "virtual:rsc-router/loader-manifest";
11
- const RESOLVED_VIRTUAL_LOADER_MANIFEST = "\0" + VIRTUAL_LOADER_MANIFEST;
12
- // ---------------------------------------------------------------------------
13
- // Virtual module prefix for extracted inline handlers
14
- // ---------------------------------------------------------------------------
15
- const VIRTUAL_HANDLER_PREFIX = "virtual:handler-extract:";
16
- const PRERENDER_CONFIG = {
17
- fnName: "Prerender",
18
- brand: "prerenderHandler",
19
- };
20
- const STATIC_CONFIG = {
21
- fnName: "Static",
22
- brand: "staticHandler",
23
- };
24
- const STRICT_CREATE_CONFIGS = [
25
- { fnName: "createLoader" },
26
- { fnName: "createHandle" },
27
- { fnName: "createLocationState" },
28
- ];
29
- function escapeRegExp(input) {
30
- return input.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
31
- }
32
- /**
33
- * Check whether every non-type export in `code` is accounted for by the given
34
- * bindings. Returns false if any export exists that is not one of the known
35
- * create* call locals/exports, allowing callers to bail out for mixed-export
36
- * files.
37
- */
38
- function isExportOnlyFile(code, bindings) {
39
- if (bindings.length === 0)
40
- return false;
41
- const knownLocals = new Set();
42
- const knownExports = new Set();
43
- for (const b of bindings) {
44
- knownLocals.add(b.localName);
45
- for (const e of b.exportNames)
46
- knownExports.add(e);
47
- }
48
- // Bail on star re-exports (unknown exports)
49
- if (/export\s*\*/.test(code))
50
- return false;
51
- // Check `export const/let/var/function/class/default X` declarations
52
- const declExportPattern = /export\s+(const|let|var|function|class|default)\s+(\w+)/g;
53
- let match;
54
- while ((match = declExportPattern.exec(code)) !== null) {
55
- if (!knownExports.has(match[2]))
56
- return false;
57
- }
58
- // Check `export { X }` and `export { X as Y }` specifiers: the local name
59
- // must reference a known create* binding.
60
- const specExportPattern = /export\s*\{([^}]+)\}/g;
61
- while ((match = specExportPattern.exec(code)) !== null) {
62
- const specifiers = match[1]
63
- .split(",")
64
- .map((s) => s.trim())
65
- .filter(Boolean);
66
- for (const spec of specifiers) {
67
- const m = spec.match(/^([A-Za-z_$][\w$]*)(?:\s+as\s+([A-Za-z_$][\w$]*))?$/);
68
- if (!m)
69
- continue;
70
- const local = m[1];
71
- if (!knownLocals.has(local))
72
- return false;
73
- }
74
- }
75
- return true;
76
- }
77
- // NOTE: This regex may over-count when the fn name appears inside strings or
78
- // comments, but it's only used for the warning heuristic (totalCalls >
79
- // supportedBindings) and the inline-extraction pre-check, so over-counting
80
- // triggers a harmless extra AST parse rather than affecting correctness.
81
- function countCreateCallsForNames(code, fnNames) {
82
- const pattern = new RegExp(`\\b(?:${fnNames.map(escapeRegExp).join("|")})\\s*(?:<[^>]*>\\s*)?\\(`, "g");
83
- return (code.match(pattern) || []).length;
84
- }
85
- function getImportedFnNames(code, importedName) {
86
- const importPattern = /import\s*\{([^}]*)\}\s*from\s*["']@rangojs\/router(?:\/[^"']*)?["']/g;
87
- const localNames = new Set();
88
- let match;
89
- while ((match = importPattern.exec(code)) !== null) {
90
- const specList = match[1]
91
- .split(",")
92
- .map((s) => s.trim())
93
- .filter(Boolean);
94
- for (const spec of specList) {
95
- const m = spec.match(/^([A-Za-z_$][\w$]*)(?:\s+as\s+([A-Za-z_$][\w$]*))?$/);
96
- if (!m)
97
- continue;
98
- const imported = m[1];
99
- const local = m[2] || imported;
100
- if (imported === importedName) {
101
- localNames.add(local);
102
- }
103
- }
104
- }
105
- const names = Array.from(localNames);
106
- return names.length > 0 ? names : [importedName];
107
- }
108
- function getCalledIdentifierFromCall(callExpr) {
109
- const callee = callExpr?.callee;
110
- if (callee?.type === "Identifier")
111
- return callee.name;
112
- if (callee?.type === "TSInstantiationExpression" &&
113
- callee.expression?.type === "Identifier") {
114
- return callee.expression.name;
115
- }
116
- return null;
117
- }
118
- function collectCreateExportBindingsFallback(code, fnNames) {
119
- const alternation = fnNames.map(escapeRegExp).join("|");
120
- const exportConstPattern = new RegExp(`export\\s+const\\s+(\\w+)\\s*=\\s*(?:${alternation})\\s*(?:<[^>]*>)?\\s*\\(`, "g");
121
- const localDeclPattern = new RegExp(`\\bconst\\s+(\\w+)\\s*=\\s*((?:${alternation})\\s*(?:<[^>]*>)?\\s*\\()`, "g");
122
- const exportSpecPattern = /export\s*\{([^}]+)\}/g;
123
- const exportMap = new Map();
124
- const pushExport = (local, exported) => {
125
- const list = exportMap.get(local);
126
- if (list) {
127
- if (!list.includes(exported))
128
- list.push(exported);
129
- return;
130
- }
131
- exportMap.set(local, [exported]);
132
- };
133
- let match;
134
- while ((match = exportConstPattern.exec(code)) !== null) {
135
- pushExport(match[1], match[1]);
136
- }
137
- while ((match = exportSpecPattern.exec(code)) !== null) {
138
- const specifiers = match[1]
139
- .split(",")
140
- .map((s) => s.trim())
141
- .filter(Boolean);
142
- for (const specifier of specifiers) {
143
- const specMatch = specifier.match(/^([A-Za-z_$][\w$]*)(?:\s+as\s+([A-Za-z_$][\w$]*))?$/);
144
- if (!specMatch)
145
- continue;
146
- const local = specMatch[1];
147
- const exported = specMatch[2] || local;
148
- pushExport(local, exported);
149
- }
150
- }
151
- const bindings = [];
152
- while ((match = localDeclPattern.exec(code)) !== null) {
153
- const localName = match[1];
154
- const exportNames = exportMap.get(localName) ?? [];
155
- if (exportNames.length === 0)
156
- continue;
157
- const openParenPos = match.index + match[0].length - 1;
158
- const closeParenPos = findMatchingParen(code, openParenPos + 1) - 1;
159
- if (closeParenPos <= openParenPos)
160
- continue;
161
- bindings.push({
162
- localName,
163
- exportNames,
164
- callExprStart: match.index + match[0].length - match[2].length,
165
- callOpenParenPos: openParenPos,
166
- callCloseParenPos: closeParenPos,
167
- argCount: countArgs(code, openParenPos + 1, closeParenPos),
168
- statementEnd: findStatementEnd(code, closeParenPos + 1),
169
- });
170
- }
171
- return bindings;
172
- }
173
- function collectCreateExportBindings(code, fnNames, program) {
174
- if (!program) {
175
- try {
176
- program = parseAst(code, { jsx: true });
177
- }
178
- catch {
179
- return collectCreateExportBindingsFallback(code, fnNames);
180
- }
181
- }
182
- const exportMap = buildExportMap(program);
183
- const fnNameSet = new Set(fnNames);
184
- const bindings = [];
185
- const collectFromVarDecl = (varDecl, statementEnd) => {
186
- if (varDecl?.type !== "VariableDeclaration" || varDecl.kind !== "const") {
187
- return;
188
- }
189
- for (const decl of varDecl.declarations ?? []) {
190
- const calledIdentifier = getCalledIdentifierFromCall(decl?.init);
191
- if (decl?.id?.type !== "Identifier" ||
192
- decl?.init?.type !== "CallExpression" ||
193
- !calledIdentifier ||
194
- !fnNameSet.has(calledIdentifier)) {
195
- continue;
196
- }
197
- const localName = decl.id.name;
198
- const exportNames = exportMap.get(localName) ?? [];
199
- if (exportNames.length === 0)
200
- continue;
201
- const callStart = decl.init.start;
202
- const callEnd = decl.init.end;
203
- const calleeEnd = decl.init.callee.end;
204
- let openParenPos = -1;
205
- for (let i = calleeEnd; i < callEnd; i++) {
206
- if (code[i] === "(") {
207
- openParenPos = i;
208
- break;
209
- }
210
- }
211
- if (openParenPos === -1)
212
- continue;
213
- const closeParenPos = findMatchingParen(code, openParenPos + 1) - 1;
214
- if (closeParenPos <= openParenPos)
215
- continue;
216
- bindings.push({
217
- localName,
218
- exportNames,
219
- callExprStart: decl.init.start,
220
- callOpenParenPos: openParenPos,
221
- callCloseParenPos: closeParenPos,
222
- argCount: decl.init.arguments?.length ?? 0,
223
- statementEnd,
224
- });
225
- }
226
- };
227
- for (const node of program.body ?? []) {
228
- if (node?.type === "VariableDeclaration") {
229
- collectFromVarDecl(node, node.end);
230
- continue;
231
- }
232
- if (node?.type === "ExportNamedDeclaration" &&
233
- node.declaration?.type === "VariableDeclaration") {
234
- collectFromVarDecl(node.declaration, node.end);
235
- }
236
- }
237
- return bindings;
238
- }
239
- function buildUnsupportedShapeWarning(filePath, fnName) {
240
- return [
241
- `[rsc-router] Unsupported ${fnName} shape in "${filePath}".`,
242
- `Supported shapes are:`,
243
- ` - export const X = ${fnName}(...)`,
244
- ` - const X = ${fnName}(...); export { X }`,
245
- ` - const X = ${fnName}(...); export { X as Y }`,
246
- `Potentially unsupported forms include:`,
247
- ` - export let/var X = ${fnName}(...)`,
248
- ` - inline ${fnName}(...) calls`,
249
- ].join("\n");
250
- }
251
- // ---------------------------------------------------------------------------
252
- // Loader helpers
253
- // ---------------------------------------------------------------------------
254
- function hasCreateLoaderImport(code) {
255
- return /import\s*\{[^}]*\bcreateLoader\b[^}]*\}\s*from\s*["']@rangojs\/router(?:\/server)?["']/.test(code);
256
- }
257
- /**
258
- * Generate lightweight client stubs for loader files.
259
- *
260
- * When a loader file is imported from a client component (e.g., for useLoader()),
261
- * the client only needs { __brand: "loader", $$id: "..." } objects.
262
- * This function replaces the entire file contents with just those stub exports,
263
- * preventing server-only data (constants, DB queries, etc.) from leaking into
264
- * the client bundle.
265
- *
266
- * Only applies when ALL named exports are createLoader() calls (plus type exports
267
- * which are erased at compile time). Files with mixed exports are left untouched.
268
- */
269
- function generateClientLoaderStubs(bindings, code, filePath, isBuild) {
270
- if (!isExportOnlyFile(code, bindings))
271
- return null;
272
- const exportNames = bindings.flatMap((b) => b.exportNames);
273
- const stubs = exportNames.map((name) => {
274
- const loaderId = isBuild
275
- ? hashId(filePath, name)
276
- : `${filePath}#${name}`;
277
- return `export const ${name} = { __brand: "loader", $$id: "${loaderId}" };`;
278
- });
279
- return { code: stubs.join("\n") + "\n" };
280
- }
281
- function transformLoaders(bindings, s, filePath, isBuild) {
282
- let hasChanges = false;
283
- for (const binding of bindings) {
284
- const exportName = binding.exportNames[0];
285
- const loaderId = isBuild
286
- ? hashId(filePath, exportName)
287
- : `${filePath}#${exportName}`;
288
- // Inject $$id as hidden third parameter.
289
- // createLoader(fn) -> createLoader(fn, undefined, "id")
290
- // createLoader(fn, true) -> createLoader(fn, true, "id")
291
- const paramInjection = binding.argCount === 1
292
- ? `, undefined, "${loaderId}"`
293
- : `, "${loaderId}"`;
294
- s.appendLeft(binding.callCloseParenPos, paramInjection);
295
- const propInjection = `\n${binding.localName}.$$id = "${loaderId}";`;
296
- s.appendRight(binding.statementEnd, propInjection);
297
- hasChanges = true;
298
- }
299
- return hasChanges;
300
- }
301
- // ---------------------------------------------------------------------------
302
- // Handle helpers
303
- // ---------------------------------------------------------------------------
304
- function analyzeCreateHandleArgs(code, startPos, endPos) {
305
- const content = code.slice(startPos, endPos).trim();
306
- return { hasArgs: content.length > 0 };
307
- }
308
- function transformHandles(bindings, s, code, filePath, isBuild) {
309
- let hasChanges = false;
310
- for (const binding of bindings) {
311
- const exportName = binding.exportNames[0];
312
- const args = analyzeCreateHandleArgs(code, binding.callOpenParenPos + 1, binding.callCloseParenPos);
313
- const handleId = isBuild
314
- ? hashId(filePath, exportName)
315
- : `${filePath}#${exportName}`;
316
- let paramInjection;
317
- if (!args.hasArgs) {
318
- paramInjection = `undefined, "${handleId}"`;
319
- }
320
- else {
321
- paramInjection = `, "${handleId}"`;
322
- }
323
- s.appendLeft(binding.callCloseParenPos, paramInjection);
324
- const propInjection = `\n${binding.localName}.$$id = "${handleId}";`;
325
- s.appendRight(binding.statementEnd, propInjection);
326
- hasChanges = true;
327
- }
328
- return hasChanges;
329
- }
330
- // ---------------------------------------------------------------------------
331
- // LocationState helpers
332
- // ---------------------------------------------------------------------------
333
- function transformLocationState(bindings, s, filePath, isBuild) {
334
- let hasChanges = false;
335
- for (const binding of bindings) {
336
- if (binding.argCount > 0)
337
- continue; // Already has a key, skip
338
- const exportName = binding.exportNames[0];
339
- const stateKey = isBuild
340
- ? hashId(filePath, exportName)
341
- : `${filePath}#${exportName}`;
342
- s.appendLeft(binding.callCloseParenPos, `"${stateKey}"`);
343
- const propInjection = `\n${binding.localName}.__rsc_ls_key = "__rsc_ls_${stateKey}";`;
344
- s.appendRight(binding.statementEnd, propInjection);
345
- hasChanges = true;
346
- }
347
- return hasChanges;
348
- }
349
- // ---------------------------------------------------------------------------
350
- // Parameterized handler helpers (prerender + static)
351
- // ---------------------------------------------------------------------------
352
- /**
353
- * Replace the entire file with lightweight stubs when ALL non-type exports are
354
- * handler calls of the given type. Returns null for files with mixed exports.
355
- */
356
- function generateWholeFileStubs(cfg, bindings, code, filePath, isBuild) {
357
- if (!isExportOnlyFile(code, bindings))
358
- return null;
359
- const exportNames = bindings.flatMap((b) => b.exportNames);
360
- const stubs = exportNames.map((name) => {
361
- const handlerId = isBuild
362
- ? hashId(filePath, name)
363
- : `${filePath}#${name}`;
364
- return `export const ${name} = { __brand: "${cfg.brand}", $$id: "${handlerId}" };`;
365
- });
366
- return { code: stubs.join("\n") + "\n", map: null };
367
- }
368
- /**
369
- * Replace handler call expressions with lightweight stub objects in non-RSC
370
- * environments. Other exports, imports, and module-level code remain untouched.
371
- */
372
- function generateExprStubs(cfg, bindings, code, filePath, sourceId, isBuild) {
373
- if (bindings.length === 0)
374
- return null;
375
- const s = new MagicString(code);
376
- let hasChanges = false;
377
- for (const binding of bindings) {
378
- const exportName = binding.exportNames[0];
379
- const handlerId = isBuild
380
- ? hashId(filePath, exportName)
381
- : `${filePath}#${exportName}`;
382
- s.overwrite(binding.callExprStart, binding.callCloseParenPos + 1, `{ __brand: "${cfg.brand}", $$id: "${handlerId}" }`);
383
- hasChanges = true;
384
- }
385
- if (!hasChanges)
386
- return null;
387
- return {
388
- code: s.toString(),
389
- map: s.generateMap({
390
- source: sourceId,
391
- includeContent: true,
392
- hires: "boundary",
393
- }),
394
- };
395
- }
396
- /**
397
- * Inject $$id into export const handler calls in RSC environments.
398
- */
399
- function transformHandlerIds(cfg, bindings, s, filePath, isBuild) {
400
- let hasChanges = false;
401
- for (const binding of bindings) {
402
- const exportName = binding.exportNames[0];
403
- const handlerId = isBuild
404
- ? hashId(filePath, exportName)
405
- : `${filePath}#${exportName}`;
406
- // Injection strategy matches the runtime overload signatures:
407
- // 0 args -> inject undefined, "id"
408
- // 1 arg (handler) -> inject , undefined, "id"
409
- // 2+ args -> inject , "id"
410
- let paramInjection;
411
- if (binding.argCount === 0) {
412
- paramInjection = `undefined, "${handlerId}"`;
413
- }
414
- else if (binding.argCount === 1) {
415
- paramInjection = `, undefined, "${handlerId}"`;
416
- }
417
- else {
418
- paramInjection = `, "${handlerId}"`;
419
- }
420
- s.appendLeft(binding.callCloseParenPos, paramInjection);
421
- const propInjection = `\n${binding.localName}.$$id = "${handlerId}";`;
422
- s.appendRight(binding.statementEnd, propInjection);
423
- hasChanges = true;
424
- }
425
- return hasChanges;
426
- }
427
- // ---------------------------------------------------------------------------
428
- // Router helpers
429
- // ---------------------------------------------------------------------------
430
- function transformRouter(code, filePath, routerFnNames) {
431
- const pat = new RegExp(`\\b(?:${routerFnNames.map(escapeRegExp).join("|")})\\s*(?:<[^>]*>)?\\s*\\(`, "g");
432
- let match;
433
- const s = new MagicString(code);
434
- let changed = false;
435
- // Compute the import path for the generated route names file.
436
- // filePath is relative to project root (e.g., "src/router.tsx")
437
- const basename = path.basename(filePath).replace(/\.(tsx?|jsx?)$/, "");
438
- const routeNamesImport = `./${basename}.named-routes.gen.js`;
439
- const routeNamesVar = `__rsc_rn`;
440
- while ((match = pat.exec(code)) !== null) {
441
- const callStart = match.index;
442
- const parenPos = match.index + match[0].length - 1;
443
- const afterParen = code.slice(parenPos + 1).trimStart();
444
- // Skip if $$id is already present
445
- if (afterParen.includes("$$id"))
446
- continue;
447
- // Compute line number for this call
448
- const lineNumber = code.slice(0, callStart).split("\n").length;
449
- const hash = createHash("sha256")
450
- .update(`${filePath}:${lineNumber}`)
451
- .digest("hex")
452
- .slice(0, 8);
453
- changed = true;
454
- const injected = ` $$id: "${hash}", $$routeNames: ${routeNamesVar},`;
455
- if (afterParen.startsWith("{")) {
456
- const bracePos = code.indexOf("{", parenPos + 1);
457
- s.appendRight(bracePos + 1, injected);
458
- }
459
- else if (afterParen.startsWith(")")) {
460
- s.appendRight(parenPos + 1, `{${injected} }`);
461
- }
462
- }
463
- if (!changed)
464
- return null;
465
- // Prepend the static import as the first line. MagicString tracks the
466
- // offset so all downstream source maps remain correct.
467
- s.prepend(`import { NamedRoutes as ${routeNamesVar} } from "${routeNamesImport}";\n`);
468
- return {
469
- code: s.toString(),
470
- map: s.generateMap({ hires: true }),
471
- };
472
- }
473
- // ---------------------------------------------------------------------------
474
- // Router ID plugin (separate: must run at normal priority, NOT "post")
475
- // ---------------------------------------------------------------------------
476
- /**
477
- * Inject stable $$id into createRouter() calls at compile time.
478
- * This must be a separate plugin without enforce:"post" because running
479
- * at "post" priority changes Vite's dep optimization timing and can cause
480
- * ERR_OUTDATED_OPTIMIZED_DEP / React dual-instance issues.
481
- */
482
- export function exposeRouterId() {
483
- let projectRoot = "";
484
- return {
485
- name: "@rangojs/router:expose-router-id",
486
- configResolved(config) {
487
- projectRoot = config.root;
488
- },
489
- transform(code, id) {
490
- if (!code.includes("createRouter"))
491
- return null;
492
- if (!/import\s*\{[^}]*\bcreateRouter\b[^}]*\}\s*from\s*["']@rangojs\/router(?:\/server)?["']/.test(code)) {
493
- return null;
494
- }
495
- if (id.includes("node_modules"))
496
- return null;
497
- const filePath = normalizePath(path.relative(projectRoot, id));
498
- const routerFnNames = getImportedFnNames(code, "createRouter");
499
- return transformRouter(code, filePath, routerFnNames);
500
- },
501
- };
502
- }
503
- // ---------------------------------------------------------------------------
504
- // Consolidated plugin
505
- // ---------------------------------------------------------------------------
506
- export function exposeInternalIds(options) {
507
- let config;
508
- let isBuild = false;
509
- let projectRoot = "";
510
- // Loader registry: hashedId -> { filePath, exportName }
511
- const loaderRegistry = new Map();
512
- // Prerender handler module tracking (consumed via plugin API)
513
- const prerenderHandlerModules = new Map();
514
- // Static handler module tracking (consumed via plugin API)
515
- const staticHandlerModules = new Map();
516
- // Virtual module registry for inline handler extraction (both types)
517
- const virtualHandlers = new Map();
518
- // De-duplicate unsupported shape warnings across repeated transforms.
519
- const unsupportedShapeWarnings = new Set();
520
- return {
521
- name: "@rangojs/router:expose-internal-ids",
522
- enforce: "post",
523
- api: {
524
- prerenderHandlerModules,
525
- staticHandlerModules,
526
- },
527
- configResolved(resolved) {
528
- config = resolved;
529
- isBuild = options?.forceBuild || config.command === "build";
530
- projectRoot = config.root;
531
- },
532
- // --------------- Virtual module support ---------------
533
- resolveId(id, importer) {
534
- if (id === VIRTUAL_LOADER_MANIFEST) {
535
- return RESOLVED_VIRTUAL_LOADER_MANIFEST;
536
- }
537
- if (id.startsWith(VIRTUAL_HANDLER_PREFIX)) {
538
- return "\0" + id;
539
- }
540
- // Resolve imports FROM virtual modules against the original file
541
- if (importer?.startsWith("\0" + VIRTUAL_HANDLER_PREFIX)) {
542
- const entry = virtualHandlers.get(importer);
543
- if (entry) {
544
- return this.resolve(id, entry.originalModuleId, { skipSelf: true });
545
- }
546
- }
547
- },
548
- load(id) {
549
- // Virtual handler modules (both prerender and static)
550
- if (id.startsWith("\0" + VIRTUAL_HANDLER_PREFIX)) {
551
- const entry = virtualHandlers.get(id);
552
- if (!entry)
553
- return null;
554
- return [
555
- ...entry.imports,
556
- `export const ${entry.exportName} = ${entry.handlerCode};`,
557
- ].join("\n") + "\n";
558
- }
559
- if (id !== RESOLVED_VIRTUAL_LOADER_MANIFEST)
560
- return;
561
- if (!isBuild) {
562
- return `import { setLoaderImports } from "@rangojs/router/server";
563
-
564
- // Dev mode: empty map, loaders are resolved dynamically via path parsing
565
- setLoaderImports({});
566
- `;
567
- }
568
- // Build mode: generate lazy import map
569
- const lazyImports = [];
570
- for (const [hashedId, { filePath, exportName }] of loaderRegistry) {
571
- lazyImports.push(` "${hashedId}": () => import("/${filePath}").then(m => m.${exportName})`);
572
- }
573
- if (lazyImports.length === 0) {
574
- return `import { setLoaderImports } from "@rangojs/router/server";
575
-
576
- // No fetchable loaders discovered during build
577
- setLoaderImports({});
578
- `;
579
- }
580
- return `import { setLoaderImports } from "@rangojs/router/server";
581
-
582
- // Lazy import map - loaders are loaded on-demand when first requested
583
- setLoaderImports({
584
- ${lazyImports.join(",\n")}
585
- });
586
- `;
587
- },
588
- // --------------- Loader pre-scan (build mode) ---------------
589
- async buildStart() {
590
- if (!isBuild)
591
- return;
592
- const fs = await import("node:fs/promises");
593
- async function scanDir(dir) {
594
- const results = [];
595
- try {
596
- const entries = await fs.readdir(dir, { withFileTypes: true });
597
- for (const entry of entries) {
598
- const fullPath = path.join(dir, entry.name);
599
- if (entry.isDirectory()) {
600
- if (entry.name !== "node_modules") {
601
- results.push(...(await scanDir(fullPath)));
602
- }
603
- }
604
- else if (/\.(ts|tsx|js|jsx)$/.test(entry.name)) {
605
- results.push(fullPath);
606
- }
607
- }
608
- }
609
- catch {
610
- // Directory doesn't exist or not readable
611
- }
612
- return results;
613
- }
614
- try {
615
- const srcDir = path.join(projectRoot, "src");
616
- const files = await scanDir(srcDir);
617
- for (const filePath of files) {
618
- const content = await fs.readFile(filePath, "utf-8");
619
- if (!content.includes("createLoader"))
620
- continue;
621
- if (!hasCreateLoaderImport(content))
622
- continue;
623
- const fnNames = getImportedFnNames(content, "createLoader");
624
- const relativePath = normalizePath(path.relative(projectRoot, filePath));
625
- const bindings = collectCreateExportBindings(content, fnNames);
626
- for (const binding of bindings) {
627
- const exportName = binding.exportNames[0];
628
- const hashedId = hashId(relativePath, exportName);
629
- loaderRegistry.set(hashedId, {
630
- filePath: relativePath,
631
- exportName,
632
- });
633
- }
634
- }
635
- }
636
- catch (error) {
637
- console.warn("[exposeInternalIds] Loader pre-scan failed:", error);
638
- }
639
- },
640
- // --------------- Unified transform ---------------
641
- transform(code, id) {
642
- if (id.includes("/node_modules/"))
643
- return;
644
- const filePath = normalizePath(path.relative(projectRoot, id));
645
- const isRscEnv = this.environment?.name === "rsc";
646
- // Warn if named-routes.gen is imported in a client component.
647
- // NamedRoutes is server-only data and would bloat the client bundle.
648
- if (id.includes(".named-routes.gen.") && !isRscEnv && this.environment?.name === "client") {
649
- this.warn(`\n` +
650
- `!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n` +
651
- `!! !!\n` +
652
- `!! WARNING: NamedRoutes imported in a CLIENT component! !!\n` +
653
- `!! !!\n` +
654
- `!! File: ${filePath.padEnd(53)}!!\n` +
655
- `!! !!\n` +
656
- `!! NamedRoutes contains your entire route structure — every !!\n` +
657
- `!! route name and URL pattern in your application. Shipping !!\n` +
658
- `!! this to the browser exposes your full routing topology to !!\n` +
659
- `!! the client, which is a security concern (internal/admin !!\n` +
660
- `!! routes, API endpoints, hidden paths become visible). !!\n` +
661
- `!! !!\n` +
662
- `!! It also bloats the client bundle — this map contains all !!\n` +
663
- `!! named routes in your application. !!\n` +
664
- `!! !!\n` +
665
- `!! Fix: remove the import or move it to a server component. !!\n` +
666
- `!! !!\n` +
667
- `!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n`);
668
- }
669
- // Fast exit: if the file doesn't import from @rangojs/router at all,
670
- // skip all create* analysis and transforms.
671
- if (!code.includes("@rangojs/router"))
672
- return;
673
- // Detect all relevant imports in one pass
674
- const has = detectImports(code);
675
- // Quick bail-out: also check for raw create* identifiers.
676
- // This is safe even with aliases (e.g., `import { createLoader as cl }`)
677
- // because the import statement itself always contains the canonical name
678
- // "createLoader", so code.includes("createLoader") will still match.
679
- const hasLoaderCode = has.loader && code.includes("createLoader");
680
- const hasHandleCode = has.handle && code.includes("createHandle");
681
- const hasLocationStateCode = has.locationState && code.includes("createLocationState");
682
- const hasPrerenderHandlerCode = has.prerenderHandler && code.includes("Prerender");
683
- const hasStaticHandlerCode = has.staticHandler && code.includes("Static");
684
- if (!hasLoaderCode &&
685
- !hasHandleCode &&
686
- !hasLocationStateCode &&
687
- !hasPrerenderHandlerCode &&
688
- !hasStaticHandlerCode) {
689
- return;
690
- }
691
- // Per-invocation caches to avoid redundant AST parsing.
692
- // getImportedFnNames is cached by canonical name (imports never change).
693
- // collectCreateExportBindings is cached by fnNames key; the cache is
694
- // cleared when `code` changes (e.g., after inline handler extraction).
695
- const _fnNamesCache = new Map();
696
- const _bindingsCache = new Map();
697
- let _cachedAst;
698
- let _astParseFailed = false;
699
- let _astCodeRef = code;
700
- const getFnNames = (canonicalName) => {
701
- let result = _fnNamesCache.get(canonicalName);
702
- if (!result) {
703
- result = getImportedFnNames(code, canonicalName);
704
- _fnNamesCache.set(canonicalName, result);
705
- }
706
- return result;
707
- };
708
- // Lazy AST parse: parsed once and shared across all
709
- // collectCreateExportBindings calls for the same code string.
710
- const lazyAst = () => {
711
- if (code !== _astCodeRef) {
712
- _cachedAst = undefined;
713
- _astParseFailed = false;
714
- _astCodeRef = code;
715
- }
716
- if (_cachedAst !== undefined || _astParseFailed)
717
- return _cachedAst;
718
- try {
719
- _cachedAst = parseAst(code, { jsx: true });
720
- }
721
- catch {
722
- _astParseFailed = true;
723
- }
724
- return _cachedAst;
725
- };
726
- const getBindings = (currentCode, fnNames) => {
727
- const key = fnNames.join("\0");
728
- let result = _bindingsCache.get(key);
729
- if (!result) {
730
- result = collectCreateExportBindings(currentCode, fnNames, lazyAst());
731
- _bindingsCache.set(key, result);
732
- }
733
- return result;
734
- };
735
- // Warn on create* declaration shapes that are currently unsupported by
736
- // non-AST transforms (loader/handle/locationState only).
737
- for (const cfg of STRICT_CREATE_CONFIGS) {
738
- const hasCode = cfg.fnName === "createLoader"
739
- ? hasLoaderCode
740
- : cfg.fnName === "createHandle"
741
- ? hasHandleCode
742
- : hasLocationStateCode;
743
- if (!hasCode)
744
- continue;
745
- const fnNames = getFnNames(cfg.fnName);
746
- const totalCalls = countCreateCallsForNames(code, fnNames);
747
- const supportedBindings = getBindings(code, fnNames).length;
748
- if (totalCalls <= supportedBindings)
749
- continue;
750
- const warnKey = `${id}::${cfg.fnName}`;
751
- if (unsupportedShapeWarnings.has(warnKey))
752
- continue;
753
- unsupportedShapeWarnings.add(warnKey);
754
- this.warn(buildUnsupportedShapeWarning(filePath, cfg.fnName));
755
- }
756
- // --- Loader: track for manifest (RSC env only) ---
757
- if (hasLoaderCode && isRscEnv) {
758
- const fnNames = getFnNames("createLoader");
759
- const bindings = getBindings(code, fnNames);
760
- for (const binding of bindings) {
761
- const exportName = binding.exportNames[0];
762
- const hashedId = hashId(filePath, exportName);
763
- loaderRegistry.set(hashedId, {
764
- filePath,
765
- exportName,
766
- });
767
- }
768
- }
769
- // --- Loader: client stubs for non-RSC environments ---
770
- if (hasLoaderCode && !isRscEnv) {
771
- const fnNames = getFnNames("createLoader");
772
- const bindings = getBindings(code, fnNames);
773
- const stubResult = generateClientLoaderStubs(bindings, code, filePath, isBuild);
774
- if (stubResult)
775
- return stubResult;
776
- }
777
- // --- PrerenderHandler: non-RSC stub replacement ---
778
- if (hasPrerenderHandlerCode && !isRscEnv) {
779
- const fnNames = getFnNames(PRERENDER_CONFIG.fnName);
780
- const bindings = getBindings(code, fnNames);
781
- const wholeFile = generateWholeFileStubs(PRERENDER_CONFIG, bindings, code, filePath, isBuild);
782
- if (wholeFile)
783
- return wholeFile;
784
- const exprStubs = generateExprStubs(PRERENDER_CONFIG, bindings, code, filePath, id, isBuild);
785
- if (exprStubs)
786
- return exprStubs;
787
- }
788
- // --- PrerenderHandler: RSC build module tracking ---
789
- if (hasPrerenderHandlerCode && isRscEnv && isBuild) {
790
- const fnNames = getFnNames(PRERENDER_CONFIG.fnName);
791
- const exportNames = getBindings(code, fnNames)
792
- .map((b) => b.exportNames[0]);
793
- if (exportNames.length > 0) {
794
- prerenderHandlerModules.set(id, exportNames);
795
- }
796
- }
797
- // --- Inline handler extraction to virtual modules ---
798
- // Runs before stubs/tracking so inline calls become imports, then
799
- // the existing regex fast path handles both the original file's
800
- // export const patterns and the virtual modules independently.
801
- //
802
- // Cheap pre-check: count total fnName( occurrences vs export const
803
- // patterns. If they match, every call is a named export and the
804
- // regex fast path handles them -- skip the AST parse entirely.
805
- //
806
- // Each iteration creates a fresh MagicString so that AST positions
807
- // from findHandlerCalls always match the string they were parsed from.
808
- let changed = false;
809
- const handlerConfigs = [
810
- hasStaticHandlerCode && STATIC_CONFIG,
811
- hasPrerenderHandlerCode && PRERENDER_CONFIG,
812
- ].filter((c) => !!c).map((cfg) => {
813
- const fnNames = getFnNames(cfg.fnName);
814
- return { cfg, fnNames };
815
- });
816
- for (const { cfg, fnNames } of handlerConfigs) {
817
- const totalCalls = countCreateCallsForNames(code, fnNames);
818
- const supportedBindings = getBindings(code, fnNames).length;
819
- if (totalCalls > supportedBindings) {
820
- const iterS = new MagicString(code);
821
- const result = transformInlineHandlers(cfg.fnName, VIRTUAL_HANDLER_PREFIX, iterS, code, filePath, virtualHandlers, id, parseAst);
822
- if (result) {
823
- changed = true;
824
- code = iterS.toString();
825
- _bindingsCache.clear();
826
- }
827
- }
828
- }
829
- // --- StaticHandler: non-RSC stub replacement ---
830
- if (hasStaticHandlerCode && !isRscEnv) {
831
- const fnNames = getFnNames(STATIC_CONFIG.fnName);
832
- const bindings = getBindings(code, fnNames);
833
- const wholeFile = generateWholeFileStubs(STATIC_CONFIG, bindings, code, filePath, isBuild);
834
- if (wholeFile)
835
- return wholeFile;
836
- const exprStubs = generateExprStubs(STATIC_CONFIG, bindings, code, filePath, id, isBuild);
837
- if (exprStubs)
838
- return exprStubs;
839
- }
840
- // --- StaticHandler: RSC build module tracking ---
841
- if (hasStaticHandlerCode && isRscEnv && isBuild) {
842
- const fnNames = getFnNames(STATIC_CONFIG.fnName);
843
- const exportNames = getBindings(code, fnNames)
844
- .map((b) => b.exportNames[0]);
845
- if (exportNames.length > 0) {
846
- staticHandlerModules.set(id, exportNames);
847
- }
848
- }
849
- // --- Unified MagicString transforms ---
850
- // Single pipeline for all downstream transforms (loaders, handles,
851
- // locationState, handler IDs). Uses the post-extraction code so
852
- // positions are always consistent.
853
- const s = new MagicString(code);
854
- if (hasLoaderCode) {
855
- const fnNames = getFnNames("createLoader");
856
- changed = transformLoaders(getBindings(code, fnNames), s, filePath, isBuild) || changed;
857
- }
858
- if (hasHandleCode) {
859
- const fnNames = getFnNames("createHandle");
860
- changed = transformHandles(getBindings(code, fnNames), s, code, filePath, isBuild) || changed;
861
- }
862
- if (hasLocationStateCode) {
863
- const fnNames = getFnNames("createLocationState");
864
- changed =
865
- transformLocationState(getBindings(code, fnNames), s, filePath, isBuild) || changed;
866
- }
867
- if (hasPrerenderHandlerCode && isRscEnv) {
868
- const fnNames = getFnNames(PRERENDER_CONFIG.fnName);
869
- changed =
870
- transformHandlerIds(PRERENDER_CONFIG, getBindings(code, fnNames), s, filePath, isBuild) || changed;
871
- }
872
- if (hasStaticHandlerCode && isRscEnv) {
873
- const fnNames = getFnNames(STATIC_CONFIG.fnName);
874
- changed =
875
- transformHandlerIds(STATIC_CONFIG, getBindings(code, fnNames), s, filePath, isBuild) || changed;
876
- }
877
- if (!changed)
878
- return;
879
- return {
880
- code: s.toString(),
881
- map: s.generateMap({ source: id, includeContent: true }),
882
- };
883
- },
884
- };
885
- }
886
- //# sourceMappingURL=expose-internal-ids.js.map