@timber-js/app 0.2.0-alpha.9 → 0.2.0-alpha.90

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 (610) hide show
  1. package/dist/_chunks/actions-DLnUaR65.js +421 -0
  2. package/dist/_chunks/actions-DLnUaR65.js.map +1 -0
  3. package/dist/_chunks/{als-registry-B7DbZ2hS.js → als-registry-HS0LGUl2.js} +1 -1
  4. package/dist/_chunks/als-registry-HS0LGUl2.js.map +1 -0
  5. package/dist/_chunks/chunk-BYIpzuS7.js +39 -0
  6. package/dist/_chunks/{debug-gwlJkDuf.js → debug-ECi_61pb.js} +2 -2
  7. package/dist/_chunks/debug-ECi_61pb.js.map +1 -0
  8. package/dist/_chunks/define-C77ScO0m.js +106 -0
  9. package/dist/_chunks/define-C77ScO0m.js.map +1 -0
  10. package/dist/_chunks/define-Itxvcd7F.js +199 -0
  11. package/dist/_chunks/define-Itxvcd7F.js.map +1 -0
  12. package/dist/_chunks/define-cookie-BowvzoP0.js +94 -0
  13. package/dist/_chunks/define-cookie-BowvzoP0.js.map +1 -0
  14. package/dist/_chunks/{format-DviM89f0.js → dev-warnings-DpGRGoDi.js} +5 -44
  15. package/dist/_chunks/dev-warnings-DpGRGoDi.js.map +1 -0
  16. package/dist/_chunks/format-CYBGxKtc.js +14 -0
  17. package/dist/_chunks/format-CYBGxKtc.js.map +1 -0
  18. package/dist/_chunks/{interception-BOoWmLUA.js → interception-DRlhJWbu.js} +219 -97
  19. package/dist/_chunks/interception-DRlhJWbu.js.map +1 -0
  20. package/dist/_chunks/merge-search-params-Cm_KIWDX.js +41 -0
  21. package/dist/_chunks/merge-search-params-Cm_KIWDX.js.map +1 -0
  22. package/dist/_chunks/{metadata-routes-Cjmvi3rQ.js → metadata-routes-DS3eKNmf.js} +1 -1
  23. package/dist/_chunks/{metadata-routes-Cjmvi3rQ.js.map → metadata-routes-DS3eKNmf.js.map} +1 -1
  24. package/dist/_chunks/request-context-CK5tZqIP.js +478 -0
  25. package/dist/_chunks/request-context-CK5tZqIP.js.map +1 -0
  26. package/dist/_chunks/schema-bridge-C3xl_vfb.js +86 -0
  27. package/dist/_chunks/schema-bridge-C3xl_vfb.js.map +1 -0
  28. package/dist/_chunks/segment-classify-BDNn6EzD.js +65 -0
  29. package/dist/_chunks/segment-classify-BDNn6EzD.js.map +1 -0
  30. package/dist/_chunks/segment-context-fHFLF1PE.js +34 -0
  31. package/dist/_chunks/segment-context-fHFLF1PE.js.map +1 -0
  32. package/dist/_chunks/{ssr-data-MjmprTmO.js → ssr-data-DzuI0bIV.js} +1 -1
  33. package/dist/_chunks/{ssr-data-MjmprTmO.js.map → ssr-data-DzuI0bIV.js.map} +1 -1
  34. package/dist/_chunks/stale-reload-BX5gL1r-.js +64 -0
  35. package/dist/_chunks/stale-reload-BX5gL1r-.js.map +1 -0
  36. package/dist/_chunks/{tracing-CemImE6h.js → tracing-CCYbKn5n.js} +60 -9
  37. package/dist/_chunks/tracing-CCYbKn5n.js.map +1 -0
  38. package/dist/_chunks/use-params-Br9YSUFV.js +295 -0
  39. package/dist/_chunks/use-params-Br9YSUFV.js.map +1 -0
  40. package/dist/_chunks/{use-query-states-D5KaffOK.js → use-query-states-BiV5GJgm.js} +7 -4
  41. package/dist/_chunks/use-query-states-BiV5GJgm.js.map +1 -0
  42. package/dist/adapters/cloudflare-dev.d.ts +109 -0
  43. package/dist/adapters/cloudflare-dev.d.ts.map +1 -0
  44. package/dist/adapters/cloudflare-dev.js +73 -0
  45. package/dist/adapters/cloudflare-dev.js.map +1 -0
  46. package/dist/adapters/cloudflare-kv-cache.d.ts +64 -0
  47. package/dist/adapters/cloudflare-kv-cache.d.ts.map +1 -0
  48. package/dist/adapters/cloudflare-kv-cache.js +95 -0
  49. package/dist/adapters/cloudflare-kv-cache.js.map +1 -0
  50. package/dist/adapters/cloudflare.d.ts +148 -12
  51. package/dist/adapters/cloudflare.d.ts.map +1 -1
  52. package/dist/adapters/cloudflare.js +135 -11
  53. package/dist/adapters/cloudflare.js.map +1 -1
  54. package/dist/adapters/compress-module.d.ts.map +1 -1
  55. package/dist/adapters/nitro.d.ts +17 -1
  56. package/dist/adapters/nitro.d.ts.map +1 -1
  57. package/dist/adapters/nitro.js +56 -13
  58. package/dist/adapters/nitro.js.map +1 -1
  59. package/dist/cache/cache-api.d.ts +24 -0
  60. package/dist/cache/cache-api.d.ts.map +1 -0
  61. package/dist/cache/handler-store.d.ts +31 -0
  62. package/dist/cache/handler-store.d.ts.map +1 -0
  63. package/dist/cache/index.d.ts +23 -7
  64. package/dist/cache/index.d.ts.map +1 -1
  65. package/dist/cache/index.js +142 -80
  66. package/dist/cache/index.js.map +1 -1
  67. package/dist/cache/singleflight.d.ts +18 -1
  68. package/dist/cache/singleflight.d.ts.map +1 -1
  69. package/dist/cache/sizeof.d.ts +22 -0
  70. package/dist/cache/sizeof.d.ts.map +1 -0
  71. package/dist/cache/timber-cache.d.ts +1 -1
  72. package/dist/cache/timber-cache.d.ts.map +1 -1
  73. package/dist/cli.d.ts +6 -1
  74. package/dist/cli.d.ts.map +1 -1
  75. package/dist/cli.js +8 -3
  76. package/dist/cli.js.map +1 -1
  77. package/dist/client/browser-dev.d.ts +27 -1
  78. package/dist/client/browser-dev.d.ts.map +1 -1
  79. package/dist/client/browser-entry/action-dispatch.d.ts +17 -0
  80. package/dist/client/browser-entry/action-dispatch.d.ts.map +1 -0
  81. package/dist/client/browser-entry/hmr.d.ts +21 -0
  82. package/dist/client/browser-entry/hmr.d.ts.map +1 -0
  83. package/dist/client/browser-entry/hydrate.d.ts +46 -0
  84. package/dist/client/browser-entry/hydrate.d.ts.map +1 -0
  85. package/dist/client/browser-entry/index.d.ts +30 -0
  86. package/dist/client/browser-entry/index.d.ts.map +1 -0
  87. package/dist/client/browser-entry/post-hydration.d.ts +26 -0
  88. package/dist/client/browser-entry/post-hydration.d.ts.map +1 -0
  89. package/dist/client/browser-entry/router-init.d.ts +23 -0
  90. package/dist/client/browser-entry/router-init.d.ts.map +1 -0
  91. package/dist/client/browser-entry/rsc-stream.d.ts +24 -0
  92. package/dist/client/browser-entry/rsc-stream.d.ts.map +1 -0
  93. package/dist/client/browser-entry/scroll.d.ts +19 -0
  94. package/dist/client/browser-entry/scroll.d.ts.map +1 -0
  95. package/dist/client/error-boundary.d.ts +12 -5
  96. package/dist/client/error-boundary.d.ts.map +1 -1
  97. package/dist/client/error-boundary.js +10 -4
  98. package/dist/client/error-boundary.js.map +1 -1
  99. package/dist/client/error-reconstituter.d.ts +54 -0
  100. package/dist/client/error-reconstituter.d.ts.map +1 -0
  101. package/dist/client/form.d.ts +6 -3
  102. package/dist/client/form.d.ts.map +1 -1
  103. package/dist/client/history.d.ts +19 -4
  104. package/dist/client/history.d.ts.map +1 -1
  105. package/dist/client/index.d.ts +9 -21
  106. package/dist/client/index.d.ts.map +1 -1
  107. package/dist/client/index.js +229 -1018
  108. package/dist/client/index.js.map +1 -1
  109. package/dist/client/internal.d.ts +18 -0
  110. package/dist/client/internal.d.ts.map +1 -0
  111. package/dist/client/internal.js +890 -0
  112. package/dist/client/internal.js.map +1 -0
  113. package/dist/client/link-pending-store.d.ts +63 -0
  114. package/dist/client/link-pending-store.d.ts.map +1 -0
  115. package/dist/client/link.d.ts +62 -55
  116. package/dist/client/link.d.ts.map +1 -1
  117. package/dist/client/nav-link-store.d.ts +36 -0
  118. package/dist/client/nav-link-store.d.ts.map +1 -0
  119. package/dist/client/navigation-api-types.d.ts +90 -0
  120. package/dist/client/navigation-api-types.d.ts.map +1 -0
  121. package/dist/client/navigation-api.d.ts +115 -0
  122. package/dist/client/navigation-api.d.ts.map +1 -0
  123. package/dist/client/navigation-context.d.ts +13 -2
  124. package/dist/client/navigation-context.d.ts.map +1 -1
  125. package/dist/client/{transition-root.d.ts → navigation-root.d.ts} +42 -8
  126. package/dist/client/navigation-root.d.ts.map +1 -0
  127. package/dist/client/nuqs-adapter.d.ts.map +1 -1
  128. package/dist/client/router-ref.d.ts +1 -1
  129. package/dist/client/router.d.ts +70 -4
  130. package/dist/client/router.d.ts.map +1 -1
  131. package/dist/client/rsc-fetch.d.ts +38 -3
  132. package/dist/client/rsc-fetch.d.ts.map +1 -1
  133. package/dist/client/segment-cache.d.ts +1 -1
  134. package/dist/client/segment-cache.d.ts.map +1 -1
  135. package/dist/client/segment-outlet.d.ts +63 -0
  136. package/dist/client/segment-outlet.d.ts.map +1 -0
  137. package/dist/client/ssr-data.d.ts +13 -4
  138. package/dist/client/ssr-data.d.ts.map +1 -1
  139. package/dist/client/stale-reload.d.ts +15 -0
  140. package/dist/client/stale-reload.d.ts.map +1 -1
  141. package/dist/client/top-loader.d.ts +5 -5
  142. package/dist/client/top-loader.d.ts.map +1 -1
  143. package/dist/client/use-link-status.d.ts +5 -5
  144. package/dist/client/use-link-status.d.ts.map +1 -1
  145. package/dist/client/use-params.d.ts +6 -4
  146. package/dist/client/use-params.d.ts.map +1 -1
  147. package/dist/client/{use-navigation-pending.d.ts → use-pending-navigation.d.ts} +4 -4
  148. package/dist/client/use-pending-navigation.d.ts.map +1 -0
  149. package/dist/client/use-query-states.d.ts +1 -1
  150. package/dist/client/use-query-states.d.ts.map +1 -1
  151. package/dist/client/use-router.d.ts +1 -1
  152. package/dist/codec.d.ts +33 -0
  153. package/dist/codec.d.ts.map +1 -0
  154. package/dist/codec.js +2 -0
  155. package/dist/config-types.d.ts +266 -0
  156. package/dist/config-types.d.ts.map +1 -0
  157. package/dist/config-validation.d.ts +51 -0
  158. package/dist/config-validation.d.ts.map +1 -0
  159. package/dist/content/index.d.ts +1 -10
  160. package/dist/content/index.d.ts.map +1 -1
  161. package/dist/content/index.js +0 -2
  162. package/dist/cookies/define-cookie.d.ts +35 -14
  163. package/dist/cookies/define-cookie.d.ts.map +1 -1
  164. package/dist/cookies/index.js +1 -83
  165. package/dist/fonts/bundle.d.ts +48 -0
  166. package/dist/fonts/bundle.d.ts.map +1 -0
  167. package/dist/fonts/css.d.ts +1 -0
  168. package/dist/fonts/css.d.ts.map +1 -1
  169. package/dist/fonts/dev-middleware.d.ts +22 -0
  170. package/dist/fonts/dev-middleware.d.ts.map +1 -0
  171. package/dist/fonts/pipeline.d.ts +138 -0
  172. package/dist/fonts/pipeline.d.ts.map +1 -0
  173. package/dist/fonts/transform.d.ts +72 -0
  174. package/dist/fonts/transform.d.ts.map +1 -0
  175. package/dist/fonts/types.d.ts +45 -1
  176. package/dist/fonts/types.d.ts.map +1 -1
  177. package/dist/fonts/virtual-modules.d.ts +59 -0
  178. package/dist/fonts/virtual-modules.d.ts.map +1 -0
  179. package/dist/index.d.ts +45 -190
  180. package/dist/index.d.ts.map +1 -1
  181. package/dist/index.js +4294 -2453
  182. package/dist/index.js.map +1 -1
  183. package/dist/plugin-context.d.ts +107 -0
  184. package/dist/plugin-context.d.ts.map +1 -0
  185. package/dist/plugins/adapter-build.d.ts +1 -1
  186. package/dist/plugins/adapter-build.d.ts.map +1 -1
  187. package/dist/plugins/build-manifest.d.ts +2 -2
  188. package/dist/plugins/build-manifest.d.ts.map +1 -1
  189. package/dist/plugins/build-report.d.ts +3 -3
  190. package/dist/plugins/build-report.d.ts.map +1 -1
  191. package/dist/plugins/client-chunks.d.ts +32 -0
  192. package/dist/plugins/client-chunks.d.ts.map +1 -0
  193. package/dist/plugins/content.d.ts +1 -1
  194. package/dist/plugins/content.d.ts.map +1 -1
  195. package/dist/plugins/dev-404-page.d.ts +56 -0
  196. package/dist/plugins/dev-404-page.d.ts.map +1 -0
  197. package/dist/plugins/dev-browser-logs.d.ts +84 -0
  198. package/dist/plugins/dev-browser-logs.d.ts.map +1 -0
  199. package/dist/plugins/dev-error-overlay.d.ts +49 -9
  200. package/dist/plugins/dev-error-overlay.d.ts.map +1 -1
  201. package/dist/plugins/dev-error-page.d.ts +58 -0
  202. package/dist/plugins/dev-error-page.d.ts.map +1 -0
  203. package/dist/plugins/dev-logs.d.ts +1 -1
  204. package/dist/plugins/dev-logs.d.ts.map +1 -1
  205. package/dist/plugins/dev-server.d.ts +1 -1
  206. package/dist/plugins/dev-server.d.ts.map +1 -1
  207. package/dist/plugins/dev-terminal-error.d.ts +28 -0
  208. package/dist/plugins/dev-terminal-error.d.ts.map +1 -0
  209. package/dist/plugins/entries.d.ts +1 -1
  210. package/dist/plugins/entries.d.ts.map +1 -1
  211. package/dist/plugins/fonts.d.ts +17 -73
  212. package/dist/plugins/fonts.d.ts.map +1 -1
  213. package/dist/plugins/mdx.d.ts +1 -1
  214. package/dist/plugins/mdx.d.ts.map +1 -1
  215. package/dist/plugins/routing.d.ts +1 -1
  216. package/dist/plugins/routing.d.ts.map +1 -1
  217. package/dist/plugins/server-bundle.d.ts.map +1 -1
  218. package/dist/plugins/shims.d.ts +6 -5
  219. package/dist/plugins/shims.d.ts.map +1 -1
  220. package/dist/plugins/static-build.d.ts +4 -4
  221. package/dist/plugins/static-build.d.ts.map +1 -1
  222. package/dist/routing/codegen.d.ts +2 -2
  223. package/dist/routing/codegen.d.ts.map +1 -1
  224. package/dist/routing/convention-lint.d.ts +41 -0
  225. package/dist/routing/convention-lint.d.ts.map +1 -0
  226. package/dist/routing/index.d.ts +2 -0
  227. package/dist/routing/index.d.ts.map +1 -1
  228. package/dist/routing/index.js +3 -2
  229. package/dist/routing/scanner.d.ts.map +1 -1
  230. package/dist/routing/segment-classify.d.ts +46 -0
  231. package/dist/routing/segment-classify.d.ts.map +1 -0
  232. package/dist/routing/status-file-lint.d.ts +2 -1
  233. package/dist/routing/status-file-lint.d.ts.map +1 -1
  234. package/dist/routing/types.d.ts +16 -4
  235. package/dist/routing/types.d.ts.map +1 -1
  236. package/dist/rsc-runtime/rsc.d.ts +1 -1
  237. package/dist/rsc-runtime/rsc.d.ts.map +1 -1
  238. package/dist/rsc-runtime/ssr.d.ts +12 -0
  239. package/dist/rsc-runtime/ssr.d.ts.map +1 -1
  240. package/dist/schema-bridge.d.ts +76 -0
  241. package/dist/schema-bridge.d.ts.map +1 -0
  242. package/dist/search-params/define.d.ts +139 -0
  243. package/dist/search-params/define.d.ts.map +1 -0
  244. package/dist/search-params/index.d.ts +4 -7
  245. package/dist/search-params/index.d.ts.map +1 -1
  246. package/dist/search-params/index.js +32 -441
  247. package/dist/search-params/index.js.map +1 -1
  248. package/dist/search-params/registry.d.ts +2 -2
  249. package/dist/search-params/registry.d.ts.map +1 -1
  250. package/dist/search-params/wrappers.d.ts +53 -0
  251. package/dist/search-params/wrappers.d.ts.map +1 -0
  252. package/dist/segment-params/define.d.ts +78 -0
  253. package/dist/segment-params/define.d.ts.map +1 -0
  254. package/dist/segment-params/index.d.ts +3 -0
  255. package/dist/segment-params/index.d.ts.map +1 -0
  256. package/dist/segment-params/index.js +2 -0
  257. package/dist/server/access-gate.d.ts +4 -0
  258. package/dist/server/access-gate.d.ts.map +1 -1
  259. package/dist/server/action-client.d.ts +41 -6
  260. package/dist/server/action-client.d.ts.map +1 -1
  261. package/dist/server/action-encryption.d.ts +76 -0
  262. package/dist/server/action-encryption.d.ts.map +1 -0
  263. package/dist/server/action-handler.d.ts +7 -0
  264. package/dist/server/action-handler.d.ts.map +1 -1
  265. package/dist/server/actions.d.ts +3 -6
  266. package/dist/server/actions.d.ts.map +1 -1
  267. package/dist/server/als-registry.d.ts +32 -4
  268. package/dist/server/als-registry.d.ts.map +1 -1
  269. package/dist/server/build-manifest.d.ts +2 -2
  270. package/dist/server/build-manifest.d.ts.map +1 -1
  271. package/dist/server/debug.d.ts +1 -1
  272. package/dist/server/default-logger.d.ts +22 -0
  273. package/dist/server/default-logger.d.ts.map +1 -0
  274. package/dist/server/deny-page-resolver.d.ts +52 -0
  275. package/dist/server/deny-page-resolver.d.ts.map +1 -0
  276. package/dist/server/deny-renderer.d.ts.map +1 -1
  277. package/dist/server/dev-holding-server.d.ts +52 -0
  278. package/dist/server/dev-holding-server.d.ts.map +1 -0
  279. package/dist/server/dev-source-map.d.ts +22 -0
  280. package/dist/server/dev-source-map.d.ts.map +1 -0
  281. package/dist/server/dev-warnings.d.ts +1 -21
  282. package/dist/server/dev-warnings.d.ts.map +1 -1
  283. package/dist/server/early-hints.d.ts +13 -5
  284. package/dist/server/early-hints.d.ts.map +1 -1
  285. package/dist/server/error-boundary-wrapper.d.ts +7 -1
  286. package/dist/server/error-boundary-wrapper.d.ts.map +1 -1
  287. package/dist/server/fallback-error.d.ts +12 -7
  288. package/dist/server/fallback-error.d.ts.map +1 -1
  289. package/dist/server/flight-injection-state.d.ts +66 -0
  290. package/dist/server/flight-injection-state.d.ts.map +1 -0
  291. package/dist/server/flight-scripts.d.ts +42 -0
  292. package/dist/server/flight-scripts.d.ts.map +1 -0
  293. package/dist/server/flush.d.ts.map +1 -1
  294. package/dist/server/form-data.d.ts +29 -0
  295. package/dist/server/form-data.d.ts.map +1 -1
  296. package/dist/server/html-injectors.d.ts +51 -11
  297. package/dist/server/html-injectors.d.ts.map +1 -1
  298. package/dist/server/index.d.ts +5 -43
  299. package/dist/server/index.d.ts.map +1 -1
  300. package/dist/server/index.js +195 -2800
  301. package/dist/server/index.js.map +1 -1
  302. package/dist/server/internal.d.ts +46 -0
  303. package/dist/server/internal.d.ts.map +1 -0
  304. package/dist/server/internal.js +2900 -0
  305. package/dist/server/internal.js.map +1 -0
  306. package/dist/server/logger.d.ts +25 -7
  307. package/dist/server/logger.d.ts.map +1 -1
  308. package/dist/server/middleware-runner.d.ts +19 -4
  309. package/dist/server/middleware-runner.d.ts.map +1 -1
  310. package/dist/server/node-stream-transforms.d.ts +113 -0
  311. package/dist/server/node-stream-transforms.d.ts.map +1 -0
  312. package/dist/server/page-deny-boundary.d.ts +31 -0
  313. package/dist/server/page-deny-boundary.d.ts.map +1 -0
  314. package/dist/server/pipeline-interception.d.ts +1 -1
  315. package/dist/server/pipeline-interception.d.ts.map +1 -1
  316. package/dist/server/pipeline-metadata.d.ts +6 -0
  317. package/dist/server/pipeline-metadata.d.ts.map +1 -1
  318. package/dist/server/pipeline.d.ts +52 -10
  319. package/dist/server/pipeline.d.ts.map +1 -1
  320. package/dist/server/primitives.d.ts +69 -18
  321. package/dist/server/primitives.d.ts.map +1 -1
  322. package/dist/server/render-timeout.d.ts +51 -0
  323. package/dist/server/render-timeout.d.ts.map +1 -0
  324. package/dist/server/request-context.d.ts +112 -43
  325. package/dist/server/request-context.d.ts.map +1 -1
  326. package/dist/server/route-element-builder.d.ts +27 -1
  327. package/dist/server/route-element-builder.d.ts.map +1 -1
  328. package/dist/server/route-handler.d.ts.map +1 -1
  329. package/dist/server/route-matcher.d.ts +16 -2
  330. package/dist/server/route-matcher.d.ts.map +1 -1
  331. package/dist/server/rsc-entry/api-handler.d.ts +2 -2
  332. package/dist/server/rsc-entry/api-handler.d.ts.map +1 -1
  333. package/dist/server/rsc-entry/error-renderer.d.ts +26 -13
  334. package/dist/server/rsc-entry/error-renderer.d.ts.map +1 -1
  335. package/dist/server/rsc-entry/helpers.d.ts +48 -5
  336. package/dist/server/rsc-entry/helpers.d.ts.map +1 -1
  337. package/dist/server/rsc-entry/index.d.ts +20 -3
  338. package/dist/server/rsc-entry/index.d.ts.map +1 -1
  339. package/dist/server/rsc-entry/rsc-payload.d.ts +3 -3
  340. package/dist/server/rsc-entry/rsc-payload.d.ts.map +1 -1
  341. package/dist/server/rsc-entry/rsc-stream.d.ts +14 -1
  342. package/dist/server/rsc-entry/rsc-stream.d.ts.map +1 -1
  343. package/dist/server/rsc-entry/ssr-bridge.d.ts +1 -1
  344. package/dist/server/rsc-entry/ssr-bridge.d.ts.map +1 -1
  345. package/dist/server/rsc-entry/ssr-renderer.d.ts +19 -4
  346. package/dist/server/rsc-entry/ssr-renderer.d.ts.map +1 -1
  347. package/dist/server/safe-load.d.ts +46 -0
  348. package/dist/server/safe-load.d.ts.map +1 -0
  349. package/dist/server/sensitive-fields.d.ts +74 -0
  350. package/dist/server/sensitive-fields.d.ts.map +1 -0
  351. package/dist/server/sitemap-generator.d.ts +129 -0
  352. package/dist/server/sitemap-generator.d.ts.map +1 -0
  353. package/dist/server/sitemap-handler.d.ts +22 -0
  354. package/dist/server/sitemap-handler.d.ts.map +1 -0
  355. package/dist/server/slot-resolver.d.ts +1 -1
  356. package/dist/server/slot-resolver.d.ts.map +1 -1
  357. package/dist/server/ssr-entry.d.ts +23 -0
  358. package/dist/server/ssr-entry.d.ts.map +1 -1
  359. package/dist/server/ssr-render.d.ts +39 -21
  360. package/dist/server/ssr-render.d.ts.map +1 -1
  361. package/dist/server/ssr-wrappers.d.ts +50 -0
  362. package/dist/server/ssr-wrappers.d.ts.map +1 -0
  363. package/dist/server/status-code-resolver.d.ts +1 -1
  364. package/dist/server/status-code-resolver.d.ts.map +1 -1
  365. package/dist/server/stream-utils.d.ts +36 -0
  366. package/dist/server/stream-utils.d.ts.map +1 -0
  367. package/dist/server/tracing.d.ts +4 -4
  368. package/dist/server/tracing.d.ts.map +1 -1
  369. package/dist/server/tree-builder.d.ts +22 -19
  370. package/dist/server/tree-builder.d.ts.map +1 -1
  371. package/dist/server/types.d.ts +1 -4
  372. package/dist/server/types.d.ts.map +1 -1
  373. package/dist/server/version-skew.d.ts +61 -0
  374. package/dist/server/version-skew.d.ts.map +1 -0
  375. package/dist/shared/merge-search-params.d.ts +22 -0
  376. package/dist/shared/merge-search-params.d.ts.map +1 -0
  377. package/dist/shims/font-google.d.ts +1 -1
  378. package/dist/shims/font-google.d.ts.map +1 -1
  379. package/dist/shims/font-google.js +42 -0
  380. package/dist/shims/font-google.js.map +1 -0
  381. package/dist/shims/font-local.d.ts +26 -0
  382. package/dist/shims/font-local.d.ts.map +1 -0
  383. package/dist/shims/font-local.js +20 -0
  384. package/dist/shims/font-local.js.map +1 -0
  385. package/dist/shims/headers.d.ts +2 -1
  386. package/dist/shims/headers.d.ts.map +1 -1
  387. package/dist/shims/navigation-client.d.ts +1 -1
  388. package/dist/shims/navigation-client.d.ts.map +1 -1
  389. package/dist/shims/navigation.d.ts +3 -2
  390. package/dist/shims/navigation.d.ts.map +1 -1
  391. package/dist/utils/directive-parser.d.ts +5 -2
  392. package/dist/utils/directive-parser.d.ts.map +1 -1
  393. package/dist/utils/state-machine.d.ts +80 -0
  394. package/dist/utils/state-machine.d.ts.map +1 -0
  395. package/package.json +51 -16
  396. package/src/adapters/cloudflare-dev.ts +177 -0
  397. package/src/adapters/cloudflare-kv-cache.ts +142 -0
  398. package/src/adapters/cloudflare.ts +342 -28
  399. package/src/adapters/compress-module.ts +24 -4
  400. package/src/adapters/nitro.ts +52 -8
  401. package/src/adapters/wrangler.d.ts +7 -0
  402. package/src/cache/cache-api.ts +38 -0
  403. package/src/cache/handler-store.ts +68 -0
  404. package/src/cache/index.ts +81 -18
  405. package/src/cache/singleflight.ts +62 -4
  406. package/src/cache/sizeof.ts +31 -0
  407. package/src/cache/timber-cache.ts +24 -20
  408. package/src/cli.ts +16 -6
  409. package/src/client/browser-dev.ts +128 -1
  410. package/src/client/browser-entry/action-dispatch.ts +116 -0
  411. package/src/client/browser-entry/hmr.ts +81 -0
  412. package/src/client/browser-entry/hydrate.ts +145 -0
  413. package/src/client/browser-entry/index.ts +143 -0
  414. package/src/client/browser-entry/post-hydration.ts +119 -0
  415. package/src/client/browser-entry/router-init.ts +193 -0
  416. package/src/client/browser-entry/rsc-stream.ts +157 -0
  417. package/src/client/browser-entry/scroll.ts +27 -0
  418. package/src/client/error-boundary.tsx +48 -16
  419. package/src/client/error-reconstituter.tsx +65 -0
  420. package/src/client/form.tsx +14 -7
  421. package/src/client/history.ts +26 -4
  422. package/src/client/index.ts +65 -38
  423. package/src/client/internal.ts +57 -0
  424. package/src/client/link-pending-store.ts +111 -0
  425. package/src/client/link.tsx +342 -113
  426. package/src/client/nav-link-store.ts +47 -0
  427. package/src/client/navigation-api-types.ts +112 -0
  428. package/src/client/navigation-api.ts +332 -0
  429. package/src/client/navigation-context.ts +31 -6
  430. package/src/client/navigation-root.tsx +342 -0
  431. package/src/client/nuqs-adapter.tsx +16 -3
  432. package/src/client/router-ref.ts +1 -1
  433. package/src/client/router.ts +299 -72
  434. package/src/client/rsc-fetch.ts +97 -8
  435. package/src/client/segment-cache.ts +1 -1
  436. package/src/client/segment-outlet.tsx +86 -0
  437. package/src/client/ssr-data.ts +13 -5
  438. package/src/client/stale-reload.ts +72 -3
  439. package/src/client/top-loader.tsx +18 -6
  440. package/src/client/use-link-status.ts +7 -7
  441. package/src/client/use-params.ts +7 -5
  442. package/src/client/{use-navigation-pending.ts → use-pending-navigation.ts} +6 -6
  443. package/src/client/use-query-states.ts +9 -3
  444. package/src/client/use-router.ts +1 -1
  445. package/src/codec.ts +49 -0
  446. package/src/config-types.ts +264 -0
  447. package/src/config-validation.ts +303 -0
  448. package/src/content/index.ts +5 -13
  449. package/src/cookies/define-cookie.ts +78 -25
  450. package/src/cookies/index.ts +8 -0
  451. package/src/fonts/bundle.ts +142 -0
  452. package/src/fonts/css.ts +2 -1
  453. package/src/fonts/dev-middleware.ts +74 -0
  454. package/src/fonts/pipeline.ts +275 -0
  455. package/src/fonts/transform.ts +353 -0
  456. package/src/fonts/types.ts +50 -1
  457. package/src/fonts/virtual-modules.ts +159 -0
  458. package/src/index.ts +314 -355
  459. package/src/plugin-context.ts +240 -0
  460. package/src/plugins/adapter-build.ts +9 -3
  461. package/src/plugins/build-manifest.ts +13 -2
  462. package/src/plugins/build-report.ts +3 -3
  463. package/src/plugins/client-chunks.ts +65 -0
  464. package/src/plugins/content.ts +1 -1
  465. package/src/plugins/dev-404-page.ts +418 -0
  466. package/src/plugins/dev-browser-logs.ts +288 -0
  467. package/src/plugins/dev-error-overlay.ts +286 -42
  468. package/src/plugins/dev-error-page.ts +536 -0
  469. package/src/plugins/dev-logs.ts +1 -1
  470. package/src/plugins/dev-server.ts +146 -19
  471. package/src/plugins/dev-terminal-error.ts +217 -0
  472. package/src/plugins/entries.ts +111 -10
  473. package/src/plugins/fonts.ts +133 -638
  474. package/src/plugins/mdx.ts +1 -1
  475. package/src/plugins/routing.ts +213 -31
  476. package/src/plugins/server-action-exports.ts +1 -1
  477. package/src/plugins/server-bundle.ts +32 -1
  478. package/src/plugins/shims.ts +136 -35
  479. package/src/plugins/static-build.ts +17 -11
  480. package/src/routing/codegen.ts +273 -105
  481. package/src/routing/convention-lint.ts +356 -0
  482. package/src/routing/index.ts +2 -0
  483. package/src/routing/scanner.ts +93 -23
  484. package/src/routing/segment-classify.ts +89 -0
  485. package/src/routing/status-file-lint.ts +3 -2
  486. package/src/routing/types.ts +17 -4
  487. package/src/rsc-runtime/rsc.ts +2 -0
  488. package/src/rsc-runtime/ssr.ts +50 -0
  489. package/src/rsc-runtime/vendor-types.d.ts +7 -0
  490. package/src/{search-params/codecs.ts → schema-bridge.ts} +57 -20
  491. package/src/search-params/define.ts +482 -0
  492. package/src/search-params/index.ts +14 -20
  493. package/src/search-params/registry.ts +2 -2
  494. package/src/search-params/wrappers.ts +85 -0
  495. package/src/segment-params/define.ts +279 -0
  496. package/src/segment-params/index.ts +9 -0
  497. package/src/server/access-gate.tsx +70 -29
  498. package/src/server/action-client.ts +88 -15
  499. package/src/server/action-encryption.ts +144 -0
  500. package/src/server/action-handler.ts +53 -6
  501. package/src/server/actions.ts +10 -9
  502. package/src/server/als-registry.ts +34 -6
  503. package/src/server/build-manifest.ts +10 -4
  504. package/src/server/compress.ts +25 -7
  505. package/src/server/debug.ts +1 -1
  506. package/src/server/default-logger.ts +99 -0
  507. package/src/server/deny-page-resolver.ts +154 -0
  508. package/src/server/deny-renderer.ts +24 -38
  509. package/src/server/dev-holding-server.ts +185 -0
  510. package/src/server/dev-source-map.ts +31 -0
  511. package/src/server/dev-warnings.ts +4 -49
  512. package/src/server/early-hints.ts +36 -15
  513. package/src/server/error-boundary-wrapper.ts +74 -22
  514. package/src/server/fallback-error.ts +74 -102
  515. package/src/server/flight-injection-state.ts +113 -0
  516. package/src/server/flight-scripts.ts +62 -0
  517. package/src/server/flush.ts +2 -1
  518. package/src/server/form-data.ts +76 -0
  519. package/src/server/html-injectors.ts +280 -120
  520. package/src/server/index.ts +25 -177
  521. package/src/server/internal.ts +169 -0
  522. package/src/server/logger.ts +44 -36
  523. package/src/server/middleware-runner.ts +31 -4
  524. package/src/server/node-stream-transforms.ts +509 -0
  525. package/src/server/page-deny-boundary.tsx +56 -0
  526. package/src/server/pipeline-interception.ts +17 -16
  527. package/src/server/pipeline-metadata.ts +13 -0
  528. package/src/server/pipeline.ts +261 -66
  529. package/src/server/primitives.ts +111 -28
  530. package/src/server/render-timeout.ts +108 -0
  531. package/src/server/request-context.ts +293 -132
  532. package/src/server/route-element-builder.ts +283 -191
  533. package/src/server/route-handler.ts +24 -4
  534. package/src/server/route-matcher.ts +31 -20
  535. package/src/server/rsc-entry/api-handler.ts +15 -16
  536. package/src/server/rsc-entry/error-renderer.ts +305 -89
  537. package/src/server/rsc-entry/helpers.ts +134 -5
  538. package/src/server/rsc-entry/index.ts +304 -111
  539. package/src/server/rsc-entry/rsc-payload.ts +65 -18
  540. package/src/server/rsc-entry/rsc-stream.ts +81 -13
  541. package/src/server/rsc-entry/ssr-bridge.ts +14 -5
  542. package/src/server/rsc-entry/ssr-renderer.ts +171 -38
  543. package/src/server/safe-load.ts +60 -0
  544. package/src/server/sensitive-fields.ts +230 -0
  545. package/src/server/sitemap-generator.ts +338 -0
  546. package/src/server/sitemap-handler.ts +126 -0
  547. package/src/server/slot-resolver.ts +244 -229
  548. package/src/server/ssr-entry.ts +215 -32
  549. package/src/server/ssr-render.ts +289 -67
  550. package/src/server/ssr-wrappers.tsx +139 -0
  551. package/src/server/status-code-resolver.ts +1 -1
  552. package/src/server/stream-utils.ts +213 -0
  553. package/src/server/tracing.ts +20 -9
  554. package/src/server/tree-builder.ts +92 -58
  555. package/src/server/types.ts +3 -6
  556. package/src/server/version-skew.ts +104 -0
  557. package/src/shared/merge-search-params.ts +55 -0
  558. package/src/shims/font-google.ts +1 -1
  559. package/src/shims/font-local.ts +34 -0
  560. package/src/shims/headers.ts +5 -1
  561. package/src/shims/navigation-client.ts +1 -1
  562. package/src/shims/navigation.ts +7 -2
  563. package/src/utils/directive-parser.ts +5 -2
  564. package/src/utils/state-machine.ts +111 -0
  565. package/dist/_chunks/als-registry-B7DbZ2hS.js.map +0 -1
  566. package/dist/_chunks/debug-gwlJkDuf.js.map +0 -1
  567. package/dist/_chunks/format-DviM89f0.js.map +0 -1
  568. package/dist/_chunks/interception-BOoWmLUA.js.map +0 -1
  569. package/dist/_chunks/request-context-DIkVh_jG.js +0 -330
  570. package/dist/_chunks/request-context-DIkVh_jG.js.map +0 -1
  571. package/dist/_chunks/tracing-CemImE6h.js.map +0 -1
  572. package/dist/_chunks/use-cookie-DX-l1_5E.js +0 -91
  573. package/dist/_chunks/use-cookie-DX-l1_5E.js.map +0 -1
  574. package/dist/_chunks/use-query-states-D5KaffOK.js.map +0 -1
  575. package/dist/cache/register-cached-function.d.ts +0 -17
  576. package/dist/cache/register-cached-function.d.ts.map +0 -1
  577. package/dist/client/browser-entry.d.ts +0 -21
  578. package/dist/client/browser-entry.d.ts.map +0 -1
  579. package/dist/client/link-status-provider.d.ts +0 -11
  580. package/dist/client/link-status-provider.d.ts.map +0 -1
  581. package/dist/client/transition-root.d.ts.map +0 -1
  582. package/dist/client/use-navigation-pending.d.ts.map +0 -1
  583. package/dist/cookies/index.js.map +0 -1
  584. package/dist/plugins/cache-transform.d.ts +0 -36
  585. package/dist/plugins/cache-transform.d.ts.map +0 -1
  586. package/dist/plugins/dynamic-transform.d.ts +0 -72
  587. package/dist/plugins/dynamic-transform.d.ts.map +0 -1
  588. package/dist/search-params/analyze.d.ts +0 -54
  589. package/dist/search-params/analyze.d.ts.map +0 -1
  590. package/dist/search-params/builtin-codecs.d.ts +0 -105
  591. package/dist/search-params/builtin-codecs.d.ts.map +0 -1
  592. package/dist/search-params/codecs.d.ts +0 -53
  593. package/dist/search-params/codecs.d.ts.map +0 -1
  594. package/dist/search-params/create.d.ts +0 -106
  595. package/dist/search-params/create.d.ts.map +0 -1
  596. package/dist/server/prerender.d.ts +0 -77
  597. package/dist/server/prerender.d.ts.map +0 -1
  598. package/dist/server/response-cache.d.ts +0 -54
  599. package/dist/server/response-cache.d.ts.map +0 -1
  600. package/src/cache/register-cached-function.ts +0 -103
  601. package/src/client/browser-entry.ts +0 -678
  602. package/src/client/link-status-provider.tsx +0 -30
  603. package/src/client/transition-root.tsx +0 -166
  604. package/src/plugins/cache-transform.ts +0 -199
  605. package/src/plugins/dynamic-transform.ts +0 -161
  606. package/src/search-params/analyze.ts +0 -192
  607. package/src/search-params/builtin-codecs.ts +0 -228
  608. package/src/search-params/create.ts +0 -321
  609. package/src/server/prerender.ts +0 -139
  610. package/src/server/response-cache.ts +0 -410
