react-router 7.15.1 → 8.0.0-pre.0

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 (369) hide show
  1. package/CHANGELOG.md +18 -2
  2. package/dist/development/dom-export.d.ts +6 -172
  3. package/dist/development/dom-export.js +12 -1007
  4. package/dist/development/index-react-server-client.d.ts +7 -4
  5. package/dist/development/index-react-server-client.js +8 -52
  6. package/dist/development/index-react-server.d.ts +1645 -1635
  7. package/dist/development/index-react-server.js +2880 -3642
  8. package/dist/development/index.d.ts +43 -1469
  9. package/dist/development/index.js +37 -2621
  10. package/dist/development/lib/actions.js +62 -0
  11. package/dist/development/lib/components.d.ts +1022 -0
  12. package/dist/development/lib/components.js +835 -0
  13. package/dist/development/lib/context.d.ts +83 -0
  14. package/dist/development/lib/context.js +41 -0
  15. package/dist/development/lib/dom/dom.d.ts +119 -0
  16. package/dist/development/lib/dom/dom.js +143 -0
  17. package/dist/development/lib/dom/lib.d.ts +2042 -0
  18. package/dist/development/lib/dom/lib.js +1259 -0
  19. package/dist/development/lib/dom/server.d.ts +138 -0
  20. package/dist/development/lib/dom/server.js +301 -0
  21. package/dist/development/lib/dom/ssr/components.d.ts +196 -0
  22. package/dist/development/lib/dom/ssr/components.js +579 -0
  23. package/dist/development/lib/dom/ssr/data.js +29 -0
  24. package/dist/development/lib/dom/ssr/entry.d.ts +59 -0
  25. package/dist/development/lib/dom/ssr/errorBoundaries.d.ts +27 -0
  26. package/dist/development/lib/dom/ssr/errorBoundaries.js +83 -0
  27. package/dist/development/lib/dom/ssr/errors.d.ts +7 -0
  28. package/dist/development/lib/dom/ssr/errors.js +36 -0
  29. package/dist/development/lib/dom/ssr/fallback.js +28 -0
  30. package/dist/development/lib/dom/ssr/fog-of-war.d.ts +12 -0
  31. package/dist/development/lib/dom/ssr/fog-of-war.js +170 -0
  32. package/dist/development/lib/dom/ssr/hydration.d.ts +32 -0
  33. package/dist/development/lib/dom/ssr/hydration.js +29 -0
  34. package/dist/development/lib/dom/ssr/invariant.js +16 -0
  35. package/dist/development/lib/dom/ssr/links.js +170 -0
  36. package/dist/development/lib/dom/ssr/markup.js +24 -0
  37. package/dist/development/lib/dom/ssr/routeModules.d.ts +206 -0
  38. package/dist/development/lib/dom/ssr/routeModules.js +31 -0
  39. package/dist/development/lib/dom/ssr/routes-test-stub.d.ts +62 -0
  40. package/dist/development/lib/dom/ssr/routes-test-stub.js +108 -0
  41. package/dist/development/lib/dom/ssr/routes.d.ts +33 -0
  42. package/dist/development/lib/dom/ssr/routes.js +303 -0
  43. package/dist/development/lib/dom/ssr/server.d.ts +45 -0
  44. package/dist/development/lib/dom/ssr/server.js +68 -0
  45. package/dist/development/lib/dom/ssr/single-fetch.d.ts +14 -0
  46. package/dist/development/lib/dom/ssr/single-fetch.js +346 -0
  47. package/dist/development/lib/dom-export/dom-router-provider.d.ts +9 -0
  48. package/dist/development/lib/dom-export/dom-router-provider.js +22 -0
  49. package/dist/development/lib/dom-export/hydrated-router.d.ts +125 -0
  50. package/dist/development/lib/dom-export/hydrated-router.js +153 -0
  51. package/dist/development/lib/errors.js +29 -0
  52. package/dist/development/lib/hooks.d.ts +947 -0
  53. package/dist/development/lib/hooks.js +1386 -0
  54. package/dist/development/lib/href.d.ts +20 -0
  55. package/dist/development/lib/href.js +50 -0
  56. package/dist/development/lib/router/history.d.ts +258 -0
  57. package/dist/development/lib/router/history.js +371 -0
  58. package/dist/development/lib/router/instrumentation.d.ts +86 -0
  59. package/dist/development/lib/router/instrumentation.js +213 -0
  60. package/dist/development/lib/router/links.d.ts +113 -0
  61. package/dist/development/lib/router/router.d.ts +663 -0
  62. package/dist/development/lib/router/router.js +2981 -0
  63. package/dist/development/lib/router/utils.d.ts +942 -0
  64. package/dist/development/lib/router/utils.js +791 -0
  65. package/dist/development/lib/rsc/browser.d.ts +137 -0
  66. package/dist/development/lib/rsc/browser.js +599 -0
  67. package/dist/development/lib/rsc/errorBoundaries.d.ts +11 -0
  68. package/dist/development/lib/rsc/errorBoundaries.js +90 -0
  69. package/dist/development/lib/rsc/html-stream/browser.d.ts +48 -0
  70. package/dist/development/lib/rsc/html-stream/browser.js +74 -0
  71. package/dist/development/lib/rsc/html-stream/server.js +78 -0
  72. package/dist/development/lib/rsc/route-modules.js +27 -0
  73. package/dist/development/lib/rsc/server.rsc.d.ts +219 -0
  74. package/dist/development/lib/rsc/server.ssr.d.ts +129 -0
  75. package/dist/development/lib/rsc/server.ssr.js +388 -0
  76. package/dist/development/lib/server-runtime/build.d.ts +66 -0
  77. package/dist/development/lib/server-runtime/cookies.d.ts +66 -0
  78. package/dist/development/lib/server-runtime/cookies.js +139 -0
  79. package/dist/development/lib/server-runtime/crypto.js +43 -0
  80. package/dist/development/lib/server-runtime/data.d.ts +13 -0
  81. package/dist/development/lib/server-runtime/data.js +25 -0
  82. package/dist/development/lib/server-runtime/dev.d.ts +9 -0
  83. package/dist/development/lib/server-runtime/dev.js +26 -0
  84. package/dist/development/lib/server-runtime/entry.js +20 -0
  85. package/dist/development/lib/server-runtime/errors.js +95 -0
  86. package/dist/development/lib/server-runtime/headers.js +73 -0
  87. package/dist/development/lib/server-runtime/invariant.js +19 -0
  88. package/dist/development/lib/server-runtime/mode.d.ts +12 -0
  89. package/dist/development/lib/server-runtime/mode.js +25 -0
  90. package/dist/development/lib/server-runtime/routeMatching.js +28 -0
  91. package/dist/development/lib/server-runtime/routes.d.ts +13 -0
  92. package/dist/development/lib/server-runtime/routes.js +74 -0
  93. package/dist/development/lib/server-runtime/server.d.ts +10 -0
  94. package/dist/development/lib/server-runtime/server.js +351 -0
  95. package/dist/development/lib/server-runtime/serverHandoff.js +17 -0
  96. package/dist/development/lib/server-runtime/sessions/cookieStorage.d.ts +25 -0
  97. package/dist/development/lib/server-runtime/sessions/cookieStorage.js +45 -0
  98. package/dist/development/lib/server-runtime/sessions/memoryStorage.d.ts +23 -0
  99. package/dist/development/lib/server-runtime/sessions/memoryStorage.js +52 -0
  100. package/dist/development/lib/server-runtime/sessions.d.ts +145 -0
  101. package/dist/development/lib/server-runtime/sessions.js +98 -0
  102. package/dist/development/lib/server-runtime/single-fetch.d.ts +7 -0
  103. package/dist/development/lib/server-runtime/single-fetch.js +215 -0
  104. package/dist/development/lib/server-runtime/urls.js +31 -0
  105. package/dist/development/lib/server-runtime/warnings.js +20 -0
  106. package/dist/development/lib/types/future.d.ts +9 -0
  107. package/dist/development/lib/types/internal.d.ts +26 -177
  108. package/dist/development/lib/types/internal.js +3 -2
  109. package/dist/{production/register-Bsscfj79.d.ts → development/lib/types/register.d.ts} +9 -15
  110. package/dist/development/lib/types/route-data.d.ts +113 -0
  111. package/dist/development/lib/types/route-module-annotations.d.ts +149 -0
  112. package/dist/development/lib/types/route-module.d.ts +19 -0
  113. package/dist/development/lib/types/serializes-to.d.ts +13 -0
  114. package/dist/development/lib/types/utils.d.ts +11 -0
  115. package/dist/development/vendor/turbo-stream-v2/flatten.js +159 -0
  116. package/dist/development/vendor/turbo-stream-v2/turbo-stream.js +178 -0
  117. package/dist/development/vendor/turbo-stream-v2/unflatten.js +198 -0
  118. package/dist/development/vendor/turbo-stream-v2/utils.js +47 -0
  119. package/dist/production/dom-export.d.ts +6 -172
  120. package/dist/production/dom-export.js +12 -1007
  121. package/dist/production/index-react-server-client.d.ts +7 -4
  122. package/dist/production/index-react-server-client.js +8 -52
  123. package/dist/production/index-react-server.d.ts +1645 -1635
  124. package/dist/production/index-react-server.js +2871 -3642
  125. package/dist/production/index.d.ts +43 -1469
  126. package/dist/production/index.js +37 -2621
  127. package/dist/production/lib/actions.js +62 -0
  128. package/dist/production/lib/components.d.ts +1022 -0
  129. package/dist/production/lib/components.js +835 -0
  130. package/dist/production/lib/context.d.ts +83 -0
  131. package/dist/production/lib/context.js +41 -0
  132. package/dist/production/lib/dom/dom.d.ts +119 -0
  133. package/dist/production/lib/dom/dom.js +143 -0
  134. package/dist/production/lib/dom/lib.d.ts +2042 -0
  135. package/dist/production/lib/dom/lib.js +1259 -0
  136. package/dist/production/lib/dom/server.d.ts +138 -0
  137. package/dist/production/lib/dom/server.js +301 -0
  138. package/dist/production/lib/dom/ssr/components.d.ts +196 -0
  139. package/dist/production/lib/dom/ssr/components.js +579 -0
  140. package/dist/production/lib/dom/ssr/data.js +29 -0
  141. package/dist/production/lib/dom/ssr/entry.d.ts +59 -0
  142. package/dist/production/lib/dom/ssr/errorBoundaries.d.ts +27 -0
  143. package/dist/production/lib/dom/ssr/errorBoundaries.js +83 -0
  144. package/dist/production/lib/dom/ssr/errors.d.ts +7 -0
  145. package/dist/production/lib/dom/ssr/errors.js +36 -0
  146. package/dist/production/lib/dom/ssr/fallback.js +21 -0
  147. package/dist/production/lib/dom/ssr/fog-of-war.d.ts +12 -0
  148. package/dist/production/lib/dom/ssr/fog-of-war.js +170 -0
  149. package/dist/production/lib/dom/ssr/hydration.d.ts +32 -0
  150. package/dist/production/lib/dom/ssr/hydration.js +29 -0
  151. package/dist/production/lib/dom/ssr/invariant.js +16 -0
  152. package/dist/production/lib/dom/ssr/links.js +170 -0
  153. package/dist/production/lib/dom/ssr/markup.js +24 -0
  154. package/dist/production/lib/dom/ssr/routeModules.d.ts +206 -0
  155. package/dist/production/lib/dom/ssr/routeModules.js +31 -0
  156. package/dist/production/lib/dom/ssr/routes-test-stub.d.ts +62 -0
  157. package/dist/production/lib/dom/ssr/routes-test-stub.js +108 -0
  158. package/dist/production/lib/dom/ssr/routes.d.ts +33 -0
  159. package/dist/production/lib/dom/ssr/routes.js +303 -0
  160. package/dist/production/lib/dom/ssr/server.d.ts +45 -0
  161. package/dist/production/lib/dom/ssr/server.js +68 -0
  162. package/dist/production/lib/dom/ssr/single-fetch.d.ts +14 -0
  163. package/dist/production/lib/dom/ssr/single-fetch.js +346 -0
  164. package/dist/production/lib/dom-export/dom-router-provider.d.ts +9 -0
  165. package/dist/production/lib/dom-export/dom-router-provider.js +22 -0
  166. package/dist/production/lib/dom-export/hydrated-router.d.ts +125 -0
  167. package/dist/production/lib/dom-export/hydrated-router.js +153 -0
  168. package/dist/production/lib/errors.js +29 -0
  169. package/dist/production/lib/hooks.d.ts +947 -0
  170. package/dist/production/lib/hooks.js +1371 -0
  171. package/dist/production/lib/href.d.ts +20 -0
  172. package/dist/production/lib/href.js +50 -0
  173. package/dist/production/lib/router/history.d.ts +258 -0
  174. package/dist/production/lib/router/history.js +371 -0
  175. package/dist/production/lib/router/instrumentation.d.ts +86 -0
  176. package/dist/production/lib/router/instrumentation.js +213 -0
  177. package/dist/production/lib/router/links.d.ts +113 -0
  178. package/dist/production/lib/router/router.d.ts +663 -0
  179. package/dist/production/lib/router/router.js +2981 -0
  180. package/dist/production/lib/router/utils.d.ts +942 -0
  181. package/dist/production/lib/router/utils.js +782 -0
  182. package/dist/production/lib/rsc/browser.d.ts +137 -0
  183. package/dist/production/lib/rsc/browser.js +599 -0
  184. package/dist/production/lib/rsc/errorBoundaries.d.ts +11 -0
  185. package/dist/production/lib/rsc/errorBoundaries.js +90 -0
  186. package/dist/production/lib/rsc/html-stream/browser.d.ts +48 -0
  187. package/dist/production/lib/rsc/html-stream/browser.js +74 -0
  188. package/dist/production/lib/rsc/html-stream/server.js +78 -0
  189. package/dist/production/lib/rsc/route-modules.js +27 -0
  190. package/dist/production/lib/rsc/server.rsc.d.ts +219 -0
  191. package/dist/production/lib/rsc/server.ssr.d.ts +129 -0
  192. package/dist/production/lib/rsc/server.ssr.js +388 -0
  193. package/dist/production/lib/server-runtime/build.d.ts +66 -0
  194. package/dist/production/lib/server-runtime/cookies.d.ts +66 -0
  195. package/dist/production/lib/server-runtime/cookies.js +139 -0
  196. package/dist/production/lib/server-runtime/crypto.js +43 -0
  197. package/dist/production/lib/server-runtime/data.d.ts +13 -0
  198. package/dist/production/lib/server-runtime/data.js +25 -0
  199. package/dist/production/lib/server-runtime/dev.d.ts +9 -0
  200. package/dist/production/lib/server-runtime/dev.js +26 -0
  201. package/dist/production/lib/server-runtime/entry.js +20 -0
  202. package/dist/production/lib/server-runtime/errors.js +95 -0
  203. package/dist/production/lib/server-runtime/headers.js +73 -0
  204. package/dist/production/lib/server-runtime/invariant.js +19 -0
  205. package/dist/production/lib/server-runtime/mode.d.ts +12 -0
  206. package/dist/production/lib/server-runtime/mode.js +25 -0
  207. package/dist/production/lib/server-runtime/routeMatching.js +28 -0
  208. package/dist/production/lib/server-runtime/routes.d.ts +13 -0
  209. package/dist/production/lib/server-runtime/routes.js +74 -0
  210. package/dist/production/lib/server-runtime/server.d.ts +10 -0
  211. package/dist/production/lib/server-runtime/server.js +351 -0
  212. package/dist/production/lib/server-runtime/serverHandoff.js +17 -0
  213. package/dist/production/lib/server-runtime/sessions/cookieStorage.d.ts +25 -0
  214. package/dist/production/lib/server-runtime/sessions/cookieStorage.js +45 -0
  215. package/dist/production/lib/server-runtime/sessions/memoryStorage.d.ts +23 -0
  216. package/dist/production/lib/server-runtime/sessions/memoryStorage.js +52 -0
  217. package/dist/production/lib/server-runtime/sessions.d.ts +145 -0
  218. package/dist/production/lib/server-runtime/sessions.js +98 -0
  219. package/dist/production/lib/server-runtime/single-fetch.d.ts +7 -0
  220. package/dist/production/lib/server-runtime/single-fetch.js +215 -0
  221. package/dist/production/lib/server-runtime/urls.js +31 -0
  222. package/dist/production/lib/server-runtime/warnings.js +20 -0
  223. package/dist/production/lib/types/future.d.ts +9 -0
  224. package/dist/production/lib/types/internal.d.ts +26 -177
  225. package/dist/production/lib/types/internal.js +3 -2
  226. package/dist/{development/register-Bsscfj79.d.ts → production/lib/types/register.d.ts} +9 -15
  227. package/dist/production/lib/types/route-data.d.ts +113 -0
  228. package/dist/production/lib/types/route-module-annotations.d.ts +149 -0
  229. package/dist/production/lib/types/route-module.d.ts +19 -0
  230. package/dist/production/lib/types/serializes-to.d.ts +13 -0
  231. package/dist/production/lib/types/utils.d.ts +11 -0
  232. package/dist/production/vendor/turbo-stream-v2/flatten.js +159 -0
  233. package/dist/production/vendor/turbo-stream-v2/turbo-stream.js +178 -0
  234. package/dist/production/vendor/turbo-stream-v2/unflatten.js +198 -0
  235. package/dist/production/vendor/turbo-stream-v2/utils.js +47 -0
  236. package/docs/explanation/backend-for-frontend.md +50 -0
  237. package/docs/explanation/code-splitting.md +77 -0
  238. package/docs/explanation/concurrency.md +135 -0
  239. package/docs/explanation/form-vs-fetcher.md +292 -0
  240. package/docs/explanation/hot-module-replacement.md +137 -0
  241. package/docs/explanation/hydration.md +14 -0
  242. package/docs/explanation/index-query-param.md +86 -0
  243. package/docs/explanation/index.md +4 -0
  244. package/docs/explanation/lazy-route-discovery.md +78 -0
  245. package/docs/explanation/location.md +6 -0
  246. package/docs/explanation/progressive-enhancement.md +150 -0
  247. package/docs/explanation/race-conditions.md +88 -0
  248. package/docs/explanation/react-transitions.md +160 -0
  249. package/docs/explanation/route-matching.md +7 -0
  250. package/docs/explanation/server-client-execution.md +4 -0
  251. package/docs/explanation/sessions-and-cookies.md +465 -0
  252. package/docs/explanation/special-files.md +16 -0
  253. package/docs/explanation/state-management.md +524 -0
  254. package/docs/explanation/styling.md +87 -0
  255. package/docs/explanation/type-safety.md +82 -0
  256. package/docs/how-to/accessibility.md +44 -0
  257. package/docs/how-to/client-data.md +199 -0
  258. package/docs/how-to/data-strategy.md +317 -0
  259. package/docs/how-to/error-boundary.md +231 -0
  260. package/docs/how-to/error-reporting.md +134 -0
  261. package/docs/how-to/fetchers.md +307 -0
  262. package/docs/how-to/file-route-conventions.md +410 -0
  263. package/docs/how-to/file-uploads.md +217 -0
  264. package/docs/how-to/form-validation.md +120 -0
  265. package/docs/how-to/headers.md +164 -0
  266. package/docs/how-to/index.md +4 -0
  267. package/docs/how-to/instrumentation.md +556 -0
  268. package/docs/how-to/meta.md +40 -0
  269. package/docs/how-to/middleware.md +728 -0
  270. package/docs/how-to/navigation-blocking.md +233 -0
  271. package/docs/how-to/optimize-revalidation.md +12 -0
  272. package/docs/how-to/pre-rendering.md +225 -0
  273. package/docs/how-to/presets.md +103 -0
  274. package/docs/how-to/react-server-components.md +899 -0
  275. package/docs/how-to/resource-routes.md +126 -0
  276. package/docs/how-to/route-module-type-safety.md +100 -0
  277. package/docs/how-to/search-params.md +4 -0
  278. package/docs/how-to/security.md +30 -0
  279. package/docs/how-to/server-bundles.md +66 -0
  280. package/docs/how-to/spa.md +120 -0
  281. package/docs/how-to/status.md +63 -0
  282. package/docs/how-to/suspense.md +132 -0
  283. package/docs/how-to/using-handle.md +117 -0
  284. package/docs/how-to/view-transitions.md +237 -0
  285. package/docs/how-to/webhook.md +50 -0
  286. package/docs/index.md +39 -0
  287. package/docs/start/data/actions.md +138 -0
  288. package/docs/start/data/custom.md +198 -0
  289. package/docs/start/data/data-loading.md +44 -0
  290. package/docs/start/data/index.md +4 -0
  291. package/docs/start/data/installation.md +52 -0
  292. package/docs/start/data/navigating.md +12 -0
  293. package/docs/start/data/pending-ui.md +12 -0
  294. package/docs/start/data/route-object.md +248 -0
  295. package/docs/start/data/routing.md +281 -0
  296. package/docs/start/data/testing.md +8 -0
  297. package/docs/start/declarative/index.md +4 -0
  298. package/docs/start/declarative/installation.md +43 -0
  299. package/docs/start/declarative/navigating.md +133 -0
  300. package/docs/start/declarative/routing.md +237 -0
  301. package/docs/start/declarative/url-values.md +65 -0
  302. package/docs/start/framework/actions.md +175 -0
  303. package/docs/start/framework/data-loading.md +201 -0
  304. package/docs/start/framework/deploying.md +96 -0
  305. package/docs/start/framework/index.md +4 -0
  306. package/docs/start/framework/installation.md +42 -0
  307. package/docs/start/framework/navigating.md +182 -0
  308. package/docs/start/framework/pending-ui.md +142 -0
  309. package/docs/start/framework/rendering.md +59 -0
  310. package/docs/start/framework/route-module.md +527 -0
  311. package/docs/start/framework/routing.md +362 -0
  312. package/docs/start/framework/testing.md +133 -0
  313. package/docs/start/index.md +4 -0
  314. package/docs/start/modes.md +201 -0
  315. package/docs/upgrading/component-routes.md +363 -0
  316. package/docs/upgrading/future.md +31 -0
  317. package/docs/upgrading/index.md +4 -0
  318. package/docs/upgrading/remix.md +403 -0
  319. package/docs/upgrading/router-provider.md +442 -0
  320. package/docs/upgrading/v6.md +379 -0
  321. package/package.json +44 -87
  322. package/dist/development/browser-3AnU12UI.d.mts +0 -318
  323. package/dist/development/browser-BOdXz9dK.d.ts +0 -318
  324. package/dist/development/chunk-4N6VE7H7.mjs +0 -11528
  325. package/dist/development/chunk-4YRVXM2U.js +0 -188
  326. package/dist/development/chunk-66UKHEGQ.js +0 -1362
  327. package/dist/development/chunk-D6LUOGOQ.js +0 -10229
  328. package/dist/development/chunk-RJYABSBD.mjs +0 -2585
  329. package/dist/development/context-ByvtofY2.d.mts +0 -1771
  330. package/dist/development/data-BVUf681J.d.mts +0 -1732
  331. package/dist/development/data-BqZ2x964.d.ts +0 -1732
  332. package/dist/development/dom-export.d.mts +0 -172
  333. package/dist/development/dom-export.mjs +0 -1008
  334. package/dist/development/index-react-server-client-BS5F89FR.d.ts +0 -3655
  335. package/dist/development/index-react-server-client-DY04-103.d.mts +0 -2600
  336. package/dist/development/index-react-server-client.d.mts +0 -4
  337. package/dist/development/index-react-server-client.mjs +0 -59
  338. package/dist/development/index-react-server.d.mts +0 -2703
  339. package/dist/development/index-react-server.mjs +0 -3780
  340. package/dist/development/index.d.mts +0 -1472
  341. package/dist/development/index.mjs +0 -277
  342. package/dist/development/instrumentation-cRWWLfsU.d.ts +0 -715
  343. package/dist/development/lib/types/internal.d.mts +0 -184
  344. package/dist/development/lib/types/internal.mjs +0 -10
  345. package/dist/development/register-Df8okEea.d.mts +0 -30
  346. package/dist/production/browser-3AnU12UI.d.mts +0 -318
  347. package/dist/production/browser-BOdXz9dK.d.ts +0 -318
  348. package/dist/production/chunk-6S4627ZB.mjs +0 -2585
  349. package/dist/production/chunk-HUBUW7R3.js +0 -10229
  350. package/dist/production/chunk-JAKZPQZC.mjs +0 -11528
  351. package/dist/production/chunk-PNZCCTKT.js +0 -1362
  352. package/dist/production/chunk-Y6IFXO7V.js +0 -188
  353. package/dist/production/context-ByvtofY2.d.mts +0 -1771
  354. package/dist/production/data-BVUf681J.d.mts +0 -1732
  355. package/dist/production/data-BqZ2x964.d.ts +0 -1732
  356. package/dist/production/dom-export.d.mts +0 -172
  357. package/dist/production/dom-export.mjs +0 -1008
  358. package/dist/production/index-react-server-client-BS5F89FR.d.ts +0 -3655
  359. package/dist/production/index-react-server-client-DY04-103.d.mts +0 -2600
  360. package/dist/production/index-react-server-client.d.mts +0 -4
  361. package/dist/production/index-react-server-client.mjs +0 -59
  362. package/dist/production/index-react-server.d.mts +0 -2703
  363. package/dist/production/index-react-server.mjs +0 -3780
  364. package/dist/production/index.d.mts +0 -1472
  365. package/dist/production/index.mjs +0 -277
  366. package/dist/production/instrumentation-cRWWLfsU.d.ts +0 -715
  367. package/dist/production/lib/types/internal.d.mts +0 -184
  368. package/dist/production/lib/types/internal.mjs +0 -10
  369. package/dist/production/register-Df8okEea.d.mts +0 -30
