@rangojs/router 0.0.0-experimental.22 → 0.0.0-experimental.24

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 (817) hide show
  1. package/dist/vite/index.js +1 -1
  2. package/package.json +1 -1
  3. package/src/router/loader-resolution.ts +1 -1
  4. package/src/router/match-result.ts +1 -2
  5. package/src/router/metrics.ts +126 -10
  6. package/src/router/middleware-types.ts +12 -0
  7. package/src/router/middleware.ts +104 -10
  8. package/src/router/segment-resolution/fresh.ts +18 -0
  9. package/src/router/segment-resolution/revalidation.ts +21 -6
  10. package/src/router.ts +12 -2
  11. package/src/rsc/rsc-rendering.ts +36 -6
  12. package/src/rsc/server-action.ts +21 -2
  13. package/src/server/context.ts +8 -2
  14. package/src/server/request-context.ts +11 -2
  15. package/dist/__internal.d.ts +0 -83
  16. package/dist/__internal.d.ts.map +0 -1
  17. package/dist/__internal.js +0 -19
  18. package/dist/__internal.js.map +0 -1
  19. package/dist/__mocks__/version.d.ts +0 -7
  20. package/dist/__mocks__/version.d.ts.map +0 -1
  21. package/dist/__mocks__/version.js +0 -7
  22. package/dist/__mocks__/version.js.map +0 -1
  23. package/dist/__tests__/client-href.test.d.ts +0 -2
  24. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  25. package/dist/__tests__/client-href.test.js +0 -74
  26. package/dist/__tests__/client-href.test.js.map +0 -1
  27. package/dist/__tests__/component-utils.test.d.ts +0 -2
  28. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  29. package/dist/__tests__/component-utils.test.js +0 -51
  30. package/dist/__tests__/component-utils.test.js.map +0 -1
  31. package/dist/__tests__/event-controller.test.d.ts +0 -2
  32. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  33. package/dist/__tests__/event-controller.test.js +0 -538
  34. package/dist/__tests__/event-controller.test.js.map +0 -1
  35. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  36. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  37. package/dist/__tests__/helpers/route-tree.js +0 -374
  38. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  39. package/dist/__tests__/match-result.test.d.ts +0 -2
  40. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  41. package/dist/__tests__/match-result.test.js +0 -154
  42. package/dist/__tests__/match-result.test.js.map +0 -1
  43. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  44. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  45. package/dist/__tests__/navigation-store.test.js +0 -440
  46. package/dist/__tests__/navigation-store.test.js.map +0 -1
  47. package/dist/__tests__/partial-update.test.d.ts +0 -2
  48. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  49. package/dist/__tests__/partial-update.test.js +0 -1009
  50. package/dist/__tests__/partial-update.test.js.map +0 -1
  51. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  52. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  53. package/dist/__tests__/reverse-types.test.js +0 -656
  54. package/dist/__tests__/reverse-types.test.js.map +0 -1
  55. package/dist/__tests__/route-definition.test.d.ts +0 -2
  56. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  57. package/dist/__tests__/route-definition.test.js +0 -55
  58. package/dist/__tests__/route-definition.test.js.map +0 -1
  59. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  60. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  61. package/dist/__tests__/router-helpers.test.js +0 -377
  62. package/dist/__tests__/router-helpers.test.js.map +0 -1
  63. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  64. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  65. package/dist/__tests__/router-integration-2.test.js +0 -426
  66. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  67. package/dist/__tests__/router-integration.test.d.ts +0 -2
  68. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  69. package/dist/__tests__/router-integration.test.js +0 -1051
  70. package/dist/__tests__/router-integration.test.js.map +0 -1
  71. package/dist/__tests__/search-params.test.d.ts +0 -5
  72. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  73. package/dist/__tests__/search-params.test.js +0 -306
  74. package/dist/__tests__/search-params.test.js.map +0 -1
  75. package/dist/__tests__/segment-system.test.d.ts +0 -2
  76. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  77. package/dist/__tests__/segment-system.test.js +0 -627
  78. package/dist/__tests__/segment-system.test.js.map +0 -1
  79. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  80. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  81. package/dist/__tests__/static-handler-types.test.js +0 -63
  82. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  83. package/dist/__tests__/urls.test.d.ts +0 -2
  84. package/dist/__tests__/urls.test.d.ts.map +0 -1
  85. package/dist/__tests__/urls.test.js +0 -421
  86. package/dist/__tests__/urls.test.js.map +0 -1
  87. package/dist/__tests__/use-mount.test.d.ts +0 -2
  88. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  89. package/dist/__tests__/use-mount.test.js +0 -35
  90. package/dist/__tests__/use-mount.test.js.map +0 -1
  91. package/dist/bin/rango.d.ts +0 -2
  92. package/dist/bin/rango.d.ts.map +0 -1
  93. package/dist/bin/rango.js.map +0 -1
  94. package/dist/browser/event-controller.d.ts +0 -191
  95. package/dist/browser/event-controller.d.ts.map +0 -1
  96. package/dist/browser/event-controller.js +0 -559
  97. package/dist/browser/event-controller.js.map +0 -1
  98. package/dist/browser/index.d.ts +0 -2
  99. package/dist/browser/index.d.ts.map +0 -1
  100. package/dist/browser/index.js +0 -14
  101. package/dist/browser/index.js.map +0 -1
  102. package/dist/browser/link-interceptor.d.ts +0 -38
  103. package/dist/browser/link-interceptor.d.ts.map +0 -1
  104. package/dist/browser/link-interceptor.js +0 -99
  105. package/dist/browser/link-interceptor.js.map +0 -1
  106. package/dist/browser/logging.d.ts +0 -10
  107. package/dist/browser/logging.d.ts.map +0 -1
  108. package/dist/browser/logging.js +0 -29
  109. package/dist/browser/logging.js.map +0 -1
  110. package/dist/browser/lru-cache.d.ts +0 -17
  111. package/dist/browser/lru-cache.d.ts.map +0 -1
  112. package/dist/browser/lru-cache.js +0 -50
  113. package/dist/browser/lru-cache.js.map +0 -1
  114. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  115. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  116. package/dist/browser/merge-segment-loaders.js +0 -102
  117. package/dist/browser/merge-segment-loaders.js.map +0 -1
  118. package/dist/browser/navigation-bridge.d.ts +0 -102
  119. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  120. package/dist/browser/navigation-bridge.js +0 -708
  121. package/dist/browser/navigation-bridge.js.map +0 -1
  122. package/dist/browser/navigation-client.d.ts +0 -25
  123. package/dist/browser/navigation-client.d.ts.map +0 -1
  124. package/dist/browser/navigation-client.js +0 -157
  125. package/dist/browser/navigation-client.js.map +0 -1
  126. package/dist/browser/navigation-store.d.ts +0 -101
  127. package/dist/browser/navigation-store.d.ts.map +0 -1
  128. package/dist/browser/navigation-store.js +0 -625
  129. package/dist/browser/navigation-store.js.map +0 -1
  130. package/dist/browser/partial-update.d.ts +0 -75
  131. package/dist/browser/partial-update.d.ts.map +0 -1
  132. package/dist/browser/partial-update.js +0 -426
  133. package/dist/browser/partial-update.js.map +0 -1
  134. package/dist/browser/react/Link.d.ts +0 -86
  135. package/dist/browser/react/Link.d.ts.map +0 -1
  136. package/dist/browser/react/Link.js +0 -128
  137. package/dist/browser/react/Link.js.map +0 -1
  138. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  139. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  140. package/dist/browser/react/NavigationProvider.js +0 -216
  141. package/dist/browser/react/NavigationProvider.js.map +0 -1
  142. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  143. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  144. package/dist/browser/react/ScrollRestoration.js +0 -57
  145. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  146. package/dist/browser/react/context.d.ts +0 -46
  147. package/dist/browser/react/context.d.ts.map +0 -1
  148. package/dist/browser/react/context.js +0 -10
  149. package/dist/browser/react/context.js.map +0 -1
  150. package/dist/browser/react/index.d.ts +0 -11
  151. package/dist/browser/react/index.d.ts.map +0 -1
  152. package/dist/browser/react/index.js +0 -22
  153. package/dist/browser/react/index.js.map +0 -1
  154. package/dist/browser/react/location-state-shared.d.ts +0 -63
  155. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  156. package/dist/browser/react/location-state-shared.js +0 -81
  157. package/dist/browser/react/location-state-shared.js.map +0 -1
  158. package/dist/browser/react/location-state.d.ts +0 -23
  159. package/dist/browser/react/location-state.d.ts.map +0 -1
  160. package/dist/browser/react/location-state.js +0 -29
  161. package/dist/browser/react/location-state.js.map +0 -1
  162. package/dist/browser/react/mount-context.d.ts +0 -24
  163. package/dist/browser/react/mount-context.d.ts.map +0 -1
  164. package/dist/browser/react/mount-context.js +0 -24
  165. package/dist/browser/react/mount-context.js.map +0 -1
  166. package/dist/browser/react/use-action.d.ts +0 -64
  167. package/dist/browser/react/use-action.d.ts.map +0 -1
  168. package/dist/browser/react/use-action.js +0 -134
  169. package/dist/browser/react/use-action.js.map +0 -1
  170. package/dist/browser/react/use-client-cache.d.ts +0 -41
  171. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  172. package/dist/browser/react/use-client-cache.js +0 -39
  173. package/dist/browser/react/use-client-cache.js.map +0 -1
  174. package/dist/browser/react/use-handle.d.ts +0 -31
  175. package/dist/browser/react/use-handle.d.ts.map +0 -1
  176. package/dist/browser/react/use-handle.js +0 -144
  177. package/dist/browser/react/use-handle.js.map +0 -1
  178. package/dist/browser/react/use-href.d.ts +0 -33
  179. package/dist/browser/react/use-href.d.ts.map +0 -1
  180. package/dist/browser/react/use-href.js +0 -39
  181. package/dist/browser/react/use-href.js.map +0 -1
  182. package/dist/browser/react/use-link-status.d.ts +0 -37
  183. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  184. package/dist/browser/react/use-link-status.js +0 -99
  185. package/dist/browser/react/use-link-status.js.map +0 -1
  186. package/dist/browser/react/use-mount.d.ts +0 -25
  187. package/dist/browser/react/use-mount.d.ts.map +0 -1
  188. package/dist/browser/react/use-mount.js +0 -30
  189. package/dist/browser/react/use-mount.js.map +0 -1
  190. package/dist/browser/react/use-navigation.d.ts +0 -27
  191. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  192. package/dist/browser/react/use-navigation.js +0 -87
  193. package/dist/browser/react/use-navigation.js.map +0 -1
  194. package/dist/browser/react/use-segments.d.ts +0 -38
  195. package/dist/browser/react/use-segments.d.ts.map +0 -1
  196. package/dist/browser/react/use-segments.js +0 -130
  197. package/dist/browser/react/use-segments.js.map +0 -1
  198. package/dist/browser/request-controller.d.ts +0 -26
  199. package/dist/browser/request-controller.d.ts.map +0 -1
  200. package/dist/browser/request-controller.js +0 -147
  201. package/dist/browser/request-controller.js.map +0 -1
  202. package/dist/browser/rsc-router.d.ts +0 -129
  203. package/dist/browser/rsc-router.d.ts.map +0 -1
  204. package/dist/browser/rsc-router.js +0 -195
  205. package/dist/browser/rsc-router.js.map +0 -1
  206. package/dist/browser/scroll-restoration.d.ts +0 -93
  207. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  208. package/dist/browser/scroll-restoration.js +0 -321
  209. package/dist/browser/scroll-restoration.js.map +0 -1
  210. package/dist/browser/segment-structure-assert.d.ts +0 -17
  211. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  212. package/dist/browser/segment-structure-assert.js +0 -59
  213. package/dist/browser/segment-structure-assert.js.map +0 -1
  214. package/dist/browser/server-action-bridge.d.ts +0 -26
  215. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  216. package/dist/browser/server-action-bridge.js +0 -668
  217. package/dist/browser/server-action-bridge.js.map +0 -1
  218. package/dist/browser/shallow.d.ts +0 -12
  219. package/dist/browser/shallow.d.ts.map +0 -1
  220. package/dist/browser/shallow.js +0 -34
  221. package/dist/browser/shallow.js.map +0 -1
  222. package/dist/browser/types.d.ts +0 -369
  223. package/dist/browser/types.d.ts.map +0 -1
  224. package/dist/browser/types.js +0 -2
  225. package/dist/browser/types.js.map +0 -1
  226. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  227. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  228. package/dist/build/__tests__/generate-cli.test.js +0 -237
  229. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  230. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  231. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  232. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  233. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  234. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  235. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  236. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  237. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  238. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  239. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  240. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  241. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  242. package/dist/build/generate-manifest.d.ts +0 -81
  243. package/dist/build/generate-manifest.d.ts.map +0 -1
  244. package/dist/build/generate-manifest.js +0 -276
  245. package/dist/build/generate-manifest.js.map +0 -1
  246. package/dist/build/generate-route-types.d.ts +0 -115
  247. package/dist/build/generate-route-types.d.ts.map +0 -1
  248. package/dist/build/generate-route-types.js +0 -740
  249. package/dist/build/generate-route-types.js.map +0 -1
  250. package/dist/build/index.d.ts +0 -21
  251. package/dist/build/index.d.ts.map +0 -1
  252. package/dist/build/index.js +0 -21
  253. package/dist/build/index.js.map +0 -1
  254. package/dist/build/route-trie.d.ts +0 -71
  255. package/dist/build/route-trie.d.ts.map +0 -1
  256. package/dist/build/route-trie.js +0 -175
  257. package/dist/build/route-trie.js.map +0 -1
  258. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  259. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  260. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  261. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  262. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  263. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  264. package/dist/cache/__tests__/document-cache.test.js +0 -345
  265. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  266. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  267. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  268. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  269. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  270. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  271. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  272. package/dist/cache/__tests__/memory-store.test.js +0 -367
  273. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  274. package/dist/cache/cache-scope.d.ts +0 -102
  275. package/dist/cache/cache-scope.d.ts.map +0 -1
  276. package/dist/cache/cache-scope.js +0 -440
  277. package/dist/cache/cache-scope.js.map +0 -1
  278. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  279. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  280. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  281. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  282. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  283. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  284. package/dist/cache/cf/cf-cache-store.js +0 -242
  285. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  286. package/dist/cache/cf/index.d.ts +0 -14
  287. package/dist/cache/cf/index.d.ts.map +0 -1
  288. package/dist/cache/cf/index.js +0 -17
  289. package/dist/cache/cf/index.js.map +0 -1
  290. package/dist/cache/document-cache.d.ts +0 -64
  291. package/dist/cache/document-cache.d.ts.map +0 -1
  292. package/dist/cache/document-cache.js +0 -228
  293. package/dist/cache/document-cache.js.map +0 -1
  294. package/dist/cache/index.d.ts +0 -19
  295. package/dist/cache/index.d.ts.map +0 -1
  296. package/dist/cache/index.js +0 -21
  297. package/dist/cache/index.js.map +0 -1
  298. package/dist/cache/memory-segment-store.d.ts +0 -110
  299. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  300. package/dist/cache/memory-segment-store.js +0 -117
  301. package/dist/cache/memory-segment-store.js.map +0 -1
  302. package/dist/cache/memory-store.d.ts +0 -41
  303. package/dist/cache/memory-store.d.ts.map +0 -1
  304. package/dist/cache/memory-store.js +0 -191
  305. package/dist/cache/memory-store.js.map +0 -1
  306. package/dist/cache/types.d.ts +0 -317
  307. package/dist/cache/types.d.ts.map +0 -1
  308. package/dist/cache/types.js +0 -12
  309. package/dist/cache/types.js.map +0 -1
  310. package/dist/client.d.ts +0 -248
  311. package/dist/client.d.ts.map +0 -1
  312. package/dist/client.js +0 -367
  313. package/dist/client.js.map +0 -1
  314. package/dist/client.rsc.d.ts +0 -26
  315. package/dist/client.rsc.d.ts.map +0 -1
  316. package/dist/client.rsc.js +0 -46
  317. package/dist/client.rsc.js.map +0 -1
  318. package/dist/component-utils.d.ts +0 -36
  319. package/dist/component-utils.d.ts.map +0 -1
  320. package/dist/component-utils.js +0 -61
  321. package/dist/component-utils.js.map +0 -1
  322. package/dist/components/DefaultDocument.d.ts +0 -13
  323. package/dist/components/DefaultDocument.d.ts.map +0 -1
  324. package/dist/components/DefaultDocument.js +0 -15
  325. package/dist/components/DefaultDocument.js.map +0 -1
  326. package/dist/debug.d.ts +0 -58
  327. package/dist/debug.d.ts.map +0 -1
  328. package/dist/debug.js +0 -157
  329. package/dist/debug.js.map +0 -1
  330. package/dist/default-error-boundary.d.ts +0 -11
  331. package/dist/default-error-boundary.d.ts.map +0 -1
  332. package/dist/default-error-boundary.js +0 -45
  333. package/dist/default-error-boundary.js.map +0 -1
  334. package/dist/deps/browser.d.ts +0 -2
  335. package/dist/deps/browser.d.ts.map +0 -1
  336. package/dist/deps/browser.js +0 -3
  337. package/dist/deps/browser.js.map +0 -1
  338. package/dist/deps/html-stream-client.d.ts +0 -2
  339. package/dist/deps/html-stream-client.d.ts.map +0 -1
  340. package/dist/deps/html-stream-client.js +0 -3
  341. package/dist/deps/html-stream-client.js.map +0 -1
  342. package/dist/deps/html-stream-server.d.ts +0 -2
  343. package/dist/deps/html-stream-server.d.ts.map +0 -1
  344. package/dist/deps/html-stream-server.js +0 -3
  345. package/dist/deps/html-stream-server.js.map +0 -1
  346. package/dist/deps/rsc.d.ts +0 -2
  347. package/dist/deps/rsc.d.ts.map +0 -1
  348. package/dist/deps/rsc.js +0 -4
  349. package/dist/deps/rsc.js.map +0 -1
  350. package/dist/deps/ssr.d.ts +0 -2
  351. package/dist/deps/ssr.d.ts.map +0 -1
  352. package/dist/deps/ssr.js +0 -3
  353. package/dist/deps/ssr.js.map +0 -1
  354. package/dist/errors.d.ts +0 -174
  355. package/dist/errors.d.ts.map +0 -1
  356. package/dist/errors.js +0 -241
  357. package/dist/errors.js.map +0 -1
  358. package/dist/handle.d.ts +0 -78
  359. package/dist/handle.d.ts.map +0 -1
  360. package/dist/handle.js +0 -82
  361. package/dist/handle.js.map +0 -1
  362. package/dist/handles/MetaTags.d.ts +0 -14
  363. package/dist/handles/MetaTags.d.ts.map +0 -1
  364. package/dist/handles/MetaTags.js +0 -136
  365. package/dist/handles/MetaTags.js.map +0 -1
  366. package/dist/handles/index.d.ts +0 -6
  367. package/dist/handles/index.d.ts.map +0 -1
  368. package/dist/handles/index.js +0 -6
  369. package/dist/handles/index.js.map +0 -1
  370. package/dist/handles/meta.d.ts +0 -39
  371. package/dist/handles/meta.d.ts.map +0 -1
  372. package/dist/handles/meta.js +0 -202
  373. package/dist/handles/meta.js.map +0 -1
  374. package/dist/host/__tests__/errors.test.d.ts +0 -2
  375. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  376. package/dist/host/__tests__/errors.test.js +0 -76
  377. package/dist/host/__tests__/errors.test.js.map +0 -1
  378. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  379. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  380. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  381. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  382. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  383. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  384. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  385. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  386. package/dist/host/__tests__/router.test.d.ts +0 -2
  387. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  388. package/dist/host/__tests__/router.test.js +0 -241
  389. package/dist/host/__tests__/router.test.js.map +0 -1
  390. package/dist/host/__tests__/testing.test.d.ts +0 -2
  391. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  392. package/dist/host/__tests__/testing.test.js +0 -64
  393. package/dist/host/__tests__/testing.test.js.map +0 -1
  394. package/dist/host/__tests__/utils.test.d.ts +0 -2
  395. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  396. package/dist/host/__tests__/utils.test.js +0 -29
  397. package/dist/host/__tests__/utils.test.js.map +0 -1
  398. package/dist/host/cookie-handler.d.ts +0 -34
  399. package/dist/host/cookie-handler.d.ts.map +0 -1
  400. package/dist/host/cookie-handler.js +0 -124
  401. package/dist/host/cookie-handler.js.map +0 -1
  402. package/dist/host/errors.d.ts +0 -56
  403. package/dist/host/errors.d.ts.map +0 -1
  404. package/dist/host/errors.js +0 -79
  405. package/dist/host/errors.js.map +0 -1
  406. package/dist/host/index.d.ts +0 -29
  407. package/dist/host/index.d.ts.map +0 -1
  408. package/dist/host/index.js +0 -32
  409. package/dist/host/index.js.map +0 -1
  410. package/dist/host/pattern-matcher.d.ts +0 -36
  411. package/dist/host/pattern-matcher.d.ts.map +0 -1
  412. package/dist/host/pattern-matcher.js +0 -172
  413. package/dist/host/pattern-matcher.js.map +0 -1
  414. package/dist/host/router.d.ts +0 -26
  415. package/dist/host/router.d.ts.map +0 -1
  416. package/dist/host/router.js +0 -218
  417. package/dist/host/router.js.map +0 -1
  418. package/dist/host/testing.d.ts +0 -36
  419. package/dist/host/testing.d.ts.map +0 -1
  420. package/dist/host/testing.js +0 -55
  421. package/dist/host/testing.js.map +0 -1
  422. package/dist/host/types.d.ts +0 -115
  423. package/dist/host/types.d.ts.map +0 -1
  424. package/dist/host/types.js +0 -7
  425. package/dist/host/types.js.map +0 -1
  426. package/dist/host/utils.d.ts +0 -21
  427. package/dist/host/utils.d.ts.map +0 -1
  428. package/dist/host/utils.js +0 -23
  429. package/dist/host/utils.js.map +0 -1
  430. package/dist/href-client.d.ts +0 -131
  431. package/dist/href-client.d.ts.map +0 -1
  432. package/dist/href-client.js +0 -64
  433. package/dist/href-client.js.map +0 -1
  434. package/dist/href-context.d.ts +0 -29
  435. package/dist/href-context.d.ts.map +0 -1
  436. package/dist/href-context.js +0 -21
  437. package/dist/href-context.js.map +0 -1
  438. package/dist/index.d.ts +0 -73
  439. package/dist/index.d.ts.map +0 -1
  440. package/dist/index.js +0 -91
  441. package/dist/index.js.map +0 -1
  442. package/dist/index.rsc.d.ts +0 -32
  443. package/dist/index.rsc.d.ts.map +0 -1
  444. package/dist/index.rsc.js +0 -40
  445. package/dist/index.rsc.js.map +0 -1
  446. package/dist/internal-debug.d.ts +0 -2
  447. package/dist/internal-debug.d.ts.map +0 -1
  448. package/dist/internal-debug.js +0 -5
  449. package/dist/internal-debug.js.map +0 -1
  450. package/dist/loader.d.ts +0 -14
  451. package/dist/loader.d.ts.map +0 -1
  452. package/dist/loader.js +0 -20
  453. package/dist/loader.js.map +0 -1
  454. package/dist/loader.rsc.d.ts +0 -19
  455. package/dist/loader.rsc.d.ts.map +0 -1
  456. package/dist/loader.rsc.js +0 -99
  457. package/dist/loader.rsc.js.map +0 -1
  458. package/dist/network-error-thrower.d.ts +0 -17
  459. package/dist/network-error-thrower.d.ts.map +0 -1
  460. package/dist/network-error-thrower.js +0 -14
  461. package/dist/network-error-thrower.js.map +0 -1
  462. package/dist/outlet-context.d.ts +0 -13
  463. package/dist/outlet-context.d.ts.map +0 -1
  464. package/dist/outlet-context.js +0 -3
  465. package/dist/outlet-context.js.map +0 -1
  466. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  467. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  468. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  469. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  470. package/dist/prerender/param-hash.d.ts +0 -16
  471. package/dist/prerender/param-hash.d.ts.map +0 -1
  472. package/dist/prerender/param-hash.js +0 -36
  473. package/dist/prerender/param-hash.js.map +0 -1
  474. package/dist/prerender/store.d.ts +0 -38
  475. package/dist/prerender/store.d.ts.map +0 -1
  476. package/dist/prerender/store.js +0 -61
  477. package/dist/prerender/store.js.map +0 -1
  478. package/dist/prerender.d.ts +0 -66
  479. package/dist/prerender.d.ts.map +0 -1
  480. package/dist/prerender.js +0 -57
  481. package/dist/prerender.js.map +0 -1
  482. package/dist/reverse.d.ts +0 -196
  483. package/dist/reverse.d.ts.map +0 -1
  484. package/dist/reverse.js +0 -78
  485. package/dist/reverse.js.map +0 -1
  486. package/dist/root-error-boundary.d.ts +0 -33
  487. package/dist/root-error-boundary.d.ts.map +0 -1
  488. package/dist/root-error-boundary.js +0 -165
  489. package/dist/root-error-boundary.js.map +0 -1
  490. package/dist/route-content-wrapper.d.ts +0 -46
  491. package/dist/route-content-wrapper.d.ts.map +0 -1
  492. package/dist/route-content-wrapper.js +0 -77
  493. package/dist/route-content-wrapper.js.map +0 -1
  494. package/dist/route-definition.d.ts +0 -421
  495. package/dist/route-definition.d.ts.map +0 -1
  496. package/dist/route-definition.js +0 -868
  497. package/dist/route-definition.js.map +0 -1
  498. package/dist/route-map-builder.d.ts +0 -155
  499. package/dist/route-map-builder.d.ts.map +0 -1
  500. package/dist/route-map-builder.js +0 -237
  501. package/dist/route-map-builder.js.map +0 -1
  502. package/dist/route-types.d.ts +0 -165
  503. package/dist/route-types.d.ts.map +0 -1
  504. package/dist/route-types.js +0 -7
  505. package/dist/route-types.js.map +0 -1
  506. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  507. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  508. package/dist/router/__tests__/handler-context.test.js +0 -65
  509. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  510. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  511. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  512. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  513. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  514. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  515. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  516. package/dist/router/__tests__/match-context.test.js +0 -92
  517. package/dist/router/__tests__/match-context.test.js.map +0 -1
  518. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  519. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  520. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  521. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  522. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  523. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  524. package/dist/router/__tests__/match-result.test.js +0 -457
  525. package/dist/router/__tests__/match-result.test.js.map +0 -1
  526. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  527. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  528. package/dist/router/__tests__/on-error.test.js +0 -678
  529. package/dist/router/__tests__/on-error.test.js.map +0 -1
  530. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  531. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  532. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  533. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  534. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  535. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  536. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  537. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  538. package/dist/router/error-handling.d.ts +0 -77
  539. package/dist/router/error-handling.d.ts.map +0 -1
  540. package/dist/router/error-handling.js +0 -202
  541. package/dist/router/error-handling.js.map +0 -1
  542. package/dist/router/handler-context.d.ts +0 -20
  543. package/dist/router/handler-context.d.ts.map +0 -1
  544. package/dist/router/handler-context.js +0 -198
  545. package/dist/router/handler-context.js.map +0 -1
  546. package/dist/router/intercept-resolution.d.ts +0 -66
  547. package/dist/router/intercept-resolution.d.ts.map +0 -1
  548. package/dist/router/intercept-resolution.js +0 -246
  549. package/dist/router/intercept-resolution.js.map +0 -1
  550. package/dist/router/loader-resolution.d.ts +0 -64
  551. package/dist/router/loader-resolution.d.ts.map +0 -1
  552. package/dist/router/loader-resolution.js +0 -284
  553. package/dist/router/loader-resolution.js.map +0 -1
  554. package/dist/router/logging.d.ts +0 -15
  555. package/dist/router/logging.d.ts.map +0 -1
  556. package/dist/router/logging.js +0 -99
  557. package/dist/router/logging.js.map +0 -1
  558. package/dist/router/manifest.d.ts +0 -22
  559. package/dist/router/manifest.d.ts.map +0 -1
  560. package/dist/router/manifest.js +0 -181
  561. package/dist/router/manifest.js.map +0 -1
  562. package/dist/router/match-api.d.ts +0 -35
  563. package/dist/router/match-api.d.ts.map +0 -1
  564. package/dist/router/match-api.js +0 -406
  565. package/dist/router/match-api.js.map +0 -1
  566. package/dist/router/match-context.d.ts +0 -206
  567. package/dist/router/match-context.d.ts.map +0 -1
  568. package/dist/router/match-context.js +0 -17
  569. package/dist/router/match-context.js.map +0 -1
  570. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  571. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  572. package/dist/router/match-middleware/background-revalidation.js +0 -75
  573. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  574. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  575. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  576. package/dist/router/match-middleware/cache-lookup.js +0 -257
  577. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  578. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  579. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  580. package/dist/router/match-middleware/cache-store.js +0 -108
  581. package/dist/router/match-middleware/cache-store.js.map +0 -1
  582. package/dist/router/match-middleware/index.d.ts +0 -81
  583. package/dist/router/match-middleware/index.d.ts.map +0 -1
  584. package/dist/router/match-middleware/index.js +0 -80
  585. package/dist/router/match-middleware/index.js.map +0 -1
  586. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  587. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  588. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  589. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  590. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  591. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  592. package/dist/router/match-middleware/segment-resolution.js +0 -53
  593. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  594. package/dist/router/match-pipelines.d.ts +0 -147
  595. package/dist/router/match-pipelines.d.ts.map +0 -1
  596. package/dist/router/match-pipelines.js +0 -82
  597. package/dist/router/match-pipelines.js.map +0 -1
  598. package/dist/router/match-result.d.ts +0 -126
  599. package/dist/router/match-result.d.ts.map +0 -1
  600. package/dist/router/match-result.js +0 -93
  601. package/dist/router/match-result.js.map +0 -1
  602. package/dist/router/metrics.d.ts +0 -20
  603. package/dist/router/metrics.d.ts.map +0 -1
  604. package/dist/router/metrics.js +0 -47
  605. package/dist/router/metrics.js.map +0 -1
  606. package/dist/router/middleware.d.ts +0 -249
  607. package/dist/router/middleware.d.ts.map +0 -1
  608. package/dist/router/middleware.js +0 -434
  609. package/dist/router/middleware.js.map +0 -1
  610. package/dist/router/middleware.test.d.ts +0 -2
  611. package/dist/router/middleware.test.d.ts.map +0 -1
  612. package/dist/router/middleware.test.js +0 -816
  613. package/dist/router/middleware.test.js.map +0 -1
  614. package/dist/router/pattern-matching.d.ts +0 -149
  615. package/dist/router/pattern-matching.d.ts.map +0 -1
  616. package/dist/router/pattern-matching.js +0 -349
  617. package/dist/router/pattern-matching.js.map +0 -1
  618. package/dist/router/revalidation.d.ts +0 -44
  619. package/dist/router/revalidation.d.ts.map +0 -1
  620. package/dist/router/revalidation.js +0 -147
  621. package/dist/router/revalidation.js.map +0 -1
  622. package/dist/router/router-context.d.ts +0 -135
  623. package/dist/router/router-context.d.ts.map +0 -1
  624. package/dist/router/router-context.js +0 -36
  625. package/dist/router/router-context.js.map +0 -1
  626. package/dist/router/segment-resolution.d.ts +0 -127
  627. package/dist/router/segment-resolution.d.ts.map +0 -1
  628. package/dist/router/segment-resolution.js +0 -919
  629. package/dist/router/segment-resolution.js.map +0 -1
  630. package/dist/router/trie-matching.d.ts +0 -40
  631. package/dist/router/trie-matching.d.ts.map +0 -1
  632. package/dist/router/trie-matching.js +0 -127
  633. package/dist/router/trie-matching.js.map +0 -1
  634. package/dist/router/types.d.ts +0 -136
  635. package/dist/router/types.d.ts.map +0 -1
  636. package/dist/router/types.js +0 -7
  637. package/dist/router/types.js.map +0 -1
  638. package/dist/router.d.ts +0 -753
  639. package/dist/router.d.ts.map +0 -1
  640. package/dist/router.gen.d.ts +0 -6
  641. package/dist/router.gen.d.ts.map +0 -1
  642. package/dist/router.gen.js +0 -6
  643. package/dist/router.gen.js.map +0 -1
  644. package/dist/router.js +0 -1304
  645. package/dist/router.js.map +0 -1
  646. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  647. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  648. package/dist/rsc/__tests__/helpers.test.js +0 -140
  649. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  650. package/dist/rsc/handler.d.ts +0 -45
  651. package/dist/rsc/handler.d.ts.map +0 -1
  652. package/dist/rsc/handler.js +0 -1172
  653. package/dist/rsc/handler.js.map +0 -1
  654. package/dist/rsc/helpers.d.ts +0 -16
  655. package/dist/rsc/helpers.d.ts.map +0 -1
  656. package/dist/rsc/helpers.js +0 -55
  657. package/dist/rsc/helpers.js.map +0 -1
  658. package/dist/rsc/index.d.ts +0 -22
  659. package/dist/rsc/index.d.ts.map +0 -1
  660. package/dist/rsc/index.js +0 -23
  661. package/dist/rsc/index.js.map +0 -1
  662. package/dist/rsc/nonce.d.ts +0 -9
  663. package/dist/rsc/nonce.d.ts.map +0 -1
  664. package/dist/rsc/nonce.js +0 -18
  665. package/dist/rsc/nonce.js.map +0 -1
  666. package/dist/rsc/types.d.ts +0 -206
  667. package/dist/rsc/types.d.ts.map +0 -1
  668. package/dist/rsc/types.js +0 -8
  669. package/dist/rsc/types.js.map +0 -1
  670. package/dist/search-params.d.ts +0 -103
  671. package/dist/search-params.d.ts.map +0 -1
  672. package/dist/search-params.js +0 -74
  673. package/dist/search-params.js.map +0 -1
  674. package/dist/segment-system.d.ts +0 -75
  675. package/dist/segment-system.d.ts.map +0 -1
  676. package/dist/segment-system.js +0 -336
  677. package/dist/segment-system.js.map +0 -1
  678. package/dist/server/context.d.ts +0 -245
  679. package/dist/server/context.d.ts.map +0 -1
  680. package/dist/server/context.js +0 -197
  681. package/dist/server/context.js.map +0 -1
  682. package/dist/server/fetchable-loader-store.d.ts +0 -18
  683. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  684. package/dist/server/fetchable-loader-store.js +0 -18
  685. package/dist/server/fetchable-loader-store.js.map +0 -1
  686. package/dist/server/handle-store.d.ts +0 -85
  687. package/dist/server/handle-store.d.ts.map +0 -1
  688. package/dist/server/handle-store.js +0 -142
  689. package/dist/server/handle-store.js.map +0 -1
  690. package/dist/server/loader-registry.d.ts +0 -55
  691. package/dist/server/loader-registry.d.ts.map +0 -1
  692. package/dist/server/loader-registry.js +0 -132
  693. package/dist/server/loader-registry.js.map +0 -1
  694. package/dist/server/request-context.d.ts +0 -226
  695. package/dist/server/request-context.d.ts.map +0 -1
  696. package/dist/server/request-context.js +0 -290
  697. package/dist/server/request-context.js.map +0 -1
  698. package/dist/server/root-layout.d.ts +0 -4
  699. package/dist/server/root-layout.d.ts.map +0 -1
  700. package/dist/server/root-layout.js +0 -5
  701. package/dist/server/root-layout.js.map +0 -1
  702. package/dist/server.d.ts +0 -15
  703. package/dist/server.d.ts.map +0 -1
  704. package/dist/server.js +0 -20
  705. package/dist/server.js.map +0 -1
  706. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  707. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  708. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  709. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  710. package/dist/ssr/index.d.ts +0 -98
  711. package/dist/ssr/index.d.ts.map +0 -1
  712. package/dist/ssr/index.js +0 -158
  713. package/dist/ssr/index.js.map +0 -1
  714. package/dist/static-handler.d.ts +0 -50
  715. package/dist/static-handler.d.ts.map +0 -1
  716. package/dist/static-handler.gen.d.ts +0 -5
  717. package/dist/static-handler.gen.d.ts.map +0 -1
  718. package/dist/static-handler.gen.js +0 -5
  719. package/dist/static-handler.gen.js.map +0 -1
  720. package/dist/static-handler.js +0 -29
  721. package/dist/static-handler.js.map +0 -1
  722. package/dist/theme/ThemeProvider.d.ts +0 -20
  723. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  724. package/dist/theme/ThemeProvider.js +0 -240
  725. package/dist/theme/ThemeProvider.js.map +0 -1
  726. package/dist/theme/ThemeScript.d.ts +0 -48
  727. package/dist/theme/ThemeScript.d.ts.map +0 -1
  728. package/dist/theme/ThemeScript.js +0 -13
  729. package/dist/theme/ThemeScript.js.map +0 -1
  730. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  731. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  732. package/dist/theme/__tests__/theme.test.js +0 -103
  733. package/dist/theme/__tests__/theme.test.js.map +0 -1
  734. package/dist/theme/constants.d.ts +0 -29
  735. package/dist/theme/constants.d.ts.map +0 -1
  736. package/dist/theme/constants.js +0 -48
  737. package/dist/theme/constants.js.map +0 -1
  738. package/dist/theme/index.d.ts +0 -31
  739. package/dist/theme/index.d.ts.map +0 -1
  740. package/dist/theme/index.js +0 -36
  741. package/dist/theme/index.js.map +0 -1
  742. package/dist/theme/theme-context.d.ts +0 -40
  743. package/dist/theme/theme-context.d.ts.map +0 -1
  744. package/dist/theme/theme-context.js +0 -60
  745. package/dist/theme/theme-context.js.map +0 -1
  746. package/dist/theme/theme-script.d.ts +0 -27
  747. package/dist/theme/theme-script.d.ts.map +0 -1
  748. package/dist/theme/theme-script.js +0 -147
  749. package/dist/theme/theme-script.js.map +0 -1
  750. package/dist/theme/types.d.ts +0 -163
  751. package/dist/theme/types.d.ts.map +0 -1
  752. package/dist/theme/types.js +0 -11
  753. package/dist/theme/types.js.map +0 -1
  754. package/dist/theme/use-theme.d.ts +0 -12
  755. package/dist/theme/use-theme.d.ts.map +0 -1
  756. package/dist/theme/use-theme.js +0 -40
  757. package/dist/theme/use-theme.js.map +0 -1
  758. package/dist/types.d.ts +0 -1479
  759. package/dist/types.d.ts.map +0 -1
  760. package/dist/types.js +0 -10
  761. package/dist/types.js.map +0 -1
  762. package/dist/urls.d.ts +0 -441
  763. package/dist/urls.d.ts.map +0 -1
  764. package/dist/urls.gen.d.ts +0 -8
  765. package/dist/urls.gen.d.ts.map +0 -1
  766. package/dist/urls.gen.js +0 -8
  767. package/dist/urls.gen.js.map +0 -1
  768. package/dist/urls.js +0 -443
  769. package/dist/urls.js.map +0 -1
  770. package/dist/use-loader.d.ts +0 -127
  771. package/dist/use-loader.d.ts.map +0 -1
  772. package/dist/use-loader.js +0 -237
  773. package/dist/use-loader.js.map +0 -1
  774. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  775. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  776. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  777. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  778. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  779. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  780. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  781. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  782. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  783. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  784. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  785. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  786. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  787. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  788. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  789. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  790. package/dist/vite/ast-handler-extract.d.ts +0 -49
  791. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  792. package/dist/vite/ast-handler-extract.js +0 -249
  793. package/dist/vite/ast-handler-extract.js.map +0 -1
  794. package/dist/vite/expose-action-id.d.ts +0 -19
  795. package/dist/vite/expose-action-id.d.ts.map +0 -1
  796. package/dist/vite/expose-action-id.js +0 -250
  797. package/dist/vite/expose-action-id.js.map +0 -1
  798. package/dist/vite/expose-id-utils.d.ts +0 -69
  799. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  800. package/dist/vite/expose-id-utils.js +0 -289
  801. package/dist/vite/expose-id-utils.js.map +0 -1
  802. package/dist/vite/expose-internal-ids.d.ts +0 -22
  803. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  804. package/dist/vite/expose-internal-ids.js +0 -886
  805. package/dist/vite/expose-internal-ids.js.map +0 -1
  806. package/dist/vite/index.d.ts +0 -149
  807. package/dist/vite/index.d.ts.map +0 -1
  808. package/dist/vite/index.js.map +0 -1
  809. package/dist/vite/index.named-routes.gen.ts +0 -103
  810. package/dist/vite/package-resolution.d.ts +0 -43
  811. package/dist/vite/package-resolution.d.ts.map +0 -1
  812. package/dist/vite/package-resolution.js +0 -112
  813. package/dist/vite/package-resolution.js.map +0 -1
  814. package/dist/vite/virtual-entries.d.ts +0 -25
  815. package/dist/vite/virtual-entries.d.ts.map +0 -1
  816. package/dist/vite/virtual-entries.js +0 -110
  817. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1745,7 +1745,7 @@ import { resolve } from "node:path";