@@ -0,0 +1,890 @@
1
+ import { t as bindUseQueryStates } from "../_chunks/use-query-states-BiV5GJgm.js";
2
+ import { n as getSsrData, r as setSsrData, t as clearSsrData } from "../_chunks/ssr-data-DzuI0bIV.js";
3
+ import { TimberErrorBoundary } from "./error-boundary.js";
4
+ import { n as useSegmentContext, t as SegmentProvider } from "../_chunks/segment-context-fHFLF1PE.js";
5
+ import { a as getNavigationState, f as getRouter, i as NavigationProvider, m as setGlobalRouter, o as setNavigationState, p as getRouterOrNull, r as setHardNavigating, t as setCurrentParams } from "../_chunks/use-params-Br9YSUFV.js";
6
+ import { cloneElement, isValidElement } from "react";
7
+ //#region src/client/segment-cache.ts
8
+ /**
9
+ * Maintains the client-side segment tree representing currently mounted
10
+ * layouts and pages. Used for navigation reconciliation — the router diffs
11
+ * new routes against this tree to determine which segments to re-fetch.
12
+ */
13
+ var SegmentCache = class {
14
+ root;
15
+ get(segment) {
16
+ if (segment === "/" || segment === this.root?.segment) return this.root;
17
+ }
18
+ set(segment, node) {
19
+ if (segment === "/" || !this.root) this.root = node;
20
+ }
21
+ clear() {
22
+ this.root = void 0;
23
+ }
24
+ /**
25
+ * Serialize the mounted segment tree for the X-Timber-State-Tree header.
26
+ * Only includes sync segments — async segments are excluded because the
27
+ * server must always re-render them (they may depend on request context).
28
+ *
29
+ * When mergeableFilter is provided, only segments whose paths are in the
30
+ * set are included. This ensures the server only skips segments that the
31
+ * client can actually merge (i.e., segments whose cached element tree
32
+ * contains an inner SegmentProvider the merger can splice into).
33
+ *
34
+ * This is a performance optimization only, NOT a security boundary.
35
+ * The server always runs all access.ts files regardless of the state tree.
36
+ */
37
+ serializeStateTree(mergeableFilter) {
38
+ const segments = [];
39
+ if (this.root) collectSyncSegments(this.root, segments, mergeableFilter);
40
+ return { segments };
41
+ }
42
+ };
43
+ /** Recursively collect sync segment paths from the tree */
44
+ function collectSyncSegments(node, out, mergeableFilter) {
45
+ if (!node.isAsync && (!mergeableFilter || mergeableFilter.has(node.segment))) out.push(node.segment);
46
+ for (const child of node.children.values()) collectSyncSegments(child, out, mergeableFilter);
47
+ }
48
+ /**
49
+ * Build a SegmentNode tree from flat segment metadata.
50
+ *
51
+ * Takes an ordered list of segment descriptors (root → leaf) from the
52
+ * server's X-Timber-Segments header and constructs the hierarchical
53
+ * tree structure that SegmentCache expects.
54
+ *
55
+ * Each segment is nested as a child of the previous one, forming a
56
+ * linear chain from root to leaf. The leaf segment (page) is excluded
57
+ * from the tree — pages are never cached across navigations.
58
+ */
59
+ function buildSegmentTree(segments) {
60
+ if (segments.length === 0) return void 0;
61
+ const layouts = segments.length > 1 ? segments.slice(0, -1) : segments;
62
+ let root;
63
+ let parent;
64
+ for (const info of layouts) {
65
+ const node = {
66
+ segment: info.path,
67
+ payload: null,
68
+ isAsync: info.isAsync,
69
+ children: /* @__PURE__ */ new Map()
70
+ };
71
+ if (!root) root = node;
72
+ if (parent) parent.children.set(info.path, node);
73
+ parent = node;
74
+ }
75
+ return root;
76
+ }
77
+ /**
78
+ * Short-lived cache for hover-triggered prefetches. Entries expire after
79
+ * 30 seconds. When a link is clicked, the prefetched payload is consumed
80
+ * (moved to the history stack) and removed from this cache.
81
+ *
82
+ * timber.js does NOT prefetch on viewport intersection — only explicit
83
+ * hover on <Link prefetch> triggers a prefetch.
84
+ */
85
+ var PrefetchCache = class PrefetchCache {
86
+ static TTL_MS = 3e4;
87
+ entries = /* @__PURE__ */ new Map();
88
+ set(url, result) {
89
+ this.entries.set(url, {
90
+ result,
91
+ expiresAt: Date.now() + PrefetchCache.TTL_MS
92
+ });
93
+ }
94
+ get(url) {
95
+ const entry = this.entries.get(url);
96
+ if (!entry) return void 0;
97
+ if (Date.now() >= entry.expiresAt) {
98
+ this.entries.delete(url);
99
+ return;
100
+ }
101
+ return entry.result;
102
+ }
103
+ /** Get and remove the entry (used when navigation consumes a prefetch) */
104
+ consume(url) {
105
+ const result = this.get(url);
106
+ if (result !== void 0) this.entries.delete(url);
107
+ return result;
108
+ }
109
+ };
110
+ //#endregion
111
+ //#region src/client/history.ts
112
+ /**
113
+ * Session-lived history stack keyed by URL. Enables instant back/forward
114
+ * navigation without a server roundtrip.
115
+ *
116
+ * On forward navigation, the new page's payload is pushed onto the stack.
117
+ * On popstate, the cached payload is replayed instantly.
118
+ *
119
+ * Supports two keying modes:
120
+ * - **URL-keyed** (default): entries keyed by pathname + search.
121
+ * Used with the History API fallback.
122
+ * - **Entry-key + URL**: when the Navigation API is available,
123
+ * entries can also be stored by Navigation entry key for
124
+ * disambiguation of duplicate URLs in the history stack.
125
+ * Falls back to URL lookup when entry key is not found.
126
+ *
127
+ * Scroll positions are stored in history.state or Navigation API entry
128
+ * state, not in this stack — see design/19-client-navigation.md §Scroll Restoration.
129
+ *
130
+ * Entries persist for the session duration (no expiry) and are cleared
131
+ * when the tab is closed — matching browser back-button behavior.
132
+ */
133
+ var HistoryStack = class {
134
+ entries = /* @__PURE__ */ new Map();
135
+ /** Entries keyed by Navigation API entry key for duplicate URL disambiguation. */
136
+ entryKeyMap = /* @__PURE__ */ new Map();
137
+ push(url, entry, entryKey) {
138
+ this.entries.set(url, entry);
139
+ if (entryKey) this.entryKeyMap.set(entryKey, entry);
140
+ }
141
+ /**
142
+ * Get an entry. When an entry key is provided (Navigation API),
143
+ * tries the entry-key map first for accurate disambiguation of
144
+ * duplicate URLs, then falls back to URL lookup.
145
+ */
146
+ get(url, entryKey) {
147
+ if (entryKey) {
148
+ const byKey = this.entryKeyMap.get(entryKey);
149
+ if (byKey) return byKey;
150
+ }
151
+ return this.entries.get(url);
152
+ }
153
+ has(url) {
154
+ return this.entries.has(url);
155
+ }
156
+ };
157
+ //#endregion
158
+ //#region src/client/segment-merger.ts
159
+ /**
160
+ * Segment Merger — client-side tree merging for partial RSC payloads.
161
+ *
162
+ * When the server skips rendering sync layouts (because the client already
163
+ * has them cached), the RSC payload is missing outer segment wrappers.
164
+ * This module reconstructs the full element tree by splicing the partial
165
+ * payload into cached segment subtrees.
166
+ *
167
+ * The approach:
168
+ * 1. After each full RSC payload render, walk the decoded element tree
169
+ * and cache each segment's subtree (identified by SegmentProvider boundaries)
170
+ * 2. When a partial payload arrives, wrap it with cached segment elements
171
+ * using React.cloneElement to preserve component identity
172
+ *
173
+ * React.cloneElement preserves the element's `type` — React sees the same
174
+ * component at the same tree position and reconciles (preserving state)
175
+ * rather than remounting. This is how layout state survives navigations.
176
+ *
177
+ * Design docs: 19-client-navigation.md §"Navigation Reconciliation"
178
+ * Security: access.ts runs on the server regardless of skipping — this
179
+ * is a performance optimization only. See 13-security.md.
180
+ */
181
+ /**
182
+ * Cache of React element subtrees per segment path.
183
+ * Updated after each navigation with the full decoded RSC element tree.
184
+ */
185
+ var SegmentElementCache = class {
186
+ entries = /* @__PURE__ */ new Map();
187
+ get(segmentPath) {
188
+ return this.entries.get(segmentPath);
189
+ }
190
+ set(segmentPath, entry) {
191
+ this.entries.set(segmentPath, entry);
192
+ }
193
+ has(segmentPath) {
194
+ return this.entries.has(segmentPath);
195
+ }
196
+ clear() {
197
+ this.entries.clear();
198
+ }
199
+ get size() {
200
+ return this.entries.size;
201
+ }
202
+ /**
203
+ * Get the set of segment paths that are safe for the server to skip.
204
+ * Only segments with an inner SegmentProvider (hasMergeableChild) are
205
+ * included — the merger can only replace inner SegmentProviders, not
206
+ * pages embedded in layout output. Used to filter the state tree.
207
+ *
208
+ * Returns an empty set if the element cache is empty (no elements
209
+ * cached yet). This is the safe default — an empty set means no
210
+ * segments pass the filter, so the state tree is empty and the server
211
+ * does a full render. The element cache is populated lazily after the
212
+ * first SPA navigation (RSC-decoded elements from hydration are
213
+ * thenables that can't be walked until React resolves them).
214
+ */
215
+ getMergeablePaths() {
216
+ const paths = /* @__PURE__ */ new Set();
217
+ for (const [, entry] of this.entries) if (entry.hasMergeableChild) paths.add(entry.segmentPath);
218
+ return paths;
219
+ }
220
+ };
221
+ /**
222
+ * Check if a React element is a SegmentProvider by looking for the
223
+ * `segments` prop (an array of path segments). This is the only
224
+ * component that receives this prop shape.
225
+ */
226
+ function isSegmentProvider(element) {
227
+ if (!isValidElement(element)) return false;
228
+ const props = element.props;
229
+ return Array.isArray(props.segments);
230
+ }
231
+ /**
232
+ * Extract the segment path from a SegmentProvider element.
233
+ *
234
+ * Uses the `segmentId` prop if available (set by the server for route groups
235
+ * to distinguish siblings that share the same urlPath). Falls back to
236
+ * reconstructing from the `segments` array prop.
237
+ */
238
+ function getSegmentPath(element) {
239
+ const props = element.props;
240
+ if (props.segmentId) return props.segmentId;
241
+ const filtered = props.segments.filter(Boolean);
242
+ return filtered.length === 0 ? "/" : "/" + filtered.join("/");
243
+ }
244
+ /**
245
+ * Walk a React element tree and extract all SegmentProvider boundaries.
246
+ * Returns an ordered list of segment entries from outermost to innermost.
247
+ *
248
+ * This only finds SegmentProviders along the main children path — it does
249
+ * not descend into parallel routes/slots (those are separate subtrees).
250
+ */
251
+ function extractSegments(element) {
252
+ const segments = [];
253
+ walkForSegments(element, segments);
254
+ for (let i = 0; i < segments.length; i++) segments[i].hasMergeableChild = i < segments.length - 1;
255
+ return segments;
256
+ }
257
+ function walkForSegments(node, out) {
258
+ if (!isValidElement(node)) return;
259
+ const el = node;
260
+ const props = el.props;
261
+ if (isSegmentProvider(node)) {
262
+ out.push({
263
+ segmentPath: getSegmentPath(el),
264
+ element: el,
265
+ hasMergeableChild: false
266
+ });
267
+ walkChildren(props.children, out);
268
+ return;
269
+ }
270
+ walkChildren(props.children, out);
271
+ }
272
+ function walkChildren(children, out) {
273
+ if (children == null) return;
274
+ if (Array.isArray(children)) for (const child of children) walkForSegments(child, out);
275
+ else walkForSegments(children, out);
276
+ }
277
+ /**
278
+ * Cache all segment subtrees from a fully-rendered RSC element tree.
279
+ * Call this after every full RSC payload render (navigate, refresh, hydration).
280
+ */
281
+ function cacheSegmentElements(element, cache) {
282
+ const segments = extractSegments(element);
283
+ for (const entry of segments) cache.set(entry.segmentPath, entry);
284
+ }
285
+ function findSegmentProviderPath(node, targetPath) {
286
+ const children = node.props.children;
287
+ if (children == null) return null;
288
+ if (Array.isArray(children)) for (let i = 0; i < children.length; i++) {
289
+ const child = children[i];
290
+ if (!isValidElement(child)) continue;
291
+ if (isSegmentProvider(child)) {
292
+ if (!targetPath || getSegmentPath(child) === targetPath) return [{
293
+ element: node,
294
+ childIndex: i
295
+ }];
296
+ }
297
+ const deeper = findSegmentProviderPath(child, targetPath);
298
+ if (deeper) return [{
299
+ element: node,
300
+ childIndex: i
301
+ }, ...deeper];
302
+ }
303
+ else if (isValidElement(children)) {
304
+ if (isSegmentProvider(children)) {
305
+ if (!targetPath || getSegmentPath(children) === targetPath) return [{
306
+ element: node,
307
+ childIndex: -1
308
+ }];
309
+ }
310
+ const deeper = findSegmentProviderPath(children, targetPath);
311
+ if (deeper) return [{
312
+ element: node,
313
+ childIndex: -1
314
+ }, ...deeper];
315
+ }
316
+ return null;
317
+ }
318
+ /**
319
+ * Replace a nested SegmentProvider within a cached element tree with
320
+ * new content. Uses cloneElement along the path to produce a new tree
321
+ * with preserved component identity at every level except the replaced node.
322
+ *
323
+ * @param cachedElement The cached SegmentProvider element for this segment
324
+ * @param newInnerContent The new React element to splice in at the inner segment position
325
+ * @param innerSegmentPath The path of the inner segment to replace (optional — replaces first found)
326
+ * @returns New element tree with the inner segment replaced
327
+ */
328
+ function replaceInnerSegment(cachedElement, newInnerContent, innerSegmentPath) {
329
+ const path = findSegmentProviderPath(cachedElement, innerSegmentPath);
330
+ if (!path || path.length === 0) return cachedElement;
331
+ let replacement = newInnerContent;
332
+ for (let i = path.length - 1; i >= 0; i--) {
333
+ const { element, childIndex } = path[i];
334
+ if (childIndex === -1) replacement = cloneElement(element, {}, replacement);
335
+ else {
336
+ const newChildren = [...element.props.children];
337
+ newChildren[childIndex] = replacement;
338
+ replacement = cloneElement(element, {}, ...newChildren);
339
+ }
340
+ }
341
+ return replacement;
342
+ }
343
+ /**
344
+ * Merge a partial RSC payload with cached segment elements.
345
+ *
346
+ * When the server skips segments, the partial payload starts from the
347
+ * first non-skipped segment. This function wraps it with cached elements
348
+ * for the skipped segments, producing a full tree that React can
349
+ * reconcile with the mounted tree (preserving layout state).
350
+ *
351
+ * @param partialPayload The RSC payload element (may be partial)
352
+ * @param skippedSegments Ordered list of segment paths that were skipped (outermost first)
353
+ * @param cache The segment element cache
354
+ * @returns The merged full element tree, or the partial payload if merging isn't possible
355
+ */
356
+ function mergeSegmentTree(partialPayload, skippedSegments, cache) {
357
+ if (!isValidElement(partialPayload)) return partialPayload;
358
+ if (skippedSegments.length === 0) return partialPayload;
359
+ let result = partialPayload;
360
+ for (let i = skippedSegments.length - 1; i >= 0; i--) {
361
+ const segmentPath = skippedSegments[i];
362
+ const cached = cache.get(segmentPath);
363
+ if (!cached) return partialPayload;
364
+ result = replaceInnerSegment(cached.element, result);
365
+ }
366
+ return result;
367
+ }
368
+ //#endregion
369
+ //#region src/client/rsc-fetch.ts
370
+ var RSC_CONTENT_TYPE = "text/x-component";
371
+ /**
372
+ * Generate a short random cache-busting ID (5 chars, a-z0-9).
373
+ * Matches the format Next.js uses for _rsc params.
374
+ */
375
+ function generateCacheBustId() {
376
+ const chars = "abcdefghijklmnopqrstuvwxyz0123456789";
377
+ let id = "";
378
+ for (let i = 0; i < 5; i++) id += chars[Math.random() * 36 | 0];
379
+ return id;
380
+ }
381
+ /**
382
+ * Append a `_rsc=<id>` query parameter to the URL.
383
+ * Follows Next.js's pattern — prevents CDN/browser from serving cached HTML
384
+ * for RSC navigation requests and signals that this is an RSC fetch.
385
+ */
386
+ function appendRscParam(url) {
387
+ return `${url}${url.includes("?") ? "&" : "?"}_rsc=${generateCacheBustId()}`;
388
+ }
389
+ /**
390
+ * The client's deployment ID, set at bootstrap from the runtime config.
391
+ * Sent with every RSC/action request for version skew detection.
392
+ * Null in dev mode. See TIM-446.
393
+ */
394
+ var clientDeploymentId = null;
395
+ /** Header name used by the server to signal a version skew reload. */
396
+ var RELOAD_HEADER = "X-Timber-Reload";
397
+ /** Header name for the client's deployment ID. */
398
+ var DEPLOYMENT_ID_HEADER = "X-Timber-Deployment-Id";
399
+ /**
400
+ * Check if a response signals a version skew reload.
401
+ * Triggers a full page reload if the server indicates the client is stale.
402
+ */
403
+ function checkReloadSignal(response) {
404
+ return response.headers.get(RELOAD_HEADER) === "1";
405
+ }
406
+ function buildRscHeaders(stateTree, currentUrl) {
407
+ const headers = { Accept: RSC_CONTENT_TYPE };
408
+ if (stateTree) headers["X-Timber-State-Tree"] = JSON.stringify(stateTree);
409
+ if (currentUrl) headers["X-Timber-URL"] = currentUrl;
410
+ if (clientDeploymentId) headers[DEPLOYMENT_ID_HEADER] = clientDeploymentId;
411
+ return headers;
412
+ }
413
+ /**
414
+ * Extract head elements from the X-Timber-Head response header.
415
+ * Returns null if the header is missing or malformed.
416
+ */
417
+ function extractHeadElements(response) {
418
+ const header = response.headers.get("X-Timber-Head");
419
+ if (!header) return null;
420
+ try {
421
+ return JSON.parse(decodeURIComponent(header));
422
+ } catch {
423
+ return null;
424
+ }
425
+ }
426
+ /**
427
+ * Extract segment metadata from the X-Timber-Segments response header.
428
+ * Returns null if the header is missing or malformed.
429
+ *
430
+ * Format: JSON array of {path, isAsync} objects describing the rendered
431
+ * segment chain from root to leaf. Used to populate the client-side
432
+ * segment cache for state tree diffing on subsequent navigations.
433
+ */
434
+ function extractSegmentInfo(response) {
435
+ const header = response.headers.get("X-Timber-Segments");
436
+ if (!header) return null;
437
+ try {
438
+ return JSON.parse(header);
439
+ } catch {
440
+ return null;
441
+ }
442
+ }
443
+ /**
444
+ * Extract skipped segment paths from the X-Timber-Skipped-Segments header.
445
+ * Returns null if the header is missing or malformed.
446
+ *
447
+ * When the server skips sync layouts the client already has cached,
448
+ * it sends this header listing the skipped segment paths (outermost first).
449
+ * The client uses this to merge the partial payload with cached segments.
450
+ */
451
+ function extractSkippedSegments(response) {
452
+ const header = response.headers.get("X-Timber-Skipped-Segments");
453
+ if (!header) return null;
454
+ try {
455
+ const parsed = JSON.parse(header);
456
+ return Array.isArray(parsed) ? parsed : null;
457
+ } catch {
458
+ return null;
459
+ }
460
+ }
461
+ /**
462
+ * Extract route params from the X-Timber-Params response header.
463
+ * Returns null if the header is missing or malformed.
464
+ *
465
+ * Used to populate useSegmentParams() after client-side navigation.
466
+ */
467
+ function extractParams(response) {
468
+ const header = response.headers.get("X-Timber-Params");
469
+ if (!header) return null;
470
+ try {
471
+ return JSON.parse(header);
472
+ } catch {
473
+ return null;
474
+ }
475
+ }
476
+ /**
477
+ * Thrown when an RSC payload response contains X-Timber-Redirect header.
478
+ * Caught in navigate() to trigger a soft router navigation to the redirect target.
479
+ */
480
+ var RedirectError = class extends Error {
481
+ redirectUrl;
482
+ constructor(url) {
483
+ super(`Server redirect to ${url}`);
484
+ this.redirectUrl = url;
485
+ }
486
+ };
487
+ /**
488
+ * Thrown when the server signals a version skew (X-Timber-Reload header).
489
+ * Caught in navigate() to trigger a full page reload via triggerStaleReload().
490
+ * See TIM-446.
491
+ */
492
+ var VersionSkewError = class extends Error {
493
+ constructor() {
494
+ super("Version skew detected — server has been redeployed");
495
+ }
496
+ };
497
+ /**
498
+ * Thrown when the server returns an error for an RSC payload request.
499
+ * The server sends X-Timber-Error header and a JSON body instead of a
500
+ * broken RSC stream for any RenderError (4xx or 5xx). Caught in
501
+ * navigate() to trigger a hard navigation so the server can render
502
+ * the error page as HTML.
503
+ *
504
+ * See design/10-error-handling.md §"Error Page Rendering for Client Navigation"
505
+ */
506
+ var ServerErrorResponse = class extends Error {
507
+ status;
508
+ url;
509
+ constructor(status, url) {
510
+ super(`Server error ${status} during navigation to ${url}`);
511
+ this.status = status;
512
+ this.url = url;
513
+ }
514
+ };
515
+ /**
516
+ * Fetch an RSC payload from the server. If a decodeRsc function is provided,
517
+ * the response is decoded into a React element tree via createFromFetch.
518
+ * Otherwise, the raw response text is returned (test mode).
519
+ *
520
+ * Also extracts head elements from the X-Timber-Head response header
521
+ * so the client can update document.title and <meta> tags after navigation.
522
+ */
523
+ async function fetchRscPayload(url, deps, stateTree, currentUrl, signal) {
524
+ const rscUrl = appendRscParam(url);
525
+ const headers = buildRscHeaders(stateTree, currentUrl);
526
+ if (deps.decodeRsc) {
527
+ const fetchPromise = deps.fetch(rscUrl, {
528
+ headers,
529
+ redirect: "manual",
530
+ signal
531
+ });
532
+ let headElements = null;
533
+ let segmentInfo = null;
534
+ let params = null;
535
+ let skippedSegments = null;
536
+ const wrappedPromise = fetchPromise.then((response) => {
537
+ if (checkReloadSignal(response)) throw new VersionSkewError();
538
+ const redirectLocation = response.headers.get("X-Timber-Redirect") || (response.status >= 300 && response.status < 400 ? response.headers.get("Location") : null);
539
+ if (redirectLocation) throw new RedirectError(redirectLocation);
540
+ if (response.headers.get("X-Timber-Error") === "1") throw new ServerErrorResponse(response.status, url);
541
+ headElements = extractHeadElements(response);
542
+ segmentInfo = extractSegmentInfo(response);
543
+ params = extractParams(response);
544
+ skippedSegments = extractSkippedSegments(response);
545
+ return response;
546
+ });
547
+ await wrappedPromise;
548
+ return {
549
+ payload: await deps.decodeRsc(wrappedPromise),
550
+ headElements,
551
+ segmentInfo,
552
+ params,
553
+ skippedSegments
554
+ };
555
+ }
556
+ const response = await deps.fetch(rscUrl, {
557
+ headers,
558
+ redirect: "manual",
559
+ signal
560
+ });
561
+ if (response.status >= 300 && response.status < 400) {
562
+ const location = response.headers.get("Location");
563
+ if (location) throw new RedirectError(location);
564
+ }
565
+ return {
566
+ payload: await response.text(),
567
+ headElements: extractHeadElements(response),
568
+ segmentInfo: extractSegmentInfo(response),
569
+ params: extractParams(response),
570
+ skippedSegments: extractSkippedSegments(response)
571
+ };
572
+ }
573
+ //#endregion
574
+ //#region src/client/router.ts
575
+ /**
576
+ * Check if an error is an abort error (connection closed / fetch aborted).
577
+ * Browsers throw DOMException with name 'AbortError' when a fetch is aborted.
578
+ */
579
+ function isAbortError(error) {
580
+ if (error instanceof DOMException && error.name === "AbortError") return true;
581
+ if (error instanceof Error && error.name === "AbortError") return true;
582
+ return false;
583
+ }
584
+ function createRouter(deps) {
585
+ const segmentCache = new SegmentCache();
586
+ const prefetchCache = new PrefetchCache();
587
+ const historyStack = new HistoryStack();
588
+ const segmentElementCache = new SegmentElementCache();
589
+ let routerPhase = { phase: "idle" };
590
+ const pendingListeners = /* @__PURE__ */ new Set();
591
+ let currentNavAbort = null;
592
+ /**
593
+ * Create a new AbortController for a navigation, aborting any
594
+ * previous in-flight navigation. Optionally links to an external
595
+ * signal (e.g., from the Navigation API's NavigateEvent.signal).
596
+ */
597
+ function createNavAbort(externalSignal) {
598
+ currentNavAbort?.abort();
599
+ const controller = new AbortController();
600
+ currentNavAbort = controller;
601
+ if (externalSignal) if (externalSignal.aborted) controller.abort();
602
+ else externalSignal.addEventListener("abort", () => controller.abort(), { once: true });
603
+ return controller;
604
+ }
605
+ function setPending(value, url) {
606
+ const next = value && url ? {
607
+ phase: "navigating",
608
+ targetUrl: url
609
+ } : { phase: "idle" };
610
+ if (routerPhase.phase === next.phase && (routerPhase.phase === "idle" || routerPhase.phase === "navigating" && next.phase === "navigating" && routerPhase.targetUrl === next.targetUrl)) return;
611
+ routerPhase = next;
612
+ for (const listener of pendingListeners) listener(value);
613
+ }
614
+ /** Update the segment cache from server-provided segment metadata. */
615
+ function updateSegmentCache(segmentInfo) {
616
+ if (!segmentInfo || segmentInfo.length === 0) return;
617
+ const tree = buildSegmentTree(segmentInfo);
618
+ if (tree) segmentCache.set("/", tree);
619
+ }
620
+ /** Render a decoded RSC payload into the DOM if a renderer is available. */
621
+ function renderPayload(payload, navState) {
622
+ if (deps.renderRoot) deps.renderRoot(payload, navState);
623
+ }
624
+ /**
625
+ * Merge a partial RSC payload with cached segment elements if segments
626
+ * were skipped, then cache segments from the (merged) payload.
627
+ * Returns the merged payload ready for rendering.
628
+ */
629
+ function mergeAndCachePayload(payload, skippedSegments) {
630
+ let merged = payload;
631
+ if (skippedSegments && skippedSegments.length > 0) merged = mergeSegmentTree(payload, skippedSegments, segmentElementCache);
632
+ cacheSegmentElements(merged, segmentElementCache);
633
+ return merged;
634
+ }
635
+ /**
636
+ * Update navigation state (params + pathname) for the next render.
637
+ *
638
+ * Sets the module-level fallback (for tests and SSR) and the
639
+ * globalThis bridge, then returns the NavigationState so callers
640
+ * can pass it explicitly to renderRoot/wrapPayload — eliminating
641
+ * temporal coupling with getNavigationState().
642
+ */
643
+ function updateNavigationState(params, url) {
644
+ const resolvedParams = params ?? {};
645
+ setCurrentParams(resolvedParams);
646
+ const navState = {
647
+ params: resolvedParams,
648
+ pathname: url.startsWith("http") ? new URL(url).pathname : url.split("?")[0] || "/"
649
+ };
650
+ setNavigationState(navState);
651
+ return navState;
652
+ }
653
+ /**
654
+ * Render a payload via navigateTransition (production) or renderRoot (tests).
655
+ * The perform callback should fetch data, update state, and return the
656
+ * FetchResult plus the NavigationState (so it can be passed explicitly
657
+ * to wrapPayload/renderRoot without temporal coupling).
658
+ */
659
+ async function renderViaTransition(url, perform) {
660
+ if (deps.navigateTransition) {
661
+ let headElements = null;
662
+ await deps.navigateTransition(url, async (wrapPayload) => {
663
+ const result = await perform();
664
+ headElements = result.headElements;
665
+ const merged = mergeAndCachePayload(result.payload, result.skippedSegments);
666
+ historyStack.push(url, {
667
+ payload: merged,
668
+ headElements: result.headElements,
669
+ params: result.params
670
+ });
671
+ return wrapPayload(merged, result.navState);
672
+ });
673
+ return headElements;
674
+ }
675
+ const result = await perform();
676
+ const merged = mergeAndCachePayload(result.payload, result.skippedSegments);
677
+ historyStack.push(url, {
678
+ payload: merged,
679
+ headElements: result.headElements,
680
+ params: result.params
681
+ });
682
+ renderPayload(merged, result.navState);
683
+ return result.headElements;
684
+ }
685
+ /** Apply head elements (title, meta tags) to the DOM if available. */
686
+ function applyHead(elements) {
687
+ if (elements && deps.applyHead) deps.applyHead(elements);
688
+ }
689
+ /** Run a callback after the next paint (after React commit). */
690
+ function afterPaint(callback) {
691
+ if (deps.afterPaint) deps.afterPaint(callback);
692
+ else callback();
693
+ }
694
+ /**
695
+ * Schedule scroll restoration after the next paint and fire the
696
+ * scroll-restored event. Used by navigate, popstate, and refresh.
697
+ */
698
+ function restoreScrollAfterPaint(scrollY) {
699
+ afterPaint(() => {
700
+ deps.scrollTo(0, scrollY);
701
+ window.dispatchEvent(new Event("timber:scroll-restored"));
702
+ });
703
+ }
704
+ /**
705
+ * Core navigation logic shared between the transition and fallback paths.
706
+ * Fetches the RSC payload, updates all state, and returns the result.
707
+ */
708
+ async function performNavigationFetch(url, options) {
709
+ const prefetched = prefetchCache.consume(url);
710
+ let result = prefetched ? {
711
+ payload: prefetched.payload,
712
+ headElements: prefetched.headElements,
713
+ segmentInfo: prefetched.segmentInfo ?? null,
714
+ params: prefetched.params ?? null,
715
+ skippedSegments: prefetched.skippedSegments ?? null
716
+ } : void 0;
717
+ if (result === void 0) {
718
+ const stateTree = segmentCache.serializeStateTree(segmentElementCache.getMergeablePaths());
719
+ const rawCurrentUrl = deps.getCurrentUrl();
720
+ result = await fetchRscPayload(url, deps, stateTree, rawCurrentUrl.startsWith("http") ? new URL(rawCurrentUrl).pathname : new URL(rawCurrentUrl, "http://localhost").pathname, options.signal);
721
+ }
722
+ if (!options.skipHistory) {
723
+ deps.setRouterNavigating?.(true);
724
+ if (options.replace) deps.replaceState({
725
+ timber: true,
726
+ scrollY: 0
727
+ }, "", url);
728
+ else deps.pushState({
729
+ timber: true,
730
+ scrollY: 0
731
+ }, "", url);
732
+ deps.setRouterNavigating?.(false);
733
+ }
734
+ updateSegmentCache(result.segmentInfo);
735
+ const navState = updateNavigationState(result.params, url);
736
+ return {
737
+ ...result,
738
+ navState
739
+ };
740
+ }
741
+ async function navigate(url, options = {}) {
742
+ const scroll = options.scroll !== false;
743
+ const replace = options.replace === true;
744
+ const externalSignal = options._signal;
745
+ const skipHistory = options._skipHistory === true;
746
+ const navAbort = createNavAbort(externalSignal);
747
+ const currentScrollY = deps.getScrollY();
748
+ if (deps.saveNavigationEntryScroll) deps.saveNavigationEntryScroll(currentScrollY);
749
+ else deps.replaceState({
750
+ timber: true,
751
+ scrollY: currentScrollY
752
+ }, "", deps.getCurrentUrl());
753
+ let effectiveSkipHistory = skipHistory;
754
+ if (!skipHistory && deps.navigationNavigate) {
755
+ deps.setRouterNavigating?.(true);
756
+ deps.navigationNavigate(url, replace);
757
+ deps.setRouterNavigating?.(false);
758
+ effectiveSkipHistory = true;
759
+ }
760
+ setPending(true, url);
761
+ try {
762
+ applyHead(await renderViaTransition(url, () => performNavigationFetch(url, {
763
+ replace,
764
+ signal: navAbort.signal,
765
+ skipHistory: effectiveSkipHistory
766
+ })));
767
+ window.dispatchEvent(new Event("timber:navigation-end"));
768
+ restoreScrollAfterPaint(scroll ? 0 : currentScrollY);
769
+ } catch (error) {
770
+ if (error instanceof VersionSkewError) {
771
+ setHardNavigating(true);
772
+ const { triggerStaleReload } = await import("../_chunks/stale-reload-BX5gL1r-.js");
773
+ triggerStaleReload();
774
+ return new Promise(() => {});
775
+ }
776
+ if (error instanceof RedirectError) {
777
+ setPending(false);
778
+ deps.completeRouterNavigation?.();
779
+ await navigate(error.redirectUrl, { replace: true });
780
+ return;
781
+ }
782
+ if (error instanceof ServerErrorResponse) {
783
+ setHardNavigating(true);
784
+ window.location.href = error.url;
785
+ return new Promise(() => {});
786
+ }
787
+ if (isAbortError(error)) return;
788
+ throw error;
789
+ } finally {
790
+ if (currentNavAbort === navAbort) currentNavAbort = null;
791
+ setPending(false);
792
+ deps.completeRouterNavigation?.();
793
+ }
794
+ }
795
+ async function refresh() {
796
+ const currentUrl = deps.getCurrentUrl();
797
+ const navAbort = createNavAbort();
798
+ setPending(true, currentUrl);
799
+ try {
800
+ applyHead(await renderViaTransition(currentUrl, async () => {
801
+ const result = await fetchRscPayload(currentUrl, deps, void 0, void 0, navAbort.signal);
802
+ updateSegmentCache(result.segmentInfo);
803
+ const navState = updateNavigationState(result.params, currentUrl);
804
+ return {
805
+ ...result,
806
+ navState
807
+ };
808
+ }));
809
+ } catch (error) {
810
+ if (isAbortError(error)) return;
811
+ throw error;
812
+ } finally {
813
+ if (currentNavAbort === navAbort) currentNavAbort = null;
814
+ setPending(false);
815
+ deps.completeRouterNavigation?.();
816
+ }
817
+ }
818
+ async function handlePopState(url, scrollY = 0, externalSignal) {
819
+ const entry = historyStack.get(url);
820
+ if (entry && entry.payload !== null) {
821
+ const navState = updateNavigationState(entry.params, url);
822
+ renderPayload(entry.payload, navState);
823
+ applyHead(entry.headElements);
824
+ restoreScrollAfterPaint(scrollY);
825
+ } else {
826
+ const navAbort = createNavAbort(externalSignal);
827
+ setPending(true, url);
828
+ try {
829
+ applyHead(await renderViaTransition(url, async () => {
830
+ const result = await fetchRscPayload(url, deps, segmentCache.serializeStateTree(segmentElementCache.getMergeablePaths()), void 0, navAbort.signal);
831
+ updateSegmentCache(result.segmentInfo);
832
+ const navState = updateNavigationState(result.params, url);
833
+ return {
834
+ ...result,
835
+ navState
836
+ };
837
+ }));
838
+ restoreScrollAfterPaint(scrollY);
839
+ } catch (error) {
840
+ if (isAbortError(error)) return;
841
+ throw error;
842
+ } finally {
843
+ if (currentNavAbort === navAbort) currentNavAbort = null;
844
+ setPending(false);
845
+ }
846
+ }
847
+ }
848
+ /**
849
+ * Prefetch an RSC payload for a URL and store it in the prefetch cache.
850
+ * Called on hover of <Link prefetch> elements.
851
+ */
852
+ function prefetch(url) {
853
+ if (prefetchCache.get(url) !== void 0) return;
854
+ if (historyStack.has(url)) return;
855
+ fetchRscPayload(url, deps, segmentCache.serializeStateTree(segmentElementCache.getMergeablePaths())).then((result) => {
856
+ prefetchCache.set(url, result);
857
+ }, () => {});
858
+ }
859
+ return {
860
+ navigate,
861
+ refresh,
862
+ handlePopState,
863
+ isPending: () => routerPhase.phase === "navigating",
864
+ getPendingUrl: () => routerPhase.phase === "navigating" ? routerPhase.targetUrl : null,
865
+ onPendingChange(listener) {
866
+ pendingListeners.add(listener);
867
+ return () => pendingListeners.delete(listener);
868
+ },
869
+ prefetch,
870
+ applyRevalidation(element, headElements) {
871
+ const currentUrl = deps.getCurrentUrl();
872
+ const merged = mergeAndCachePayload(element, null);
873
+ historyStack.push(currentUrl, {
874
+ payload: merged,
875
+ headElements
876
+ });
877
+ renderPayload(merged, getNavigationState());
878
+ applyHead(headElements);
879
+ },
880
+ initSegmentCache: (segments) => updateSegmentCache(segments),
881
+ cacheElementTree: (element) => cacheSegmentElements(element, segmentElementCache),
882
+ segmentCache,
883
+ prefetchCache,
884
+ historyStack
885
+ };
886
+ }
887
+ //#endregion
888
+ export { HistoryStack, NavigationProvider, PrefetchCache, SegmentCache, SegmentProvider, TimberErrorBoundary, bindUseQueryStates, clearSsrData, createRouter, getNavigationState, getRouter, getRouterOrNull, getSsrData, setCurrentParams, setGlobalRouter, setNavigationState, setSsrData, useSegmentContext };
889
+
890
+ //# sourceMappingURL=internal.js.map