@rangojs/router 0.0.0-experimental.85 → 0.0.0-experimental.86

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 (843) hide show
  1. package/README.md +3 -1
  2. package/dist/vite/index.js +19 -9
  3. package/package.json +14 -15
  4. package/skills/breadcrumbs/SKILL.md +3 -1
  5. package/skills/hooks/SKILL.md +3 -1
  6. package/skills/links/SKILL.md +24 -15
  7. package/skills/loader/SKILL.md +35 -2
  8. package/skills/typesafety/SKILL.md +3 -1
  9. package/src/browser/app-shell.ts +52 -0
  10. package/src/browser/navigation-bridge.ts +51 -2
  11. package/src/browser/navigation-store.ts +25 -1
  12. package/src/browser/partial-update.ts +20 -1
  13. package/src/browser/prefetch/cache.ts +16 -0
  14. package/src/browser/rango-state.ts +53 -13
  15. package/src/browser/react/NavigationProvider.tsx +44 -9
  16. package/src/browser/react/use-router.ts +8 -1
  17. package/src/browser/rsc-router.tsx +34 -6
  18. package/src/browser/types.ts +13 -0
  19. package/src/cache/cf/cf-cache-store.ts +5 -7
  20. package/src/index.rsc.ts +3 -0
  21. package/src/index.ts +3 -0
  22. package/src/outlet-context.ts +1 -1
  23. package/src/router/handler-context.ts +17 -1
  24. package/src/router/lazy-includes.ts +1 -1
  25. package/src/router/loader-resolution.ts +3 -0
  26. package/src/router/match-api.ts +3 -3
  27. package/src/router/middleware-types.ts +2 -22
  28. package/src/router/middleware.ts +10 -1
  29. package/src/router.ts +1 -2
  30. package/src/rsc/handler.ts +2 -1
  31. package/src/rsc/response-route-handler.ts +3 -0
  32. package/src/server/request-context.ts +10 -42
  33. package/src/types/handler-context.ts +2 -34
  34. package/src/types/loader-types.ts +2 -6
  35. package/src/types/request-scope.ts +126 -0
  36. package/src/urls/response-types.ts +2 -10
  37. package/src/vite/rango.ts +23 -7
  38. package/src/vite/utils/banner.ts +1 -1
  39. package/src/vite/utils/package-resolution.ts +1 -1
  40. package/dist/__internal.d.ts +0 -83
  41. package/dist/__internal.d.ts.map +0 -1
  42. package/dist/__internal.js +0 -19
  43. package/dist/__internal.js.map +0 -1
  44. package/dist/__mocks__/version.d.ts +0 -7
  45. package/dist/__mocks__/version.d.ts.map +0 -1
  46. package/dist/__mocks__/version.js +0 -7
  47. package/dist/__mocks__/version.js.map +0 -1
  48. package/dist/__tests__/client-href.test.d.ts +0 -2
  49. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  50. package/dist/__tests__/client-href.test.js +0 -74
  51. package/dist/__tests__/client-href.test.js.map +0 -1
  52. package/dist/__tests__/component-utils.test.d.ts +0 -2
  53. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  54. package/dist/__tests__/component-utils.test.js +0 -51
  55. package/dist/__tests__/component-utils.test.js.map +0 -1
  56. package/dist/__tests__/event-controller.test.d.ts +0 -2
  57. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  58. package/dist/__tests__/event-controller.test.js +0 -538
  59. package/dist/__tests__/event-controller.test.js.map +0 -1
  60. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  61. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  62. package/dist/__tests__/helpers/route-tree.js +0 -374
  63. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  64. package/dist/__tests__/match-result.test.d.ts +0 -2
  65. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  66. package/dist/__tests__/match-result.test.js +0 -154
  67. package/dist/__tests__/match-result.test.js.map +0 -1
  68. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  69. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  70. package/dist/__tests__/navigation-store.test.js +0 -440
  71. package/dist/__tests__/navigation-store.test.js.map +0 -1
  72. package/dist/__tests__/partial-update.test.d.ts +0 -2
  73. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  74. package/dist/__tests__/partial-update.test.js +0 -1009
  75. package/dist/__tests__/partial-update.test.js.map +0 -1
  76. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  77. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  78. package/dist/__tests__/reverse-types.test.js +0 -656
  79. package/dist/__tests__/reverse-types.test.js.map +0 -1
  80. package/dist/__tests__/route-definition.test.d.ts +0 -2
  81. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  82. package/dist/__tests__/route-definition.test.js +0 -55
  83. package/dist/__tests__/route-definition.test.js.map +0 -1
  84. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  85. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  86. package/dist/__tests__/router-helpers.test.js +0 -377
  87. package/dist/__tests__/router-helpers.test.js.map +0 -1
  88. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  89. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  90. package/dist/__tests__/router-integration-2.test.js +0 -426
  91. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  92. package/dist/__tests__/router-integration.test.d.ts +0 -2
  93. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  94. package/dist/__tests__/router-integration.test.js +0 -1051
  95. package/dist/__tests__/router-integration.test.js.map +0 -1
  96. package/dist/__tests__/search-params.test.d.ts +0 -5
  97. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  98. package/dist/__tests__/search-params.test.js +0 -306
  99. package/dist/__tests__/search-params.test.js.map +0 -1
  100. package/dist/__tests__/segment-system.test.d.ts +0 -2
  101. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  102. package/dist/__tests__/segment-system.test.js +0 -627
  103. package/dist/__tests__/segment-system.test.js.map +0 -1
  104. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  105. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  106. package/dist/__tests__/static-handler-types.test.js +0 -63
  107. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  108. package/dist/__tests__/urls.test.d.ts +0 -2
  109. package/dist/__tests__/urls.test.d.ts.map +0 -1
  110. package/dist/__tests__/urls.test.js +0 -421
  111. package/dist/__tests__/urls.test.js.map +0 -1
  112. package/dist/__tests__/use-mount.test.d.ts +0 -2
  113. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  114. package/dist/__tests__/use-mount.test.js +0 -35
  115. package/dist/__tests__/use-mount.test.js.map +0 -1
  116. package/dist/bin/rango.d.ts +0 -2
  117. package/dist/bin/rango.d.ts.map +0 -1
  118. package/dist/bin/rango.js.map +0 -1
  119. package/dist/browser/event-controller.d.ts +0 -191
  120. package/dist/browser/event-controller.d.ts.map +0 -1
  121. package/dist/browser/event-controller.js +0 -559
  122. package/dist/browser/event-controller.js.map +0 -1
  123. package/dist/browser/index.d.ts +0 -2
  124. package/dist/browser/index.d.ts.map +0 -1
  125. package/dist/browser/index.js +0 -14
  126. package/dist/browser/index.js.map +0 -1
  127. package/dist/browser/link-interceptor.d.ts +0 -38
  128. package/dist/browser/link-interceptor.d.ts.map +0 -1
  129. package/dist/browser/link-interceptor.js +0 -99
  130. package/dist/browser/link-interceptor.js.map +0 -1
  131. package/dist/browser/logging.d.ts +0 -10
  132. package/dist/browser/logging.d.ts.map +0 -1
  133. package/dist/browser/logging.js +0 -29
  134. package/dist/browser/logging.js.map +0 -1
  135. package/dist/browser/lru-cache.d.ts +0 -17
  136. package/dist/browser/lru-cache.d.ts.map +0 -1
  137. package/dist/browser/lru-cache.js +0 -50
  138. package/dist/browser/lru-cache.js.map +0 -1
  139. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  140. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  141. package/dist/browser/merge-segment-loaders.js +0 -102
  142. package/dist/browser/merge-segment-loaders.js.map +0 -1
  143. package/dist/browser/navigation-bridge.d.ts +0 -102
  144. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  145. package/dist/browser/navigation-bridge.js +0 -708
  146. package/dist/browser/navigation-bridge.js.map +0 -1
  147. package/dist/browser/navigation-client.d.ts +0 -25
  148. package/dist/browser/navigation-client.d.ts.map +0 -1
  149. package/dist/browser/navigation-client.js +0 -157
  150. package/dist/browser/navigation-client.js.map +0 -1
  151. package/dist/browser/navigation-store.d.ts +0 -101
  152. package/dist/browser/navigation-store.d.ts.map +0 -1
  153. package/dist/browser/navigation-store.js +0 -625
  154. package/dist/browser/navigation-store.js.map +0 -1
  155. package/dist/browser/partial-update.d.ts +0 -75
  156. package/dist/browser/partial-update.d.ts.map +0 -1
  157. package/dist/browser/partial-update.js +0 -426
  158. package/dist/browser/partial-update.js.map +0 -1
  159. package/dist/browser/react/Link.d.ts +0 -86
  160. package/dist/browser/react/Link.d.ts.map +0 -1
  161. package/dist/browser/react/Link.js +0 -128
  162. package/dist/browser/react/Link.js.map +0 -1
  163. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  164. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  165. package/dist/browser/react/NavigationProvider.js +0 -216
  166. package/dist/browser/react/NavigationProvider.js.map +0 -1
  167. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  168. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  169. package/dist/browser/react/ScrollRestoration.js +0 -57
  170. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  171. package/dist/browser/react/context.d.ts +0 -46
  172. package/dist/browser/react/context.d.ts.map +0 -1
  173. package/dist/browser/react/context.js +0 -10
  174. package/dist/browser/react/context.js.map +0 -1
  175. package/dist/browser/react/index.d.ts +0 -11
  176. package/dist/browser/react/index.d.ts.map +0 -1
  177. package/dist/browser/react/index.js +0 -22
  178. package/dist/browser/react/index.js.map +0 -1
  179. package/dist/browser/react/location-state-shared.d.ts +0 -63
  180. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  181. package/dist/browser/react/location-state-shared.js +0 -81
  182. package/dist/browser/react/location-state-shared.js.map +0 -1
  183. package/dist/browser/react/location-state.d.ts +0 -23
  184. package/dist/browser/react/location-state.d.ts.map +0 -1
  185. package/dist/browser/react/location-state.js +0 -29
  186. package/dist/browser/react/location-state.js.map +0 -1
  187. package/dist/browser/react/mount-context.d.ts +0 -24
  188. package/dist/browser/react/mount-context.d.ts.map +0 -1
  189. package/dist/browser/react/mount-context.js +0 -24
  190. package/dist/browser/react/mount-context.js.map +0 -1
  191. package/dist/browser/react/use-action.d.ts +0 -64
  192. package/dist/browser/react/use-action.d.ts.map +0 -1
  193. package/dist/browser/react/use-action.js +0 -134
  194. package/dist/browser/react/use-action.js.map +0 -1
  195. package/dist/browser/react/use-client-cache.d.ts +0 -41
  196. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  197. package/dist/browser/react/use-client-cache.js +0 -39
  198. package/dist/browser/react/use-client-cache.js.map +0 -1
  199. package/dist/browser/react/use-handle.d.ts +0 -31
  200. package/dist/browser/react/use-handle.d.ts.map +0 -1
  201. package/dist/browser/react/use-handle.js +0 -144
  202. package/dist/browser/react/use-handle.js.map +0 -1
  203. package/dist/browser/react/use-href.d.ts +0 -33
  204. package/dist/browser/react/use-href.d.ts.map +0 -1
  205. package/dist/browser/react/use-href.js +0 -39
  206. package/dist/browser/react/use-href.js.map +0 -1
  207. package/dist/browser/react/use-link-status.d.ts +0 -37
  208. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  209. package/dist/browser/react/use-link-status.js +0 -99
  210. package/dist/browser/react/use-link-status.js.map +0 -1
  211. package/dist/browser/react/use-mount.d.ts +0 -25
  212. package/dist/browser/react/use-mount.d.ts.map +0 -1
  213. package/dist/browser/react/use-mount.js +0 -30
  214. package/dist/browser/react/use-mount.js.map +0 -1
  215. package/dist/browser/react/use-navigation.d.ts +0 -27
  216. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  217. package/dist/browser/react/use-navigation.js +0 -87
  218. package/dist/browser/react/use-navigation.js.map +0 -1
  219. package/dist/browser/react/use-segments.d.ts +0 -38
  220. package/dist/browser/react/use-segments.d.ts.map +0 -1
  221. package/dist/browser/react/use-segments.js +0 -130
  222. package/dist/browser/react/use-segments.js.map +0 -1
  223. package/dist/browser/request-controller.d.ts +0 -26
  224. package/dist/browser/request-controller.d.ts.map +0 -1
  225. package/dist/browser/request-controller.js +0 -147
  226. package/dist/browser/request-controller.js.map +0 -1
  227. package/dist/browser/rsc-router.d.ts +0 -129
  228. package/dist/browser/rsc-router.d.ts.map +0 -1
  229. package/dist/browser/rsc-router.js +0 -195
  230. package/dist/browser/rsc-router.js.map +0 -1
  231. package/dist/browser/scroll-restoration.d.ts +0 -93
  232. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  233. package/dist/browser/scroll-restoration.js +0 -321
  234. package/dist/browser/scroll-restoration.js.map +0 -1
  235. package/dist/browser/segment-structure-assert.d.ts +0 -17
  236. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  237. package/dist/browser/segment-structure-assert.js +0 -59
  238. package/dist/browser/segment-structure-assert.js.map +0 -1
  239. package/dist/browser/server-action-bridge.d.ts +0 -26
  240. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  241. package/dist/browser/server-action-bridge.js +0 -668
  242. package/dist/browser/server-action-bridge.js.map +0 -1
  243. package/dist/browser/shallow.d.ts +0 -12
  244. package/dist/browser/shallow.d.ts.map +0 -1
  245. package/dist/browser/shallow.js +0 -34
  246. package/dist/browser/shallow.js.map +0 -1
  247. package/dist/browser/types.d.ts +0 -369
  248. package/dist/browser/types.d.ts.map +0 -1
  249. package/dist/browser/types.js +0 -2
  250. package/dist/browser/types.js.map +0 -1
  251. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  252. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  253. package/dist/build/__tests__/generate-cli.test.js +0 -237
  254. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  255. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  256. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  257. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  258. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  259. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  260. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  261. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  262. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  263. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  264. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  265. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  266. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  267. package/dist/build/generate-manifest.d.ts +0 -81
  268. package/dist/build/generate-manifest.d.ts.map +0 -1
  269. package/dist/build/generate-manifest.js +0 -276
  270. package/dist/build/generate-manifest.js.map +0 -1
  271. package/dist/build/generate-route-types.d.ts +0 -115
  272. package/dist/build/generate-route-types.d.ts.map +0 -1
  273. package/dist/build/generate-route-types.js +0 -740
  274. package/dist/build/generate-route-types.js.map +0 -1
  275. package/dist/build/index.d.ts +0 -21
  276. package/dist/build/index.d.ts.map +0 -1
  277. package/dist/build/index.js +0 -21
  278. package/dist/build/index.js.map +0 -1
  279. package/dist/build/route-trie.d.ts +0 -71
  280. package/dist/build/route-trie.d.ts.map +0 -1
  281. package/dist/build/route-trie.js +0 -175
  282. package/dist/build/route-trie.js.map +0 -1
  283. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  284. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  285. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  286. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  287. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  288. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  289. package/dist/cache/__tests__/document-cache.test.js +0 -345
  290. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  291. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  292. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  293. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  294. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  295. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  296. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  297. package/dist/cache/__tests__/memory-store.test.js +0 -367
  298. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  299. package/dist/cache/cache-scope.d.ts +0 -102
  300. package/dist/cache/cache-scope.d.ts.map +0 -1
  301. package/dist/cache/cache-scope.js +0 -440
  302. package/dist/cache/cache-scope.js.map +0 -1
  303. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  304. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  305. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  306. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  307. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  308. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  309. package/dist/cache/cf/cf-cache-store.js +0 -242
  310. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  311. package/dist/cache/cf/index.d.ts +0 -14
  312. package/dist/cache/cf/index.d.ts.map +0 -1
  313. package/dist/cache/cf/index.js +0 -17
  314. package/dist/cache/cf/index.js.map +0 -1
  315. package/dist/cache/document-cache.d.ts +0 -64
  316. package/dist/cache/document-cache.d.ts.map +0 -1
  317. package/dist/cache/document-cache.js +0 -228
  318. package/dist/cache/document-cache.js.map +0 -1
  319. package/dist/cache/index.d.ts +0 -19
  320. package/dist/cache/index.d.ts.map +0 -1
  321. package/dist/cache/index.js +0 -21
  322. package/dist/cache/index.js.map +0 -1
  323. package/dist/cache/memory-segment-store.d.ts +0 -110
  324. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  325. package/dist/cache/memory-segment-store.js +0 -117
  326. package/dist/cache/memory-segment-store.js.map +0 -1
  327. package/dist/cache/memory-store.d.ts +0 -41
  328. package/dist/cache/memory-store.d.ts.map +0 -1
  329. package/dist/cache/memory-store.js +0 -191
  330. package/dist/cache/memory-store.js.map +0 -1
  331. package/dist/cache/types.d.ts +0 -317
  332. package/dist/cache/types.d.ts.map +0 -1
  333. package/dist/cache/types.js +0 -12
  334. package/dist/cache/types.js.map +0 -1
  335. package/dist/client.d.ts +0 -248
  336. package/dist/client.d.ts.map +0 -1
  337. package/dist/client.js +0 -367
  338. package/dist/client.js.map +0 -1
  339. package/dist/client.rsc.d.ts +0 -26
  340. package/dist/client.rsc.d.ts.map +0 -1
  341. package/dist/client.rsc.js +0 -46
  342. package/dist/client.rsc.js.map +0 -1
  343. package/dist/component-utils.d.ts +0 -36
  344. package/dist/component-utils.d.ts.map +0 -1
  345. package/dist/component-utils.js +0 -61
  346. package/dist/component-utils.js.map +0 -1
  347. package/dist/components/DefaultDocument.d.ts +0 -13
  348. package/dist/components/DefaultDocument.d.ts.map +0 -1
  349. package/dist/components/DefaultDocument.js +0 -15
  350. package/dist/components/DefaultDocument.js.map +0 -1
  351. package/dist/debug.d.ts +0 -58
  352. package/dist/debug.d.ts.map +0 -1
  353. package/dist/debug.js +0 -157
  354. package/dist/debug.js.map +0 -1
  355. package/dist/default-error-boundary.d.ts +0 -11
  356. package/dist/default-error-boundary.d.ts.map +0 -1
  357. package/dist/default-error-boundary.js +0 -45
  358. package/dist/default-error-boundary.js.map +0 -1
  359. package/dist/deps/browser.d.ts +0 -2
  360. package/dist/deps/browser.d.ts.map +0 -1
  361. package/dist/deps/browser.js +0 -3
  362. package/dist/deps/browser.js.map +0 -1
  363. package/dist/deps/html-stream-client.d.ts +0 -2
  364. package/dist/deps/html-stream-client.d.ts.map +0 -1
  365. package/dist/deps/html-stream-client.js +0 -3
  366. package/dist/deps/html-stream-client.js.map +0 -1
  367. package/dist/deps/html-stream-server.d.ts +0 -2
  368. package/dist/deps/html-stream-server.d.ts.map +0 -1
  369. package/dist/deps/html-stream-server.js +0 -3
  370. package/dist/deps/html-stream-server.js.map +0 -1
  371. package/dist/deps/rsc.d.ts +0 -2
  372. package/dist/deps/rsc.d.ts.map +0 -1
  373. package/dist/deps/rsc.js +0 -4
  374. package/dist/deps/rsc.js.map +0 -1
  375. package/dist/deps/ssr.d.ts +0 -2
  376. package/dist/deps/ssr.d.ts.map +0 -1
  377. package/dist/deps/ssr.js +0 -3
  378. package/dist/deps/ssr.js.map +0 -1
  379. package/dist/errors.d.ts +0 -174
  380. package/dist/errors.d.ts.map +0 -1
  381. package/dist/errors.js +0 -241
  382. package/dist/errors.js.map +0 -1
  383. package/dist/handle.d.ts +0 -78
  384. package/dist/handle.d.ts.map +0 -1
  385. package/dist/handle.js +0 -82
  386. package/dist/handle.js.map +0 -1
  387. package/dist/handles/MetaTags.d.ts +0 -14
  388. package/dist/handles/MetaTags.d.ts.map +0 -1
  389. package/dist/handles/MetaTags.js +0 -136
  390. package/dist/handles/MetaTags.js.map +0 -1
  391. package/dist/handles/index.d.ts +0 -6
  392. package/dist/handles/index.d.ts.map +0 -1
  393. package/dist/handles/index.js +0 -6
  394. package/dist/handles/index.js.map +0 -1
  395. package/dist/handles/meta.d.ts +0 -39
  396. package/dist/handles/meta.d.ts.map +0 -1
  397. package/dist/handles/meta.js +0 -202
  398. package/dist/handles/meta.js.map +0 -1
  399. package/dist/host/__tests__/errors.test.d.ts +0 -2
  400. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  401. package/dist/host/__tests__/errors.test.js +0 -76
  402. package/dist/host/__tests__/errors.test.js.map +0 -1
  403. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  404. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  405. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  406. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  407. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  408. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  409. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  410. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  411. package/dist/host/__tests__/router.test.d.ts +0 -2
  412. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  413. package/dist/host/__tests__/router.test.js +0 -241
  414. package/dist/host/__tests__/router.test.js.map +0 -1
  415. package/dist/host/__tests__/testing.test.d.ts +0 -2
  416. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  417. package/dist/host/__tests__/testing.test.js +0 -64
  418. package/dist/host/__tests__/testing.test.js.map +0 -1
  419. package/dist/host/__tests__/utils.test.d.ts +0 -2
  420. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  421. package/dist/host/__tests__/utils.test.js +0 -29
  422. package/dist/host/__tests__/utils.test.js.map +0 -1
  423. package/dist/host/cookie-handler.d.ts +0 -34
  424. package/dist/host/cookie-handler.d.ts.map +0 -1
  425. package/dist/host/cookie-handler.js +0 -124
  426. package/dist/host/cookie-handler.js.map +0 -1
  427. package/dist/host/errors.d.ts +0 -56
  428. package/dist/host/errors.d.ts.map +0 -1
  429. package/dist/host/errors.js +0 -79
  430. package/dist/host/errors.js.map +0 -1
  431. package/dist/host/index.d.ts +0 -29
  432. package/dist/host/index.d.ts.map +0 -1
  433. package/dist/host/index.js +0 -32
  434. package/dist/host/index.js.map +0 -1
  435. package/dist/host/pattern-matcher.d.ts +0 -36
  436. package/dist/host/pattern-matcher.d.ts.map +0 -1
  437. package/dist/host/pattern-matcher.js +0 -172
  438. package/dist/host/pattern-matcher.js.map +0 -1
  439. package/dist/host/router.d.ts +0 -26
  440. package/dist/host/router.d.ts.map +0 -1
  441. package/dist/host/router.js +0 -218
  442. package/dist/host/router.js.map +0 -1
  443. package/dist/host/testing.d.ts +0 -36
  444. package/dist/host/testing.d.ts.map +0 -1
  445. package/dist/host/testing.js +0 -55
  446. package/dist/host/testing.js.map +0 -1
  447. package/dist/host/types.d.ts +0 -115
  448. package/dist/host/types.d.ts.map +0 -1
  449. package/dist/host/types.js +0 -7
  450. package/dist/host/types.js.map +0 -1
  451. package/dist/host/utils.d.ts +0 -21
  452. package/dist/host/utils.d.ts.map +0 -1
  453. package/dist/host/utils.js +0 -23
  454. package/dist/host/utils.js.map +0 -1
  455. package/dist/href-client.d.ts +0 -131
  456. package/dist/href-client.d.ts.map +0 -1
  457. package/dist/href-client.js +0 -64
  458. package/dist/href-client.js.map +0 -1
  459. package/dist/href-context.d.ts +0 -29
  460. package/dist/href-context.d.ts.map +0 -1
  461. package/dist/href-context.js +0 -21
  462. package/dist/href-context.js.map +0 -1
  463. package/dist/index.d.ts +0 -73
  464. package/dist/index.d.ts.map +0 -1
  465. package/dist/index.js +0 -91
  466. package/dist/index.js.map +0 -1
  467. package/dist/index.rsc.d.ts +0 -32
  468. package/dist/index.rsc.d.ts.map +0 -1
  469. package/dist/index.rsc.js +0 -40
  470. package/dist/index.rsc.js.map +0 -1
  471. package/dist/internal-debug.d.ts +0 -2
  472. package/dist/internal-debug.d.ts.map +0 -1
  473. package/dist/internal-debug.js +0 -5
  474. package/dist/internal-debug.js.map +0 -1
  475. package/dist/loader.d.ts +0 -14
  476. package/dist/loader.d.ts.map +0 -1
  477. package/dist/loader.js +0 -20
  478. package/dist/loader.js.map +0 -1
  479. package/dist/loader.rsc.d.ts +0 -19
  480. package/dist/loader.rsc.d.ts.map +0 -1
  481. package/dist/loader.rsc.js +0 -99
  482. package/dist/loader.rsc.js.map +0 -1
  483. package/dist/network-error-thrower.d.ts +0 -17
  484. package/dist/network-error-thrower.d.ts.map +0 -1
  485. package/dist/network-error-thrower.js +0 -14
  486. package/dist/network-error-thrower.js.map +0 -1
  487. package/dist/outlet-context.d.ts +0 -13
  488. package/dist/outlet-context.d.ts.map +0 -1
  489. package/dist/outlet-context.js +0 -3
  490. package/dist/outlet-context.js.map +0 -1
  491. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  492. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  493. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  494. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  495. package/dist/prerender/param-hash.d.ts +0 -16
  496. package/dist/prerender/param-hash.d.ts.map +0 -1
  497. package/dist/prerender/param-hash.js +0 -36
  498. package/dist/prerender/param-hash.js.map +0 -1
  499. package/dist/prerender/store.d.ts +0 -38
  500. package/dist/prerender/store.d.ts.map +0 -1
  501. package/dist/prerender/store.js +0 -61
  502. package/dist/prerender/store.js.map +0 -1
  503. package/dist/prerender.d.ts +0 -66
  504. package/dist/prerender.d.ts.map +0 -1
  505. package/dist/prerender.js +0 -57
  506. package/dist/prerender.js.map +0 -1
  507. package/dist/reverse.d.ts +0 -196
  508. package/dist/reverse.d.ts.map +0 -1
  509. package/dist/reverse.js +0 -78
  510. package/dist/reverse.js.map +0 -1
  511. package/dist/root-error-boundary.d.ts +0 -33
  512. package/dist/root-error-boundary.d.ts.map +0 -1
  513. package/dist/root-error-boundary.js +0 -165
  514. package/dist/root-error-boundary.js.map +0 -1
  515. package/dist/route-content-wrapper.d.ts +0 -46
  516. package/dist/route-content-wrapper.d.ts.map +0 -1
  517. package/dist/route-content-wrapper.js +0 -77
  518. package/dist/route-content-wrapper.js.map +0 -1
  519. package/dist/route-definition.d.ts +0 -421
  520. package/dist/route-definition.d.ts.map +0 -1
  521. package/dist/route-definition.js +0 -868
  522. package/dist/route-definition.js.map +0 -1
  523. package/dist/route-map-builder.d.ts +0 -155
  524. package/dist/route-map-builder.d.ts.map +0 -1
  525. package/dist/route-map-builder.js +0 -237
  526. package/dist/route-map-builder.js.map +0 -1
  527. package/dist/route-types.d.ts +0 -165
  528. package/dist/route-types.d.ts.map +0 -1
  529. package/dist/route-types.js +0 -7
  530. package/dist/route-types.js.map +0 -1
  531. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  532. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  533. package/dist/router/__tests__/handler-context.test.js +0 -65
  534. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  535. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  536. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  537. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  538. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  539. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  540. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  541. package/dist/router/__tests__/match-context.test.js +0 -92
  542. package/dist/router/__tests__/match-context.test.js.map +0 -1
  543. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  544. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  545. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  546. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  547. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  548. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  549. package/dist/router/__tests__/match-result.test.js +0 -457
  550. package/dist/router/__tests__/match-result.test.js.map +0 -1
  551. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  552. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  553. package/dist/router/__tests__/on-error.test.js +0 -678
  554. package/dist/router/__tests__/on-error.test.js.map +0 -1
  555. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  556. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  557. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  558. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  559. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  560. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  561. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  562. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  563. package/dist/router/error-handling.d.ts +0 -77
  564. package/dist/router/error-handling.d.ts.map +0 -1
  565. package/dist/router/error-handling.js +0 -202
  566. package/dist/router/error-handling.js.map +0 -1
  567. package/dist/router/handler-context.d.ts +0 -20
  568. package/dist/router/handler-context.d.ts.map +0 -1
  569. package/dist/router/handler-context.js +0 -198
  570. package/dist/router/handler-context.js.map +0 -1
  571. package/dist/router/intercept-resolution.d.ts +0 -66
  572. package/dist/router/intercept-resolution.d.ts.map +0 -1
  573. package/dist/router/intercept-resolution.js +0 -246
  574. package/dist/router/intercept-resolution.js.map +0 -1
  575. package/dist/router/loader-resolution.d.ts +0 -64
  576. package/dist/router/loader-resolution.d.ts.map +0 -1
  577. package/dist/router/loader-resolution.js +0 -284
  578. package/dist/router/loader-resolution.js.map +0 -1
  579. package/dist/router/logging.d.ts +0 -15
  580. package/dist/router/logging.d.ts.map +0 -1
  581. package/dist/router/logging.js +0 -99
  582. package/dist/router/logging.js.map +0 -1
  583. package/dist/router/manifest.d.ts +0 -22
  584. package/dist/router/manifest.d.ts.map +0 -1
  585. package/dist/router/manifest.js +0 -181
  586. package/dist/router/manifest.js.map +0 -1
  587. package/dist/router/match-api.d.ts +0 -35
  588. package/dist/router/match-api.d.ts.map +0 -1
  589. package/dist/router/match-api.js +0 -406
  590. package/dist/router/match-api.js.map +0 -1
  591. package/dist/router/match-context.d.ts +0 -206
  592. package/dist/router/match-context.d.ts.map +0 -1
  593. package/dist/router/match-context.js +0 -17
  594. package/dist/router/match-context.js.map +0 -1
  595. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  596. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  597. package/dist/router/match-middleware/background-revalidation.js +0 -75
  598. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  599. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  600. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  601. package/dist/router/match-middleware/cache-lookup.js +0 -257
  602. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  603. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  604. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  605. package/dist/router/match-middleware/cache-store.js +0 -108
  606. package/dist/router/match-middleware/cache-store.js.map +0 -1
  607. package/dist/router/match-middleware/index.d.ts +0 -81
  608. package/dist/router/match-middleware/index.d.ts.map +0 -1
  609. package/dist/router/match-middleware/index.js +0 -80
  610. package/dist/router/match-middleware/index.js.map +0 -1
  611. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  612. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  613. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  614. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  615. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  616. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  617. package/dist/router/match-middleware/segment-resolution.js +0 -53
  618. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  619. package/dist/router/match-pipelines.d.ts +0 -147
  620. package/dist/router/match-pipelines.d.ts.map +0 -1
  621. package/dist/router/match-pipelines.js +0 -82
  622. package/dist/router/match-pipelines.js.map +0 -1
  623. package/dist/router/match-result.d.ts +0 -126
  624. package/dist/router/match-result.d.ts.map +0 -1
  625. package/dist/router/match-result.js +0 -93
  626. package/dist/router/match-result.js.map +0 -1
  627. package/dist/router/metrics.d.ts +0 -20
  628. package/dist/router/metrics.d.ts.map +0 -1
  629. package/dist/router/metrics.js +0 -47
  630. package/dist/router/metrics.js.map +0 -1
  631. package/dist/router/middleware.d.ts +0 -249
  632. package/dist/router/middleware.d.ts.map +0 -1
  633. package/dist/router/middleware.js +0 -434
  634. package/dist/router/middleware.js.map +0 -1
  635. package/dist/router/middleware.test.d.ts +0 -2
  636. package/dist/router/middleware.test.d.ts.map +0 -1
  637. package/dist/router/middleware.test.js +0 -816
  638. package/dist/router/middleware.test.js.map +0 -1
  639. package/dist/router/pattern-matching.d.ts +0 -149
  640. package/dist/router/pattern-matching.d.ts.map +0 -1
  641. package/dist/router/pattern-matching.js +0 -349
  642. package/dist/router/pattern-matching.js.map +0 -1
  643. package/dist/router/revalidation.d.ts +0 -44
  644. package/dist/router/revalidation.d.ts.map +0 -1
  645. package/dist/router/revalidation.js +0 -147
  646. package/dist/router/revalidation.js.map +0 -1
  647. package/dist/router/router-context.d.ts +0 -135
  648. package/dist/router/router-context.d.ts.map +0 -1
  649. package/dist/router/router-context.js +0 -36
  650. package/dist/router/router-context.js.map +0 -1
  651. package/dist/router/segment-resolution.d.ts +0 -127
  652. package/dist/router/segment-resolution.d.ts.map +0 -1
  653. package/dist/router/segment-resolution.js +0 -919
  654. package/dist/router/segment-resolution.js.map +0 -1
  655. package/dist/router/trie-matching.d.ts +0 -40
  656. package/dist/router/trie-matching.d.ts.map +0 -1
  657. package/dist/router/trie-matching.js +0 -127
  658. package/dist/router/trie-matching.js.map +0 -1
  659. package/dist/router/types.d.ts +0 -136
  660. package/dist/router/types.d.ts.map +0 -1
  661. package/dist/router/types.js +0 -7
  662. package/dist/router/types.js.map +0 -1
  663. package/dist/router.d.ts +0 -753
  664. package/dist/router.d.ts.map +0 -1
  665. package/dist/router.gen.d.ts +0 -6
  666. package/dist/router.gen.d.ts.map +0 -1
  667. package/dist/router.gen.js +0 -6
  668. package/dist/router.gen.js.map +0 -1
  669. package/dist/router.js +0 -1304
  670. package/dist/router.js.map +0 -1
  671. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  672. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  673. package/dist/rsc/__tests__/helpers.test.js +0 -140
  674. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  675. package/dist/rsc/handler.d.ts +0 -45
  676. package/dist/rsc/handler.d.ts.map +0 -1
  677. package/dist/rsc/handler.js +0 -1172
  678. package/dist/rsc/handler.js.map +0 -1
  679. package/dist/rsc/helpers.d.ts +0 -16
  680. package/dist/rsc/helpers.d.ts.map +0 -1
  681. package/dist/rsc/helpers.js +0 -55
  682. package/dist/rsc/helpers.js.map +0 -1
  683. package/dist/rsc/index.d.ts +0 -22
  684. package/dist/rsc/index.d.ts.map +0 -1
  685. package/dist/rsc/index.js +0 -23
  686. package/dist/rsc/index.js.map +0 -1
  687. package/dist/rsc/nonce.d.ts +0 -9
  688. package/dist/rsc/nonce.d.ts.map +0 -1
  689. package/dist/rsc/nonce.js +0 -18
  690. package/dist/rsc/nonce.js.map +0 -1
  691. package/dist/rsc/types.d.ts +0 -206
  692. package/dist/rsc/types.d.ts.map +0 -1
  693. package/dist/rsc/types.js +0 -8
  694. package/dist/rsc/types.js.map +0 -1
  695. package/dist/search-params.d.ts +0 -103
  696. package/dist/search-params.d.ts.map +0 -1
  697. package/dist/search-params.js +0 -74
  698. package/dist/search-params.js.map +0 -1
  699. package/dist/segment-system.d.ts +0 -75
  700. package/dist/segment-system.d.ts.map +0 -1
  701. package/dist/segment-system.js +0 -336
  702. package/dist/segment-system.js.map +0 -1
  703. package/dist/server/context.d.ts +0 -245
  704. package/dist/server/context.d.ts.map +0 -1
  705. package/dist/server/context.js +0 -197
  706. package/dist/server/context.js.map +0 -1
  707. package/dist/server/fetchable-loader-store.d.ts +0 -18
  708. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  709. package/dist/server/fetchable-loader-store.js +0 -18
  710. package/dist/server/fetchable-loader-store.js.map +0 -1
  711. package/dist/server/handle-store.d.ts +0 -85
  712. package/dist/server/handle-store.d.ts.map +0 -1
  713. package/dist/server/handle-store.js +0 -142
  714. package/dist/server/handle-store.js.map +0 -1
  715. package/dist/server/loader-registry.d.ts +0 -55
  716. package/dist/server/loader-registry.d.ts.map +0 -1
  717. package/dist/server/loader-registry.js +0 -132
  718. package/dist/server/loader-registry.js.map +0 -1
  719. package/dist/server/request-context.d.ts +0 -226
  720. package/dist/server/request-context.d.ts.map +0 -1
  721. package/dist/server/request-context.js +0 -290
  722. package/dist/server/request-context.js.map +0 -1
  723. package/dist/server/root-layout.d.ts +0 -4
  724. package/dist/server/root-layout.d.ts.map +0 -1
  725. package/dist/server/root-layout.js +0 -5
  726. package/dist/server/root-layout.js.map +0 -1
  727. package/dist/server.d.ts +0 -15
  728. package/dist/server.d.ts.map +0 -1
  729. package/dist/server.js +0 -20
  730. package/dist/server.js.map +0 -1
  731. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  732. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  733. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  734. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  735. package/dist/ssr/index.d.ts +0 -98
  736. package/dist/ssr/index.d.ts.map +0 -1
  737. package/dist/ssr/index.js +0 -158
  738. package/dist/ssr/index.js.map +0 -1
  739. package/dist/static-handler.d.ts +0 -50
  740. package/dist/static-handler.d.ts.map +0 -1
  741. package/dist/static-handler.gen.d.ts +0 -5
  742. package/dist/static-handler.gen.d.ts.map +0 -1
  743. package/dist/static-handler.gen.js +0 -5
  744. package/dist/static-handler.gen.js.map +0 -1
  745. package/dist/static-handler.js +0 -29
  746. package/dist/static-handler.js.map +0 -1
  747. package/dist/theme/ThemeProvider.d.ts +0 -20
  748. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  749. package/dist/theme/ThemeProvider.js +0 -240
  750. package/dist/theme/ThemeProvider.js.map +0 -1
  751. package/dist/theme/ThemeScript.d.ts +0 -48
  752. package/dist/theme/ThemeScript.d.ts.map +0 -1
  753. package/dist/theme/ThemeScript.js +0 -13
  754. package/dist/theme/ThemeScript.js.map +0 -1
  755. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  756. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  757. package/dist/theme/__tests__/theme.test.js +0 -103
  758. package/dist/theme/__tests__/theme.test.js.map +0 -1
  759. package/dist/theme/constants.d.ts +0 -29
  760. package/dist/theme/constants.d.ts.map +0 -1
  761. package/dist/theme/constants.js +0 -48
  762. package/dist/theme/constants.js.map +0 -1
  763. package/dist/theme/index.d.ts +0 -31
  764. package/dist/theme/index.d.ts.map +0 -1
  765. package/dist/theme/index.js +0 -36
  766. package/dist/theme/index.js.map +0 -1
  767. package/dist/theme/theme-context.d.ts +0 -40
  768. package/dist/theme/theme-context.d.ts.map +0 -1
  769. package/dist/theme/theme-context.js +0 -60
  770. package/dist/theme/theme-context.js.map +0 -1
  771. package/dist/theme/theme-script.d.ts +0 -27
  772. package/dist/theme/theme-script.d.ts.map +0 -1
  773. package/dist/theme/theme-script.js +0 -147
  774. package/dist/theme/theme-script.js.map +0 -1
  775. package/dist/theme/types.d.ts +0 -163
  776. package/dist/theme/types.d.ts.map +0 -1
  777. package/dist/theme/types.js +0 -11
  778. package/dist/theme/types.js.map +0 -1
  779. package/dist/theme/use-theme.d.ts +0 -12
  780. package/dist/theme/use-theme.d.ts.map +0 -1
  781. package/dist/theme/use-theme.js +0 -40
  782. package/dist/theme/use-theme.js.map +0 -1
  783. package/dist/types.d.ts +0 -1479
  784. package/dist/types.d.ts.map +0 -1
  785. package/dist/types.js +0 -10
  786. package/dist/types.js.map +0 -1
  787. package/dist/urls.d.ts +0 -441
  788. package/dist/urls.d.ts.map +0 -1
  789. package/dist/urls.gen.d.ts +0 -8
  790. package/dist/urls.gen.d.ts.map +0 -1
  791. package/dist/urls.gen.js +0 -8
  792. package/dist/urls.gen.js.map +0 -1
  793. package/dist/urls.js +0 -443
  794. package/dist/urls.js.map +0 -1
  795. package/dist/use-loader.d.ts +0 -127
  796. package/dist/use-loader.d.ts.map +0 -1
  797. package/dist/use-loader.js +0 -237
  798. package/dist/use-loader.js.map +0 -1
  799. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  800. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  801. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  802. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  803. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  804. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  805. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  806. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  807. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  808. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  809. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  810. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  811. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  812. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  813. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  814. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  815. package/dist/vite/ast-handler-extract.d.ts +0 -49
  816. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  817. package/dist/vite/ast-handler-extract.js +0 -249
  818. package/dist/vite/ast-handler-extract.js.map +0 -1
  819. package/dist/vite/expose-action-id.d.ts +0 -19
  820. package/dist/vite/expose-action-id.d.ts.map +0 -1
  821. package/dist/vite/expose-action-id.js +0 -250
  822. package/dist/vite/expose-action-id.js.map +0 -1
  823. package/dist/vite/expose-id-utils.d.ts +0 -69
  824. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  825. package/dist/vite/expose-id-utils.js +0 -289
  826. package/dist/vite/expose-id-utils.js.map +0 -1
  827. package/dist/vite/expose-internal-ids.d.ts +0 -22
  828. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  829. package/dist/vite/expose-internal-ids.js +0 -886
  830. package/dist/vite/expose-internal-ids.js.map +0 -1
  831. package/dist/vite/index.d.ts +0 -149
  832. package/dist/vite/index.d.ts.map +0 -1
  833. package/dist/vite/index.js.bak +0 -5448
  834. package/dist/vite/index.js.map +0 -1
  835. package/dist/vite/index.named-routes.gen.ts +0 -103
  836. package/dist/vite/package-resolution.d.ts +0 -43
  837. package/dist/vite/package-resolution.d.ts.map +0 -1
  838. package/dist/vite/package-resolution.js +0 -112
  839. package/dist/vite/package-resolution.js.map +0 -1
  840. package/dist/vite/virtual-entries.d.ts +0 -25
  841. package/dist/vite/virtual-entries.d.ts.map +0 -1
  842. package/dist/vite/virtual-entries.js +0 -110
  843. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1,668 +0,0 @@
