@rangojs/router 0.0.0-experimental.21 → 0.0.0-experimental.23

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