@@ -1,5 +1,5 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }/**
2
- * react-router v7.15.1
1
+ /**
2
+ * react-router v8.0.0-pre.0
3
3
  *
4
4
  * Copyright (c) Remix Software Inc.
5
5
  *
@@ -9,1008 +9,13 @@
9
9
  * @license MIT
10
10
  */
11
11
  "use client";
12
-
13
-
14
-
15
-
16
- var _chunkY6IFXO7Vjs = require('./chunk-Y6IFXO7V.js');
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
- var _chunkHUBUW7R3js = require('./chunk-HUBUW7R3.js');
38
-
39
- // lib/dom-export/dom-router-provider.tsx
40
- var _react = require('react'); var React = _interopRequireWildcard(_react); var React2 = _interopRequireWildcard(_react); var React3 = _interopRequireWildcard(_react);
41
- var _reactdom = require('react-dom'); var ReactDOM = _interopRequireWildcard(_reactdom); var ReactDOM2 = _interopRequireWildcard(_reactdom);
42
- var _reactrouter = require('react-router');
43
- function RouterProvider2(props) {
44
- return /* @__PURE__ */ React.createElement(_reactrouter.RouterProvider, { flushSync: ReactDOM.flushSync, ...props });
45
- }
46
-
47
- // lib/dom-export/hydrated-router.tsx
48
-
49
-
50
-
51
-
52
-
53
-
54
-
55
-
56
-
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
-
65
-
66
- var ssrInfo = null;
67
- var router = null;
68
- function initSsrInfo() {
69
- if (!ssrInfo && window.__reactRouterContext && window.__reactRouterManifest && window.__reactRouterRouteModules) {
70
- if (window.__reactRouterManifest.sri === true) {
71
- const importMap = document.querySelector("script[rr-importmap]");
72
- if (_optionalChain([importMap, 'optionalAccess', _2 => _2.textContent])) {
73
- try {
74
- window.__reactRouterManifest.sri = JSON.parse(
75
- importMap.textContent
76
- ).integrity;
77
- } catch (err) {
78
- console.error("Failed to parse import map", err);
79
- }
80
- }
81
- }
82
- ssrInfo = {
83
- context: window.__reactRouterContext,
84
- manifest: window.__reactRouterManifest,
85
- routeModules: window.__reactRouterRouteModules,
86
- stateDecodingPromise: void 0,
87
- router: void 0,
88
- routerInitialized: false
89
- };
90
- }
91
- }
92
- function createHydratedRouter({
93
- getContext,
94
- instrumentations
95
- }) {
96
- initSsrInfo();
97
- if (!ssrInfo) {
98
- throw new Error(
99
- "You must be using the SSR features of React Router in order to skip passing a `router` prop to `<RouterProvider>`"
100
- );
101
- }
102
- let localSsrInfo = ssrInfo;
103
- if (!ssrInfo.stateDecodingPromise) {
104
- let stream = ssrInfo.context.stream;
105
- _reactrouter.UNSAFE_invariant.call(void 0, stream, "No stream found for single fetch decoding");
106
- ssrInfo.context.stream = void 0;
107
- ssrInfo.stateDecodingPromise = _reactrouter.UNSAFE_decodeViaTurboStream.call(void 0, stream, window).then((value) => {
108
- ssrInfo.context.state = value.value;
109
- localSsrInfo.stateDecodingPromise.value = true;
110
- }).catch((e) => {
111
- localSsrInfo.stateDecodingPromise.error = e;
112
- });
113
- }
114
- if (ssrInfo.stateDecodingPromise.error) {
115
- throw ssrInfo.stateDecodingPromise.error;
116
- }
117
- if (!ssrInfo.stateDecodingPromise.value) {
118
- throw ssrInfo.stateDecodingPromise;
119
- }
120
- let routes = _reactrouter.UNSAFE_createClientRoutes.call(void 0,
121
- ssrInfo.manifest.routes,
122
- ssrInfo.routeModules,
123
- ssrInfo.context.state,
124
- ssrInfo.context.ssr,
125
- ssrInfo.context.isSpaMode
126
- );
127
- let hydrationData = void 0;
128
- if (ssrInfo.context.isSpaMode) {
129
- let { loaderData } = ssrInfo.context.state;
130
- if (_optionalChain([ssrInfo, 'access', _3 => _3.manifest, 'access', _4 => _4.routes, 'access', _5 => _5.root, 'optionalAccess', _6 => _6.hasLoader]) && loaderData && "root" in loaderData) {
131
- hydrationData = {
132
- loaderData: {
133
- root: loaderData.root
134
- }
135
- };
136
- }
137
- } else {
138
- hydrationData = _reactrouter.UNSAFE_getHydrationData.call(void 0, {
139
- state: ssrInfo.context.state,
140
- routes,
141
- getRouteInfo: (routeId) => ({
142
- clientLoader: _optionalChain([ssrInfo, 'access', _7 => _7.routeModules, 'access', _8 => _8[routeId], 'optionalAccess', _9 => _9.clientLoader]),
143
- hasLoader: _optionalChain([ssrInfo, 'access', _10 => _10.manifest, 'access', _11 => _11.routes, 'access', _12 => _12[routeId], 'optionalAccess', _13 => _13.hasLoader]) === true,
144
- hasHydrateFallback: _optionalChain([ssrInfo, 'access', _14 => _14.routeModules, 'access', _15 => _15[routeId], 'optionalAccess', _16 => _16.HydrateFallback]) != null
145
- }),
146
- location: window.location,
147
- basename: _optionalChain([window, 'access', _17 => _17.__reactRouterContext, 'optionalAccess', _18 => _18.basename]),
148
- isSpaMode: ssrInfo.context.isSpaMode
149
- });
150
- if (hydrationData && hydrationData.errors) {
151
- hydrationData.errors = _reactrouter.UNSAFE_deserializeErrors.call(void 0, hydrationData.errors);
152
- }
153
- }
154
- if (window.history.state && window.history.state.masked) {
155
- window.history.replaceState(
156
- { ...window.history.state, masked: void 0 },
157
- ""
158
- );
159
- }
160
- let router2 = _reactrouter.UNSAFE_createRouter.call(void 0, {
161
- routes,
162
- history: _reactrouter.UNSAFE_createBrowserHistory.call(void 0, ),
163
- basename: ssrInfo.context.basename,
164
- getContext,
165
- hydrationData,
166
- hydrationRouteProperties: _reactrouter.UNSAFE_hydrationRouteProperties,
167
- instrumentations,
168
- mapRouteProperties: _reactrouter.UNSAFE_mapRouteProperties,
169
- future: {
170
- v8_passThroughRequests: ssrInfo.context.future.v8_passThroughRequests
171
- },
172
- dataStrategy: _reactrouter.UNSAFE_getTurboStreamSingleFetchDataStrategy.call(void 0,
173
- () => router2,
174
- ssrInfo.manifest,
175
- ssrInfo.routeModules,
176
- ssrInfo.context.ssr,
177
- ssrInfo.context.basename,
178
- ssrInfo.context.future.unstable_trailingSlashAwareDataRequests
179
- ),
180
- patchRoutesOnNavigation: _reactrouter.UNSAFE_getPatchRoutesOnNavigationFunction.call(void 0,
181
- () => router2,
182
- ssrInfo.manifest,
183
- ssrInfo.routeModules,
184
- ssrInfo.context.ssr,
185
- ssrInfo.context.routeDiscovery,
186
- ssrInfo.context.isSpaMode,
187
- ssrInfo.context.basename
188
- )
189
- });
190
- ssrInfo.router = router2;
191
- if (router2.state.initialized) {
192
- ssrInfo.routerInitialized = true;
193
- router2.initialize();
194
- }
195
- router2.createRoutesForHMR = /* spacer so ts-ignore does not affect the right hand of the assignment */
196
- _reactrouter.UNSAFE_createClientRoutesWithHMRRevalidationOptOut;
197
- window.__reactRouterDataRouter = router2;
198
- return router2;
199
- }
200
- function HydratedRouter(props) {
201
- if (!router) {
202
- router = createHydratedRouter({
203
- getContext: props.getContext,
204
- instrumentations: props.instrumentations
205
- });
206
- }
207
- let [criticalCss, setCriticalCss] = React2.useState(
208
- process.env.NODE_ENV === "development" ? _optionalChain([ssrInfo, 'optionalAccess', _19 => _19.context, 'access', _20 => _20.criticalCss]) : void 0
209
- );
210
- React2.useEffect(() => {
211
- if (process.env.NODE_ENV === "development") {
212
- setCriticalCss(void 0);
213
- }
214
- }, []);
215
- React2.useEffect(() => {
216
- if (process.env.NODE_ENV === "development" && criticalCss === void 0) {
217
- document.querySelectorAll(`[${_chunkHUBUW7R3js.CRITICAL_CSS_DATA_ATTRIBUTE}]`).forEach((element) => element.remove());
218
- }
219
- }, [criticalCss]);
220
- let [location2, setLocation] = React2.useState(router.state.location);
221
- React2.useLayoutEffect(() => {
222
- if (ssrInfo && ssrInfo.router && !ssrInfo.routerInitialized) {
223
- ssrInfo.routerInitialized = true;
224
- ssrInfo.router.initialize();
225
- }
226
- }, []);
227
- React2.useLayoutEffect(() => {
228
- if (ssrInfo && ssrInfo.router) {
229
- return ssrInfo.router.subscribe((newState) => {
230
- if (newState.location !== location2) {
231
- setLocation(newState.location);
232
- }
233
- });
234
- }
235
- }, [location2]);
236
- _reactrouter.UNSAFE_invariant.call(void 0, ssrInfo, "ssrInfo unavailable for HydratedRouter");
237
- _reactrouter.UNSAFE_useFogOFWarDiscovery.call(void 0,
238
- router,
239
- ssrInfo.manifest,
240
- ssrInfo.routeModules,
241
- ssrInfo.context.ssr,
242
- ssrInfo.context.routeDiscovery,
243
- ssrInfo.context.isSpaMode
244
- );
245
- return (
246
- // This fragment is important to ensure we match the <ServerRouter> JSX
247
- // structure so that useId values hydrate correctly
248
- /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(
249
- _reactrouter.UNSAFE_FrameworkContext.Provider,
250
- {
251
- value: {
252
- manifest: ssrInfo.manifest,
253
- routeModules: ssrInfo.routeModules,
254
- future: ssrInfo.context.future,
255
- criticalCss,
256
- ssr: ssrInfo.context.ssr,
257
- isSpaMode: ssrInfo.context.isSpaMode,
258
- routeDiscovery: ssrInfo.context.routeDiscovery
259
- }
260
- },
261
- /* @__PURE__ */ React2.createElement(_reactrouter.UNSAFE_RemixErrorBoundary, { location: location2 }, /* @__PURE__ */ React2.createElement(
262
- RouterProvider2,
263
- {
264
- router,
265
- useTransitions: props.useTransitions,
266
- onError: props.onError
267
- }
268
- ))
269
- ), /* @__PURE__ */ React2.createElement(React2.Fragment, null))
270
- );
271
- }
272
-
273
- // lib/rsc/browser.tsx
274
-
275
-
276
- var defaultManifestPath = "/__manifest";
277
- function createCallServer({
278
- createFromReadableStream,
279
- createTemporaryReferenceSet,
280
- encodeReply,
281
- fetch: fetchImplementation = fetch
282
- }) {
283
- const globalVar = window;
284
- let landedActionId = 0;
285
- return async (id, args) => {
286
- let actionId = globalVar.__routerActionID = (_nullishCoalesce(globalVar.__routerActionID, () => ( (globalVar.__routerActionID = 0)))) + 1;
287
- const temporaryReferences = createTemporaryReferenceSet();
288
- const payloadPromise = fetchImplementation(
289
- new Request(location.href, {
290
- body: await encodeReply(args, { temporaryReferences }),
291
- method: "POST",
292
- headers: {
293
- Accept: "text/x-component",
294
- "rsc-action-id": id
295
- }
296
- })
297
- ).then((response) => {
298
- if (!response.body) {
299
- throw new Error("No response body");
300
- }
301
- return createFromReadableStream(response.body, {
302
- temporaryReferences
303
- });
304
- });
305
- React3.startTransition(
306
- () => (
307
- // @ts-expect-error - Needs React 19 types
308
- Promise.resolve(payloadPromise).then(async (payload) => {
309
- if (payload.type === "redirect") {
310
- if (payload.reload || isExternalLocation(payload.location)) {
311
- if (hasInvalidProtocol(payload.location)) {
312
- throw new Error("Invalid redirect location");
313
- }
314
- window.location.href = payload.location;
315
- return;
316
- }
317
- React3.startTransition(() => {
318
- globalVar.__reactRouterDataRouter.navigate(payload.location, {
319
- replace: payload.replace
320
- });
321
- });
322
- return;
323
- }
324
- if (payload.type !== "action") {
325
- throw new Error("Unexpected payload type");
326
- }
327
- const rerender = await payload.rerender;
328
- if (rerender && landedActionId < actionId && globalVar.__routerActionID <= actionId) {
329
- if (rerender.type === "redirect") {
330
- if (rerender.reload || isExternalLocation(rerender.location)) {
331
- if (hasInvalidProtocol(rerender.location)) {
332
- throw new Error("Invalid redirect location");
333
- }
334
- window.location.href = rerender.location;
335
- return;
336
- }
337
- React3.startTransition(() => {
338
- globalVar.__reactRouterDataRouter.navigate(rerender.location, {
339
- replace: rerender.replace
340
- });
341
- });
342
- return;
343
- }
344
- React3.startTransition(() => {
345
- let lastMatch;
346
- for (const match of rerender.matches) {
347
- globalVar.__reactRouterDataRouter.patchRoutes(
348
- _nullishCoalesce(_optionalChain([lastMatch, 'optionalAccess', _21 => _21.id]), () => ( null)),
349
- [createRouteFromServerManifest(match)],
350
- true
351
- );
352
- lastMatch = match;
353
- }
354
- window.__reactRouterDataRouter._internalSetStateDoNotUseOrYouWillBreakYourApp(
355
- {
356
- loaderData: Object.assign(
357
- {},
358
- globalVar.__reactRouterDataRouter.state.loaderData,
359
- rerender.loaderData
360
- ),
361
- errors: rerender.errors ? Object.assign(
362
- {},
363
- globalVar.__reactRouterDataRouter.state.errors,
364
- rerender.errors
365
- ) : null
366
- }
367
- );
368
- });
369
- }
370
- }).catch(() => {
371
- })
372
- )
373
- );
374
- return payloadPromise.then((payload) => {
375
- if (payload.type !== "action" && payload.type !== "redirect") {
376
- throw new Error("Unexpected payload type");
377
- }
378
- return payload.actionResult;
379
- });
380
- };
381
- }
382
- function createRouterFromPayload({
383
- fetchImplementation,
384
- createFromReadableStream,
385
- getContext,
386
- payload
387
- }) {
388
- const globalVar = window;
389
- if (globalVar.__reactRouterDataRouter && globalVar.__reactRouterRouteModules)
390
- return {
391
- router: globalVar.__reactRouterDataRouter,
392
- routeModules: globalVar.__reactRouterRouteModules
393
- };
394
- if (payload.type !== "render") throw new Error("Invalid payload type");
395
- globalVar.__reactRouterRouteModules = _nullishCoalesce(globalVar.__reactRouterRouteModules, () => ( {}));
396
- _chunkY6IFXO7Vjs.populateRSCRouteModules.call(void 0, globalVar.__reactRouterRouteModules, payload.matches);
397
- let routes = payload.matches.reduceRight((previous, match) => {
398
- const route = createRouteFromServerManifest(
399
- match,
400
- payload
401
- );
402
- if (previous.length > 0) {
403
- route.children = previous;
404
- } else if (!route.index) {
405
- route.children = [];
406
- }
407
- return [route];
408
- }, []);
409
- let applyPatchesPromise;
410
- globalVar.__reactRouterDataRouter = _chunkHUBUW7R3js.createRouter.call(void 0, {
411
- routes,
412
- getContext,
413
- basename: payload.basename,
414
- history: _chunkHUBUW7R3js.createBrowserHistory.call(void 0, ),
415
- hydrationData: _chunkY6IFXO7Vjs.getHydrationData.call(void 0, {
416
- state: {
417
- loaderData: payload.loaderData,
418
- actionData: payload.actionData,
419
- errors: payload.errors
420
- },
421
- routes,
422
- getRouteInfo: (routeId) => {
423
- let match = payload.matches.find((m) => m.id === routeId);
424
- _chunkHUBUW7R3js.invariant.call(void 0, match, "Route not found in payload");
425
- return {
426
- clientLoader: match.clientLoader,
427
- hasLoader: match.hasLoader,
428
- hasHydrateFallback: match.hydrateFallbackElement != null
429
- };
430
- },
431
- location: payload.location,
432
- basename: payload.basename,
433
- isSpaMode: false
434
- }),
435
- async patchRoutesOnNavigation({ path, signal }) {
436
- if (payload.routeDiscovery.mode === "initial") {
437
- if (!applyPatchesPromise) {
438
- applyPatchesPromise = (async () => {
439
- if (!payload.patches) return;
440
- let patches = await payload.patches;
441
- React3.startTransition(() => {
442
- patches.forEach((p) => {
443
- window.__reactRouterDataRouter.patchRoutes(_nullishCoalesce(p.parentId, () => ( null)), [
444
- createRouteFromServerManifest(p)
445
- ]);
446
- });
447
- });
448
- })();
449
- }
450
- await applyPatchesPromise;
451
- return;
452
- }
453
- if (discoveredPaths.has(path)) {
454
- return;
455
- }
456
- await fetchAndApplyManifestPatches(
457
- [path],
458
- createFromReadableStream,
459
- fetchImplementation,
460
- signal
461
- );
462
- },
463
- // FIXME: Pass `build.ssr` into this function
464
- dataStrategy: getRSCSingleFetchDataStrategy(
465
- () => globalVar.__reactRouterDataRouter,
466
- true,
467
- payload.basename,
468
- createFromReadableStream,
469
- fetchImplementation
470
- )
471
- });
472
- if (globalVar.__reactRouterDataRouter.state.initialized) {
473
- globalVar.__routerInitialized = true;
474
- globalVar.__reactRouterDataRouter.initialize();
475
- } else {
476
- globalVar.__routerInitialized = false;
477
- }
478
- let lastLoaderData = void 0;
479
- globalVar.__reactRouterDataRouter.subscribe(({ loaderData, actionData }) => {
480
- if (lastLoaderData !== loaderData) {
481
- globalVar.__routerActionID = (_nullishCoalesce(globalVar.__routerActionID, () => ( (globalVar.__routerActionID = 0)))) + 1;
482
- }
483
- });
484
- globalVar.__reactRouterDataRouter._updateRoutesForHMR = (routeUpdateByRouteId) => {
485
- const oldRoutes = window.__reactRouterDataRouter.routes;
486
- const newRoutes = [];
487
- function walkRoutes(routes2, parentId) {
488
- return routes2.map((route) => {
489
- const routeUpdate = routeUpdateByRouteId.get(route.id);
490
- if (routeUpdate) {
491
- const {
492
- routeModule,
493
- hasAction,
494
- hasComponent,
495
- hasErrorBoundary,
496
- hasLoader
497
- } = routeUpdate;
498
- const newRoute = createRouteFromServerManifest({
499
- clientAction: routeModule.clientAction,
500
- clientLoader: routeModule.clientLoader,
501
- element: route.element,
502
- errorElement: route.errorElement,
503
- handle: route.handle,
504
- hasAction,
505
- hasComponent,
506
- hasErrorBoundary,
507
- hasLoader,
508
- hydrateFallbackElement: route.hydrateFallbackElement,
509
- id: route.id,
510
- index: route.index,
511
- links: routeModule.links,
512
- meta: routeModule.meta,
513
- parentId,
514
- path: route.path,
515
- shouldRevalidate: routeModule.shouldRevalidate
516
- });
517
- if (route.children) {
518
- newRoute.children = walkRoutes(route.children, route.id);
519
- }
520
- return newRoute;
521
- }
522
- const updatedRoute = { ...route };
523
- if (route.children) {
524
- updatedRoute.children = walkRoutes(route.children, route.id);
525
- }
526
- return updatedRoute;
527
- });
528
- }
529
- newRoutes.push(
530
- ...walkRoutes(oldRoutes, void 0)
531
- );
532
- window.__reactRouterDataRouter._internalSetRoutes(newRoutes);
533
- };
534
- return {
535
- router: globalVar.__reactRouterDataRouter,
536
- routeModules: globalVar.__reactRouterRouteModules
537
- };
538
- }
539
- var renderedRoutesContext = _chunkHUBUW7R3js.createContext.call(void 0, );
540
- function getRSCSingleFetchDataStrategy(getRouter, ssr, basename, createFromReadableStream, fetchImplementation) {
541
- let dataStrategy = _chunkHUBUW7R3js.getSingleFetchDataStrategyImpl.call(void 0,
542
- getRouter,
543
- (match) => {
544
- let M = match;
545
- return {
546
- hasLoader: M.route.hasLoader,
547
- hasClientLoader: M.route.hasClientLoader,
548
- hasComponent: M.route.hasComponent,
549
- hasAction: M.route.hasAction,
550
- hasClientAction: M.route.hasClientAction
551
- };
552
- },
553
- // pass map into fetchAndDecode so it can add payloads
554
- getFetchAndDecodeViaRSC(createFromReadableStream, fetchImplementation),
555
- ssr,
556
- basename,
557
- // .rsc requests are always trailing slash aware
558
- true,
559
- // If the route has a component but we don't have an element, we need to hit
560
- // the server loader flow regardless of whether the client loader calls
561
- // `serverLoader` or not, otherwise we'll have nothing to render.
562
- (match) => {
563
- let M = match;
564
- return M.route.hasComponent && !M.route.element;
565
- }
566
- );
567
- return async (args) => args.runClientMiddleware(async () => {
568
- let context = args.context;
569
- context.set(renderedRoutesContext, []);
570
- let results = await dataStrategy(args);
571
- const renderedRoutesById = /* @__PURE__ */ new Map();
572
- for (const route of context.get(renderedRoutesContext)) {
573
- if (!renderedRoutesById.has(route.id)) {
574
- renderedRoutesById.set(route.id, []);
575
- }
576
- renderedRoutesById.get(route.id).push(route);
577
- }
578
- React3.startTransition(() => {
579
- for (const match of args.matches) {
580
- const renderedRoutes = renderedRoutesById.get(match.route.id);
581
- if (renderedRoutes) {
582
- for (const rendered of renderedRoutes) {
583
- window.__reactRouterDataRouter.patchRoutes(
584
- _nullishCoalesce(rendered.parentId, () => ( null)),
585
- [createRouteFromServerManifest(rendered)],
586
- true
587
- );
588
- }
589
- }
590
- }
591
- });
592
- return results;
593
- });
594
- }
595
- function getFetchAndDecodeViaRSC(createFromReadableStream, fetchImplementation) {
596
- return async (args, basename, trailingSlashAware, targetRoutes) => {
597
- let { request, context } = args;
598
- let url = _chunkHUBUW7R3js.singleFetchUrl.call(void 0, request.url, basename, trailingSlashAware, "rsc");
599
- if (request.method === "GET") {
600
- url = _chunkHUBUW7R3js.stripIndexParam.call(void 0, url);
601
- if (targetRoutes) {
602
- url.searchParams.set("_routes", targetRoutes.join(","));
603
- }
604
- }
605
- let res = await fetchImplementation(
606
- new Request(url, await _chunkHUBUW7R3js.createRequestInit.call(void 0, request))
607
- );
608
- if (res.status >= 400 && !res.headers.has("X-Remix-Response")) {
609
- throw new (0, _chunkHUBUW7R3js.ErrorResponseImpl)(res.status, res.statusText, await res.text());
610
- }
611
- _chunkHUBUW7R3js.invariant.call(void 0, res.body, "No response body to decode");
612
- try {
613
- const payload = await createFromReadableStream(res.body, {
614
- temporaryReferences: void 0
615
- });
616
- if (payload.type === "redirect") {
617
- return {
618
- status: res.status,
619
- data: {
620
- redirect: {
621
- redirect: payload.location,
622
- reload: payload.reload,
623
- replace: payload.replace,
624
- revalidate: false,
625
- status: payload.status
626
- }
627
- }
628
- };
629
- }
630
- if (payload.type !== "render") {
631
- throw new Error("Unexpected payload type");
632
- }
633
- context.get(renderedRoutesContext).push(...payload.matches);
634
- let results = { routes: {} };
635
- const dataKey = _chunkHUBUW7R3js.isMutationMethod.call(void 0, request.method) ? "actionData" : "loaderData";
636
- for (let [routeId, data] of Object.entries(payload[dataKey] || {})) {
637
- results.routes[routeId] = { data };
638
- }
639
- if (payload.errors) {
640
- for (let [routeId, error] of Object.entries(payload.errors)) {
641
- results.routes[routeId] = { error };
642
- }
643
- }
644
- return { status: res.status, data: results };
645
- } catch (cause) {
646
- throw new Error("Unable to decode RSC response", { cause });
647
- }
648
- };
649
- }
650
- function RSCHydratedRouter({
651
- createFromReadableStream,
652
- fetch: fetchImplementation = fetch,
653
- payload,
654
- getContext
655
- }) {
656
- if (payload.type !== "render") throw new Error("Invalid payload type");
657
- let { routeDiscovery } = payload;
658
- let { router: router2, routeModules } = React3.useMemo(
659
- () => createRouterFromPayload({
660
- payload,
661
- fetchImplementation,
662
- getContext,
663
- createFromReadableStream
664
- }),
665
- [createFromReadableStream, payload, fetchImplementation, getContext]
666
- );
667
- React3.useEffect(() => {
668
- _chunkHUBUW7R3js.setIsHydrated.call(void 0, );
669
- }, []);
670
- React3.useLayoutEffect(() => {
671
- const globalVar = window;
672
- if (!globalVar.__routerInitialized) {
673
- globalVar.__routerInitialized = true;
674
- globalVar.__reactRouterDataRouter.initialize();
675
- }
676
- }, []);
677
- let [{ routes, state }, setState] = React3.useState(() => ({
678
- routes: cloneRoutes(router2.routes),
679
- state: router2.state
680
- }));
681
- React3.useLayoutEffect(
682
- () => router2.subscribe((newState) => {
683
- if (diffRoutes(router2.routes, routes))
684
- React3.startTransition(() => {
685
- setState({
686
- routes: cloneRoutes(router2.routes),
687
- state: newState
688
- });
689
- });
690
- }),
691
- [router2.subscribe, routes, router2]
692
- );
693
- const transitionEnabledRouter = React3.useMemo(
694
- () => ({
695
- ...router2,
696
- state,
697
- routes
698
- }),
699
- [router2, routes, state]
700
- );
701
- React3.useEffect(() => {
702
- if (routeDiscovery.mode === "initial" || // @ts-expect-error - TS doesn't know about this yet
703
- _optionalChain([window, 'access', _22 => _22.navigator, 'optionalAccess', _23 => _23.connection, 'optionalAccess', _24 => _24.saveData]) === true) {
704
- return;
705
- }
706
- function registerElement(el) {
707
- let path = el.tagName === "FORM" ? el.getAttribute("action") : el.getAttribute("href");
708
- if (!path) {
709
- return;
710
- }
711
- let pathname = el.tagName === "A" ? el.pathname : new URL(path, window.location.origin).pathname;
712
- if (!discoveredPaths.has(pathname)) {
713
- nextPaths.add(pathname);
714
- }
715
- }
716
- async function fetchPatches() {
717
- document.querySelectorAll("a[data-discover], form[data-discover]").forEach(registerElement);
718
- let paths = Array.from(nextPaths.keys()).filter((path) => {
719
- if (discoveredPaths.has(path)) {
720
- nextPaths.delete(path);
721
- return false;
722
- }
723
- return true;
724
- });
725
- if (paths.length === 0) {
726
- return;
727
- }
728
- try {
729
- await fetchAndApplyManifestPatches(
730
- paths,
731
- createFromReadableStream,
732
- fetchImplementation
733
- );
734
- } catch (e) {
735
- console.error("Failed to fetch manifest patches", e);
736
- }
737
- }
738
- let debouncedFetchPatches = debounce(fetchPatches, 100);
739
- fetchPatches();
740
- let observer = new MutationObserver(() => debouncedFetchPatches());
741
- observer.observe(document.documentElement, {
742
- subtree: true,
743
- childList: true,
744
- attributes: true,
745
- attributeFilter: ["data-discover", "href", "action"]
746
- });
747
- }, [routeDiscovery, createFromReadableStream, fetchImplementation]);
748
- const frameworkContext = {
749
- future: {
750
- // These flags have no runtime impact so can always be false. If we add
751
- // flags that drive runtime behavior they'll need to be proxied through.
752
- v8_middleware: false,
753
- unstable_trailingSlashAwareDataRequests: true,
754
- // always on for RSC
755
- v8_passThroughRequests: true
756
- // always on for RSC
757
- },
758
- isSpaMode: false,
759
- ssr: true,
760
- criticalCss: "",
761
- manifest: {
762
- routes: {},
763
- version: "1",
764
- url: "",
765
- entry: {
766
- module: "",
767
- imports: []
768
- }
769
- },
770
- routeDiscovery: payload.routeDiscovery.mode === "initial" ? { mode: "initial", manifestPath: defaultManifestPath } : {
771
- mode: "lazy",
772
- manifestPath: payload.routeDiscovery.manifestPath || defaultManifestPath
773
- },
774
- routeModules
775
- };
776
- return /* @__PURE__ */ React3.createElement(_chunkHUBUW7R3js.RSCRouterContext.Provider, { value: true }, /* @__PURE__ */ React3.createElement(_chunkY6IFXO7Vjs.RSCRouterGlobalErrorBoundary, { location: state.location }, /* @__PURE__ */ React3.createElement(_chunkHUBUW7R3js.FrameworkContext.Provider, { value: frameworkContext }, /* @__PURE__ */ React3.createElement(
777
- _chunkHUBUW7R3js.RouterProvider,
778
- {
779
- router: transitionEnabledRouter,
780
- flushSync: ReactDOM2.flushSync
781
- }
782
- ))));
783
- }
784
- function createRouteFromServerManifest(match, payload) {
785
- let hasInitialData = payload && match.id in payload.loaderData;
786
- let initialData = _optionalChain([payload, 'optionalAccess', _25 => _25.loaderData, 'access', _26 => _26[match.id]]);
787
- let hasInitialError = _optionalChain([payload, 'optionalAccess', _27 => _27.errors]) && match.id in payload.errors;
788
- let initialError = _optionalChain([payload, 'optionalAccess', _28 => _28.errors, 'optionalAccess', _29 => _29[match.id]]);
789
- let isHydrationRequest = _optionalChain([match, 'access', _30 => _30.clientLoader, 'optionalAccess', _31 => _31.hydrate]) === true || !match.hasLoader || // If the route has a component but we don't have an element, we need to hit
790
- // the server loader flow regardless of whether the client loader calls
791
- // `serverLoader` or not, otherwise we'll have nothing to render.
792
- match.hasComponent && !match.element;
793
- _chunkHUBUW7R3js.invariant.call(void 0, window.__reactRouterRouteModules);
794
- _chunkY6IFXO7Vjs.populateRSCRouteModules.call(void 0, window.__reactRouterRouteModules, match);
795
- let dataRoute = {
796
- id: match.id,
797
- element: match.element,
798
- errorElement: match.errorElement,
799
- handle: match.handle,
800
- hasErrorBoundary: match.hasErrorBoundary,
801
- hydrateFallbackElement: match.hydrateFallbackElement,
802
- index: match.index,
803
- loader: match.clientLoader ? async (args, singleFetch) => {
804
- let _isHydrationRequest = isHydrationRequest;
805
- isHydrationRequest = false;
806
- let result = await match.clientLoader({
807
- ...args,
808
- serverLoader: () => {
809
- preventInvalidServerHandlerCall(
810
- "loader",
811
- match.id,
812
- match.hasLoader
813
- );
814
- if (_isHydrationRequest) {
815
- if (hasInitialData) {
816
- return initialData;
817
- }
818
- if (hasInitialError) {
819
- throw initialError;
820
- }
821
- }
822
- return callSingleFetch(singleFetch);
823
- }
824
- });
825
- return result;
826
- } : (
827
- // We always make the call in this RSC world since even if we don't
828
- // have a `loader` we may need to get the `element` implementation
829
- (_, singleFetch) => callSingleFetch(singleFetch)
830
- ),
831
- action: match.clientAction ? (args, singleFetch) => match.clientAction({
832
- ...args,
833
- serverAction: async () => {
834
- preventInvalidServerHandlerCall(
835
- "action",
836
- match.id,
837
- match.hasLoader
838
- );
839
- return await callSingleFetch(singleFetch);
840
- }
841
- }) : match.hasAction ? (_, singleFetch) => callSingleFetch(singleFetch) : () => {
842
- throw _chunkHUBUW7R3js.noActionDefinedError.call(void 0, "action", match.id);
843
- },
844
- path: match.path,
845
- shouldRevalidate: match.shouldRevalidate,
846
- // We always have a "loader" in this RSC world since even if we don't
847
- // have a `loader` we may need to get the `element` implementation
848
- hasLoader: true,
849
- hasClientLoader: match.clientLoader != null,
850
- hasAction: match.hasAction,
851
- hasClientAction: match.clientAction != null
852
- };
853
- if (typeof dataRoute.loader === "function") {
854
- dataRoute.loader.hydrate = _chunkHUBUW7R3js.shouldHydrateRouteLoader.call(void 0,
855
- match.id,
856
- match.clientLoader,
857
- match.hasLoader,
858
- false
859
- );
860
- }
861
- return dataRoute;
862
- }
863
- function callSingleFetch(singleFetch) {
864
- _chunkHUBUW7R3js.invariant.call(void 0, typeof singleFetch === "function", "Invalid singleFetch parameter");
865
- return singleFetch();
866
- }
867
- function preventInvalidServerHandlerCall(type, routeId, hasHandler) {
868
- if (!hasHandler) {
869
- let fn = type === "action" ? "serverAction()" : "serverLoader()";
870
- let msg = `You are trying to call ${fn} on a route that does not have a server ${type} (routeId: "${routeId}")`;
871
- console.error(msg);
872
- throw new (0, _chunkHUBUW7R3js.ErrorResponseImpl)(400, "Bad Request", new Error(msg), true);
873
- }
874
- }
875
- var nextPaths = /* @__PURE__ */ new Set();
876
- var discoveredPathsMaxSize = 1e3;
877
- var discoveredPaths = /* @__PURE__ */ new Set();
878
- function getManifestUrl(paths) {
879
- if (paths.length === 0) {
880
- return null;
881
- }
882
- if (paths.length === 1) {
883
- return new URL(`${paths[0]}.manifest`, window.location.origin);
884
- }
885
- const globalVar = window;
886
- let basename = (_nullishCoalesce(globalVar.__reactRouterDataRouter.basename, () => ( ""))).replace(
887
- /^\/|\/$/g,
888
- ""
889
- );
890
- let url = new URL(`${basename}/.manifest`, window.location.origin);
891
- url.searchParams.set("paths", paths.sort().join(","));
892
- return url;
893
- }
894
- async function fetchAndApplyManifestPatches(paths, createFromReadableStream, fetchImplementation, signal) {
895
- let url = getManifestUrl(paths);
896
- if (url == null) {
897
- return;
898
- }
899
- if (url.toString().length > _chunkHUBUW7R3js.URL_LIMIT) {
900
- nextPaths.clear();
901
- return;
902
- }
903
- let response = await fetchImplementation(new Request(url, { signal }));
904
- if (!response.body || response.status < 200 || response.status >= 300) {
905
- throw new Error("Unable to fetch new route matches from the server");
906
- }
907
- let payload = await createFromReadableStream(response.body, {
908
- temporaryReferences: void 0
909
- });
910
- if (payload.type !== "manifest") {
911
- throw new Error("Failed to patch routes");
912
- }
913
- paths.forEach((p) => addToFifoQueue(p, discoveredPaths));
914
- let patches = await payload.patches;
915
- React3.startTransition(() => {
916
- patches.forEach((p) => {
917
- window.__reactRouterDataRouter.patchRoutes(
918
- _nullishCoalesce(p.parentId, () => ( null)),
919
- [createRouteFromServerManifest(p)]
920
- );
921
- });
922
- });
923
- }
924
- function addToFifoQueue(path, queue) {
925
- if (queue.size >= discoveredPathsMaxSize) {
926
- let first = queue.values().next().value;
927
- if (typeof first === "string") queue.delete(first);
928
- }
929
- queue.add(path);
930
- }
931
- function debounce(callback, wait) {
932
- let timeoutId;
933
- return (...args) => {
934
- window.clearTimeout(timeoutId);
935
- timeoutId = window.setTimeout(() => callback(...args), wait);
936
- };
937
- }
938
- function isExternalLocation(location2) {
939
- const newLocation = new URL(location2, window.location.href);
940
- return newLocation.origin !== window.location.origin;
941
- }
942
- function hasInvalidProtocol(location2) {
943
- try {
944
- return _chunkHUBUW7R3js.invalidProtocols.includes(new URL(location2).protocol);
945
- } catch (e2) {
946
- return false;
947
- }
948
- }
949
- function cloneRoutes(routes) {
950
- if (!routes) return void 0;
951
- return routes.map((route) => ({
952
- ...route,
953
- children: cloneRoutes(route.children)
954
- }));
955
- }
956
- function diffRoutes(a, b) {
957
- if (a.length !== b.length) return true;
958
- return a.some((route, index) => {
959
- if (route.element !== b[index].element) return true;
960
- if (route.errorElement !== b[index].errorElement)
961
- return true;
962
- if (route.hydrateFallbackElement !== b[index].hydrateFallbackElement)
963
- return true;
964
- if (route.hasErrorBoundary !== b[index].hasErrorBoundary)
965
- return true;
966
- if (route.hasLoader !== b[index].hasLoader) return true;
967
- if (route.hasClientLoader !== b[index].hasClientLoader)
968
- return true;
969
- if (route.hasAction !== b[index].hasAction) return true;
970
- if (route.hasClientAction !== b[index].hasClientAction)
971
- return true;
972
- return diffRoutes(route.children || [], b[index].children || []);
973
- });
974
- }
975
-
976
- // lib/rsc/html-stream/browser.ts
977
- function getRSCStream() {
978
- let encoder = new TextEncoder();
979
- let streamController = null;
980
- let rscStream = new ReadableStream({
981
- start(controller) {
982
- if (typeof window === "undefined") {
983
- return;
984
- }
985
- let handleChunk = (chunk) => {
986
- if (typeof chunk === "string") {
987
- controller.enqueue(encoder.encode(chunk));
988
- } else {
989
- controller.enqueue(chunk);
990
- }
991
- };
992
- window.__FLIGHT_DATA || (window.__FLIGHT_DATA = []);
993
- window.__FLIGHT_DATA.forEach(handleChunk);
994
- window.__FLIGHT_DATA.push = (chunk) => {
995
- handleChunk(chunk);
996
- return 0;
997
- };
998
- streamController = controller;
999
- }
1000
- });
1001
- if (typeof document !== "undefined" && document.readyState === "loading") {
1002
- document.addEventListener("DOMContentLoaded", () => {
1003
- _optionalChain([streamController, 'optionalAccess', _32 => _32.close, 'call', _33 => _33()]);
1004
- });
1005
- } else {
1006
- _optionalChain([streamController, 'optionalAccess', _34 => _34.close, 'call', _35 => _35()]);
1007
- }
1008
- return rscStream;
1009
- }
1010
-
1011
-
1012
-
1013
-
1014
-
1015
-
1016
- exports.HydratedRouter = HydratedRouter; exports.RouterProvider = RouterProvider2; exports.unstable_RSCHydratedRouter = RSCHydratedRouter; exports.unstable_createCallServer = createCallServer; exports.unstable_getRSCStream = getRSCStream;
12
+ import { RouterProvider } from "./lib/dom-export/dom-router-provider.js";
13
+ import { HydratedRouter } from "./lib/dom-export/hydrated-router.js";
14
+ import { RSCHydratedRouter, createCallServer } from "./lib/rsc/browser.js";
15
+ import { getRSCStream } from "./lib/rsc/html-stream/browser.js";
16
+ //#region dom-export.ts
17
+ /**
18
+ * @module dom
19
+ */
20
+ //#endregion
21
+ export { HydratedRouter, RouterProvider, RSCHydratedRouter as unstable_RSCHydratedRouter, createCallServer as unstable_createCallServer, getRSCStream as unstable_getRSCStream };