1
- var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
2
- if (value !== null && value !== void 0) {
3
- if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
4
- var dispose, inner;
5
- if (async) {
6
- if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
7
- dispose = value[Symbol.asyncDispose];
8
- }
9
- if (dispose === void 0) {
10
- if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
11
- dispose = value[Symbol.dispose];
12
- if (async) inner = dispose;
13
- }
14
- if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
15
- if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };
16
- env.stack.push({ value: value, dispose: dispose, async: async });
17
- }
18
- else if (async) {
19
- env.stack.push({ async: true });
20
- }
21
- return value;
22
- };
23
- var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
24
- return function (env) {
25
- function fail(e) {
26
- env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
27
- env.hasError = true;
28
- }
29
- var r, s = 0;
30
- function next() {
31
- while (r = env.stack.pop()) {
32
- try {
33
- if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);
34
- if (r.dispose) {
35
- var result = r.dispose.call(r.value);
36
- if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
37
- }
38
- else s |= 1;
39
- }
40
- catch (e) {
41
- fail(e);
42
- }
43
- }
44
- if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();
45
- if (env.hasError) throw env.error;
46
- }
47
- return next();
48
- };
49
- })(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
50
- var e = new Error(message);
51
- return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
52
- });
53
- import { createPartialUpdater } from "./partial-update.js";
54
- import { createNavigationTransaction } from "./navigation-bridge.js";
55
- import { mergeSegmentLoaders, needsLoaderMerge, } from "./merge-segment-loaders.js";
56
- import { assertSegmentStructure } from "./segment-structure-assert.js";
57
- import { startTransition, createElement } from "react";
58
- import { NetworkError, isNetworkError } from "../errors.js";
59
- import { NetworkErrorThrower } from "../network-error-thrower.js";
60
- import { browserDebugLog, isBrowserDebugEnabled, startBrowserTransaction, } from "./logging.js";
61
- // Polyfill Symbol.dispose/asyncDispose for Safari and older browsers
62
- if (typeof Symbol.dispose === "undefined") {
63
- Symbol.dispose = Symbol("Symbol.dispose");
64
- }
65
- if (typeof Symbol.asyncDispose === "undefined") {
66
- Symbol.asyncDispose = Symbol("Symbol.asyncDispose");
67
- }
68
- /**
69
- * Normalize action ID - returns the ID as-is
70
- *
71
- * Server actions have IDs like "hash#actionName" or "src/actions.ts#actionName".
72
- * The full ID is used for tracking in the event controller. When subscribing
73
- * via useAction, both exact matching (full ID) and suffix matching (action name
74
- * only) are supported by the event controller.
75
- */
76
- function normalizeActionId(actionId) {
77
- return actionId;
78
- }
79
- /**
80
- * Create a server action bridge for handling RSC server actions
81
- *
82
- * The bridge registers a callback with the RSC runtime that handles:
83
- * - Encoding action arguments
84
- * - Sending action requests to the server
85
- * - Processing responses and updating UI
86
- * - Managing concurrent action requests via event controller
87
- * - HMR resilience (refetching if segments are missing)
88
- *
89
- * @param config - Bridge configuration
90
- * @returns ServerActionBridge instance
91
- */
92
- export function createServerActionBridge(config) {
93
- const { store, client, eventController, deps, onUpdate, renderSegments, version } = config;
94
- let isRegistered = false;
95
- const fetchPartialUpdate = createPartialUpdater({
96
- store,
97
- client,
98
- onUpdate,
99
- renderSegments,
100
- version,
101
- });
102
- /**
103
- * Server action callback handler
104
- */
105
- async function handleServerAction(id, args) {
106
- const env_1 = { stack: [], error: void 0, hasError: false };
107
- try {
108
- const tx = isBrowserDebugEnabled()
109
- ? startBrowserTransaction("action")
110
- : null;
111
- // Normalize action ID to just the function name for store tracking
112
- const locationKey = window.history.state?.key;
113
- const actionId = normalizeActionId(id);
114
- if (tx) {
115
- browserDebugLog(tx, "action start", { id, actionId, argsCount: args.length });
116
- }
117
- // Start action in event controller - handles lifecycle tracking
118
- const handle = __addDisposableResource(env_1, eventController.startAction(actionId, args), false);
119
- const segmentState = store.getSegmentState();
120
- if (tx) {
121
- browserDebugLog(tx, "action args prepared");
122
- }
123
- // Mark cache as stale immediately when action starts
124
- // This ensures SWR pattern kicks in if user navigates away during action
125
- store.markCacheAsStaleAndBroadcast();
126
- // Create temporary references for serialization
127
- const temporaryReferences = deps.createTemporaryReferenceSet();
128
- // Capture URL pathname at action start to detect navigation during action
129
- // Must use window.location (not store.path) because intercepts change URL
130
- // without changing store.path (e.g., /kanban -> /kanban/card/1)
131
- const actionStartPathname = window.location.pathname;
132
- // Build action request URL with current segments
133
- const url = new URL(window.location.href);
134
- url.searchParams.set("_rsc_action", id);
135
- url.searchParams.set("_rsc_segments", segmentState.currentSegmentIds.join(","));
136
- // Add version param for version mismatch detection
137
- if (version) {
138
- url.searchParams.set("_rsc_v", version);
139
- }
140
- // Encode arguments
141
- const encodedBody = await deps.encodeReply(args, { temporaryReferences });
142
- if (tx) {
143
- browserDebugLog(tx, "sending action request", {
144
- url: url.href,
145
- bodyType: typeof encodedBody,
146
- isFormData: encodedBody instanceof FormData,
147
- segmentCount: segmentState.currentSegmentIds.length,
148
- });
149
- }
150
- // Track when the stream completes
151
- let resolveStreamComplete;
152
- const streamComplete = new Promise((resolve) => {
153
- resolveStreamComplete = resolve;
154
- });
155
- // Get intercept source URL if in intercept context
156
- const interceptSourceUrl = store.getInterceptSourceUrl();
157
- // Track streaming token - will be set when response arrives
158
- let streamingToken = null;
159
- // Send action request with stream tracking
160
- const responsePromise = fetch(url, {
161
- method: "POST",
162
- headers: {
163
- "rsc-action": id,
164
- "X-RSC-Router-Client-Path": segmentState.currentUrl,
165
- ...(tx && { "X-RSC-Router-Request-Id": tx.requestId }),
166
- // Send intercept source URL so server can maintain intercept context
167
- ...(interceptSourceUrl && {
168
- "X-RSC-Router-Intercept-Source": interceptSourceUrl,
169
- }),
170
- },
171
- body: encodedBody,
172
- }).then(async (response) => {
173
- // Check for version mismatch - server wants us to reload
174
- const reloadUrl = response.headers.get("X-RSC-Reload");
175
- if (reloadUrl) {
176
- if (tx) {
177
- browserDebugLog(tx, "version mismatch on action, reloading", { reloadUrl });
178
- }
179
- window.location.href = reloadUrl;
180
- // Return a never-resolving promise to prevent further processing
181
- return new Promise(() => { });
182
- }
183
- // Start streaming immediately when response arrives
184
- if (!handle.signal.aborted) {
185
- streamingToken = handle.startStreaming();
186
- }
187
- if (!response.body) {
188
- // No body means stream is already complete
189
- streamingToken?.end();
190
- resolveStreamComplete();
191
- return response;
192
- }
193
- // Tee the stream: one for RSC runtime, one for tracking completion
194
- const [rscStream, trackingStream] = response.body.tee();
195
- // Consume the tracking stream to detect when it closes
196
- (async () => {
197
- const reader = trackingStream.getReader();
198
- try {
199
- while (true) {
200
- const { done } = await reader.read();
201
- if (done)
202
- break;
203
- }
204
- }
205
- finally {
206
- reader.releaseLock();
207
- if (tx) {
208
- browserDebugLog(tx, "stream complete");
209
- }
210
- streamingToken?.end();
211
- resolveStreamComplete();
212
- }
213
- })().catch((error) => {
214
- console.error("[STREAMING] Error reading tracking stream:", error);
215
- streamingToken?.end();
216
- });
217
- // Return response with the RSC stream
218
- return new Response(rscStream, {
219
- headers: response.headers,
220
- status: response.status,
221
- statusText: response.statusText,
222
- });
223
- });
224
- // Deserialize response (MUST use same temporaryReferences)
225
- let payload;
226
- try {
227
- payload = await deps.createFromFetch(responsePromise, {
228
- temporaryReferences,
229
- });
230
- }
231
- catch (error) {
232
- // Clean up streaming token on error (may be null if fetch failed before .then() ran)
233
- // The token is assigned in .then() callback which runs before this catch block,
234
- // but TypeScript doesn't track cross-async assignments, so use type assertion
235
- streamingToken?.end();
236
- // resolveStreamComplete is assigned in the Promise constructor so it's safe to call
237
- resolveStreamComplete();
238
- // Convert network-level errors to NetworkError for proper handling
239
- if (isNetworkError(error)) {
240
- const networkError = new NetworkError("Unable to connect to server. Please check your connection.", {
241
- cause: error,
242
- url: url.toString(),
243
- operation: "action",
244
- });
245
- // Mark action as failed
246
- handle.fail(networkError);
247
- // Emit the network error so the root error boundary can catch it
248
- // NetworkErrorThrower throws during render to trigger the error boundary
249
- startTransition(() => {
250
- onUpdate({
251
- root: createElement(NetworkErrorThrower, { error: networkError }),
252
- metadata: {
253
- pathname: segmentState.currentUrl,
254
- segments: [],
255
- isError: true,
256
- },
257
- });
258
- });
259
- throw networkError;
260
- }
261
- throw error;
262
- }
263
- if (tx) {
264
- browserDebugLog(tx, "action response received", {
265
- isPartial: payload.metadata?.isPartial,
266
- isError: payload.metadata?.isError,
267
- matchedCount: payload.metadata?.matched?.length ?? 0,
268
- diffCount: payload.metadata?.diff?.length ?? 0,
269
- });
270
- }
271
- // Process response
272
- const { metadata, returnValue } = payload;
273
- const { matched, diff, segments, isPartial, isError } = metadata || {};
274
- // Log action result
275
- if (returnValue) {
276
- console.log(`[Browser] Action result:`, returnValue);
277
- if (!returnValue.ok) {
278
- console.error(`[Browser] Action failed:`, returnValue.data);
279
- }
280
- }
281
- // Handle error responses with error boundary UI
282
- if (isError && isPartial && segments && diff) {
283
- console.log(`[Browser] Processing error boundary response`);
284
- // Abort all other pending action requests - error takes precedence
285
- // This prevents other actions from completing and overwriting the error UI
286
- eventController.abortAllActions();
287
- // Clear concurrent action tracking - no consolidation needed when showing error
288
- handle.clearConsolidation();
289
- // Get current page's cached segments
290
- const currentKey = store.getHistoryKey();
291
- const cached = store.getCachedSegments(currentKey);
292
- const cachedSegments = cached?.segments || [];
293
- // Create lookup for error segment from server
294
- const errorSegmentMap = new Map();
295
- segments.forEach((s) => errorSegmentMap.set(s.id, s));
296
- // For error responses, use ALL cached segments but replace the errored one
297
- // This preserves sibling layouts that aren't in the parent chain
298
- const fullSegments = cachedSegments.map((cached) => {
299
- // Replace the error segment with the one from server
300
- const fromServer = errorSegmentMap.get(cached.id);
301
- if (fromServer)
302
- return fromServer;
303
- return cached;
304
- });
305
- // INTERCEPT HANDLING: Separate intercept segments for explicit injection
306
- const isInterceptSegment = (s) => s.namespace?.startsWith("intercept:") ||
307
- (s.type === "parallel" && s.id.includes(".@"));
308
- const interceptSegments = fullSegments.filter(isInterceptSegment);
309
- const mainSegments = fullSegments.filter((s) => !isInterceptSegment(s));
310
- // Render the full tree with error segment merged with parent layouts
311
- const errorRenderOptions = {
312
- isAction: true,
313
- interceptSegments: interceptSegments.length > 0 ? interceptSegments : undefined,
314
- };
315
- const errorTree = await renderSegments(mainSegments, errorRenderOptions);
316
- // Update UI with error boundary
317
- startTransition(() => {
318
- onUpdate({ root: errorTree, metadata: metadata });
319
- });
320
- console.log(`[Browser] Error boundary UI rendered`);
321
- // Update segment tracking to exclude error segment IDs
322
- const errorSegmentIds = new Set(diff);
323
- const segmentIdsAfterError = segmentState.currentSegmentIds.filter((id) => !errorSegmentIds.has(id));
324
- // Update store state
325
- store.setSegmentIds(segmentIdsAfterError);
326
- const currentHandleData = eventController.getHandleState().data;
327
- store.cacheSegmentsForHistory(currentKey, fullSegments, currentHandleData);
328
- console.log(`[Browser] Segment IDs updated (excluding error segments):`, segmentIdsAfterError);
329
- // Throw the error so the action promise rejects
330
- if (returnValue && !returnValue.ok) {
331
- handle.fail(returnValue.data);
332
- throw returnValue.data;
333
- }
334
- // No error in returnValue (shouldn't happen with isError: true)
335
- handle.complete(undefined);
336
- return undefined;
337
- }
338
- if (isPartial) {
339
- console.log(`[Browser] Processing partial update`);
340
- console.log(`[Browser] Server sent ${segments?.length || 0} segments in diff:`, diff);
341
- console.log(`[Browser] Server expects client to have:`, matched);
342
- // Record revalidated segments for concurrent action tracking
343
- if (diff) {
344
- handle.recordRevalidatedSegments(diff);
345
- }
346
- // Get current page's cached segments for merging
347
- const currentKey = store.getHistoryKey();
348
- const cached = store.getCachedSegments(currentKey);
349
- const cachedSegments = cached?.segments || [];
350
- const currentSegmentMap = new Map();
351
- cachedSegments.forEach((s) => currentSegmentMap.set(s.id, s));
352
- // Create lookup for new segments from server
353
- const newSegmentMap = new Map();
354
- (segments || []).forEach((s) => newSegmentMap.set(s.id, s));
355
- if (!matched) {
356
- throw new Error("No matched segments in response");
357
- }
358
- // Rebuild from matched: merge server segments with cached, or use cached as fallback
359
- const fullSegments = matched
360
- .map((segId) => {
361
- const fromServer = newSegmentMap.get(segId);
362
- const fromCache = currentSegmentMap.get(segId);
363
- if (fromServer) {
364
- // Server returned this segment - check if we need to merge partial loaders
365
- if (needsLoaderMerge(fromServer, fromCache)) {
366
- return mergeSegmentLoaders(fromServer, fromCache);
367
- }
368
- const cached = currentSegmentMap.get(segId); // Re-fetch to avoid type narrowing issues
369
- // Dev-mode assertion: warn if tree structure would change
370
- if (cached) {
371
- assertSegmentStructure(cached, fromServer, "action-bridge");
372
- }
373
- // Preserve cached structural properties to maintain consistent React tree.
374
- // Changing these between renders alters the element nesting
375
- // (with/without RouteContentWrapper, MountContextProvider, etc.),
376
- // causing React to remount components and destroy useActionState.
377
- if (cached) {
378
- let merged = fromServer;
379
- // When server returns component: null for a layout segment, it means
380
- // "this segment doesn't need re-rendering" - preserve the cached component
381
- // to maintain the outlet chain and prevent React tree changes
382
- if (fromServer.component === null &&
383
- fromServer.type === "layout" &&
384
- cached.component != null) {
385
- merged = { ...merged, component: cached.component };
386
- }
387
- // loading: SSR may set loading=false for skipSSR routes, but actions
388
- // resolve loading=<skeleton> (isSSR=false). Preserve cached value.
389
- if (cached.loading !== undefined &&
390
- fromServer.loading !== cached.loading) {
391
- merged = { ...merged, loading: cached.loading };
392
- }
393
- // mountPath: SSR segments may lack mountPath while action-revalidated
394
- // segments include it (from include() scope). The conditional
395
- // MountContextProvider wrapper in renderSegments changes tree depth.
396
- if (fromServer.mountPath !== cached.mountPath) {
397
- merged = { ...merged, mountPath: cached.mountPath };
398
- }
399
- return merged;
400
- }
401
- return fromServer;
402
- }
403
- // Fall back to current page's cached segments
404
- if (!fromCache) {
405
- console.error(`[Browser] MISSING SEGMENT: ${segId} not in cache!`);
406
- }
407
- return fromCache;
408
- })
409
- .filter(Boolean);
410
- const returnData = returnValue?.data;
411
- console.log(`[Browser] Action complete - UI updated (after action state committed)`);
412
- if (returnValue && !returnValue.ok) {
413
- handle.fail(returnValue.data);
414
- throw returnValue.data;
415
- }
416
- // Check if user navigated away during the action
417
- const currentPathname = window.location.pathname;
418
- const currentLocationKey = window.history.state?.key;
419
- const userNavigatedAway = currentPathname !== actionStartPathname ||
420
- currentLocationKey !== locationKey;
421
- if (userNavigatedAway) {
422
- const env_2 = { stack: [], error: void 0, hasError: false };
423
- try {
424
- console.log(`[Browser] User navigated away during action (${actionStartPathname} -> ${currentPathname})`);
425
- // Clear concurrent action tracking - don't consolidate for old route's segments
426
- handle.clearConsolidation();
427
- // Check if the history key changed (different cache entry)
428
- // This happens when navigating between intercept and non-intercept routes
429
- if (currentLocationKey !== locationKey) {
430
- console.log(`[Browser] History key changed (${locationKey} -> ${currentLocationKey}), triggering background revalidation`);
431
- // The action completed on the server, but the user navigated to a different route.
432
- // The navigation fetch may have gotten stale data (before action committed).
433
- // Trigger a background revalidation of the CURRENT route to get fresh data.
434
- // User navigated to a different history entry.
435
- // Check if we should do background revalidation:
436
- // - YES if user is on a non-intercept route (safe to revalidate)
437
- // - NO if user is on an intercept route (would lose background segments)
438
- const currentInterceptSource = store.getInterceptSourceUrl();
439
- if (currentInterceptSource) {
440
- // User is on an intercept route - skip revalidation to preserve background
441
- console.log(`[Browser] Skipping background revalidation - user on intercept route`);
442
- }
443
- else {
444
- // User is on a non-intercept route - safe to revalidate
445
- console.log(`[Browser] History key changed, triggering background revalidation`);
446
- store.markCacheAsStaleAndBroadcast();
447
- const navTx = createNavigationTransaction(store, eventController, window.location.href, { replace: true, skipLoadingState: true });
448
- fetchPartialUpdate(window.location.href, [], false, navTx.handle.signal, navTx.with({
449
- url: window.location.href,
450
- storeOnly: true,
451
- }), {
452
- isAction: true,
453
- }).then(() => {
454
- console.log(`[Browser] Background revalidation complete`);
455
- }).catch((error) => {
456
- if (error instanceof DOMException &&
457
- error.name === "AbortError") {
458
- console.log("[Browser] Background revalidation aborted");
459
- return;
460
- }
461
- if (error instanceof NetworkError || isNetworkError(error)) {
462
- console.warn("[Browser] Background revalidation network error (action):", error.message);
463
- return;
464
- }
465
- console.error("[Browser] Background revalidation failed:", error);
466
- }).finally(() => {
467
- navTx[Symbol.dispose]();
468
- });
469
- }
470
- handle.complete(returnData);
471
- return returnData;
472
- }
473
- // Same history key but different pathname (e.g., same-page navigation)
474
- // Safe to refetch current route
475
- console.log(`[Browser] Same history key, refetching current route`);
476
- store.markCacheAsStaleAndBroadcast();
477
- const navTx = __addDisposableResource(env_2, createNavigationTransaction(store, eventController, window.location.href, { replace: true, skipLoadingState: true }), false);
478
- // Preserve intercept context
479
- const currentInterceptSource = store.getInterceptSourceUrl();
480
- await fetchPartialUpdate(window.location.href, [], // Empty array = refetch all segments for current route
481
- false, navTx.handle.signal, navTx.with({
482
- url: window.location.href,
483
- storeOnly: true,
484
- intercept: !!currentInterceptSource,
485
- interceptSourceUrl: currentInterceptSource ?? undefined,
486
- }), {
487
- isAction: true,
488
- interceptSourceUrl: currentInterceptSource ?? undefined,
489
- });
490
- console.log(`[Browser] Refetch after navigation complete`);
491
- handle.complete(returnData);
492
- return returnData;
493
- }
494
- catch (e_1) {
495
- env_2.error = e_1;
496
- env_2.hasError = true;
497
- }
498
- finally {
499
- __disposeResources(env_2);
500
- }
501
- }
502
- // HMR resilience check - only runs if user DIDN'T navigate away
503
- if (fullSegments.length < matched.length) {
504
- const env_3 = { stack: [], error: void 0, hasError: false };
505
- try {
506
- console.warn(`[Browser] Missing segments after action (HMR detected), refetching...`);
507
- const navTx = __addDisposableResource(env_3, createNavigationTransaction(store, eventController, window.location.href, { replace: true, skipLoadingState: true }), false);
508
- await fetchPartialUpdate(window.location.href, [], false, navTx.handle.signal, navTx.with({
509
- url: window.location.href,
510
- storeOnly: true,
511
- intercept: !!interceptSourceUrl,
512
- interceptSourceUrl: interceptSourceUrl ?? undefined,
513
- }), {
514
- isAction: true,
515
- interceptSourceUrl: interceptSourceUrl ?? undefined,
516
- });
517
- console.log(`[Browser] Refetch complete (HMR), now returning action result`);
518
- // Broadcast to other tabs
519
- store.broadcastCacheInvalidation();
520
- handle.complete(returnData);
521
- return returnData;
522
- }
523
- catch (e_2) {
524
- env_3.error = e_2;
525
- env_3.hasError = true;
526
- }
527
- finally {
528
- __disposeResources(env_3);
529
- }
530
- }
531
- // Check if we need a consolidation fetch due to concurrent actions
532
- const consolidationSegments = handle.getConsolidationSegments();
533
- if (consolidationSegments && consolidationSegments.length > 0) {
534
- const env_4 = { stack: [], error: void 0, hasError: false };
535
- try {
536
- // This is the last concurrent action - do consolidation fetch
537
- console.log(`[Browser] Concurrent actions detected - consolidation fetch needed for:`, consolidationSegments);
538
- // Calculate segments to send (exclude the ones we want fresh)
539
- const currentSegmentIds = store.getSegmentState().currentSegmentIds;
540
- const segmentsToSend = currentSegmentIds.filter((id) => !consolidationSegments.includes(id));
541
- console.log(`[Browser] Sending segments (excluding revalidated):`, segmentsToSend);
542
- // Clear consolidation tracking before fetch
543
- handle.clearConsolidation();
544
- const navTx = __addDisposableResource(env_4, createNavigationTransaction(store, eventController, window.location.href, { replace: true, skipLoadingState: true }), false);
545
- console.warn("Fetch partial", id);
546
- await fetchPartialUpdate(window.location.href, segmentsToSend, false, navTx.handle.signal, navTx.with({
547
- url: window.location.href,
548
- storeOnly: true,
549
- intercept: !!interceptSourceUrl,
550
- interceptSourceUrl: interceptSourceUrl ?? undefined,
551
- }), {
552
- isAction: true,
553
- interceptSourceUrl: interceptSourceUrl ?? undefined,
554
- });
555
- console.log(`[Browser] Consolidation fetch complete`);
556
- // Broadcast to other tabs
557
- store.broadcastCacheInvalidation();
558
- console.log(`[Browser] Consolidate/Reconcile - Returning to React:`, returnData);
559
- handle.complete(returnData);
560
- return returnData;
561
- }
562
- catch (e_3) {
563
- env_4.error = e_3;
564
- env_4.hasError = true;
565
- }
566
- finally {
567
- __disposeResources(env_4);
568
- }
569
- }
570
- // Check if there are OTHER actions still fetching (waiting for server response)
571
- // Exclude the current action since we already have our response
572
- // We don't need to wait for streaming to complete - just for the response to arrive
573
- const otherFetchingActions = [...eventController.getInflightActions().values()].filter((a) => a.phase === "fetching" && a.id !== handle.id);
574
- if (otherFetchingActions.length > 0) {
575
- console.log(`[Browser] Skipping UI update - ${otherFetchingActions.length} other action(s) still fetching`);
576
- console.log(`[Browser] Multi actions - Returning to React (no cache clear):`, returnData);
577
- // Only update store if history key hasn't changed (user didn't navigate away)
578
- const currentKeyNow = store.getHistoryKey();
579
- if (currentKeyNow === currentKey) {
580
- store.setSegmentIds(matched);
581
- const currentHandleData = eventController.getHandleState().data;
582
- store.cacheSegmentsForHistory(currentKey, fullSegments, currentHandleData);
583
- }
584
- else {
585
- console.log(`[Browser] History key changed during multi-action (${currentKey} -> ${currentKeyNow}), skipping cache update`);
586
- }
587
- handle.complete(returnData);
588
- return returnData;
589
- }
590
- // No concurrent actions - normal flow with single action
591
- // INTERCEPT HANDLING: Separate intercept segments for explicit injection
592
- const isInterceptSegment = (s) => s.namespace?.startsWith("intercept:") ||
593
- (s.type === "parallel" && s.id.includes(".@"));
594
- const interceptSegments = fullSegments.filter(isInterceptSegment);
595
- const mainSegments = fullSegments.filter((s) => !isInterceptSegment(s));
596
- // Prepare new tree (await loader data resolution)
597
- const renderOptions = {
598
- isAction: true,
599
- interceptSegments: interceptSegments.length > 0 ? interceptSegments : undefined,
600
- };
601
- const newTree = await renderSegments(mainSegments, renderOptions);
602
- // Re-check if user navigated away (could happen during async wait)
603
- const currentPathnameNow = window.location.pathname;
604
- if (currentPathnameNow !== actionStartPathname) {
605
- console.log(`[Browser] User navigated during UI update scheduling, skipping`);
606
- handle.complete(returnData);
607
- return returnData;
608
- }
609
- // Verify the store's current key still matches what we captured at action start
610
- // If they differ, user navigated away and we should NOT cache under the old key
611
- const currentKeyNow = store.getHistoryKey();
612
- if (currentKeyNow !== currentKey) {
613
- console.log(`[Browser] History key changed during action (${currentKey} -> ${currentKeyNow}), skipping cache update`);
614
- handle.complete(returnData);
615
- return returnData;
616
- }
617
- startTransition(() => {
618
- onUpdate({ root: newTree, metadata: metadata });
619
- });
620
- // Update store state
621
- store.setSegmentIds(matched);
622
- const currentHandleData = eventController.getHandleState().data;
623
- store.cacheSegmentsForHistory(currentKey, fullSegments, currentHandleData);
624
- store.markCacheAsStaleAndBroadcast();
625
- console.log(`[Browser] Normal - Returning to React:`, returnData);
626
- handle.complete(returnData);
627
- return returnData;
628
- }
629
- else {
630
- // Full update not supported for actions
631
- throw new Error(`[Browser] Full update after action is not supported yet`);
632
- }
633
- }
634
- catch (e_4) {
635
- env_1.error = e_4;
636
- env_1.hasError = true;
637
- }
638
- finally {
639
- __disposeResources(env_1);
640
- }
641
- }
642
- return {
643
- /**
644
- * Register the server action callback with the RSC runtime
645
- */
646
- register() {
647
- if (isRegistered) {
648
- console.warn("[Browser] Server action bridge already registered");
649
- return;
650
- }
651
- deps.setServerCallback(handleServerAction);
652
- isRegistered = true;
653
- console.log("[Browser] Server action callback registered");
654
- },
655
- /**
656
- * Unregister the server action callback
657
- */
658
- unregister() {
659
- if (!isRegistered) {
660
- return;
661
- }
662
- isRegistered = false;
663
- console.log("[Browser] Server action bridge unregistered");
664
- },
665
- };
666
- }
667
- export { createServerActionBridge as default };
668
- //# sourceMappingURL=server-action-bridge.js.map