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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (843) hide show
  1. package/README.md +3 -1
  2. package/dist/vite/index.js +19 -9
  3. package/package.json +14 -15
  4. package/skills/breadcrumbs/SKILL.md +3 -1
  5. package/skills/hooks/SKILL.md +3 -1
  6. package/skills/links/SKILL.md +24 -15
  7. package/skills/loader/SKILL.md +35 -2
  8. package/skills/typesafety/SKILL.md +3 -1
  9. package/src/browser/app-shell.ts +52 -0
  10. package/src/browser/navigation-bridge.ts +51 -2
  11. package/src/browser/navigation-store.ts +25 -1
  12. package/src/browser/partial-update.ts +20 -1
  13. package/src/browser/prefetch/cache.ts +16 -0
  14. package/src/browser/rango-state.ts +53 -13
  15. package/src/browser/react/NavigationProvider.tsx +44 -9
  16. package/src/browser/react/use-router.ts +8 -1
  17. package/src/browser/rsc-router.tsx +34 -6
  18. package/src/browser/types.ts +13 -0
  19. package/src/cache/cf/cf-cache-store.ts +5 -7
  20. package/src/index.rsc.ts +3 -0
  21. package/src/index.ts +3 -0
  22. package/src/outlet-context.ts +1 -1
  23. package/src/router/handler-context.ts +17 -1
  24. package/src/router/lazy-includes.ts +1 -1
  25. package/src/router/loader-resolution.ts +3 -0
  26. package/src/router/match-api.ts +3 -3
  27. package/src/router/middleware-types.ts +2 -22
  28. package/src/router/middleware.ts +10 -1
  29. package/src/router.ts +1 -2
  30. package/src/rsc/handler.ts +2 -1
  31. package/src/rsc/response-route-handler.ts +3 -0
  32. package/src/server/request-context.ts +10 -42
  33. package/src/types/handler-context.ts +2 -34
  34. package/src/types/loader-types.ts +2 -6
  35. package/src/types/request-scope.ts +126 -0
  36. package/src/urls/response-types.ts +2 -10
  37. package/src/vite/rango.ts +23 -7
  38. package/src/vite/utils/banner.ts +1 -1
  39. package/src/vite/utils/package-resolution.ts +1 -1
  40. package/dist/__internal.d.ts +0 -83
  41. package/dist/__internal.d.ts.map +0 -1
  42. package/dist/__internal.js +0 -19
  43. package/dist/__internal.js.map +0 -1
  44. package/dist/__mocks__/version.d.ts +0 -7
  45. package/dist/__mocks__/version.d.ts.map +0 -1
  46. package/dist/__mocks__/version.js +0 -7
  47. package/dist/__mocks__/version.js.map +0 -1
  48. package/dist/__tests__/client-href.test.d.ts +0 -2
  49. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  50. package/dist/__tests__/client-href.test.js +0 -74
  51. package/dist/__tests__/client-href.test.js.map +0 -1
  52. package/dist/__tests__/component-utils.test.d.ts +0 -2
  53. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  54. package/dist/__tests__/component-utils.test.js +0 -51
  55. package/dist/__tests__/component-utils.test.js.map +0 -1
  56. package/dist/__tests__/event-controller.test.d.ts +0 -2
  57. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  58. package/dist/__tests__/event-controller.test.js +0 -538
  59. package/dist/__tests__/event-controller.test.js.map +0 -1
  60. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  61. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  62. package/dist/__tests__/helpers/route-tree.js +0 -374
  63. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  64. package/dist/__tests__/match-result.test.d.ts +0 -2
  65. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  66. package/dist/__tests__/match-result.test.js +0 -154
  67. package/dist/__tests__/match-result.test.js.map +0 -1
  68. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  69. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  70. package/dist/__tests__/navigation-store.test.js +0 -440
  71. package/dist/__tests__/navigation-store.test.js.map +0 -1
  72. package/dist/__tests__/partial-update.test.d.ts +0 -2
  73. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  74. package/dist/__tests__/partial-update.test.js +0 -1009
  75. package/dist/__tests__/partial-update.test.js.map +0 -1
  76. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  77. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  78. package/dist/__tests__/reverse-types.test.js +0 -656
  79. package/dist/__tests__/reverse-types.test.js.map +0 -1
  80. package/dist/__tests__/route-definition.test.d.ts +0 -2
  81. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  82. package/dist/__tests__/route-definition.test.js +0 -55
  83. package/dist/__tests__/route-definition.test.js.map +0 -1
  84. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  85. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  86. package/dist/__tests__/router-helpers.test.js +0 -377
  87. package/dist/__tests__/router-helpers.test.js.map +0 -1
  88. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  89. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  90. package/dist/__tests__/router-integration-2.test.js +0 -426
  91. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  92. package/dist/__tests__/router-integration.test.d.ts +0 -2
  93. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  94. package/dist/__tests__/router-integration.test.js +0 -1051
  95. package/dist/__tests__/router-integration.test.js.map +0 -1
  96. package/dist/__tests__/search-params.test.d.ts +0 -5
  97. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  98. package/dist/__tests__/search-params.test.js +0 -306
  99. package/dist/__tests__/search-params.test.js.map +0 -1
  100. package/dist/__tests__/segment-system.test.d.ts +0 -2
  101. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  102. package/dist/__tests__/segment-system.test.js +0 -627
  103. package/dist/__tests__/segment-system.test.js.map +0 -1
  104. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  105. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  106. package/dist/__tests__/static-handler-types.test.js +0 -63
  107. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  108. package/dist/__tests__/urls.test.d.ts +0 -2
  109. package/dist/__tests__/urls.test.d.ts.map +0 -1
  110. package/dist/__tests__/urls.test.js +0 -421
  111. package/dist/__tests__/urls.test.js.map +0 -1
  112. package/dist/__tests__/use-mount.test.d.ts +0 -2
  113. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  114. package/dist/__tests__/use-mount.test.js +0 -35
  115. package/dist/__tests__/use-mount.test.js.map +0 -1
  116. package/dist/bin/rango.d.ts +0 -2
  117. package/dist/bin/rango.d.ts.map +0 -1
  118. package/dist/bin/rango.js.map +0 -1
  119. package/dist/browser/event-controller.d.ts +0 -191
  120. package/dist/browser/event-controller.d.ts.map +0 -1
  121. package/dist/browser/event-controller.js +0 -559
  122. package/dist/browser/event-controller.js.map +0 -1
  123. package/dist/browser/index.d.ts +0 -2
  124. package/dist/browser/index.d.ts.map +0 -1
  125. package/dist/browser/index.js +0 -14
  126. package/dist/browser/index.js.map +0 -1
  127. package/dist/browser/link-interceptor.d.ts +0 -38
  128. package/dist/browser/link-interceptor.d.ts.map +0 -1
  129. package/dist/browser/link-interceptor.js +0 -99
  130. package/dist/browser/link-interceptor.js.map +0 -1
  131. package/dist/browser/logging.d.ts +0 -10
  132. package/dist/browser/logging.d.ts.map +0 -1
  133. package/dist/browser/logging.js +0 -29
  134. package/dist/browser/logging.js.map +0 -1
  135. package/dist/browser/lru-cache.d.ts +0 -17
  136. package/dist/browser/lru-cache.d.ts.map +0 -1
  137. package/dist/browser/lru-cache.js +0 -50
  138. package/dist/browser/lru-cache.js.map +0 -1
  139. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  140. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  141. package/dist/browser/merge-segment-loaders.js +0 -102
  142. package/dist/browser/merge-segment-loaders.js.map +0 -1
  143. package/dist/browser/navigation-bridge.d.ts +0 -102
  144. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  145. package/dist/browser/navigation-bridge.js +0 -708
  146. package/dist/browser/navigation-bridge.js.map +0 -1
  147. package/dist/browser/navigation-client.d.ts +0 -25
  148. package/dist/browser/navigation-client.d.ts.map +0 -1
  149. package/dist/browser/navigation-client.js +0 -157
  150. package/dist/browser/navigation-client.js.map +0 -1
  151. package/dist/browser/navigation-store.d.ts +0 -101
  152. package/dist/browser/navigation-store.d.ts.map +0 -1
  153. package/dist/browser/navigation-store.js +0 -625
  154. package/dist/browser/navigation-store.js.map +0 -1
  155. package/dist/browser/partial-update.d.ts +0 -75
  156. package/dist/browser/partial-update.d.ts.map +0 -1
  157. package/dist/browser/partial-update.js +0 -426
  158. package/dist/browser/partial-update.js.map +0 -1
  159. package/dist/browser/react/Link.d.ts +0 -86
  160. package/dist/browser/react/Link.d.ts.map +0 -1
  161. package/dist/browser/react/Link.js +0 -128
  162. package/dist/browser/react/Link.js.map +0 -1
  163. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  164. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  165. package/dist/browser/react/NavigationProvider.js +0 -216
  166. package/dist/browser/react/NavigationProvider.js.map +0 -1
  167. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  168. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  169. package/dist/browser/react/ScrollRestoration.js +0 -57
  170. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  171. package/dist/browser/react/context.d.ts +0 -46
  172. package/dist/browser/react/context.d.ts.map +0 -1
  173. package/dist/browser/react/context.js +0 -10
  174. package/dist/browser/react/context.js.map +0 -1
  175. package/dist/browser/react/index.d.ts +0 -11
  176. package/dist/browser/react/index.d.ts.map +0 -1
  177. package/dist/browser/react/index.js +0 -22
  178. package/dist/browser/react/index.js.map +0 -1
  179. package/dist/browser/react/location-state-shared.d.ts +0 -63
  180. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  181. package/dist/browser/react/location-state-shared.js +0 -81
  182. package/dist/browser/react/location-state-shared.js.map +0 -1
  183. package/dist/browser/react/location-state.d.ts +0 -23
  184. package/dist/browser/react/location-state.d.ts.map +0 -1
  185. package/dist/browser/react/location-state.js +0 -29
  186. package/dist/browser/react/location-state.js.map +0 -1
  187. package/dist/browser/react/mount-context.d.ts +0 -24
  188. package/dist/browser/react/mount-context.d.ts.map +0 -1
  189. package/dist/browser/react/mount-context.js +0 -24
  190. package/dist/browser/react/mount-context.js.map +0 -1
  191. package/dist/browser/react/use-action.d.ts +0 -64
  192. package/dist/browser/react/use-action.d.ts.map +0 -1
  193. package/dist/browser/react/use-action.js +0 -134
  194. package/dist/browser/react/use-action.js.map +0 -1
  195. package/dist/browser/react/use-client-cache.d.ts +0 -41
  196. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  197. package/dist/browser/react/use-client-cache.js +0 -39
  198. package/dist/browser/react/use-client-cache.js.map +0 -1
  199. package/dist/browser/react/use-handle.d.ts +0 -31
  200. package/dist/browser/react/use-handle.d.ts.map +0 -1
  201. package/dist/browser/react/use-handle.js +0 -144
  202. package/dist/browser/react/use-handle.js.map +0 -1
  203. package/dist/browser/react/use-href.d.ts +0 -33
  204. package/dist/browser/react/use-href.d.ts.map +0 -1
  205. package/dist/browser/react/use-href.js +0 -39
  206. package/dist/browser/react/use-href.js.map +0 -1
  207. package/dist/browser/react/use-link-status.d.ts +0 -37
  208. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  209. package/dist/browser/react/use-link-status.js +0 -99
  210. package/dist/browser/react/use-link-status.js.map +0 -1
  211. package/dist/browser/react/use-mount.d.ts +0 -25
  212. package/dist/browser/react/use-mount.d.ts.map +0 -1
  213. package/dist/browser/react/use-mount.js +0 -30
  214. package/dist/browser/react/use-mount.js.map +0 -1
  215. package/dist/browser/react/use-navigation.d.ts +0 -27
  216. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  217. package/dist/browser/react/use-navigation.js +0 -87
  218. package/dist/browser/react/use-navigation.js.map +0 -1
  219. package/dist/browser/react/use-segments.d.ts +0 -38
  220. package/dist/browser/react/use-segments.d.ts.map +0 -1
  221. package/dist/browser/react/use-segments.js +0 -130
  222. package/dist/browser/react/use-segments.js.map +0 -1
  223. package/dist/browser/request-controller.d.ts +0 -26
  224. package/dist/browser/request-controller.d.ts.map +0 -1
  225. package/dist/browser/request-controller.js +0 -147
  226. package/dist/browser/request-controller.js.map +0 -1
  227. package/dist/browser/rsc-router.d.ts +0 -129
  228. package/dist/browser/rsc-router.d.ts.map +0 -1
  229. package/dist/browser/rsc-router.js +0 -195
  230. package/dist/browser/rsc-router.js.map +0 -1
  231. package/dist/browser/scroll-restoration.d.ts +0 -93
  232. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  233. package/dist/browser/scroll-restoration.js +0 -321
  234. package/dist/browser/scroll-restoration.js.map +0 -1
  235. package/dist/browser/segment-structure-assert.d.ts +0 -17
  236. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  237. package/dist/browser/segment-structure-assert.js +0 -59
  238. package/dist/browser/segment-structure-assert.js.map +0 -1
  239. package/dist/browser/server-action-bridge.d.ts +0 -26
  240. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  241. package/dist/browser/server-action-bridge.js +0 -668
  242. package/dist/browser/server-action-bridge.js.map +0 -1
  243. package/dist/browser/shallow.d.ts +0 -12
  244. package/dist/browser/shallow.d.ts.map +0 -1
  245. package/dist/browser/shallow.js +0 -34
  246. package/dist/browser/shallow.js.map +0 -1
  247. package/dist/browser/types.d.ts +0 -369
  248. package/dist/browser/types.d.ts.map +0 -1
  249. package/dist/browser/types.js +0 -2
  250. package/dist/browser/types.js.map +0 -1
  251. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  252. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  253. package/dist/build/__tests__/generate-cli.test.js +0 -237
  254. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  255. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  256. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  257. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  258. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  259. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  260. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  261. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  262. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  263. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  264. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  265. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  266. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  267. package/dist/build/generate-manifest.d.ts +0 -81
  268. package/dist/build/generate-manifest.d.ts.map +0 -1
  269. package/dist/build/generate-manifest.js +0 -276
  270. package/dist/build/generate-manifest.js.map +0 -1
  271. package/dist/build/generate-route-types.d.ts +0 -115
  272. package/dist/build/generate-route-types.d.ts.map +0 -1
  273. package/dist/build/generate-route-types.js +0 -740
  274. package/dist/build/generate-route-types.js.map +0 -1
  275. package/dist/build/index.d.ts +0 -21
  276. package/dist/build/index.d.ts.map +0 -1
  277. package/dist/build/index.js +0 -21
  278. package/dist/build/index.js.map +0 -1
  279. package/dist/build/route-trie.d.ts +0 -71
  280. package/dist/build/route-trie.d.ts.map +0 -1
  281. package/dist/build/route-trie.js +0 -175
  282. package/dist/build/route-trie.js.map +0 -1
  283. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  284. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  285. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  286. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  287. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  288. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  289. package/dist/cache/__tests__/document-cache.test.js +0 -345
  290. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  291. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  292. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  293. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  294. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  295. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  296. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  297. package/dist/cache/__tests__/memory-store.test.js +0 -367
  298. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  299. package/dist/cache/cache-scope.d.ts +0 -102
  300. package/dist/cache/cache-scope.d.ts.map +0 -1
  301. package/dist/cache/cache-scope.js +0 -440
  302. package/dist/cache/cache-scope.js.map +0 -1
  303. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  304. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  305. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  306. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  307. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  308. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  309. package/dist/cache/cf/cf-cache-store.js +0 -242
  310. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  311. package/dist/cache/cf/index.d.ts +0 -14
  312. package/dist/cache/cf/index.d.ts.map +0 -1
  313. package/dist/cache/cf/index.js +0 -17
  314. package/dist/cache/cf/index.js.map +0 -1
  315. package/dist/cache/document-cache.d.ts +0 -64
  316. package/dist/cache/document-cache.d.ts.map +0 -1
  317. package/dist/cache/document-cache.js +0 -228
  318. package/dist/cache/document-cache.js.map +0 -1
  319. package/dist/cache/index.d.ts +0 -19
  320. package/dist/cache/index.d.ts.map +0 -1
  321. package/dist/cache/index.js +0 -21
  322. package/dist/cache/index.js.map +0 -1
  323. package/dist/cache/memory-segment-store.d.ts +0 -110
  324. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  325. package/dist/cache/memory-segment-store.js +0 -117
  326. package/dist/cache/memory-segment-store.js.map +0 -1
  327. package/dist/cache/memory-store.d.ts +0 -41
  328. package/dist/cache/memory-store.d.ts.map +0 -1
  329. package/dist/cache/memory-store.js +0 -191
  330. package/dist/cache/memory-store.js.map +0 -1
  331. package/dist/cache/types.d.ts +0 -317
  332. package/dist/cache/types.d.ts.map +0 -1
  333. package/dist/cache/types.js +0 -12
  334. package/dist/cache/types.js.map +0 -1
  335. package/dist/client.d.ts +0 -248
  336. package/dist/client.d.ts.map +0 -1
  337. package/dist/client.js +0 -367
  338. package/dist/client.js.map +0 -1
  339. package/dist/client.rsc.d.ts +0 -26
  340. package/dist/client.rsc.d.ts.map +0 -1
  341. package/dist/client.rsc.js +0 -46
  342. package/dist/client.rsc.js.map +0 -1
  343. package/dist/component-utils.d.ts +0 -36
  344. package/dist/component-utils.d.ts.map +0 -1
  345. package/dist/component-utils.js +0 -61
  346. package/dist/component-utils.js.map +0 -1
  347. package/dist/components/DefaultDocument.d.ts +0 -13
  348. package/dist/components/DefaultDocument.d.ts.map +0 -1
  349. package/dist/components/DefaultDocument.js +0 -15
  350. package/dist/components/DefaultDocument.js.map +0 -1
  351. package/dist/debug.d.ts +0 -58
  352. package/dist/debug.d.ts.map +0 -1
  353. package/dist/debug.js +0 -157
  354. package/dist/debug.js.map +0 -1
  355. package/dist/default-error-boundary.d.ts +0 -11
  356. package/dist/default-error-boundary.d.ts.map +0 -1
  357. package/dist/default-error-boundary.js +0 -45
  358. package/dist/default-error-boundary.js.map +0 -1
  359. package/dist/deps/browser.d.ts +0 -2
  360. package/dist/deps/browser.d.ts.map +0 -1
  361. package/dist/deps/browser.js +0 -3
  362. package/dist/deps/browser.js.map +0 -1
  363. package/dist/deps/html-stream-client.d.ts +0 -2
  364. package/dist/deps/html-stream-client.d.ts.map +0 -1
  365. package/dist/deps/html-stream-client.js +0 -3
  366. package/dist/deps/html-stream-client.js.map +0 -1
  367. package/dist/deps/html-stream-server.d.ts +0 -2
  368. package/dist/deps/html-stream-server.d.ts.map +0 -1
  369. package/dist/deps/html-stream-server.js +0 -3
  370. package/dist/deps/html-stream-server.js.map +0 -1
  371. package/dist/deps/rsc.d.ts +0 -2
  372. package/dist/deps/rsc.d.ts.map +0 -1
  373. package/dist/deps/rsc.js +0 -4
  374. package/dist/deps/rsc.js.map +0 -1
  375. package/dist/deps/ssr.d.ts +0 -2
  376. package/dist/deps/ssr.d.ts.map +0 -1
  377. package/dist/deps/ssr.js +0 -3
  378. package/dist/deps/ssr.js.map +0 -1
  379. package/dist/errors.d.ts +0 -174
  380. package/dist/errors.d.ts.map +0 -1
  381. package/dist/errors.js +0 -241
  382. package/dist/errors.js.map +0 -1
  383. package/dist/handle.d.ts +0 -78
  384. package/dist/handle.d.ts.map +0 -1
  385. package/dist/handle.js +0 -82
  386. package/dist/handle.js.map +0 -1
  387. package/dist/handles/MetaTags.d.ts +0 -14
  388. package/dist/handles/MetaTags.d.ts.map +0 -1
  389. package/dist/handles/MetaTags.js +0 -136
  390. package/dist/handles/MetaTags.js.map +0 -1
  391. package/dist/handles/index.d.ts +0 -6
  392. package/dist/handles/index.d.ts.map +0 -1
  393. package/dist/handles/index.js +0 -6
  394. package/dist/handles/index.js.map +0 -1
  395. package/dist/handles/meta.d.ts +0 -39
  396. package/dist/handles/meta.d.ts.map +0 -1
  397. package/dist/handles/meta.js +0 -202
  398. package/dist/handles/meta.js.map +0 -1
  399. package/dist/host/__tests__/errors.test.d.ts +0 -2
  400. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  401. package/dist/host/__tests__/errors.test.js +0 -76
  402. package/dist/host/__tests__/errors.test.js.map +0 -1
  403. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  404. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  405. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  406. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  407. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  408. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  409. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  410. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  411. package/dist/host/__tests__/router.test.d.ts +0 -2
  412. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  413. package/dist/host/__tests__/router.test.js +0 -241
  414. package/dist/host/__tests__/router.test.js.map +0 -1
  415. package/dist/host/__tests__/testing.test.d.ts +0 -2
  416. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  417. package/dist/host/__tests__/testing.test.js +0 -64
  418. package/dist/host/__tests__/testing.test.js.map +0 -1
  419. package/dist/host/__tests__/utils.test.d.ts +0 -2
  420. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  421. package/dist/host/__tests__/utils.test.js +0 -29
  422. package/dist/host/__tests__/utils.test.js.map +0 -1
  423. package/dist/host/cookie-handler.d.ts +0 -34
  424. package/dist/host/cookie-handler.d.ts.map +0 -1
  425. package/dist/host/cookie-handler.js +0 -124
  426. package/dist/host/cookie-handler.js.map +0 -1
  427. package/dist/host/errors.d.ts +0 -56
  428. package/dist/host/errors.d.ts.map +0 -1
  429. package/dist/host/errors.js +0 -79
  430. package/dist/host/errors.js.map +0 -1
  431. package/dist/host/index.d.ts +0 -29
  432. package/dist/host/index.d.ts.map +0 -1
  433. package/dist/host/index.js +0 -32
  434. package/dist/host/index.js.map +0 -1
  435. package/dist/host/pattern-matcher.d.ts +0 -36
  436. package/dist/host/pattern-matcher.d.ts.map +0 -1
  437. package/dist/host/pattern-matcher.js +0 -172
  438. package/dist/host/pattern-matcher.js.map +0 -1
  439. package/dist/host/router.d.ts +0 -26
  440. package/dist/host/router.d.ts.map +0 -1
  441. package/dist/host/router.js +0 -218
  442. package/dist/host/router.js.map +0 -1
  443. package/dist/host/testing.d.ts +0 -36
  444. package/dist/host/testing.d.ts.map +0 -1
  445. package/dist/host/testing.js +0 -55
  446. package/dist/host/testing.js.map +0 -1
  447. package/dist/host/types.d.ts +0 -115
  448. package/dist/host/types.d.ts.map +0 -1
  449. package/dist/host/types.js +0 -7
  450. package/dist/host/types.js.map +0 -1
  451. package/dist/host/utils.d.ts +0 -21
  452. package/dist/host/utils.d.ts.map +0 -1
  453. package/dist/host/utils.js +0 -23
  454. package/dist/host/utils.js.map +0 -1
  455. package/dist/href-client.d.ts +0 -131
  456. package/dist/href-client.d.ts.map +0 -1
  457. package/dist/href-client.js +0 -64
  458. package/dist/href-client.js.map +0 -1
  459. package/dist/href-context.d.ts +0 -29
  460. package/dist/href-context.d.ts.map +0 -1
  461. package/dist/href-context.js +0 -21
  462. package/dist/href-context.js.map +0 -1
  463. package/dist/index.d.ts +0 -73
  464. package/dist/index.d.ts.map +0 -1
  465. package/dist/index.js +0 -91
  466. package/dist/index.js.map +0 -1
  467. package/dist/index.rsc.d.ts +0 -32
  468. package/dist/index.rsc.d.ts.map +0 -1
  469. package/dist/index.rsc.js +0 -40
  470. package/dist/index.rsc.js.map +0 -1
  471. package/dist/internal-debug.d.ts +0 -2
  472. package/dist/internal-debug.d.ts.map +0 -1
  473. package/dist/internal-debug.js +0 -5
  474. package/dist/internal-debug.js.map +0 -1
  475. package/dist/loader.d.ts +0 -14
  476. package/dist/loader.d.ts.map +0 -1
  477. package/dist/loader.js +0 -20
  478. package/dist/loader.js.map +0 -1
  479. package/dist/loader.rsc.d.ts +0 -19
  480. package/dist/loader.rsc.d.ts.map +0 -1
  481. package/dist/loader.rsc.js +0 -99
  482. package/dist/loader.rsc.js.map +0 -1
  483. package/dist/network-error-thrower.d.ts +0 -17
  484. package/dist/network-error-thrower.d.ts.map +0 -1
  485. package/dist/network-error-thrower.js +0 -14
  486. package/dist/network-error-thrower.js.map +0 -1
  487. package/dist/outlet-context.d.ts +0 -13
  488. package/dist/outlet-context.d.ts.map +0 -1
  489. package/dist/outlet-context.js +0 -3
  490. package/dist/outlet-context.js.map +0 -1
  491. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  492. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  493. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  494. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  495. package/dist/prerender/param-hash.d.ts +0 -16
  496. package/dist/prerender/param-hash.d.ts.map +0 -1
  497. package/dist/prerender/param-hash.js +0 -36
  498. package/dist/prerender/param-hash.js.map +0 -1
  499. package/dist/prerender/store.d.ts +0 -38
  500. package/dist/prerender/store.d.ts.map +0 -1
  501. package/dist/prerender/store.js +0 -61
  502. package/dist/prerender/store.js.map +0 -1
  503. package/dist/prerender.d.ts +0 -66
  504. package/dist/prerender.d.ts.map +0 -1
  505. package/dist/prerender.js +0 -57
  506. package/dist/prerender.js.map +0 -1
  507. package/dist/reverse.d.ts +0 -196
  508. package/dist/reverse.d.ts.map +0 -1
  509. package/dist/reverse.js +0 -78
  510. package/dist/reverse.js.map +0 -1
  511. package/dist/root-error-boundary.d.ts +0 -33
  512. package/dist/root-error-boundary.d.ts.map +0 -1
  513. package/dist/root-error-boundary.js +0 -165
  514. package/dist/root-error-boundary.js.map +0 -1
  515. package/dist/route-content-wrapper.d.ts +0 -46
  516. package/dist/route-content-wrapper.d.ts.map +0 -1
  517. package/dist/route-content-wrapper.js +0 -77
  518. package/dist/route-content-wrapper.js.map +0 -1
  519. package/dist/route-definition.d.ts +0 -421
  520. package/dist/route-definition.d.ts.map +0 -1
  521. package/dist/route-definition.js +0 -868
  522. package/dist/route-definition.js.map +0 -1
  523. package/dist/route-map-builder.d.ts +0 -155
  524. package/dist/route-map-builder.d.ts.map +0 -1
  525. package/dist/route-map-builder.js +0 -237
  526. package/dist/route-map-builder.js.map +0 -1
  527. package/dist/route-types.d.ts +0 -165
  528. package/dist/route-types.d.ts.map +0 -1
  529. package/dist/route-types.js +0 -7
  530. package/dist/route-types.js.map +0 -1
  531. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  532. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  533. package/dist/router/__tests__/handler-context.test.js +0 -65
  534. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  535. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  536. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  537. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  538. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  539. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  540. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  541. package/dist/router/__tests__/match-context.test.js +0 -92
  542. package/dist/router/__tests__/match-context.test.js.map +0 -1
  543. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  544. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  545. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  546. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  547. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  548. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  549. package/dist/router/__tests__/match-result.test.js +0 -457
  550. package/dist/router/__tests__/match-result.test.js.map +0 -1
  551. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  552. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  553. package/dist/router/__tests__/on-error.test.js +0 -678
  554. package/dist/router/__tests__/on-error.test.js.map +0 -1
  555. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  556. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  557. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  558. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  559. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  560. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  561. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  562. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  563. package/dist/router/error-handling.d.ts +0 -77
  564. package/dist/router/error-handling.d.ts.map +0 -1
  565. package/dist/router/error-handling.js +0 -202
  566. package/dist/router/error-handling.js.map +0 -1
  567. package/dist/router/handler-context.d.ts +0 -20
  568. package/dist/router/handler-context.d.ts.map +0 -1
  569. package/dist/router/handler-context.js +0 -198
  570. package/dist/router/handler-context.js.map +0 -1
  571. package/dist/router/intercept-resolution.d.ts +0 -66
  572. package/dist/router/intercept-resolution.d.ts.map +0 -1
  573. package/dist/router/intercept-resolution.js +0 -246
  574. package/dist/router/intercept-resolution.js.map +0 -1
  575. package/dist/router/loader-resolution.d.ts +0 -64
  576. package/dist/router/loader-resolution.d.ts.map +0 -1
  577. package/dist/router/loader-resolution.js +0 -284
  578. package/dist/router/loader-resolution.js.map +0 -1
  579. package/dist/router/logging.d.ts +0 -15
  580. package/dist/router/logging.d.ts.map +0 -1
  581. package/dist/router/logging.js +0 -99
  582. package/dist/router/logging.js.map +0 -1
  583. package/dist/router/manifest.d.ts +0 -22
  584. package/dist/router/manifest.d.ts.map +0 -1
  585. package/dist/router/manifest.js +0 -181
  586. package/dist/router/manifest.js.map +0 -1
  587. package/dist/router/match-api.d.ts +0 -35
  588. package/dist/router/match-api.d.ts.map +0 -1
  589. package/dist/router/match-api.js +0 -406
  590. package/dist/router/match-api.js.map +0 -1
  591. package/dist/router/match-context.d.ts +0 -206
  592. package/dist/router/match-context.d.ts.map +0 -1
  593. package/dist/router/match-context.js +0 -17
  594. package/dist/router/match-context.js.map +0 -1
  595. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  596. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  597. package/dist/router/match-middleware/background-revalidation.js +0 -75
  598. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  599. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  600. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  601. package/dist/router/match-middleware/cache-lookup.js +0 -257
  602. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  603. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  604. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  605. package/dist/router/match-middleware/cache-store.js +0 -108
  606. package/dist/router/match-middleware/cache-store.js.map +0 -1
  607. package/dist/router/match-middleware/index.d.ts +0 -81
  608. package/dist/router/match-middleware/index.d.ts.map +0 -1
  609. package/dist/router/match-middleware/index.js +0 -80
  610. package/dist/router/match-middleware/index.js.map +0 -1
  611. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  612. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  613. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  614. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  615. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  616. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  617. package/dist/router/match-middleware/segment-resolution.js +0 -53
  618. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  619. package/dist/router/match-pipelines.d.ts +0 -147
  620. package/dist/router/match-pipelines.d.ts.map +0 -1
  621. package/dist/router/match-pipelines.js +0 -82
  622. package/dist/router/match-pipelines.js.map +0 -1
  623. package/dist/router/match-result.d.ts +0 -126
  624. package/dist/router/match-result.d.ts.map +0 -1
  625. package/dist/router/match-result.js +0 -93
  626. package/dist/router/match-result.js.map +0 -1
  627. package/dist/router/metrics.d.ts +0 -20
  628. package/dist/router/metrics.d.ts.map +0 -1
  629. package/dist/router/metrics.js +0 -47
  630. package/dist/router/metrics.js.map +0 -1
  631. package/dist/router/middleware.d.ts +0 -249
  632. package/dist/router/middleware.d.ts.map +0 -1
  633. package/dist/router/middleware.js +0 -434
  634. package/dist/router/middleware.js.map +0 -1
  635. package/dist/router/middleware.test.d.ts +0 -2
  636. package/dist/router/middleware.test.d.ts.map +0 -1
  637. package/dist/router/middleware.test.js +0 -816
  638. package/dist/router/middleware.test.js.map +0 -1
  639. package/dist/router/pattern-matching.d.ts +0 -149
  640. package/dist/router/pattern-matching.d.ts.map +0 -1
  641. package/dist/router/pattern-matching.js +0 -349
  642. package/dist/router/pattern-matching.js.map +0 -1
  643. package/dist/router/revalidation.d.ts +0 -44
  644. package/dist/router/revalidation.d.ts.map +0 -1
  645. package/dist/router/revalidation.js +0 -147
  646. package/dist/router/revalidation.js.map +0 -1
  647. package/dist/router/router-context.d.ts +0 -135
  648. package/dist/router/router-context.d.ts.map +0 -1
  649. package/dist/router/router-context.js +0 -36
  650. package/dist/router/router-context.js.map +0 -1
  651. package/dist/router/segment-resolution.d.ts +0 -127
  652. package/dist/router/segment-resolution.d.ts.map +0 -1
  653. package/dist/router/segment-resolution.js +0 -919
  654. package/dist/router/segment-resolution.js.map +0 -1
  655. package/dist/router/trie-matching.d.ts +0 -40
  656. package/dist/router/trie-matching.d.ts.map +0 -1
  657. package/dist/router/trie-matching.js +0 -127
  658. package/dist/router/trie-matching.js.map +0 -1
  659. package/dist/router/types.d.ts +0 -136
  660. package/dist/router/types.d.ts.map +0 -1
  661. package/dist/router/types.js +0 -7
  662. package/dist/router/types.js.map +0 -1
  663. package/dist/router.d.ts +0 -753
  664. package/dist/router.d.ts.map +0 -1
  665. package/dist/router.gen.d.ts +0 -6
  666. package/dist/router.gen.d.ts.map +0 -1
  667. package/dist/router.gen.js +0 -6
  668. package/dist/router.gen.js.map +0 -1
  669. package/dist/router.js +0 -1304
  670. package/dist/router.js.map +0 -1
  671. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  672. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  673. package/dist/rsc/__tests__/helpers.test.js +0 -140
  674. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  675. package/dist/rsc/handler.d.ts +0 -45
  676. package/dist/rsc/handler.d.ts.map +0 -1
  677. package/dist/rsc/handler.js +0 -1172
  678. package/dist/rsc/handler.js.map +0 -1
  679. package/dist/rsc/helpers.d.ts +0 -16
  680. package/dist/rsc/helpers.d.ts.map +0 -1
  681. package/dist/rsc/helpers.js +0 -55
  682. package/dist/rsc/helpers.js.map +0 -1
  683. package/dist/rsc/index.d.ts +0 -22
  684. package/dist/rsc/index.d.ts.map +0 -1
  685. package/dist/rsc/index.js +0 -23
  686. package/dist/rsc/index.js.map +0 -1
  687. package/dist/rsc/nonce.d.ts +0 -9
  688. package/dist/rsc/nonce.d.ts.map +0 -1
  689. package/dist/rsc/nonce.js +0 -18
  690. package/dist/rsc/nonce.js.map +0 -1
  691. package/dist/rsc/types.d.ts +0 -206
  692. package/dist/rsc/types.d.ts.map +0 -1
  693. package/dist/rsc/types.js +0 -8
  694. package/dist/rsc/types.js.map +0 -1
  695. package/dist/search-params.d.ts +0 -103
  696. package/dist/search-params.d.ts.map +0 -1
  697. package/dist/search-params.js +0 -74
  698. package/dist/search-params.js.map +0 -1
  699. package/dist/segment-system.d.ts +0 -75
  700. package/dist/segment-system.d.ts.map +0 -1
  701. package/dist/segment-system.js +0 -336
  702. package/dist/segment-system.js.map +0 -1
  703. package/dist/server/context.d.ts +0 -245
  704. package/dist/server/context.d.ts.map +0 -1
  705. package/dist/server/context.js +0 -197
  706. package/dist/server/context.js.map +0 -1
  707. package/dist/server/fetchable-loader-store.d.ts +0 -18
  708. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  709. package/dist/server/fetchable-loader-store.js +0 -18
  710. package/dist/server/fetchable-loader-store.js.map +0 -1
  711. package/dist/server/handle-store.d.ts +0 -85
  712. package/dist/server/handle-store.d.ts.map +0 -1
  713. package/dist/server/handle-store.js +0 -142
  714. package/dist/server/handle-store.js.map +0 -1
  715. package/dist/server/loader-registry.d.ts +0 -55
  716. package/dist/server/loader-registry.d.ts.map +0 -1
  717. package/dist/server/loader-registry.js +0 -132
  718. package/dist/server/loader-registry.js.map +0 -1
  719. package/dist/server/request-context.d.ts +0 -226
  720. package/dist/server/request-context.d.ts.map +0 -1
  721. package/dist/server/request-context.js +0 -290
  722. package/dist/server/request-context.js.map +0 -1
  723. package/dist/server/root-layout.d.ts +0 -4
  724. package/dist/server/root-layout.d.ts.map +0 -1
  725. package/dist/server/root-layout.js +0 -5
  726. package/dist/server/root-layout.js.map +0 -1
  727. package/dist/server.d.ts +0 -15
  728. package/dist/server.d.ts.map +0 -1
  729. package/dist/server.js +0 -20
  730. package/dist/server.js.map +0 -1
  731. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  732. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  733. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  734. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  735. package/dist/ssr/index.d.ts +0 -98
  736. package/dist/ssr/index.d.ts.map +0 -1
  737. package/dist/ssr/index.js +0 -158
  738. package/dist/ssr/index.js.map +0 -1
  739. package/dist/static-handler.d.ts +0 -50
  740. package/dist/static-handler.d.ts.map +0 -1
  741. package/dist/static-handler.gen.d.ts +0 -5
  742. package/dist/static-handler.gen.d.ts.map +0 -1
  743. package/dist/static-handler.gen.js +0 -5
  744. package/dist/static-handler.gen.js.map +0 -1
  745. package/dist/static-handler.js +0 -29
  746. package/dist/static-handler.js.map +0 -1
  747. package/dist/theme/ThemeProvider.d.ts +0 -20
  748. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  749. package/dist/theme/ThemeProvider.js +0 -240
  750. package/dist/theme/ThemeProvider.js.map +0 -1
  751. package/dist/theme/ThemeScript.d.ts +0 -48
  752. package/dist/theme/ThemeScript.d.ts.map +0 -1
  753. package/dist/theme/ThemeScript.js +0 -13
  754. package/dist/theme/ThemeScript.js.map +0 -1
  755. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  756. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  757. package/dist/theme/__tests__/theme.test.js +0 -103
  758. package/dist/theme/__tests__/theme.test.js.map +0 -1
  759. package/dist/theme/constants.d.ts +0 -29
  760. package/dist/theme/constants.d.ts.map +0 -1
  761. package/dist/theme/constants.js +0 -48
  762. package/dist/theme/constants.js.map +0 -1
  763. package/dist/theme/index.d.ts +0 -31
  764. package/dist/theme/index.d.ts.map +0 -1
  765. package/dist/theme/index.js +0 -36
  766. package/dist/theme/index.js.map +0 -1
  767. package/dist/theme/theme-context.d.ts +0 -40
  768. package/dist/theme/theme-context.d.ts.map +0 -1
  769. package/dist/theme/theme-context.js +0 -60
  770. package/dist/theme/theme-context.js.map +0 -1
  771. package/dist/theme/theme-script.d.ts +0 -27
  772. package/dist/theme/theme-script.d.ts.map +0 -1
  773. package/dist/theme/theme-script.js +0 -147
  774. package/dist/theme/theme-script.js.map +0 -1
  775. package/dist/theme/types.d.ts +0 -163
  776. package/dist/theme/types.d.ts.map +0 -1
  777. package/dist/theme/types.js +0 -11
  778. package/dist/theme/types.js.map +0 -1
  779. package/dist/theme/use-theme.d.ts +0 -12
  780. package/dist/theme/use-theme.d.ts.map +0 -1
  781. package/dist/theme/use-theme.js +0 -40
  782. package/dist/theme/use-theme.js.map +0 -1
  783. package/dist/types.d.ts +0 -1479
  784. package/dist/types.d.ts.map +0 -1
  785. package/dist/types.js +0 -10
  786. package/dist/types.js.map +0 -1
  787. package/dist/urls.d.ts +0 -441
  788. package/dist/urls.d.ts.map +0 -1
  789. package/dist/urls.gen.d.ts +0 -8
  790. package/dist/urls.gen.d.ts.map +0 -1
  791. package/dist/urls.gen.js +0 -8
  792. package/dist/urls.gen.js.map +0 -1
  793. package/dist/urls.js +0 -443
  794. package/dist/urls.js.map +0 -1
  795. package/dist/use-loader.d.ts +0 -127
  796. package/dist/use-loader.d.ts.map +0 -1
  797. package/dist/use-loader.js +0 -237
  798. package/dist/use-loader.js.map +0 -1
  799. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  800. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  801. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  802. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  803. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  804. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  805. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  806. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  807. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  808. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  809. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  810. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  811. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  812. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  813. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  814. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  815. package/dist/vite/ast-handler-extract.d.ts +0 -49
  816. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  817. package/dist/vite/ast-handler-extract.js +0 -249
  818. package/dist/vite/ast-handler-extract.js.map +0 -1
  819. package/dist/vite/expose-action-id.d.ts +0 -19
  820. package/dist/vite/expose-action-id.d.ts.map +0 -1
  821. package/dist/vite/expose-action-id.js +0 -250
  822. package/dist/vite/expose-action-id.js.map +0 -1
  823. package/dist/vite/expose-id-utils.d.ts +0 -69
  824. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  825. package/dist/vite/expose-id-utils.js +0 -289
  826. package/dist/vite/expose-id-utils.js.map +0 -1
  827. package/dist/vite/expose-internal-ids.d.ts +0 -22
  828. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  829. package/dist/vite/expose-internal-ids.js +0 -886
  830. package/dist/vite/expose-internal-ids.js.map +0 -1
  831. package/dist/vite/index.d.ts +0 -149
  832. package/dist/vite/index.d.ts.map +0 -1
  833. package/dist/vite/index.js.bak +0 -5448
  834. package/dist/vite/index.js.map +0 -1
  835. package/dist/vite/index.named-routes.gen.ts +0 -103
  836. package/dist/vite/package-resolution.d.ts +0 -43
  837. package/dist/vite/package-resolution.d.ts.map +0 -1
  838. package/dist/vite/package-resolution.js +0 -112
  839. package/dist/vite/package-resolution.js.map +0 -1
  840. package/dist/vite/virtual-entries.d.ts +0 -25
  841. package/dist/vite/virtual-entries.d.ts.map +0 -1
  842. package/dist/vite/virtual-entries.js +0 -110
  843. package/dist/vite/virtual-entries.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"client-href.test.js","sourceRoot":"","sources":["../../src/__tests__/client-href.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=component-utils.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"component-utils.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/component-utils.test.ts"],"names":[],"mappings":""}
@@ -1,51 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { isClientComponent, assertClientComponent } from "../component-utils";
3
- describe("component-utils", () => {
4
- describe("isClientComponent", () => {
5
- it("should return false for regular functions", () => {
6
- const ServerComponent = () => null;
7
- expect(isClientComponent(ServerComponent)).toBe(false);
8
- });
9
- it("should return false for non-functions", () => {
10
- expect(isClientComponent(null)).toBe(false);
11
- expect(isClientComponent(undefined)).toBe(false);
12
- expect(isClientComponent("string")).toBe(false);
13
- expect(isClientComponent(123)).toBe(false);
14
- expect(isClientComponent({})).toBe(false);
15
- });
16
- it("should return true for functions with client reference marker", () => {
17
- const ClientComponent = () => null;
18
- // Simulate what the bundler does for "use client" components
19
- ClientComponent.$$typeof = Symbol.for("react.client.reference");
20
- ClientComponent.$$id = "src/components/MyComponent.tsx#default";
21
- expect(isClientComponent(ClientComponent)).toBe(true);
22
- });
23
- it("should return false for functions with wrong $$typeof symbol", () => {
24
- const Component = () => null;
25
- Component.$$typeof = Symbol.for("react.element");
26
- expect(isClientComponent(Component)).toBe(false);
27
- });
28
- });
29
- describe("assertClientComponent", () => {
30
- it("should throw for non-function values", () => {
31
- expect(() => assertClientComponent(null, "document")).toThrow('document must be a client component function with "use client" directive');
32
- expect(() => assertClientComponent({}, "document")).toThrow('document must be a client component function with "use client" directive');
33
- });
34
- it("should throw for server components (no client marker)", () => {
35
- const ServerComponent = () => null;
36
- expect(() => assertClientComponent(ServerComponent, "document")).toThrow('document must be a client component with "use client" directive');
37
- expect(() => assertClientComponent(ServerComponent, "document")).toThrow("cannot be serialized in the RSC payload");
38
- });
39
- it("should not throw for client components", () => {
40
- const ClientComponent = () => null;
41
- ClientComponent.$$typeof = Symbol.for("react.client.reference");
42
- ClientComponent.$$id = "src/document.tsx#default";
43
- expect(() => assertClientComponent(ClientComponent, "document")).not.toThrow();
44
- });
45
- it("should include component name in error message", () => {
46
- const ServerComponent = () => null;
47
- expect(() => assertClientComponent(ServerComponent, "myLayout")).toThrow("myLayout must be a client component");
48
- });
49
- });
50
- });
51
- //# sourceMappingURL=component-utils.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"component-utils.test.js","sourceRoot":"","sources":["../../src/__tests__/component-utils.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=event-controller.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"event-controller.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/event-controller.test.ts"],"names":[],"mappings":""}
@@ -1,538 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
- import { createEventController, } from "../browser/event-controller.js";
3
- // All tests use fake timers because the controller debounces notifications
4
- // via setTimeout(0) and settles actions after 100ms.
5
- function loc(path = "/") {
6
- return new URL(path, "http://localhost");
7
- }
8
- function createController(path = "/") {
9
- return createEventController({ initialLocation: loc(path) });
10
- }
11
- describe("createEventController", () => {
12
- beforeEach(() => {
13
- vi.useFakeTimers();
14
- });
15
- afterEach(() => {
16
- vi.useRealTimers();
17
- });
18
- // ======================================================================
19
- // Initial State
20
- // ======================================================================
21
- describe("initial state", () => {
22
- it("starts idle with no pending navigation or actions", () => {
23
- const ctrl = createController();
24
- const state = ctrl.getState();
25
- expect(state.state).toBe("idle");
26
- expect(state.isStreaming).toBe(false);
27
- expect(state.pendingUrl).toBeNull();
28
- expect(state.inflightActions).toEqual([]);
29
- });
30
- it("uses provided initialLocation", () => {
31
- const ctrl = createController("/products");
32
- expect(ctrl.getState().location.pathname).toBe("/products");
33
- });
34
- it("returns idle action state for unknown action", () => {
35
- const ctrl = createController();
36
- const actionState = ctrl.getActionState("unknown");
37
- expect(actionState.state).toBe("idle");
38
- expect(actionState.actionId).toBeNull();
39
- expect(actionState.payload).toBeNull();
40
- expect(actionState.error).toBeNull();
41
- expect(actionState.result).toBeNull();
42
- });
43
- });
44
- // ======================================================================
45
- // Navigation Operations
46
- // ======================================================================
47
- describe("navigation", () => {
48
- it("startNavigation transitions state to loading with pendingUrl", () => {
49
- const ctrl = createController();
50
- ctrl.startNavigation("/about");
51
- const state = ctrl.getState();
52
- expect(state.state).toBe("loading");
53
- expect(state.pendingUrl).toBe("/about");
54
- });
55
- it("complete updates location and returns to idle", () => {
56
- const ctrl = createController();
57
- const handle = ctrl.startNavigation("/about");
58
- handle.complete(loc("/about"));
59
- const state = ctrl.getState();
60
- expect(state.state).toBe("idle");
61
- expect(state.location.pathname).toBe("/about");
62
- expect(state.pendingUrl).toBeNull();
63
- expect(handle.completed).toBe(true);
64
- });
65
- it("switchMap: new navigation aborts previous", () => {
66
- const ctrl = createController();
67
- const first = ctrl.startNavigation("/page1");
68
- const second = ctrl.startNavigation("/page2");
69
- expect(first.signal.aborted).toBe(true);
70
- expect(second.signal.aborted).toBe(false);
71
- expect(ctrl.getState().pendingUrl).toBe("/page2");
72
- });
73
- it("abortNavigation clears current navigation", () => {
74
- const ctrl = createController();
75
- ctrl.startNavigation("/about");
76
- ctrl.abortNavigation();
77
- expect(ctrl.getState().state).toBe("idle");
78
- expect(ctrl.getState().pendingUrl).toBeNull();
79
- expect(ctrl.getCurrentNavigation()).toBeNull();
80
- });
81
- it("abortNavigation is a no-op when idle", () => {
82
- const ctrl = createController();
83
- ctrl.abortNavigation(); // should not throw
84
- expect(ctrl.getState().state).toBe("idle");
85
- });
86
- it("streaming token increments/decrements active streams", () => {
87
- const ctrl = createController();
88
- const handle = ctrl.startNavigation("/about");
89
- const token = handle.startStreaming();
90
- // pendingUrl is null during streaming (already fetched)
91
- // but isStreaming is true
92
- expect(ctrl.getState().isStreaming).toBe(true);
93
- token.end();
94
- handle.complete(loc("/about"));
95
- expect(ctrl.getState().isStreaming).toBe(false);
96
- });
97
- it("streaming token end is idempotent", () => {
98
- const ctrl = createController();
99
- const handle = ctrl.startNavigation("/about");
100
- const token = handle.startStreaming();
101
- token.end();
102
- token.end(); // second call should be a no-op
103
- handle.complete(loc("/about"));
104
- expect(ctrl.getState().state).toBe("idle");
105
- });
106
- it("Symbol.dispose cleans up if not completed", () => {
107
- const ctrl = createController();
108
- const handle = ctrl.startNavigation("/about");
109
- handle[Symbol.dispose]();
110
- expect(ctrl.getState().state).toBe("idle");
111
- expect(ctrl.getCurrentNavigation()).toBeNull();
112
- });
113
- it("Symbol.dispose is a no-op if navigation was aborted by another", () => {
114
- const ctrl = createController();
115
- const first = ctrl.startNavigation("/page1");
116
- ctrl.startNavigation("/page2"); // aborts first
117
- first[Symbol.dispose](); // should not clear second navigation
118
- expect(ctrl.getState().pendingUrl).toBe("/page2");
119
- });
120
- it("Symbol.dispose is a no-op if already completed", () => {
121
- const ctrl = createController();
122
- const handle = ctrl.startNavigation("/about");
123
- handle.complete(loc("/about"));
124
- handle[Symbol.dispose](); // should not reset state
125
- expect(ctrl.getState().location.pathname).toBe("/about");
126
- });
127
- it("complete is a no-op if navigation was replaced", () => {
128
- const ctrl = createController();
129
- const first = ctrl.startNavigation("/page1");
130
- ctrl.startNavigation("/page2");
131
- first.complete(loc("/page1")); // should not update location
132
- expect(ctrl.getState().location.pathname).toBe("/");
133
- });
134
- });
135
- // ======================================================================
136
- // setLocation
137
- // ======================================================================
138
- describe("setLocation", () => {
139
- it("updates location without navigation", () => {
140
- const ctrl = createController();
141
- ctrl.setLocation(loc("/popstate-target"));
142
- expect(ctrl.getState().location.pathname).toBe("/popstate-target");
143
- });
144
- });
145
- // ======================================================================
146
- // Action Operations
147
- // ======================================================================
148
- describe("actions", () => {
149
- it("startAction creates an inflight action in loading state", () => {
150
- const ctrl = createController();
151
- ctrl.startAction("hash#addToCart", [1]);
152
- const state = ctrl.getState();
153
- expect(state.state).toBe("loading");
154
- expect(state.inflightActions).toHaveLength(1);
155
- expect(state.inflightActions[0].actionId).toBe("hash#addToCart");
156
- expect(state.inflightActions[0].payload).toEqual([1]);
157
- });
158
- it("getActionState returns loading for fetching action", () => {
159
- const ctrl = createController();
160
- ctrl.startAction("hash#addToCart", ["item-1"]);
161
- const actionState = ctrl.getActionState("hash#addToCart");
162
- expect(actionState.state).toBe("loading");
163
- expect(actionState.actionId).toBe("hash#addToCart");
164
- expect(actionState.payload).toEqual(["item-1"]);
165
- });
166
- it("getActionState suffix matching: 'addToCart' matches 'hash#addToCart'", () => {
167
- const ctrl = createController();
168
- ctrl.startAction("hash#addToCart", []);
169
- const actionState = ctrl.getActionState("addToCart");
170
- expect(actionState.state).toBe("loading");
171
- expect(actionState.actionId).toBe("hash#addToCart");
172
- });
173
- it("getActionState exact matching when subscription has #", () => {
174
- const ctrl = createController();
175
- ctrl.startAction("hash#addToCart", []);
176
- ctrl.startAction("other#addToCart", []);
177
- // Exact match: only gets the matching action
178
- const state = ctrl.getActionState("hash#addToCart");
179
- expect(state.actionId).toBe("hash#addToCart");
180
- });
181
- it("action streaming lifecycle", () => {
182
- const ctrl = createController();
183
- const handle = ctrl.startAction("hash#save", []);
184
- // Start streaming
185
- const token = handle.startStreaming();
186
- expect(ctrl.getActionState("save").state).toBe("streaming");
187
- // End streaming, then complete
188
- token.end();
189
- handle.complete("saved!");
190
- // After settlement delay (100ms), action is cleaned up
191
- vi.advanceTimersByTime(100);
192
- expect(ctrl.getActionState("save").state).toBe("idle");
193
- });
194
- it("action complete without streaming finalizes immediately", () => {
195
- const ctrl = createController();
196
- const handle = ctrl.startAction("hash#delete", [42]);
197
- handle.complete("deleted");
198
- // Phase is settling, but result is accessible
199
- const actionState = ctrl.getActionState("delete");
200
- expect(actionState.result).toBe("deleted");
201
- expect(actionState.state).toBe("idle"); // settling maps to idle
202
- // After 100ms, entry is removed
203
- vi.advanceTimersByTime(100);
204
- expect(ctrl.getInflightActions().size).toBe(0);
205
- });
206
- it("action fail sets error", () => {
207
- const ctrl = createController();
208
- const handle = ctrl.startAction("hash#save", []);
209
- handle.fail(new Error("network error"));
210
- const actionState = ctrl.getActionState("save");
211
- expect(actionState.error).toBeInstanceOf(Error);
212
- expect(actionState.state).toBe("idle"); // settling
213
- vi.advanceTimersByTime(100);
214
- expect(ctrl.getInflightActions().size).toBe(0);
215
- });
216
- it("complete and fail are no-ops after settlement", () => {
217
- const ctrl = createController();
218
- const handle = ctrl.startAction("hash#save", []);
219
- handle.complete("first");
220
- vi.advanceTimersByTime(100); // settle
221
- handle.complete("second"); // no-op
222
- handle.fail("error"); // no-op
223
- expect(ctrl.getInflightActions().size).toBe(0);
224
- });
225
- it("action complete waits for streaming to end before finalizing", () => {
226
- const ctrl = createController();
227
- const handle = ctrl.startAction("hash#save", []);
228
- const token = handle.startStreaming();
229
- handle.complete("result");
230
- // Action is complete but streaming hasn't ended - should still be streaming
231
- expect(ctrl.getActionState("save").state).toBe("streaming");
232
- expect(handle.settled).toBe(false);
233
- // End streaming - now it finalizes
234
- token.end();
235
- expect(ctrl.getActionState("save").state).toBe("idle"); // settling
236
- expect(handle.settled).toBe(true);
237
- });
238
- it("action fail waits for streaming to end before finalizing", () => {
239
- const ctrl = createController();
240
- const handle = ctrl.startAction("hash#save", []);
241
- const token = handle.startStreaming();
242
- handle.fail(new Error("fail"));
243
- // Still streaming
244
- expect(ctrl.getActionState("save").state).toBe("streaming");
245
- token.end();
246
- expect(ctrl.getActionState("save").error).toBeInstanceOf(Error);
247
- });
248
- it("Symbol.dispose force-finalizes if action was not completed", () => {
249
- const ctrl = createController();
250
- const handle = ctrl.startAction("hash#save", []);
251
- handle[Symbol.dispose]();
252
- // Action should be settling
253
- const state = ctrl.getActionState("save");
254
- expect(state.state).toBe("idle"); // settling maps to idle
255
- vi.advanceTimersByTime(100);
256
- expect(ctrl.getInflightActions().size).toBe(0);
257
- });
258
- it("Symbol.dispose is a no-op if action was already completed", () => {
259
- const ctrl = createController();
260
- const handle = ctrl.startAction("hash#save", []);
261
- handle.complete("ok");
262
- handle[Symbol.dispose](); // should not throw or double-settle
263
- expect(handle.settled).toBe(true);
264
- });
265
- it("Symbol.dispose cleans up immediately if aborted", () => {
266
- const ctrl = createController();
267
- const handle = ctrl.startAction("hash#save", []);
268
- handle.abort.abort();
269
- handle[Symbol.dispose]();
270
- // Action removed immediately, no settlement
271
- expect(ctrl.getInflightActions().size).toBe(0);
272
- });
273
- it("streaming token end is idempotent for actions", () => {
274
- const ctrl = createController();
275
- const handle = ctrl.startAction("hash#save", []);
276
- const token = handle.startStreaming();
277
- token.end();
278
- token.end(); // no-op
279
- handle.complete("ok");
280
- vi.advanceTimersByTime(100);
281
- expect(ctrl.getInflightActions().size).toBe(0);
282
- });
283
- });
284
- // ======================================================================
285
- // Concurrent Actions & Consolidation
286
- // ======================================================================
287
- describe("concurrent actions", () => {
288
- it("tracks hadConcurrentActions when multiple actions overlap", () => {
289
- const ctrl = createController();
290
- const first = ctrl.startAction("hash#a", []);
291
- const second = ctrl.startAction("hash#b", []);
292
- expect(first.hadConcurrentActions).toBe(false); // first had no prior
293
- expect(second.hadConcurrentActions).toBe(true); // second saw first
294
- });
295
- it("recordRevalidatedSegments tracks segments for consolidation", () => {
296
- const ctrl = createController();
297
- const first = ctrl.startAction("hash#a", []);
298
- const second = ctrl.startAction("hash#b", []);
299
- first.recordRevalidatedSegments(["seg1", "seg2"]);
300
- second.recordRevalidatedSegments(["seg2", "seg3"]);
301
- // Can't consolidate while any action is still fetching
302
- expect(second.getConsolidationSegments()).toBeNull();
303
- // Complete both so none are fetching
304
- first.complete();
305
- second.complete();
306
- // Now consolidation returns all revalidated segments
307
- const segments = second.getConsolidationSegments();
308
- expect(segments).toContain("seg1");
309
- expect(segments).toContain("seg2");
310
- expect(segments).toContain("seg3");
311
- });
312
- it("getConsolidationSegments returns null when no concurrent actions", () => {
313
- const ctrl = createController();
314
- const handle = ctrl.startAction("hash#a", []);
315
- expect(handle.getConsolidationSegments()).toBeNull();
316
- });
317
- it("getConsolidationSegments returns null when segments are empty", () => {
318
- const ctrl = createController();
319
- const first = ctrl.startAction("hash#a", []);
320
- const second = ctrl.startAction("hash#b", []);
321
- first.complete();
322
- // No segments were recorded
323
- expect(second.getConsolidationSegments()).toBeNull();
324
- });
325
- it("clearConsolidation resets tracking", () => {
326
- const ctrl = createController();
327
- const first = ctrl.startAction("hash#a", []);
328
- const second = ctrl.startAction("hash#b", []);
329
- first.recordRevalidatedSegments(["seg1"]);
330
- first.complete();
331
- second.clearConsolidation();
332
- expect(second.getConsolidationSegments()).toBeNull();
333
- });
334
- it("settlement of last action resets concurrent tracking", () => {
335
- const ctrl = createController();
336
- const first = ctrl.startAction("hash#a", []);
337
- const second = ctrl.startAction("hash#b", []);
338
- first.recordRevalidatedSegments(["seg1"]);
339
- first.complete();
340
- second.complete();
341
- vi.advanceTimersByTime(100); // settle first
342
- vi.advanceTimersByTime(100); // settle second
343
- // All actions cleaned up, concurrent tracking reset
344
- expect(ctrl.getInflightActions().size).toBe(0);
345
- });
346
- it("abortAllActions clears all inflight actions and tracking", () => {
347
- const ctrl = createController();
348
- const first = ctrl.startAction("hash#a", []);
349
- const second = ctrl.startAction("hash#b", []);
350
- first.recordRevalidatedSegments(["seg1"]);
351
- ctrl.abortAllActions();
352
- expect(first.signal.aborted).toBe(true);
353
- expect(second.signal.aborted).toBe(true);
354
- expect(ctrl.getInflightActions().size).toBe(0);
355
- expect(ctrl.getState().state).toBe("idle");
356
- });
357
- });
358
- // ======================================================================
359
- // Derived State
360
- // ======================================================================
361
- describe("derived state", () => {
362
- it("state is loading when navigation OR actions are active", () => {
363
- const ctrl = createController();
364
- expect(ctrl.getState().state).toBe("idle");
365
- ctrl.startNavigation("/a");
366
- expect(ctrl.getState().state).toBe("loading");
367
- ctrl.abortNavigation();
368
- expect(ctrl.getState().state).toBe("idle");
369
- ctrl.startAction("hash#x", []);
370
- expect(ctrl.getState().state).toBe("loading");
371
- });
372
- it("pendingUrl is only set during fetching phase", () => {
373
- const ctrl = createController();
374
- const handle = ctrl.startNavigation("/about");
375
- expect(ctrl.getState().pendingUrl).toBe("/about");
376
- // Once streaming starts, we don't report pendingUrl
377
- // (but navigation entry phase doesn't change via startStreaming on navigation handle)
378
- // pendingUrl comes from currentNavigation.phase === "fetching"
379
- handle.complete(loc("/about"));
380
- expect(ctrl.getState().pendingUrl).toBeNull();
381
- });
382
- it("inflightActions excludes settling actions", () => {
383
- const ctrl = createController();
384
- const handle = ctrl.startAction("hash#save", []);
385
- expect(ctrl.getState().inflightActions).toHaveLength(1);
386
- handle.complete("ok"); // phase becomes settling
387
- expect(ctrl.getState().inflightActions).toHaveLength(0);
388
- });
389
- it("isStreaming reflects active stream count", () => {
390
- const ctrl = createController();
391
- expect(ctrl.getState().isStreaming).toBe(false);
392
- const navHandle = ctrl.startNavigation("/x");
393
- // loading implies streaming
394
- expect(ctrl.getState().isStreaming).toBe(true);
395
- const token1 = navHandle.startStreaming();
396
- navHandle.complete(loc("/x"));
397
- // Still streaming because token hasn't ended
398
- expect(ctrl.getState().isStreaming).toBe(true);
399
- token1.end();
400
- expect(ctrl.getState().isStreaming).toBe(false);
401
- });
402
- });
403
- // ======================================================================
404
- // Handle Operations
405
- // ======================================================================
406
- describe("handle data", () => {
407
- it("setHandleData full update replaces all data", () => {
408
- const ctrl = createController();
409
- const data = { title: { "seg.1": ["Page 1"] } };
410
- ctrl.setHandleData(data, ["seg.1"]);
411
- const state = ctrl.getHandleState();
412
- expect(state.data).toEqual(data);
413
- expect(state.segmentOrder).toEqual(["seg.1"]);
414
- });
415
- it("setHandleData partial update merges new data", () => {
416
- const ctrl = createController();
417
- ctrl.setHandleData({ title: { "seg.1": ["Page 1"] } }, ["seg.1"]);
418
- // Partial: add seg.2 data
419
- ctrl.setHandleData({ title: { "seg.2": ["Page 2"] } }, ["seg.1", "seg.2"], true);
420
- const state = ctrl.getHandleState();
421
- expect(state.data.title["seg.1"]).toEqual(["Page 1"]);
422
- expect(state.data.title["seg.2"]).toEqual(["Page 2"]);
423
- });
424
- it("partial update removes data for segments not in matched list", () => {
425
- const ctrl = createController();
426
- ctrl.setHandleData({ title: { "seg.1": ["A"], "seg.2": ["B"] } }, ["seg.1", "seg.2"]);
427
- // Navigate: seg.2 replaced with seg.3
428
- ctrl.setHandleData({ title: { "seg.3": ["C"] } }, ["seg.1", "seg.3"], true);
429
- const state = ctrl.getHandleState();
430
- expect(state.data.title["seg.1"]).toEqual(["A"]);
431
- expect(state.data.title["seg.2"]).toBeUndefined();
432
- expect(state.data.title["seg.3"]).toEqual(["C"]);
433
- });
434
- it("filterSegmentOrder excludes parallels (.@) and loaders (D digit)", () => {
435
- const ctrl = createController();
436
- ctrl.setHandleData({}, ["root", "layout.@sidebar", "page", "D1.loader", "content"]);
437
- const state = ctrl.getHandleState();
438
- expect(state.segmentOrder).toEqual(["root", "page", "content"]);
439
- });
440
- });
441
- // ======================================================================
442
- // Subscriptions & Debounced Notifications
443
- // ======================================================================
444
- describe("subscriptions", () => {
445
- it("subscribe notifies on state changes (debounced)", () => {
446
- const ctrl = createController();
447
- const listener = vi.fn();
448
- ctrl.subscribe(listener);
449
- ctrl.startNavigation("/about");
450
- expect(listener).not.toHaveBeenCalled(); // debounced
451
- vi.advanceTimersByTime(0);
452
- expect(listener).toHaveBeenCalledTimes(1);
453
- });
454
- it("multiple rapid changes are batched into one notification", () => {
455
- const ctrl = createController();
456
- const listener = vi.fn();
457
- ctrl.subscribe(listener);
458
- ctrl.startNavigation("/a");
459
- ctrl.abortNavigation();
460
- ctrl.startNavigation("/b");
461
- vi.advanceTimersByTime(0);
462
- expect(listener).toHaveBeenCalledTimes(1);
463
- });
464
- it("unsubscribe stops notifications", () => {
465
- const ctrl = createController();
466
- const listener = vi.fn();
467
- const unsub = ctrl.subscribe(listener);
468
- unsub();
469
- ctrl.startNavigation("/about");
470
- vi.advanceTimersByTime(0);
471
- expect(listener).not.toHaveBeenCalled();
472
- });
473
- it("subscribeToAction notifies for matching action (suffix match)", () => {
474
- const ctrl = createController();
475
- const listener = vi.fn();
476
- ctrl.subscribeToAction("addToCart", listener);
477
- ctrl.startAction("hash#addToCart", []);
478
- vi.advanceTimersByTime(0);
479
- expect(listener).toHaveBeenCalledTimes(1);
480
- expect(listener).toHaveBeenCalledWith(expect.objectContaining({ state: "loading", actionId: "hash#addToCart" }));
481
- });
482
- it("subscribeToAction does not notify for non-matching action", () => {
483
- const ctrl = createController();
484
- const listener = vi.fn();
485
- ctrl.subscribeToAction("removeFromCart", listener);
486
- ctrl.startAction("hash#addToCart", []);
487
- vi.advanceTimersByTime(0);
488
- expect(listener).not.toHaveBeenCalled();
489
- });
490
- it("subscribeToAction unsubscribe cleans up listener set", () => {
491
- const ctrl = createController();
492
- const listener = vi.fn();
493
- const unsub = ctrl.subscribeToAction("save", listener);
494
- unsub();
495
- ctrl.startAction("hash#save", []);
496
- vi.advanceTimersByTime(0);
497
- expect(listener).not.toHaveBeenCalled();
498
- });
499
- it("subscribeToHandles notifies on handle data changes", () => {
500
- const ctrl = createController();
501
- const listener = vi.fn();
502
- ctrl.subscribeToHandles(listener);
503
- ctrl.setHandleData({ title: { s: ["T"] } }, ["s"]);
504
- vi.advanceTimersByTime(0);
505
- expect(listener).toHaveBeenCalledTimes(1);
506
- });
507
- it("subscribeToHandles unsubscribe stops notifications", () => {
508
- const ctrl = createController();
509
- const listener = vi.fn();
510
- const unsub = ctrl.subscribeToHandles(listener);
511
- unsub();
512
- ctrl.setHandleData({ title: { s: ["T"] } }, ["s"]);
513
- vi.advanceTimersByTime(0);
514
- expect(listener).not.toHaveBeenCalled();
515
- });
516
- });
517
- // ======================================================================
518
- // Direct Access
519
- // ======================================================================
520
- describe("direct access", () => {
521
- it("getCurrentNavigation returns entry during navigation", () => {
522
- const ctrl = createController();
523
- expect(ctrl.getCurrentNavigation()).toBeNull();
524
- ctrl.startNavigation("/about");
525
- const nav = ctrl.getCurrentNavigation();
526
- expect(nav).not.toBeNull();
527
- expect(nav.url).toBe("/about");
528
- expect(nav.phase).toBe("fetching");
529
- });
530
- it("getInflightActions returns the internal map", () => {
531
- const ctrl = createController();
532
- expect(ctrl.getInflightActions().size).toBe(0);
533
- ctrl.startAction("hash#save", []);
534
- expect(ctrl.getInflightActions().size).toBe(1);
535
- });
536
- });
537
- });
538
- //# sourceMappingURL=event-controller.test.js.map