@rangojs/router 0.0.0-experimental.42 → 0.0.0-experimental.44

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 (835) hide show
  1. package/dist/bin/rango.js +8 -3
  2. package/dist/vite/index.js +136 -197
  3. package/package.json +1 -1
  4. package/skills/caching/SKILL.md +37 -4
  5. package/src/browser/event-controller.ts +5 -0
  6. package/src/browser/navigation-bridge.ts +1 -11
  7. package/src/browser/navigation-client.ts +70 -24
  8. package/src/browser/navigation-transaction.ts +11 -9
  9. package/src/browser/partial-update.ts +39 -9
  10. package/src/browser/prefetch/cache.ts +54 -2
  11. package/src/browser/prefetch/fetch.ts +22 -12
  12. package/src/browser/prefetch/queue.ts +53 -13
  13. package/src/browser/react/Link.tsx +9 -1
  14. package/src/browser/react/NavigationProvider.tsx +27 -0
  15. package/src/browser/rsc-router.tsx +109 -57
  16. package/src/browser/scroll-restoration.ts +20 -11
  17. package/src/browser/types.ts +9 -0
  18. package/src/build/route-types/router-processing.ts +12 -2
  19. package/src/cache/cache-scope.ts +2 -2
  20. package/src/cache/cf/cf-cache-store.ts +453 -11
  21. package/src/cache/cf/index.ts +5 -1
  22. package/src/cache/index.ts +1 -0
  23. package/src/route-definition/redirect.ts +2 -2
  24. package/src/router/middleware.ts +2 -1
  25. package/src/server/request-context.ts +10 -4
  26. package/src/ssr/index.tsx +1 -0
  27. package/src/vite/discovery/state.ts +0 -2
  28. package/src/vite/plugin-types.ts +0 -83
  29. package/src/vite/plugins/expose-action-id.ts +1 -3
  30. package/src/vite/plugins/version-plugin.ts +13 -1
  31. package/src/vite/rango.ts +144 -209
  32. package/src/vite/router-discovery.ts +0 -8
  33. package/dist/__internal.d.ts +0 -83
  34. package/dist/__internal.d.ts.map +0 -1
  35. package/dist/__internal.js +0 -19
  36. package/dist/__internal.js.map +0 -1
  37. package/dist/__mocks__/version.d.ts +0 -7
  38. package/dist/__mocks__/version.d.ts.map +0 -1
  39. package/dist/__mocks__/version.js +0 -7
  40. package/dist/__mocks__/version.js.map +0 -1
  41. package/dist/__tests__/client-href.test.d.ts +0 -2
  42. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  43. package/dist/__tests__/client-href.test.js +0 -74
  44. package/dist/__tests__/client-href.test.js.map +0 -1
  45. package/dist/__tests__/component-utils.test.d.ts +0 -2
  46. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  47. package/dist/__tests__/component-utils.test.js +0 -51
  48. package/dist/__tests__/component-utils.test.js.map +0 -1
  49. package/dist/__tests__/event-controller.test.d.ts +0 -2
  50. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  51. package/dist/__tests__/event-controller.test.js +0 -538
  52. package/dist/__tests__/event-controller.test.js.map +0 -1
  53. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  54. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  55. package/dist/__tests__/helpers/route-tree.js +0 -374
  56. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  57. package/dist/__tests__/match-result.test.d.ts +0 -2
  58. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  59. package/dist/__tests__/match-result.test.js +0 -154
  60. package/dist/__tests__/match-result.test.js.map +0 -1
  61. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  62. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  63. package/dist/__tests__/navigation-store.test.js +0 -440
  64. package/dist/__tests__/navigation-store.test.js.map +0 -1
  65. package/dist/__tests__/partial-update.test.d.ts +0 -2
  66. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  67. package/dist/__tests__/partial-update.test.js +0 -1009
  68. package/dist/__tests__/partial-update.test.js.map +0 -1
  69. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  70. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  71. package/dist/__tests__/reverse-types.test.js +0 -656
  72. package/dist/__tests__/reverse-types.test.js.map +0 -1
  73. package/dist/__tests__/route-definition.test.d.ts +0 -2
  74. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  75. package/dist/__tests__/route-definition.test.js +0 -55
  76. package/dist/__tests__/route-definition.test.js.map +0 -1
  77. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  78. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  79. package/dist/__tests__/router-helpers.test.js +0 -377
  80. package/dist/__tests__/router-helpers.test.js.map +0 -1
  81. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  82. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  83. package/dist/__tests__/router-integration-2.test.js +0 -426
  84. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  85. package/dist/__tests__/router-integration.test.d.ts +0 -2
  86. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  87. package/dist/__tests__/router-integration.test.js +0 -1051
  88. package/dist/__tests__/router-integration.test.js.map +0 -1
  89. package/dist/__tests__/search-params.test.d.ts +0 -5
  90. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  91. package/dist/__tests__/search-params.test.js +0 -306
  92. package/dist/__tests__/search-params.test.js.map +0 -1
  93. package/dist/__tests__/segment-system.test.d.ts +0 -2
  94. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  95. package/dist/__tests__/segment-system.test.js +0 -627
  96. package/dist/__tests__/segment-system.test.js.map +0 -1
  97. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  98. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  99. package/dist/__tests__/static-handler-types.test.js +0 -63
  100. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  101. package/dist/__tests__/urls.test.d.ts +0 -2
  102. package/dist/__tests__/urls.test.d.ts.map +0 -1
  103. package/dist/__tests__/urls.test.js +0 -421
  104. package/dist/__tests__/urls.test.js.map +0 -1
  105. package/dist/__tests__/use-mount.test.d.ts +0 -2
  106. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  107. package/dist/__tests__/use-mount.test.js +0 -35
  108. package/dist/__tests__/use-mount.test.js.map +0 -1
  109. package/dist/bin/rango.d.ts +0 -2
  110. package/dist/bin/rango.d.ts.map +0 -1
  111. package/dist/bin/rango.js.map +0 -1
  112. package/dist/browser/event-controller.d.ts +0 -191
  113. package/dist/browser/event-controller.d.ts.map +0 -1
  114. package/dist/browser/event-controller.js +0 -559
  115. package/dist/browser/event-controller.js.map +0 -1
  116. package/dist/browser/index.d.ts +0 -2
  117. package/dist/browser/index.d.ts.map +0 -1
  118. package/dist/browser/index.js +0 -14
  119. package/dist/browser/index.js.map +0 -1
  120. package/dist/browser/link-interceptor.d.ts +0 -38
  121. package/dist/browser/link-interceptor.d.ts.map +0 -1
  122. package/dist/browser/link-interceptor.js +0 -99
  123. package/dist/browser/link-interceptor.js.map +0 -1
  124. package/dist/browser/logging.d.ts +0 -10
  125. package/dist/browser/logging.d.ts.map +0 -1
  126. package/dist/browser/logging.js +0 -29
  127. package/dist/browser/logging.js.map +0 -1
  128. package/dist/browser/lru-cache.d.ts +0 -17
  129. package/dist/browser/lru-cache.d.ts.map +0 -1
  130. package/dist/browser/lru-cache.js +0 -50
  131. package/dist/browser/lru-cache.js.map +0 -1
  132. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  133. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  134. package/dist/browser/merge-segment-loaders.js +0 -102
  135. package/dist/browser/merge-segment-loaders.js.map +0 -1
  136. package/dist/browser/navigation-bridge.d.ts +0 -102
  137. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  138. package/dist/browser/navigation-bridge.js +0 -708
  139. package/dist/browser/navigation-bridge.js.map +0 -1
  140. package/dist/browser/navigation-client.d.ts +0 -25
  141. package/dist/browser/navigation-client.d.ts.map +0 -1
  142. package/dist/browser/navigation-client.js +0 -157
  143. package/dist/browser/navigation-client.js.map +0 -1
  144. package/dist/browser/navigation-store.d.ts +0 -101
  145. package/dist/browser/navigation-store.d.ts.map +0 -1
  146. package/dist/browser/navigation-store.js +0 -625
  147. package/dist/browser/navigation-store.js.map +0 -1
  148. package/dist/browser/partial-update.d.ts +0 -75
  149. package/dist/browser/partial-update.d.ts.map +0 -1
  150. package/dist/browser/partial-update.js +0 -426
  151. package/dist/browser/partial-update.js.map +0 -1
  152. package/dist/browser/react/Link.d.ts +0 -86
  153. package/dist/browser/react/Link.d.ts.map +0 -1
  154. package/dist/browser/react/Link.js +0 -128
  155. package/dist/browser/react/Link.js.map +0 -1
  156. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  157. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  158. package/dist/browser/react/NavigationProvider.js +0 -216
  159. package/dist/browser/react/NavigationProvider.js.map +0 -1
  160. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  161. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  162. package/dist/browser/react/ScrollRestoration.js +0 -57
  163. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  164. package/dist/browser/react/context.d.ts +0 -46
  165. package/dist/browser/react/context.d.ts.map +0 -1
  166. package/dist/browser/react/context.js +0 -10
  167. package/dist/browser/react/context.js.map +0 -1
  168. package/dist/browser/react/index.d.ts +0 -11
  169. package/dist/browser/react/index.d.ts.map +0 -1
  170. package/dist/browser/react/index.js +0 -22
  171. package/dist/browser/react/index.js.map +0 -1
  172. package/dist/browser/react/location-state-shared.d.ts +0 -63
  173. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  174. package/dist/browser/react/location-state-shared.js +0 -81
  175. package/dist/browser/react/location-state-shared.js.map +0 -1
  176. package/dist/browser/react/location-state.d.ts +0 -23
  177. package/dist/browser/react/location-state.d.ts.map +0 -1
  178. package/dist/browser/react/location-state.js +0 -29
  179. package/dist/browser/react/location-state.js.map +0 -1
  180. package/dist/browser/react/mount-context.d.ts +0 -24
  181. package/dist/browser/react/mount-context.d.ts.map +0 -1
  182. package/dist/browser/react/mount-context.js +0 -24
  183. package/dist/browser/react/mount-context.js.map +0 -1
  184. package/dist/browser/react/use-action.d.ts +0 -64
  185. package/dist/browser/react/use-action.d.ts.map +0 -1
  186. package/dist/browser/react/use-action.js +0 -134
  187. package/dist/browser/react/use-action.js.map +0 -1
  188. package/dist/browser/react/use-client-cache.d.ts +0 -41
  189. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  190. package/dist/browser/react/use-client-cache.js +0 -39
  191. package/dist/browser/react/use-client-cache.js.map +0 -1
  192. package/dist/browser/react/use-handle.d.ts +0 -31
  193. package/dist/browser/react/use-handle.d.ts.map +0 -1
  194. package/dist/browser/react/use-handle.js +0 -144
  195. package/dist/browser/react/use-handle.js.map +0 -1
  196. package/dist/browser/react/use-href.d.ts +0 -33
  197. package/dist/browser/react/use-href.d.ts.map +0 -1
  198. package/dist/browser/react/use-href.js +0 -39
  199. package/dist/browser/react/use-href.js.map +0 -1
  200. package/dist/browser/react/use-link-status.d.ts +0 -37
  201. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  202. package/dist/browser/react/use-link-status.js +0 -99
  203. package/dist/browser/react/use-link-status.js.map +0 -1
  204. package/dist/browser/react/use-mount.d.ts +0 -25
  205. package/dist/browser/react/use-mount.d.ts.map +0 -1
  206. package/dist/browser/react/use-mount.js +0 -30
  207. package/dist/browser/react/use-mount.js.map +0 -1
  208. package/dist/browser/react/use-navigation.d.ts +0 -27
  209. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  210. package/dist/browser/react/use-navigation.js +0 -87
  211. package/dist/browser/react/use-navigation.js.map +0 -1
  212. package/dist/browser/react/use-segments.d.ts +0 -38
  213. package/dist/browser/react/use-segments.d.ts.map +0 -1
  214. package/dist/browser/react/use-segments.js +0 -130
  215. package/dist/browser/react/use-segments.js.map +0 -1
  216. package/dist/browser/request-controller.d.ts +0 -26
  217. package/dist/browser/request-controller.d.ts.map +0 -1
  218. package/dist/browser/request-controller.js +0 -147
  219. package/dist/browser/request-controller.js.map +0 -1
  220. package/dist/browser/rsc-router.d.ts +0 -129
  221. package/dist/browser/rsc-router.d.ts.map +0 -1
  222. package/dist/browser/rsc-router.js +0 -195
  223. package/dist/browser/rsc-router.js.map +0 -1
  224. package/dist/browser/scroll-restoration.d.ts +0 -93
  225. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  226. package/dist/browser/scroll-restoration.js +0 -321
  227. package/dist/browser/scroll-restoration.js.map +0 -1
  228. package/dist/browser/segment-structure-assert.d.ts +0 -17
  229. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  230. package/dist/browser/segment-structure-assert.js +0 -59
  231. package/dist/browser/segment-structure-assert.js.map +0 -1
  232. package/dist/browser/server-action-bridge.d.ts +0 -26
  233. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  234. package/dist/browser/server-action-bridge.js +0 -668
  235. package/dist/browser/server-action-bridge.js.map +0 -1
  236. package/dist/browser/shallow.d.ts +0 -12
  237. package/dist/browser/shallow.d.ts.map +0 -1
  238. package/dist/browser/shallow.js +0 -34
  239. package/dist/browser/shallow.js.map +0 -1
  240. package/dist/browser/types.d.ts +0 -369
  241. package/dist/browser/types.d.ts.map +0 -1
  242. package/dist/browser/types.js +0 -2
  243. package/dist/browser/types.js.map +0 -1
  244. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  245. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  246. package/dist/build/__tests__/generate-cli.test.js +0 -237
  247. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  248. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  249. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  250. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  251. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  252. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  253. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  254. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  255. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  256. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  257. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  258. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  259. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  260. package/dist/build/generate-manifest.d.ts +0 -81
  261. package/dist/build/generate-manifest.d.ts.map +0 -1
  262. package/dist/build/generate-manifest.js +0 -276
  263. package/dist/build/generate-manifest.js.map +0 -1
  264. package/dist/build/generate-route-types.d.ts +0 -115
  265. package/dist/build/generate-route-types.d.ts.map +0 -1
  266. package/dist/build/generate-route-types.js +0 -740
  267. package/dist/build/generate-route-types.js.map +0 -1
  268. package/dist/build/index.d.ts +0 -21
  269. package/dist/build/index.d.ts.map +0 -1
  270. package/dist/build/index.js +0 -21
  271. package/dist/build/index.js.map +0 -1
  272. package/dist/build/route-trie.d.ts +0 -71
  273. package/dist/build/route-trie.d.ts.map +0 -1
  274. package/dist/build/route-trie.js +0 -175
  275. package/dist/build/route-trie.js.map +0 -1
  276. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  277. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  278. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  279. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  280. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  281. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  282. package/dist/cache/__tests__/document-cache.test.js +0 -345
  283. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  284. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  285. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  286. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  287. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  288. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  289. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  290. package/dist/cache/__tests__/memory-store.test.js +0 -367
  291. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  292. package/dist/cache/cache-scope.d.ts +0 -102
  293. package/dist/cache/cache-scope.d.ts.map +0 -1
  294. package/dist/cache/cache-scope.js +0 -440
  295. package/dist/cache/cache-scope.js.map +0 -1
  296. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  297. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  298. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  299. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  300. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  301. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  302. package/dist/cache/cf/cf-cache-store.js +0 -242
  303. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  304. package/dist/cache/cf/index.d.ts +0 -14
  305. package/dist/cache/cf/index.d.ts.map +0 -1
  306. package/dist/cache/cf/index.js +0 -17
  307. package/dist/cache/cf/index.js.map +0 -1
  308. package/dist/cache/document-cache.d.ts +0 -64
  309. package/dist/cache/document-cache.d.ts.map +0 -1
  310. package/dist/cache/document-cache.js +0 -228
  311. package/dist/cache/document-cache.js.map +0 -1
  312. package/dist/cache/index.d.ts +0 -19
  313. package/dist/cache/index.d.ts.map +0 -1
  314. package/dist/cache/index.js +0 -21
  315. package/dist/cache/index.js.map +0 -1
  316. package/dist/cache/memory-segment-store.d.ts +0 -110
  317. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  318. package/dist/cache/memory-segment-store.js +0 -117
  319. package/dist/cache/memory-segment-store.js.map +0 -1
  320. package/dist/cache/memory-store.d.ts +0 -41
  321. package/dist/cache/memory-store.d.ts.map +0 -1
  322. package/dist/cache/memory-store.js +0 -191
  323. package/dist/cache/memory-store.js.map +0 -1
  324. package/dist/cache/types.d.ts +0 -317
  325. package/dist/cache/types.d.ts.map +0 -1
  326. package/dist/cache/types.js +0 -12
  327. package/dist/cache/types.js.map +0 -1
  328. package/dist/client.d.ts +0 -248
  329. package/dist/client.d.ts.map +0 -1
  330. package/dist/client.js +0 -367
  331. package/dist/client.js.map +0 -1
  332. package/dist/client.rsc.d.ts +0 -26
  333. package/dist/client.rsc.d.ts.map +0 -1
  334. package/dist/client.rsc.js +0 -46
  335. package/dist/client.rsc.js.map +0 -1
  336. package/dist/component-utils.d.ts +0 -36
  337. package/dist/component-utils.d.ts.map +0 -1
  338. package/dist/component-utils.js +0 -61
  339. package/dist/component-utils.js.map +0 -1
  340. package/dist/components/DefaultDocument.d.ts +0 -13
  341. package/dist/components/DefaultDocument.d.ts.map +0 -1
  342. package/dist/components/DefaultDocument.js +0 -15
  343. package/dist/components/DefaultDocument.js.map +0 -1
  344. package/dist/debug.d.ts +0 -58
  345. package/dist/debug.d.ts.map +0 -1
  346. package/dist/debug.js +0 -157
  347. package/dist/debug.js.map +0 -1
  348. package/dist/default-error-boundary.d.ts +0 -11
  349. package/dist/default-error-boundary.d.ts.map +0 -1
  350. package/dist/default-error-boundary.js +0 -45
  351. package/dist/default-error-boundary.js.map +0 -1
  352. package/dist/deps/browser.d.ts +0 -2
  353. package/dist/deps/browser.d.ts.map +0 -1
  354. package/dist/deps/browser.js +0 -3
  355. package/dist/deps/browser.js.map +0 -1
  356. package/dist/deps/html-stream-client.d.ts +0 -2
  357. package/dist/deps/html-stream-client.d.ts.map +0 -1
  358. package/dist/deps/html-stream-client.js +0 -3
  359. package/dist/deps/html-stream-client.js.map +0 -1
  360. package/dist/deps/html-stream-server.d.ts +0 -2
  361. package/dist/deps/html-stream-server.d.ts.map +0 -1
  362. package/dist/deps/html-stream-server.js +0 -3
  363. package/dist/deps/html-stream-server.js.map +0 -1
  364. package/dist/deps/rsc.d.ts +0 -2
  365. package/dist/deps/rsc.d.ts.map +0 -1
  366. package/dist/deps/rsc.js +0 -4
  367. package/dist/deps/rsc.js.map +0 -1
  368. package/dist/deps/ssr.d.ts +0 -2
  369. package/dist/deps/ssr.d.ts.map +0 -1
  370. package/dist/deps/ssr.js +0 -3
  371. package/dist/deps/ssr.js.map +0 -1
  372. package/dist/errors.d.ts +0 -174
  373. package/dist/errors.d.ts.map +0 -1
  374. package/dist/errors.js +0 -241
  375. package/dist/errors.js.map +0 -1
  376. package/dist/handle.d.ts +0 -78
  377. package/dist/handle.d.ts.map +0 -1
  378. package/dist/handle.js +0 -82
  379. package/dist/handle.js.map +0 -1
  380. package/dist/handles/MetaTags.d.ts +0 -14
  381. package/dist/handles/MetaTags.d.ts.map +0 -1
  382. package/dist/handles/MetaTags.js +0 -136
  383. package/dist/handles/MetaTags.js.map +0 -1
  384. package/dist/handles/index.d.ts +0 -6
  385. package/dist/handles/index.d.ts.map +0 -1
  386. package/dist/handles/index.js +0 -6
  387. package/dist/handles/index.js.map +0 -1
  388. package/dist/handles/meta.d.ts +0 -39
  389. package/dist/handles/meta.d.ts.map +0 -1
  390. package/dist/handles/meta.js +0 -202
  391. package/dist/handles/meta.js.map +0 -1
  392. package/dist/host/__tests__/errors.test.d.ts +0 -2
  393. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  394. package/dist/host/__tests__/errors.test.js +0 -76
  395. package/dist/host/__tests__/errors.test.js.map +0 -1
  396. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  397. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  398. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  399. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  400. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  401. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  402. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  403. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  404. package/dist/host/__tests__/router.test.d.ts +0 -2
  405. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  406. package/dist/host/__tests__/router.test.js +0 -241
  407. package/dist/host/__tests__/router.test.js.map +0 -1
  408. package/dist/host/__tests__/testing.test.d.ts +0 -2
  409. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  410. package/dist/host/__tests__/testing.test.js +0 -64
  411. package/dist/host/__tests__/testing.test.js.map +0 -1
  412. package/dist/host/__tests__/utils.test.d.ts +0 -2
  413. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  414. package/dist/host/__tests__/utils.test.js +0 -29
  415. package/dist/host/__tests__/utils.test.js.map +0 -1
  416. package/dist/host/cookie-handler.d.ts +0 -34
  417. package/dist/host/cookie-handler.d.ts.map +0 -1
  418. package/dist/host/cookie-handler.js +0 -124
  419. package/dist/host/cookie-handler.js.map +0 -1
  420. package/dist/host/errors.d.ts +0 -56
  421. package/dist/host/errors.d.ts.map +0 -1
  422. package/dist/host/errors.js +0 -79
  423. package/dist/host/errors.js.map +0 -1
  424. package/dist/host/index.d.ts +0 -29
  425. package/dist/host/index.d.ts.map +0 -1
  426. package/dist/host/index.js +0 -32
  427. package/dist/host/index.js.map +0 -1
  428. package/dist/host/pattern-matcher.d.ts +0 -36
  429. package/dist/host/pattern-matcher.d.ts.map +0 -1
  430. package/dist/host/pattern-matcher.js +0 -172
  431. package/dist/host/pattern-matcher.js.map +0 -1
  432. package/dist/host/router.d.ts +0 -26
  433. package/dist/host/router.d.ts.map +0 -1
  434. package/dist/host/router.js +0 -218
  435. package/dist/host/router.js.map +0 -1
  436. package/dist/host/testing.d.ts +0 -36
  437. package/dist/host/testing.d.ts.map +0 -1
  438. package/dist/host/testing.js +0 -55
  439. package/dist/host/testing.js.map +0 -1
  440. package/dist/host/types.d.ts +0 -115
  441. package/dist/host/types.d.ts.map +0 -1
  442. package/dist/host/types.js +0 -7
  443. package/dist/host/types.js.map +0 -1
  444. package/dist/host/utils.d.ts +0 -21
  445. package/dist/host/utils.d.ts.map +0 -1
  446. package/dist/host/utils.js +0 -23
  447. package/dist/host/utils.js.map +0 -1
  448. package/dist/href-client.d.ts +0 -131
  449. package/dist/href-client.d.ts.map +0 -1
  450. package/dist/href-client.js +0 -64
  451. package/dist/href-client.js.map +0 -1
  452. package/dist/href-context.d.ts +0 -29
  453. package/dist/href-context.d.ts.map +0 -1
  454. package/dist/href-context.js +0 -21
  455. package/dist/href-context.js.map +0 -1
  456. package/dist/index.d.ts +0 -73
  457. package/dist/index.d.ts.map +0 -1
  458. package/dist/index.js +0 -91
  459. package/dist/index.js.map +0 -1
  460. package/dist/index.rsc.d.ts +0 -32
  461. package/dist/index.rsc.d.ts.map +0 -1
  462. package/dist/index.rsc.js +0 -40
  463. package/dist/index.rsc.js.map +0 -1
  464. package/dist/internal-debug.d.ts +0 -2
  465. package/dist/internal-debug.d.ts.map +0 -1
  466. package/dist/internal-debug.js +0 -5
  467. package/dist/internal-debug.js.map +0 -1
  468. package/dist/loader.d.ts +0 -14
  469. package/dist/loader.d.ts.map +0 -1
  470. package/dist/loader.js +0 -20
  471. package/dist/loader.js.map +0 -1
  472. package/dist/loader.rsc.d.ts +0 -19
  473. package/dist/loader.rsc.d.ts.map +0 -1
  474. package/dist/loader.rsc.js +0 -99
  475. package/dist/loader.rsc.js.map +0 -1
  476. package/dist/network-error-thrower.d.ts +0 -17
  477. package/dist/network-error-thrower.d.ts.map +0 -1
  478. package/dist/network-error-thrower.js +0 -14
  479. package/dist/network-error-thrower.js.map +0 -1
  480. package/dist/outlet-context.d.ts +0 -13
  481. package/dist/outlet-context.d.ts.map +0 -1
  482. package/dist/outlet-context.js +0 -3
  483. package/dist/outlet-context.js.map +0 -1
  484. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  485. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  486. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  487. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  488. package/dist/prerender/param-hash.d.ts +0 -16
  489. package/dist/prerender/param-hash.d.ts.map +0 -1
  490. package/dist/prerender/param-hash.js +0 -36
  491. package/dist/prerender/param-hash.js.map +0 -1
  492. package/dist/prerender/store.d.ts +0 -38
  493. package/dist/prerender/store.d.ts.map +0 -1
  494. package/dist/prerender/store.js +0 -61
  495. package/dist/prerender/store.js.map +0 -1
  496. package/dist/prerender.d.ts +0 -66
  497. package/dist/prerender.d.ts.map +0 -1
  498. package/dist/prerender.js +0 -57
  499. package/dist/prerender.js.map +0 -1
  500. package/dist/reverse.d.ts +0 -196
  501. package/dist/reverse.d.ts.map +0 -1
  502. package/dist/reverse.js +0 -78
  503. package/dist/reverse.js.map +0 -1
  504. package/dist/root-error-boundary.d.ts +0 -33
  505. package/dist/root-error-boundary.d.ts.map +0 -1
  506. package/dist/root-error-boundary.js +0 -165
  507. package/dist/root-error-boundary.js.map +0 -1
  508. package/dist/route-content-wrapper.d.ts +0 -46
  509. package/dist/route-content-wrapper.d.ts.map +0 -1
  510. package/dist/route-content-wrapper.js +0 -77
  511. package/dist/route-content-wrapper.js.map +0 -1
  512. package/dist/route-definition.d.ts +0 -421
  513. package/dist/route-definition.d.ts.map +0 -1
  514. package/dist/route-definition.js +0 -868
  515. package/dist/route-definition.js.map +0 -1
  516. package/dist/route-map-builder.d.ts +0 -155
  517. package/dist/route-map-builder.d.ts.map +0 -1
  518. package/dist/route-map-builder.js +0 -237
  519. package/dist/route-map-builder.js.map +0 -1
  520. package/dist/route-types.d.ts +0 -165
  521. package/dist/route-types.d.ts.map +0 -1
  522. package/dist/route-types.js +0 -7
  523. package/dist/route-types.js.map +0 -1
  524. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  525. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  526. package/dist/router/__tests__/handler-context.test.js +0 -65
  527. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  528. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  529. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  530. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  531. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  532. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  533. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  534. package/dist/router/__tests__/match-context.test.js +0 -92
  535. package/dist/router/__tests__/match-context.test.js.map +0 -1
  536. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  537. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  538. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  539. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  540. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  541. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  542. package/dist/router/__tests__/match-result.test.js +0 -457
  543. package/dist/router/__tests__/match-result.test.js.map +0 -1
  544. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  545. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  546. package/dist/router/__tests__/on-error.test.js +0 -678
  547. package/dist/router/__tests__/on-error.test.js.map +0 -1
  548. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  549. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  550. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  551. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  552. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  553. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  554. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  555. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  556. package/dist/router/error-handling.d.ts +0 -77
  557. package/dist/router/error-handling.d.ts.map +0 -1
  558. package/dist/router/error-handling.js +0 -202
  559. package/dist/router/error-handling.js.map +0 -1
  560. package/dist/router/handler-context.d.ts +0 -20
  561. package/dist/router/handler-context.d.ts.map +0 -1
  562. package/dist/router/handler-context.js +0 -198
  563. package/dist/router/handler-context.js.map +0 -1
  564. package/dist/router/intercept-resolution.d.ts +0 -66
  565. package/dist/router/intercept-resolution.d.ts.map +0 -1
  566. package/dist/router/intercept-resolution.js +0 -246
  567. package/dist/router/intercept-resolution.js.map +0 -1
  568. package/dist/router/loader-resolution.d.ts +0 -64
  569. package/dist/router/loader-resolution.d.ts.map +0 -1
  570. package/dist/router/loader-resolution.js +0 -284
  571. package/dist/router/loader-resolution.js.map +0 -1
  572. package/dist/router/logging.d.ts +0 -15
  573. package/dist/router/logging.d.ts.map +0 -1
  574. package/dist/router/logging.js +0 -99
  575. package/dist/router/logging.js.map +0 -1
  576. package/dist/router/manifest.d.ts +0 -22
  577. package/dist/router/manifest.d.ts.map +0 -1
  578. package/dist/router/manifest.js +0 -181
  579. package/dist/router/manifest.js.map +0 -1
  580. package/dist/router/match-api.d.ts +0 -35
  581. package/dist/router/match-api.d.ts.map +0 -1
  582. package/dist/router/match-api.js +0 -406
  583. package/dist/router/match-api.js.map +0 -1
  584. package/dist/router/match-context.d.ts +0 -206
  585. package/dist/router/match-context.d.ts.map +0 -1
  586. package/dist/router/match-context.js +0 -17
  587. package/dist/router/match-context.js.map +0 -1
  588. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  589. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  590. package/dist/router/match-middleware/background-revalidation.js +0 -75
  591. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  592. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  593. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  594. package/dist/router/match-middleware/cache-lookup.js +0 -257
  595. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  596. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  597. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  598. package/dist/router/match-middleware/cache-store.js +0 -108
  599. package/dist/router/match-middleware/cache-store.js.map +0 -1
  600. package/dist/router/match-middleware/index.d.ts +0 -81
  601. package/dist/router/match-middleware/index.d.ts.map +0 -1
  602. package/dist/router/match-middleware/index.js +0 -80
  603. package/dist/router/match-middleware/index.js.map +0 -1
  604. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  605. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  606. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  607. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  608. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  609. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  610. package/dist/router/match-middleware/segment-resolution.js +0 -53
  611. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  612. package/dist/router/match-pipelines.d.ts +0 -147
  613. package/dist/router/match-pipelines.d.ts.map +0 -1
  614. package/dist/router/match-pipelines.js +0 -82
  615. package/dist/router/match-pipelines.js.map +0 -1
  616. package/dist/router/match-result.d.ts +0 -126
  617. package/dist/router/match-result.d.ts.map +0 -1
  618. package/dist/router/match-result.js +0 -93
  619. package/dist/router/match-result.js.map +0 -1
  620. package/dist/router/metrics.d.ts +0 -20
  621. package/dist/router/metrics.d.ts.map +0 -1
  622. package/dist/router/metrics.js +0 -47
  623. package/dist/router/metrics.js.map +0 -1
  624. package/dist/router/middleware.d.ts +0 -249
  625. package/dist/router/middleware.d.ts.map +0 -1
  626. package/dist/router/middleware.js +0 -434
  627. package/dist/router/middleware.js.map +0 -1
  628. package/dist/router/middleware.test.d.ts +0 -2
  629. package/dist/router/middleware.test.d.ts.map +0 -1
  630. package/dist/router/middleware.test.js +0 -816
  631. package/dist/router/middleware.test.js.map +0 -1
  632. package/dist/router/pattern-matching.d.ts +0 -149
  633. package/dist/router/pattern-matching.d.ts.map +0 -1
  634. package/dist/router/pattern-matching.js +0 -349
  635. package/dist/router/pattern-matching.js.map +0 -1
  636. package/dist/router/revalidation.d.ts +0 -44
  637. package/dist/router/revalidation.d.ts.map +0 -1
  638. package/dist/router/revalidation.js +0 -147
  639. package/dist/router/revalidation.js.map +0 -1
  640. package/dist/router/router-context.d.ts +0 -135
  641. package/dist/router/router-context.d.ts.map +0 -1
  642. package/dist/router/router-context.js +0 -36
  643. package/dist/router/router-context.js.map +0 -1
  644. package/dist/router/segment-resolution.d.ts +0 -127
  645. package/dist/router/segment-resolution.d.ts.map +0 -1
  646. package/dist/router/segment-resolution.js +0 -919
  647. package/dist/router/segment-resolution.js.map +0 -1
  648. package/dist/router/trie-matching.d.ts +0 -40
  649. package/dist/router/trie-matching.d.ts.map +0 -1
  650. package/dist/router/trie-matching.js +0 -127
  651. package/dist/router/trie-matching.js.map +0 -1
  652. package/dist/router/types.d.ts +0 -136
  653. package/dist/router/types.d.ts.map +0 -1
  654. package/dist/router/types.js +0 -7
  655. package/dist/router/types.js.map +0 -1
  656. package/dist/router.d.ts +0 -753
  657. package/dist/router.d.ts.map +0 -1
  658. package/dist/router.gen.d.ts +0 -6
  659. package/dist/router.gen.d.ts.map +0 -1
  660. package/dist/router.gen.js +0 -6
  661. package/dist/router.gen.js.map +0 -1
  662. package/dist/router.js +0 -1304
  663. package/dist/router.js.map +0 -1
  664. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  665. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  666. package/dist/rsc/__tests__/helpers.test.js +0 -140
  667. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  668. package/dist/rsc/handler.d.ts +0 -45
  669. package/dist/rsc/handler.d.ts.map +0 -1
  670. package/dist/rsc/handler.js +0 -1172
  671. package/dist/rsc/handler.js.map +0 -1
  672. package/dist/rsc/helpers.d.ts +0 -16
  673. package/dist/rsc/helpers.d.ts.map +0 -1
  674. package/dist/rsc/helpers.js +0 -55
  675. package/dist/rsc/helpers.js.map +0 -1
  676. package/dist/rsc/index.d.ts +0 -22
  677. package/dist/rsc/index.d.ts.map +0 -1
  678. package/dist/rsc/index.js +0 -23
  679. package/dist/rsc/index.js.map +0 -1
  680. package/dist/rsc/nonce.d.ts +0 -9
  681. package/dist/rsc/nonce.d.ts.map +0 -1
  682. package/dist/rsc/nonce.js +0 -18
  683. package/dist/rsc/nonce.js.map +0 -1
  684. package/dist/rsc/types.d.ts +0 -206
  685. package/dist/rsc/types.d.ts.map +0 -1
  686. package/dist/rsc/types.js +0 -8
  687. package/dist/rsc/types.js.map +0 -1
  688. package/dist/search-params.d.ts +0 -103
  689. package/dist/search-params.d.ts.map +0 -1
  690. package/dist/search-params.js +0 -74
  691. package/dist/search-params.js.map +0 -1
  692. package/dist/segment-system.d.ts +0 -75
  693. package/dist/segment-system.d.ts.map +0 -1
  694. package/dist/segment-system.js +0 -336
  695. package/dist/segment-system.js.map +0 -1
  696. package/dist/server/context.d.ts +0 -245
  697. package/dist/server/context.d.ts.map +0 -1
  698. package/dist/server/context.js +0 -197
  699. package/dist/server/context.js.map +0 -1
  700. package/dist/server/fetchable-loader-store.d.ts +0 -18
  701. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  702. package/dist/server/fetchable-loader-store.js +0 -18
  703. package/dist/server/fetchable-loader-store.js.map +0 -1
  704. package/dist/server/handle-store.d.ts +0 -85
  705. package/dist/server/handle-store.d.ts.map +0 -1
  706. package/dist/server/handle-store.js +0 -142
  707. package/dist/server/handle-store.js.map +0 -1
  708. package/dist/server/loader-registry.d.ts +0 -55
  709. package/dist/server/loader-registry.d.ts.map +0 -1
  710. package/dist/server/loader-registry.js +0 -132
  711. package/dist/server/loader-registry.js.map +0 -1
  712. package/dist/server/request-context.d.ts +0 -226
  713. package/dist/server/request-context.d.ts.map +0 -1
  714. package/dist/server/request-context.js +0 -290
  715. package/dist/server/request-context.js.map +0 -1
  716. package/dist/server/root-layout.d.ts +0 -4
  717. package/dist/server/root-layout.d.ts.map +0 -1
  718. package/dist/server/root-layout.js +0 -5
  719. package/dist/server/root-layout.js.map +0 -1
  720. package/dist/server.d.ts +0 -15
  721. package/dist/server.d.ts.map +0 -1
  722. package/dist/server.js +0 -20
  723. package/dist/server.js.map +0 -1
  724. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  725. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  726. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  727. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  728. package/dist/ssr/index.d.ts +0 -98
  729. package/dist/ssr/index.d.ts.map +0 -1
  730. package/dist/ssr/index.js +0 -158
  731. package/dist/ssr/index.js.map +0 -1
  732. package/dist/static-handler.d.ts +0 -50
  733. package/dist/static-handler.d.ts.map +0 -1
  734. package/dist/static-handler.gen.d.ts +0 -5
  735. package/dist/static-handler.gen.d.ts.map +0 -1
  736. package/dist/static-handler.gen.js +0 -5
  737. package/dist/static-handler.gen.js.map +0 -1
  738. package/dist/static-handler.js +0 -29
  739. package/dist/static-handler.js.map +0 -1
  740. package/dist/theme/ThemeProvider.d.ts +0 -20
  741. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  742. package/dist/theme/ThemeProvider.js +0 -240
  743. package/dist/theme/ThemeProvider.js.map +0 -1
  744. package/dist/theme/ThemeScript.d.ts +0 -48
  745. package/dist/theme/ThemeScript.d.ts.map +0 -1
  746. package/dist/theme/ThemeScript.js +0 -13
  747. package/dist/theme/ThemeScript.js.map +0 -1
  748. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  749. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  750. package/dist/theme/__tests__/theme.test.js +0 -103
  751. package/dist/theme/__tests__/theme.test.js.map +0 -1
  752. package/dist/theme/constants.d.ts +0 -29
  753. package/dist/theme/constants.d.ts.map +0 -1
  754. package/dist/theme/constants.js +0 -48
  755. package/dist/theme/constants.js.map +0 -1
  756. package/dist/theme/index.d.ts +0 -31
  757. package/dist/theme/index.d.ts.map +0 -1
  758. package/dist/theme/index.js +0 -36
  759. package/dist/theme/index.js.map +0 -1
  760. package/dist/theme/theme-context.d.ts +0 -40
  761. package/dist/theme/theme-context.d.ts.map +0 -1
  762. package/dist/theme/theme-context.js +0 -60
  763. package/dist/theme/theme-context.js.map +0 -1
  764. package/dist/theme/theme-script.d.ts +0 -27
  765. package/dist/theme/theme-script.d.ts.map +0 -1
  766. package/dist/theme/theme-script.js +0 -147
  767. package/dist/theme/theme-script.js.map +0 -1
  768. package/dist/theme/types.d.ts +0 -163
  769. package/dist/theme/types.d.ts.map +0 -1
  770. package/dist/theme/types.js +0 -11
  771. package/dist/theme/types.js.map +0 -1
  772. package/dist/theme/use-theme.d.ts +0 -12
  773. package/dist/theme/use-theme.d.ts.map +0 -1
  774. package/dist/theme/use-theme.js +0 -40
  775. package/dist/theme/use-theme.js.map +0 -1
  776. package/dist/types.d.ts +0 -1479
  777. package/dist/types.d.ts.map +0 -1
  778. package/dist/types.js +0 -10
  779. package/dist/types.js.map +0 -1
  780. package/dist/urls.d.ts +0 -441
  781. package/dist/urls.d.ts.map +0 -1
  782. package/dist/urls.gen.d.ts +0 -8
  783. package/dist/urls.gen.d.ts.map +0 -1
  784. package/dist/urls.gen.js +0 -8
  785. package/dist/urls.gen.js.map +0 -1
  786. package/dist/urls.js +0 -443
  787. package/dist/urls.js.map +0 -1
  788. package/dist/use-loader.d.ts +0 -127
  789. package/dist/use-loader.d.ts.map +0 -1
  790. package/dist/use-loader.js +0 -237
  791. package/dist/use-loader.js.map +0 -1
  792. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  793. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  794. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  795. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  796. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  797. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  798. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  799. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  800. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  801. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  802. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  803. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  804. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  805. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  806. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  807. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  808. package/dist/vite/ast-handler-extract.d.ts +0 -49
  809. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  810. package/dist/vite/ast-handler-extract.js +0 -249
  811. package/dist/vite/ast-handler-extract.js.map +0 -1
  812. package/dist/vite/expose-action-id.d.ts +0 -19
  813. package/dist/vite/expose-action-id.d.ts.map +0 -1
  814. package/dist/vite/expose-action-id.js +0 -250
  815. package/dist/vite/expose-action-id.js.map +0 -1
  816. package/dist/vite/expose-id-utils.d.ts +0 -69
  817. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  818. package/dist/vite/expose-id-utils.js +0 -289
  819. package/dist/vite/expose-id-utils.js.map +0 -1
  820. package/dist/vite/expose-internal-ids.d.ts +0 -22
  821. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  822. package/dist/vite/expose-internal-ids.js +0 -886
  823. package/dist/vite/expose-internal-ids.js.map +0 -1
  824. package/dist/vite/index.d.ts +0 -149
  825. package/dist/vite/index.d.ts.map +0 -1
  826. package/dist/vite/index.js.map +0 -1
  827. package/dist/vite/index.named-routes.gen.ts +0 -103
  828. package/dist/vite/package-resolution.d.ts +0 -43
  829. package/dist/vite/package-resolution.d.ts.map +0 -1
  830. package/dist/vite/package-resolution.js +0 -112
  831. package/dist/vite/package-resolution.js.map +0 -1
  832. package/dist/vite/virtual-entries.d.ts +0 -25
  833. package/dist/vite/virtual-entries.d.ts.map +0 -1
  834. package/dist/vite/virtual-entries.js +0 -110
  835. 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