1745
1745
  // package.json
1746
1746
  var package_default = {
1747
1747
  name: "@rangojs/router",
1748
- version: "0.0.0-experimental.22",
1748
+ version: "0.0.0-experimental.24",
1749
1749
  description: "Django-inspired RSC router with composable URL patterns",
1750
1750
  keywords: [
1751
1751
  "react",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rangojs/router",
3
- "version": "0.0.0-experimental.22",
3
+ "version": "0.0.0-experimental.24",
4
4
  "description": "Django-inspired RSC router with composable URL patterns",
5
5
  "keywords": [
6
6
  "react",
@@ -262,7 +262,7 @@ function createLoaderExecutor<TEnv>(
262
262
  reverse: ctx.reverse as LoaderContext["reverse"],
263
263
  };
264
264
 
265
- const doneLoader = track(`loader:${loader.$$id}`);
265
+ const doneLoader = track(`loader:${loader.$$id}`, 2);
266
266
  const promise = Promise.resolve(
267
267
  loaderFn(loaderCtx as LoaderContext<any, TEnv>),
268
268
  ).finally(() => {
@@ -108,7 +108,7 @@
108
108
  */
109
109
  import type { MatchResult, ResolvedSegment } from "../types.js";
110
110
  import type { MatchContext, MatchPipelineState } from "./match-context.js";
111
- import { generateServerTiming, logMetrics } from "./metrics.js";
111
+ import { generateServerTiming } from "./metrics.js";
112
112
  import { debugLog } from "./logging.js";
113
113
 
114
114
  /**
@@ -189,7 +189,6 @@ export function buildMatchResult<TEnv>(
189
189
  // Output metrics if enabled
190
190
  let serverTiming: string | undefined;
191
191
  if (ctx.metricsStore) {
192
- logMetrics(ctx.request.method, ctx.pathname, ctx.metricsStore);
193
192
  serverTiming = generateServerTiming(ctx.metricsStore);
194
193
  }
195
194
 
@@ -4,7 +4,56 @@
4
4
  * Performance metrics collection and reporting for RSC Router.
5
5
  */
6
6
 
7
- import type { MetricsStore } from "../server/context";
7
+ import type { MetricsStore, PerformanceMetric } from "../server/context";
8
+
9
+ const BASE_INDENT = 2;
10
+ const DEPTH_INDENT = 2;
11
+ const TIMELINE_WIDTH = 40;
12
+
13
+ function formatMs(value: number): string {
14
+ return `${value.toFixed(1)}ms`;
15
+ }
16
+
17
+ function sortMetrics(metrics: PerformanceMetric[]): PerformanceMetric[] {
18
+ return [...metrics].sort((a, b) => a.startTime - b.startTime);
19
+ }
20
+
21
+ function renderTimeline(metric: PerformanceMetric, total: number): string {
22
+ if (TIMELINE_WIDTH <= 0) {
23
+ return "||";
24
+ }
25
+
26
+ const cells = Array(TIMELINE_WIDTH).fill(".");
27
+
28
+ if (!(total > 0)) {
29
+ cells[0] = "#";
30
+ return `|${cells.join("")}|`;
31
+ }
32
+
33
+ const start = Math.max(0, metric.startTime);
34
+ const end = Math.max(start, metric.startTime + metric.duration);
35
+ const startColumn = Math.min(
36
+ TIMELINE_WIDTH - 1,
37
+ Math.floor((start / total) * TIMELINE_WIDTH),
38
+ );
39
+ const endColumn = Math.max(
40
+ startColumn + 1,
41
+ Math.min(
42
+ TIMELINE_WIDTH,
43
+ Math.ceil((Math.min(total, end) / total) * TIMELINE_WIDTH),
44
+ ),
45
+ );
46
+
47
+ cells.fill("#", startColumn, endColumn);
48
+ return `|${cells.join("")}|`;
49
+ }
50
+
51
+ function createTimelineAxis(total: number): string {
52
+ const totalLabel = formatMs(total);
53
+ return `0ms${" ".repeat(
54
+ Math.max(1, TIMELINE_WIDTH - "0ms".length - totalLabel.length),
55
+ )}${totalLabel}`;
56
+ }
8
57
 
9
58
  /**
10
59
  * Create a metrics store for the request if debugPerformance is enabled
@@ -21,7 +70,44 @@ export function createMetricsStore(
21
70
  }
22
71
 
23
72
  /**
24
- * Log metrics to console in a formatted way
73
+ * Append a metric to the request store using an absolute start timestamp.
74
+ */
75
+ export function appendMetric(
76
+ metricsStore: MetricsStore | undefined,
77
+ label: string,
78
+ start: number,
79
+ duration: number,
80
+ depth?: number,
81
+ ): void {
82
+ if (!metricsStore) return;
83
+ metricsStore.metrics.push({
84
+ label,
85
+ duration,
86
+ startTime: start - metricsStore.requestStart,
87
+ depth,
88
+ });
89
+ }
90
+
91
+ /**
92
+ * Log the current request metrics and return the corresponding Server-Timing value.
93
+ * Falls back to an existing header value when no metrics store is active.
94
+ */
95
+ export function buildMetricsTiming(
96
+ method: string,
97
+ pathname: string,
98
+ metricsStore: MetricsStore | undefined,
99
+ fallback?: string,
100
+ ): string | undefined {
101
+ if (!metricsStore) {
102
+ return fallback;
103
+ }
104
+ logMetrics(method, pathname, metricsStore);
105
+ return generateServerTiming(metricsStore) || undefined;
106
+ }
107
+
108
+ /**
109
+ * Log metrics to console in a formatted way.
110
+ * Uses a shared-axis timeline so overlapping work stays visible.
25
111
  */
26
112
  export function logMetrics(
27
113
  method: string,
@@ -30,32 +116,62 @@ export function logMetrics(
30
116
  ): void {
31
117
  const total = performance.now() - metricsStore.requestStart;
32
118
 
33
- // Find max label length for alignment
34
- const maxLabelLen = Math.max(
35
- ...metricsStore.metrics.map((m) => m.label.length),
36
- 20,
119
+ const sorted = sortMetrics(metricsStore.metrics);
120
+ const labels = sorted.map(
121
+ (m) =>
122
+ `${" ".repeat(BASE_INDENT + (m.depth ?? 0) * DEPTH_INDENT)}${m.label}`,
123
+ );
124
+ const startValues = sorted.map((m) => formatMs(m.startTime));
125
+ const durationValues = sorted.map((m) => formatMs(m.duration));
126
+ const startWidth = Math.max(
127
+ "start".length,
128
+ ...startValues.map((v) => v.length),
129
+ );
130
+ const durationWidth = Math.max(
131
+ "dur".length,
132
+ ...durationValues.map((v) => v.length),
133
+ );
134
+ const spanWidth = Math.max(
135
+ "span".length,
136
+ ...labels.map((label) => label.length),
137
+ 22,
138
+ );
139
+ const timelinePadding = " ".repeat(
140
+ startWidth + 2 + durationWidth + 2 + spanWidth + 2,
37
141
  );
38
142
 
39
143
  console.log(`[RSC Perf] ${method} ${pathname} (${total.toFixed(1)}ms)`);
144
+ console.log(
145
+ `${"start".padStart(startWidth)} ${"dur".padStart(durationWidth)} ${"span".padEnd(spanWidth)} timeline`,
146
+ );
147
+ console.log(`${timelinePadding}${createTimelineAxis(total)}`);
148
+
149
+ for (let index = 0; index < sorted.length; index++) {
150
+ const metric = sorted[index];
151
+ const label = labels[index].padEnd(spanWidth);
152
+ const start = formatMs(metric.startTime).padStart(startWidth);
153
+ const duration = formatMs(metric.duration).padStart(durationWidth);
40
154
 
41
- for (const m of metricsStore.metrics) {
42
- const paddedLabel = m.label.padEnd(maxLabelLen);
43
- console.log(` ${paddedLabel} ${m.duration.toFixed(1)}ms`);
155
+ console.log(
156
+ `${start} ${duration} ${label} ${renderTimeline(metric, total)}`,
157
+ );
44
158
  }
45
159
  }
46
160
 
47
161
  /**
48
162
  * Generate Server-Timing header value from metrics
49
163
  * Format: metric-name;dur=X.XX
164
+ * Depth is encoded as a "d{N}-" prefix for nested metrics.
50
165
  */
51
166
  export function generateServerTiming(metricsStore: MetricsStore): string {
52
167
  return metricsStore.metrics
53
168
  .map((m) => {
54
169
  // Convert label to valid Server-Timing name (alphanumeric and hyphens)
55
- const name = m.label
170
+ const base = m.label
56
171
  .replace(/:/g, "-")
57
172
  .replace(/[^a-zA-Z0-9-]/g, "")
58
173
  .toLowerCase();
174
+ const name = m.depth ? `d${m.depth}-${base}` : base;
59
175
  return `${name};dur=${m.duration.toFixed(2)}`;
60
176
  })
61
177
  .join(", ");
@@ -100,6 +100,18 @@ export interface MiddlewareContext<
100
100
  */
101
101
  routeName?: DefaultRouteName;
102
102
 
103
+ /**
104
+ * Enable performance metrics for this request.
105
+ * When called, granular timing breakdown is logged to console and
106
+ * included in the Server-Timing response header, regardless of the
107
+ * router-level `debugPerformance` option.
108
+ *
109
+ * Must be called **before** `await next()` — the metrics store is
110
+ * created at the start of route matching inside `next()`, so calling
111
+ * this after `next()` returns has no effect.
112
+ */
113
+ debugPerformance(): void;
114
+
103
115
  /**
104
116
  * Generate URLs from route names.
105
117
  * - `name` — global route, from the named-routes definition
@@ -20,6 +20,7 @@ import type {
20
20
  } from "./middleware-types.js";
21
21
  import { _getRequestContext } from "../server/request-context.js";
22
22
  import { isAutoGeneratedRouteName } from "../route-name.js";
23
+ import { appendMetric } from "./metrics.js";
23
24
 
24
25
  // Re-export types and cookie utilities for backward compatibility
25
26
  export type {
@@ -49,6 +50,29 @@ function warnCtxSetBeforeRedirect(handler: Function): void {
49
50
  );
50
51
  }
51
52
 
53
+ const MIDDLEWARE_METRIC_DEPTH = 1;
54
+
55
+ function getMiddlewareMetricBase<TEnv>(
56
+ entry: MiddlewareEntry<TEnv>,
57
+ ordinal: number,
58
+ ): string {
59
+ const handlerName = entry.handler.name?.trim();
60
+ const scope = entry.pattern ?? "*";
61
+
62
+ if (handlerName) {
63
+ return `${handlerName}@${scope}`;
64
+ }
65
+
66
+ return `${scope}#${ordinal + 1}`;
67
+ }
68
+
69
+ function getMiddlewareMetricLabel<TEnv>(
70
+ entry: MiddlewareEntry<TEnv>,
71
+ ordinal: number,
72
+ ): string {
73
+ return `middleware:${getMiddlewareMetricBase(entry, ordinal)}`;
74
+ }
75
+
52
76
  /** Reset W5 deduplication state (for tests only). */
53
77
  export function _resetW5Warnings(): void {
54
78
  warnedRedirectMiddleware = new WeakSet();
@@ -227,6 +251,13 @@ export function createMiddlewareContext<TEnv>(
227
251
  `ctx.reverse() is not available - route map was not provided to middleware context`,
228
252
  );
229
253
  }),
254
+
255
+ debugPerformance(): void {
256
+ const reqCtx = _getRequestContext();
257
+ if (reqCtx) {
258
+ reqCtx._debugPerformance = true;
259
+ }
260
+ },
230
261
  };
231
262
  }
232
263
 
@@ -309,14 +340,21 @@ export async function executeMiddleware<TEnv>(
309
340
  }
310
341
  });
311
342
  // Also merge shared RequestContext stub (cookies written via cookies().set()).
312
- // Set-Cookie duplication is prevented by createResponseWithMergedHeaders
313
- // draining Set-Cookie from ctx.res after merging (helpers.ts).
343
+ // Dedup Set-Cookie: an inner executeMiddleware (route-level middleware)
344
+ // may have already merged the same reqCtx cookies into the response.
314
345
  const reqCtx = _getRequestContext();
315
346
  if (reqCtx) {
347
+ const stubCookies = reqCtx.res.headers.getSetCookie();
348
+ if (stubCookies.length > 0) {
349
+ const existing = new Set(mergedHeaders.getSetCookie());
350
+ for (const cookie of stubCookies) {
351
+ if (!existing.has(cookie)) {
352
+ mergedHeaders.append("set-cookie", cookie);
353
+ }
354
+ }
355
+ }
316
356
  reqCtx.res.headers.forEach((value, name) => {
317
- if (name.toLowerCase() === "set-cookie") {
318
- mergedHeaders.append(name, value);
319
- } else if (!mergedHeaders.has(name)) {
357
+ if (name !== "set-cookie" && !mergedHeaders.has(name)) {
320
358
  mergedHeaders.set(name, value);
321
359
  }
322
360
  });
@@ -332,6 +370,7 @@ export async function executeMiddleware<TEnv>(
332
370
  return responseHolder.response;
333
371
  }
334
372
 
373
+ const middlewareOrdinal = index;
335
374
  const { entry, params } = middlewares[index++];
336
375
  const ctx = createMiddlewareContext(
337
376
  request,
@@ -341,6 +380,21 @@ export async function executeMiddleware<TEnv>(
341
380
  responseHolder,
342
381
  reverse,
343
382
  );
383
+ const metricsStore = _getRequestContext()?._metricsStore;
384
+ const metricStart = performance.now();
385
+ let middlewareFinished = false;
386
+ const finishMiddleware = () => {
387
+ if (!middlewareFinished) {
388
+ middlewareFinished = true;
389
+ appendMetric(
390
+ metricsStore,
391
+ getMiddlewareMetricLabel(entry, middlewareOrdinal),
392
+ metricStart,
393
+ performance.now() - metricStart,
394
+ MIDDLEWARE_METRIC_DEPTH,
395
+ );
396
+ }
397
+ };
344
398
 
345
399
  // Track if next() was called and capture its Promise.
346
400
  // Guard against double-calling: a second call would re-enter the
@@ -352,6 +406,7 @@ export async function executeMiddleware<TEnv>(
352
406
  `[@rangojs/router] Middleware called next() more than once.`,
353
407
  );
354
408
  }
409
+ finishMiddleware();
355
410
  nextPromise = next();
356
411
  return nextPromise;
357
412
  };
@@ -366,7 +421,14 @@ export async function executeMiddleware<TEnv>(
366
421
  }) as typeof ctx.set;
367
422
  }
368
423
 
369
- const result = await entry.handler(ctx, wrappedNext);
424
+ let result: Response | void;
425
+ try {
426
+ result = await entry.handler(ctx, wrappedNext);
427
+ } catch (error) {
428
+ finishMiddleware();
429
+ throw error;
430
+ }
431
+ finishMiddleware();
370
432
 
371
433
  // Explicit return takes precedence (middleware short-circuit).
372
434
  // Merge stub headers (from ctx.header before this point) and
@@ -391,13 +453,22 @@ export async function executeMiddleware<TEnv>(
391
453
  mergedHeaders.set(name, value);
392
454
  }
393
455
  });
394
- // Also merge shared RequestContext stub (cookies written via setCookie)
456
+ // Also merge shared RequestContext stub (cookies written via setCookie).
457
+ // Dedup Set-Cookie: an inner executeMiddleware (route-level middleware)
458
+ // may have already merged the same reqCtx cookies into the response.
395
459
  const reqCtx = _getRequestContext();
396
460
  if (reqCtx) {
461
+ const stubCookies = reqCtx.res.headers.getSetCookie();
462
+ if (stubCookies.length > 0) {
463
+ const existing = new Set(mergedHeaders.getSetCookie());
464
+ for (const cookie of stubCookies) {
465
+ if (!existing.has(cookie)) {
466
+ mergedHeaders.append("set-cookie", cookie);
467
+ }
468
+ }
469
+ }
397
470
  reqCtx.res.headers.forEach((value, name) => {
398
- if (name.toLowerCase() === "set-cookie") {
399
- mergedHeaders.append(name, value);
400
- } else if (!mergedHeaders.has(name)) {
471
+ if (name !== "set-cookie" && !mergedHeaders.has(name)) {
401
472
  mergedHeaders.set(name, value);
402
473
  }
403
474
  });
@@ -459,6 +530,29 @@ export async function executeMiddleware<TEnv>(
459
530
  throw new Error("No response generated by middleware chain");
460
531
  }
461
532
 
533
+ // Final re-merge: capture any RequestContext stub headers added after the
534
+ // last merge point (e.g. cookies().set() called after await next()).
535
+ // The reqCtx stub may have already been partially merged during finalHandler
536
+ // or early-return paths; only append *new* Set-Cookie entries to avoid dupes.
537
+ const reqCtx = _getRequestContext();
538
+ if (reqCtx) {
539
+ const stubCookies = reqCtx.res.headers.getSetCookie();
540
+ if (stubCookies.length > 0) {
541
+ const existingCookies = new Set(finalResponse.headers.getSetCookie());
542
+ for (const cookie of stubCookies) {
543
+ if (!existingCookies.has(cookie)) {
544
+ finalResponse.headers.append("set-cookie", cookie);
545
+ }
546
+ }
547
+ }
548
+ // Fill in non-cookie headers that aren't already on the response
549
+ reqCtx.res.headers.forEach((value, name) => {
550
+ if (name !== "set-cookie" && !finalResponse.headers.has(name)) {
551
+ finalResponse.headers.set(name, value);
552
+ }
553
+ });
554
+ }
555
+
462
556
  return finalResponse;
463
557
  }
464
558
 
@@ -24,6 +24,7 @@ import {
24
24
  } from "./helpers.js";
25
25
  import { getRouterContext } from "../router-context.js";
26
26
  import { resolveSink, safeEmit } from "../telemetry.js";
27
+ import { track } from "../../server/context.js";
27
28
 
28
29
  // ---------------------------------------------------------------------------
29
30
  // Streamed handler telemetry
@@ -178,7 +179,9 @@ export async function resolveSegment<TEnv>(
178
179
  (context as InternalHandlerContext<any, TEnv>)._currentSegmentId =
179
180
  entry.shortCode;
180
181
 
182
+ const doneLayoutHandler = track(`handler:${entry.id}`, 2);
181
183
  const component = await resolveLayoutComponent(entry, context);
184
+ doneLayoutHandler();
182
185
 
183
186
  segments.push({
184
187
  id: entry.shortCode,
@@ -241,9 +244,11 @@ export async function resolveSegment<TEnv>(
241
244
  entry.shortCode,
242
245
  );
243
246
  if (component === undefined) {
247
+ const doneRouteHandler = track(`handler:${entry.id}`, 2);
244
248
  if (entry.loading) {
245
249
  const result = handleHandlerResult(entry.handler(context));
246
250
  if (result instanceof Promise) {
251
+ result.finally(doneRouteHandler).catch(() => {});
247
252
  const tracked = deps.trackHandler(result, {
248
253
  segmentId: entry.shortCode,
249
254
  segmentType: entry.type,
@@ -258,10 +263,12 @@ export async function resolveSegment<TEnv>(
258
263
  );
259
264
  component = tracked;
260
265
  } else {
266
+ doneRouteHandler();
261
267
  component = result;
262
268
  }
263
269
  } else {
264
270
  component = handleHandlerResult(await entry.handler(context));
271
+ doneRouteHandler();
265
272
  }
266
273
  }
267
274
 
@@ -343,7 +350,9 @@ export async function resolveOrphanLayout<TEnv>(
343
350
 
344
351
  // Handler-first: orphan layout handler executes before its parallels
345
352
  // so that ctx.set() values are visible to parallel children.
353
+ const doneOrphanHandler = track(`handler:${orphan.id}`, 2);
346
354
  const component = await resolveLayoutComponent(orphan, context);
355
+ doneOrphanHandler();
347
356
 
348
357
  segments.push({
349
358
  id: orphan.shortCode,
@@ -410,12 +419,17 @@ export async function resolveParallelEntry<TEnv>(
410
419
  );
411
420
 
412
421
  if (component === undefined) {
422
+ const doneParallelHandler = track(
423
+ `handler:${parallelEntry.id}.${slot}`,
424
+ 2,
425
+ );
413
426
  const hasLoadingFallback =
414
427
  parallelEntry.loading !== undefined && parallelEntry.loading !== false;
415
428
  if (hasLoadingFallback) {
416
429
  const result =
417
430
  typeof handler === "function" ? handler(context) : handler;
418
431
  if (result instanceof Promise) {
432
+ result.finally(doneParallelHandler).catch(() => {});
419
433
  const tracked = deps.trackHandler(result, {
420
434
  segmentId: `${parentShortCode}.${slot}`,
421
435
  segmentType: "parallel",
@@ -430,11 +444,13 @@ export async function resolveParallelEntry<TEnv>(
430
444
  );
431
445
  component = tracked as ReactNode;
432
446
  } else {
447
+ doneParallelHandler();
433
448
  component = result as ReactNode;
434
449
  }
435
450
  } else {
436
451
  component =
437
452
  typeof handler === "function" ? await handler(context) : handler;
453
+ doneParallelHandler();
438
454
  }
439
455
  }
440
456
 
@@ -499,6 +515,7 @@ export async function resolveAllSegments<TEnv>(
499
515
  } catch {}
500
516
 
501
517
  for (const entry of entries) {
518
+ const doneEntry = track(`segment:${entry.id}`, 1);
502
519
  const resolvedSegments = await resolveWithErrorBoundary(
503
520
  entry,
504
521
  params,
@@ -518,6 +535,7 @@ export async function resolveAllSegments<TEnv>(
518
535
  { request: safeRequest, url: context.url, routeKey, telemetry },
519
536
  context.pathname,
520
537
  );
538
+ doneEntry();
521
539
  // Deduplicate by segment ID. include() scopes can produce entries that
522
540
  // resolve the same shared layout/loader segment. Duplicates in the segment
523
541
  // array propagate to the client's matched[] and change the React tree depth.
@@ -37,6 +37,7 @@ import {
37
37
  } from "./helpers.js";
38
38
  import { getRouterContext } from "../router-context.js";
39
39
  import { resolveSink, safeEmit } from "../telemetry.js";
40
+ import { track } from "../../server/context.js";
40
41
 
41
42
  // ---------------------------------------------------------------------------
42
43
  // Telemetry helpers
@@ -621,20 +622,29 @@ export async function resolveEntryHandlerWithRevalidation<TEnv>(
621
622
  return shouldRevalidate;
622
623
  },
623
624
  async () => {
625
+ const doneHandler = track(`handler:${entry.id}`, 2);
624
626
  (context as InternalHandlerContext<any, TEnv>)._currentSegmentId =
625
627
  entry.shortCode;
626
628
  if (entry.type === "layout" || entry.type === "cache") {
627
- return resolveLayoutComponent(entry, context);
629
+ const layoutComponent = await resolveLayoutComponent(entry, context);
630
+ doneHandler();
631
+ return layoutComponent;
628
632
  }
629
633
  const staticComponent = await tryStaticHandler(entry, entry.shortCode);
630
- if (staticComponent !== undefined) return staticComponent;
634
+ if (staticComponent !== undefined) {
635
+ doneHandler();
636
+ return staticComponent;
637
+ }
631
638
  const routeEntry = entry as Extract<EntryData, { type: "route" }>;
632
639
  if (!routeEntry.loading) {
633
- return handleHandlerResult(await routeEntry.handler(context));
640
+ const result = handleHandlerResult(await routeEntry.handler(context));
641
+ doneHandler();
642
+ return result;
634
643
  }
635
644
  if (!actionContext) {
636
645
  const result = handleHandlerResult(routeEntry.handler(context));
637
646
  if (result instanceof Promise) {
647
+ result.finally(doneHandler).catch(() => {});
638
648
  const tracked = deps.trackHandler(result, {
639
649
  segmentId: entry.shortCode,
640
650
  segmentType: entry.type,
@@ -649,15 +659,18 @@ export async function resolveEntryHandlerWithRevalidation<TEnv>(
649
659
  );
650
660
  return { content: tracked };
651
661
  }
662
+ doneHandler();
652
663
  return { content: result };
653
664
  }
654
665
  debugLog("segment.action", "resolving action route with awaited value", {
655
666
  entryId: entry.id,
656
667
  });
668
+ const actionResult = handleHandlerResult(
669
+ await routeEntry.handler(context),
670
+ );
671
+ doneHandler();
657
672
  return {
658
- content: Promise.resolve(
659
- handleHandlerResult(await routeEntry.handler(context)),
660
- ),
673
+ content: Promise.resolve(actionResult),
661
674
  };
662
675
  },
663
676
  () => null,
@@ -1178,6 +1191,7 @@ export async function resolveAllSegmentsWithRevalidation<TEnv>(
1178
1191
  }
1179
1192
 
1180
1193
  const nonParallelEntry = entry as Exclude<EntryData, { type: "parallel" }>;
1194
+ const doneEntry = track(`segment:${entry.id}`, 1);
1181
1195
  const resolved = await resolveWithErrorBoundary(
1182
1196
  nonParallelEntry,
1183
1197
  params,
@@ -1204,6 +1218,7 @@ export async function resolveAllSegmentsWithRevalidation<TEnv>(
1204
1218
  : undefined,
1205
1219
  pathname,
1206
1220
  );
1221
+ doneEntry();
1207
1222
 
1208
1223
  // Deduplicate segments and matchedIds by ID, matching resolveAllSegments.
1209
1224
  // include() scopes can produce entries that resolve the same shared
package/src/router.ts CHANGED
@@ -357,8 +357,18 @@ export function createRouter<TEnv = any>(
357
357
  return precomputedByPrefix;
358
358
  }
359
359
 
360
- // Wrapper to pass debugPerformance to external createMetricsStore
361
- const getMetricsStore = () => createMetricsStore(debugPerformance);
360
+ // Wrapper to pass debugPerformance to external createMetricsStore.
361
+ // Also checks per-request flag set by ctx.debugPerformance() in middleware.
362
+ const getMetricsStore = () => {
363
+ const reqCtx = _getRequestContext();
364
+ const enabled = debugPerformance || !!reqCtx?._debugPerformance;
365
+ if (!enabled) return undefined;
366
+ if (!reqCtx) {
367
+ return createMetricsStore(true);
368
+ }
369
+ reqCtx._metricsStore ??= createMetricsStore(true);
370
+ return reqCtx._metricsStore;
371
+ };
362
372
 
363
373
  // Wrapper to pass defaults to error/notFound boundary finders
364
374
  const findNearestErrorBoundary = (entry: EntryData | null) =>