@timber-js/app 0.2.0-alpha.4 → 0.2.0-alpha.40

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 (336) hide show
  1. package/LICENSE +8 -0
  2. package/dist/_chunks/{als-registry-B7DbZ2hS.js → als-registry-Ba7URUIn.js} +1 -1
  3. package/dist/_chunks/als-registry-Ba7URUIn.js.map +1 -0
  4. package/dist/_chunks/chunk-DYhsFzuS.js +33 -0
  5. package/dist/_chunks/debug-ECi_61pb.js +108 -0
  6. package/dist/_chunks/debug-ECi_61pb.js.map +1 -0
  7. package/dist/_chunks/define-cookie-BmKbSyp0.js +93 -0
  8. package/dist/_chunks/define-cookie-BmKbSyp0.js.map +1 -0
  9. package/dist/_chunks/error-boundary-BAN3751q.js +211 -0
  10. package/dist/_chunks/error-boundary-BAN3751q.js.map +1 -0
  11. package/dist/_chunks/{format-CwdaB0_2.js → format-cX7wzEp2.js} +2 -2
  12. package/dist/_chunks/{format-CwdaB0_2.js.map → format-cX7wzEp2.js.map} +1 -1
  13. package/dist/_chunks/{interception-BOoWmLUA.js → interception-D2djYaIm.js} +112 -77
  14. package/dist/_chunks/interception-D2djYaIm.js.map +1 -0
  15. package/dist/_chunks/{metadata-routes-Cjmvi3rQ.js → metadata-routes-BU684ls2.js} +1 -1
  16. package/dist/_chunks/{metadata-routes-Cjmvi3rQ.js.map → metadata-routes-BU684ls2.js.map} +1 -1
  17. package/dist/_chunks/{request-context-CZJi4CuK.js → request-context-BxYIJM24.js} +93 -69
  18. package/dist/_chunks/request-context-BxYIJM24.js.map +1 -0
  19. package/dist/_chunks/segment-context-C6byCyZU.js +69 -0
  20. package/dist/_chunks/segment-context-C6byCyZU.js.map +1 -0
  21. package/dist/_chunks/stale-reload-C0ValzG7.js +47 -0
  22. package/dist/_chunks/stale-reload-C0ValzG7.js.map +1 -0
  23. package/dist/_chunks/{tracing-Cwn7697K.js → tracing-CuXiCP5p.js} +17 -3
  24. package/dist/_chunks/{tracing-Cwn7697K.js.map → tracing-CuXiCP5p.js.map} +1 -1
  25. package/dist/_chunks/{use-query-states-D5KaffOK.js → use-query-states-BvW0TKDn.js} +1 -1
  26. package/dist/_chunks/{use-query-states-D5KaffOK.js.map → use-query-states-BvW0TKDn.js.map} +1 -1
  27. package/dist/_chunks/wrappers-C6J0nNji.js +331 -0
  28. package/dist/_chunks/wrappers-C6J0nNji.js.map +1 -0
  29. package/dist/adapters/compress-module.d.ts.map +1 -1
  30. package/dist/adapters/nitro.d.ts +17 -1
  31. package/dist/adapters/nitro.d.ts.map +1 -1
  32. package/dist/adapters/nitro.js +56 -13
  33. package/dist/adapters/nitro.js.map +1 -1
  34. package/dist/cache/fast-hash.d.ts +22 -0
  35. package/dist/cache/fast-hash.d.ts.map +1 -0
  36. package/dist/cache/index.d.ts +5 -2
  37. package/dist/cache/index.d.ts.map +1 -1
  38. package/dist/cache/index.js +88 -18
  39. package/dist/cache/index.js.map +1 -1
  40. package/dist/cache/register-cached-function.d.ts.map +1 -1
  41. package/dist/cache/singleflight.d.ts +18 -1
  42. package/dist/cache/singleflight.d.ts.map +1 -1
  43. package/dist/cache/timber-cache.d.ts.map +1 -1
  44. package/dist/client/error-boundary.d.ts +10 -1
  45. package/dist/client/error-boundary.d.ts.map +1 -1
  46. package/dist/client/error-boundary.js +1 -125
  47. package/dist/client/index.d.ts +3 -2
  48. package/dist/client/index.d.ts.map +1 -1
  49. package/dist/client/index.js +213 -93
  50. package/dist/client/index.js.map +1 -1
  51. package/dist/client/link.d.ts +22 -8
  52. package/dist/client/link.d.ts.map +1 -1
  53. package/dist/client/navigation-context.d.ts +2 -2
  54. package/dist/client/router.d.ts +25 -3
  55. package/dist/client/router.d.ts.map +1 -1
  56. package/dist/client/rsc-fetch.d.ts +23 -2
  57. package/dist/client/rsc-fetch.d.ts.map +1 -1
  58. package/dist/client/segment-cache.d.ts +1 -1
  59. package/dist/client/segment-cache.d.ts.map +1 -1
  60. package/dist/client/segment-context.d.ts +1 -1
  61. package/dist/client/segment-context.d.ts.map +1 -1
  62. package/dist/client/segment-merger.d.ts.map +1 -1
  63. package/dist/client/stale-reload.d.ts +15 -0
  64. package/dist/client/stale-reload.d.ts.map +1 -1
  65. package/dist/client/top-loader.d.ts +1 -1
  66. package/dist/client/top-loader.d.ts.map +1 -1
  67. package/dist/client/transition-root.d.ts +1 -1
  68. package/dist/client/transition-root.d.ts.map +1 -1
  69. package/dist/client/use-params.d.ts +2 -2
  70. package/dist/client/use-params.d.ts.map +1 -1
  71. package/dist/client/use-query-states.d.ts +1 -1
  72. package/dist/codec.d.ts +21 -0
  73. package/dist/codec.d.ts.map +1 -0
  74. package/dist/cookies/define-cookie.d.ts +33 -12
  75. package/dist/cookies/define-cookie.d.ts.map +1 -1
  76. package/dist/cookies/index.js +1 -83
  77. package/dist/fonts/css.d.ts +1 -0
  78. package/dist/fonts/css.d.ts.map +1 -1
  79. package/dist/fonts/local.d.ts +4 -2
  80. package/dist/fonts/local.d.ts.map +1 -1
  81. package/dist/index.d.ts +112 -35
  82. package/dist/index.d.ts.map +1 -1
  83. package/dist/index.js +635 -233
  84. package/dist/index.js.map +1 -1
  85. package/dist/params/define.d.ts +76 -0
  86. package/dist/params/define.d.ts.map +1 -0
  87. package/dist/params/index.d.ts +8 -0
  88. package/dist/params/index.d.ts.map +1 -0
  89. package/dist/params/index.js +104 -0
  90. package/dist/params/index.js.map +1 -0
  91. package/dist/plugins/adapter-build.d.ts.map +1 -1
  92. package/dist/plugins/build-manifest.d.ts.map +1 -1
  93. package/dist/plugins/client-chunks.d.ts +32 -0
  94. package/dist/plugins/client-chunks.d.ts.map +1 -0
  95. package/dist/plugins/dev-error-overlay.d.ts +26 -1
  96. package/dist/plugins/dev-error-overlay.d.ts.map +1 -1
  97. package/dist/plugins/entries.d.ts +7 -0
  98. package/dist/plugins/entries.d.ts.map +1 -1
  99. package/dist/plugins/fonts.d.ts +9 -1
  100. package/dist/plugins/fonts.d.ts.map +1 -1
  101. package/dist/plugins/mdx.d.ts +6 -0
  102. package/dist/plugins/mdx.d.ts.map +1 -1
  103. package/dist/plugins/routing.d.ts.map +1 -1
  104. package/dist/plugins/server-bundle.d.ts.map +1 -1
  105. package/dist/plugins/static-build.d.ts.map +1 -1
  106. package/dist/routing/codegen.d.ts +2 -2
  107. package/dist/routing/codegen.d.ts.map +1 -1
  108. package/dist/routing/index.js +1 -1
  109. package/dist/routing/scanner.d.ts.map +1 -1
  110. package/dist/routing/status-file-lint.d.ts +2 -1
  111. package/dist/routing/status-file-lint.d.ts.map +1 -1
  112. package/dist/routing/types.d.ts +6 -4
  113. package/dist/routing/types.d.ts.map +1 -1
  114. package/dist/rsc-runtime/rsc.d.ts +1 -1
  115. package/dist/rsc-runtime/rsc.d.ts.map +1 -1
  116. package/dist/rsc-runtime/ssr.d.ts +12 -0
  117. package/dist/rsc-runtime/ssr.d.ts.map +1 -1
  118. package/dist/search-params/codecs.d.ts +1 -1
  119. package/dist/search-params/define.d.ts +153 -0
  120. package/dist/search-params/define.d.ts.map +1 -0
  121. package/dist/search-params/index.d.ts +4 -5
  122. package/dist/search-params/index.d.ts.map +1 -1
  123. package/dist/search-params/index.js +3 -474
  124. package/dist/search-params/registry.d.ts +1 -1
  125. package/dist/search-params/wrappers.d.ts +53 -0
  126. package/dist/search-params/wrappers.d.ts.map +1 -0
  127. package/dist/server/access-gate.d.ts +4 -0
  128. package/dist/server/access-gate.d.ts.map +1 -1
  129. package/dist/server/action-client.d.ts.map +1 -1
  130. package/dist/server/action-encryption.d.ts +76 -0
  131. package/dist/server/action-encryption.d.ts.map +1 -0
  132. package/dist/server/action-handler.d.ts.map +1 -1
  133. package/dist/server/als-registry.d.ts +18 -4
  134. package/dist/server/als-registry.d.ts.map +1 -1
  135. package/dist/server/build-manifest.d.ts +2 -2
  136. package/dist/server/debug.d.ts +46 -15
  137. package/dist/server/debug.d.ts.map +1 -1
  138. package/dist/server/default-logger.d.ts +22 -0
  139. package/dist/server/default-logger.d.ts.map +1 -0
  140. package/dist/server/deny-renderer.d.ts.map +1 -1
  141. package/dist/server/early-hints.d.ts +13 -5
  142. package/dist/server/early-hints.d.ts.map +1 -1
  143. package/dist/server/error-boundary-wrapper.d.ts +4 -0
  144. package/dist/server/error-boundary-wrapper.d.ts.map +1 -1
  145. package/dist/server/flight-injection-state.d.ts +78 -0
  146. package/dist/server/flight-injection-state.d.ts.map +1 -0
  147. package/dist/server/flight-scripts.d.ts +39 -0
  148. package/dist/server/flight-scripts.d.ts.map +1 -0
  149. package/dist/server/flush.d.ts.map +1 -1
  150. package/dist/server/form-data.d.ts +29 -0
  151. package/dist/server/form-data.d.ts.map +1 -1
  152. package/dist/server/html-injectors.d.ts +5 -11
  153. package/dist/server/html-injectors.d.ts.map +1 -1
  154. package/dist/server/index.d.ts +4 -2
  155. package/dist/server/index.d.ts.map +1 -1
  156. package/dist/server/index.js +1975 -1649
  157. package/dist/server/index.js.map +1 -1
  158. package/dist/server/logger.d.ts +24 -7
  159. package/dist/server/logger.d.ts.map +1 -1
  160. package/dist/server/node-stream-transforms.d.ts +77 -0
  161. package/dist/server/node-stream-transforms.d.ts.map +1 -0
  162. package/dist/server/pipeline.d.ts +7 -4
  163. package/dist/server/pipeline.d.ts.map +1 -1
  164. package/dist/server/primitives.d.ts +30 -3
  165. package/dist/server/primitives.d.ts.map +1 -1
  166. package/dist/server/render-timeout.d.ts +51 -0
  167. package/dist/server/render-timeout.d.ts.map +1 -0
  168. package/dist/server/request-context.d.ts +65 -38
  169. package/dist/server/request-context.d.ts.map +1 -1
  170. package/dist/server/route-element-builder.d.ts +7 -0
  171. package/dist/server/route-element-builder.d.ts.map +1 -1
  172. package/dist/server/route-handler.d.ts.map +1 -1
  173. package/dist/server/route-matcher.d.ts +2 -2
  174. package/dist/server/route-matcher.d.ts.map +1 -1
  175. package/dist/server/rsc-entry/error-renderer.d.ts.map +1 -1
  176. package/dist/server/rsc-entry/helpers.d.ts +46 -3
  177. package/dist/server/rsc-entry/helpers.d.ts.map +1 -1
  178. package/dist/server/rsc-entry/index.d.ts +6 -1
  179. package/dist/server/rsc-entry/index.d.ts.map +1 -1
  180. package/dist/server/rsc-entry/rsc-payload.d.ts.map +1 -1
  181. package/dist/server/rsc-entry/rsc-stream.d.ts +9 -0
  182. package/dist/server/rsc-entry/rsc-stream.d.ts.map +1 -1
  183. package/dist/server/rsc-entry/ssr-renderer.d.ts.map +1 -1
  184. package/dist/server/slot-resolver.d.ts +1 -1
  185. package/dist/server/slot-resolver.d.ts.map +1 -1
  186. package/dist/server/ssr-entry.d.ts +22 -0
  187. package/dist/server/ssr-entry.d.ts.map +1 -1
  188. package/dist/server/ssr-render.d.ts +39 -21
  189. package/dist/server/ssr-render.d.ts.map +1 -1
  190. package/dist/server/tracing.d.ts +10 -0
  191. package/dist/server/tracing.d.ts.map +1 -1
  192. package/dist/server/tree-builder.d.ts +19 -12
  193. package/dist/server/tree-builder.d.ts.map +1 -1
  194. package/dist/server/types.d.ts +1 -3
  195. package/dist/server/types.d.ts.map +1 -1
  196. package/dist/server/version-skew.d.ts +61 -0
  197. package/dist/server/version-skew.d.ts.map +1 -0
  198. package/dist/server/waituntil-bridge.d.ts.map +1 -1
  199. package/dist/shared/merge-search-params.d.ts +22 -0
  200. package/dist/shared/merge-search-params.d.ts.map +1 -0
  201. package/dist/shims/navigation-client.d.ts +1 -1
  202. package/dist/shims/navigation-client.d.ts.map +1 -1
  203. package/dist/shims/navigation.d.ts +1 -1
  204. package/dist/shims/navigation.d.ts.map +1 -1
  205. package/dist/utils/state-machine.d.ts +80 -0
  206. package/dist/utils/state-machine.d.ts.map +1 -0
  207. package/package.json +17 -14
  208. package/src/adapters/compress-module.ts +24 -4
  209. package/src/adapters/nitro.ts +58 -9
  210. package/src/cache/fast-hash.ts +34 -0
  211. package/src/cache/index.ts +5 -2
  212. package/src/cache/register-cached-function.ts +7 -3
  213. package/src/cache/singleflight.ts +62 -4
  214. package/src/cache/timber-cache.ts +34 -26
  215. package/src/cli.ts +0 -0
  216. package/src/client/browser-entry.ts +94 -90
  217. package/src/client/error-boundary.tsx +18 -1
  218. package/src/client/index.ts +10 -1
  219. package/src/client/link.tsx +78 -19
  220. package/src/client/navigation-context.ts +2 -2
  221. package/src/client/router.ts +105 -60
  222. package/src/client/rsc-fetch.ts +63 -2
  223. package/src/client/segment-cache.ts +1 -1
  224. package/src/client/segment-context.ts +6 -1
  225. package/src/client/segment-merger.ts +2 -8
  226. package/src/client/stale-reload.ts +32 -6
  227. package/src/client/top-loader.tsx +10 -9
  228. package/src/client/transition-root.tsx +7 -1
  229. package/src/client/use-params.ts +3 -3
  230. package/src/client/use-query-states.ts +1 -1
  231. package/src/codec.ts +21 -0
  232. package/src/cookies/define-cookie.ts +69 -18
  233. package/src/fonts/css.ts +2 -1
  234. package/src/fonts/local.ts +7 -3
  235. package/src/index.ts +280 -85
  236. package/src/params/define.ts +260 -0
  237. package/src/params/index.ts +28 -0
  238. package/src/plugins/adapter-build.ts +6 -0
  239. package/src/plugins/build-manifest.ts +11 -0
  240. package/src/plugins/client-chunks.ts +65 -0
  241. package/src/plugins/dev-error-overlay.ts +70 -1
  242. package/src/plugins/dev-server.ts +38 -4
  243. package/src/plugins/entries.ts +12 -11
  244. package/src/plugins/fonts.ts +171 -19
  245. package/src/plugins/mdx.ts +9 -5
  246. package/src/plugins/routing.ts +40 -14
  247. package/src/plugins/server-bundle.ts +32 -1
  248. package/src/plugins/shims.ts +1 -1
  249. package/src/plugins/static-build.ts +8 -4
  250. package/src/routing/codegen.ts +109 -88
  251. package/src/routing/scanner.ts +55 -6
  252. package/src/routing/status-file-lint.ts +2 -1
  253. package/src/routing/types.ts +7 -4
  254. package/src/rsc-runtime/rsc.ts +2 -0
  255. package/src/rsc-runtime/ssr.ts +50 -0
  256. package/src/rsc-runtime/vendor-types.d.ts +7 -0
  257. package/src/search-params/codecs.ts +1 -1
  258. package/src/search-params/define.ts +504 -0
  259. package/src/search-params/index.ts +12 -18
  260. package/src/search-params/registry.ts +1 -1
  261. package/src/search-params/wrappers.ts +85 -0
  262. package/src/server/access-gate.tsx +40 -9
  263. package/src/server/action-client.ts +14 -5
  264. package/src/server/action-encryption.ts +144 -0
  265. package/src/server/action-handler.ts +19 -2
  266. package/src/server/als-registry.ts +18 -4
  267. package/src/server/build-manifest.ts +4 -4
  268. package/src/server/compress.ts +25 -7
  269. package/src/server/debug.ts +55 -17
  270. package/src/server/default-logger.ts +98 -0
  271. package/src/server/deny-renderer.ts +2 -1
  272. package/src/server/early-hints.ts +36 -15
  273. package/src/server/error-boundary-wrapper.ts +57 -14
  274. package/src/server/flight-injection-state.ts +152 -0
  275. package/src/server/flight-scripts.ts +59 -0
  276. package/src/server/flush.ts +2 -1
  277. package/src/server/form-data.ts +76 -0
  278. package/src/server/html-injectors.ts +103 -66
  279. package/src/server/index.ts +9 -4
  280. package/src/server/logger.ts +38 -35
  281. package/src/server/node-stream-transforms.ts +381 -0
  282. package/src/server/pipeline.ts +131 -39
  283. package/src/server/primitives.ts +47 -5
  284. package/src/server/render-timeout.ts +108 -0
  285. package/src/server/request-context.ts +112 -119
  286. package/src/server/route-element-builder.ts +106 -114
  287. package/src/server/route-handler.ts +2 -1
  288. package/src/server/route-matcher.ts +2 -2
  289. package/src/server/rsc-entry/error-renderer.ts +5 -3
  290. package/src/server/rsc-entry/helpers.ts +122 -3
  291. package/src/server/rsc-entry/index.ts +125 -49
  292. package/src/server/rsc-entry/rsc-payload.ts +52 -12
  293. package/src/server/rsc-entry/rsc-stream.ts +33 -8
  294. package/src/server/rsc-entry/ssr-renderer.ts +40 -13
  295. package/src/server/slot-resolver.ts +199 -210
  296. package/src/server/ssr-entry.ts +169 -17
  297. package/src/server/ssr-render.ts +266 -67
  298. package/src/server/tracing.ts +23 -0
  299. package/src/server/tree-builder.ts +91 -57
  300. package/src/server/types.ts +1 -3
  301. package/src/server/version-skew.ts +104 -0
  302. package/src/server/waituntil-bridge.ts +4 -1
  303. package/src/shared/merge-search-params.ts +48 -0
  304. package/src/shims/navigation-client.ts +1 -1
  305. package/src/shims/navigation.ts +1 -1
  306. package/src/utils/state-machine.ts +111 -0
  307. package/dist/_chunks/als-registry-B7DbZ2hS.js.map +0 -1
  308. package/dist/_chunks/debug-B4WUeqJ-.js +0 -75
  309. package/dist/_chunks/debug-B4WUeqJ-.js.map +0 -1
  310. package/dist/_chunks/interception-BOoWmLUA.js.map +0 -1
  311. package/dist/_chunks/request-context-CZJi4CuK.js.map +0 -1
  312. package/dist/_chunks/ssr-data-MjmprTmO.js +0 -88
  313. package/dist/_chunks/ssr-data-MjmprTmO.js.map +0 -1
  314. package/dist/_chunks/use-cookie-DX-l1_5E.js +0 -91
  315. package/dist/_chunks/use-cookie-DX-l1_5E.js.map +0 -1
  316. package/dist/client/error-boundary.js.map +0 -1
  317. package/dist/cookies/index.js.map +0 -1
  318. package/dist/plugins/dynamic-transform.d.ts +0 -72
  319. package/dist/plugins/dynamic-transform.d.ts.map +0 -1
  320. package/dist/search-params/analyze.d.ts +0 -54
  321. package/dist/search-params/analyze.d.ts.map +0 -1
  322. package/dist/search-params/builtin-codecs.d.ts +0 -105
  323. package/dist/search-params/builtin-codecs.d.ts.map +0 -1
  324. package/dist/search-params/create.d.ts +0 -106
  325. package/dist/search-params/create.d.ts.map +0 -1
  326. package/dist/search-params/index.js.map +0 -1
  327. package/dist/server/prerender.d.ts +0 -77
  328. package/dist/server/prerender.d.ts.map +0 -1
  329. package/dist/server/response-cache.d.ts +0 -53
  330. package/dist/server/response-cache.d.ts.map +0 -1
  331. package/src/plugins/dynamic-transform.ts +0 -161
  332. package/src/search-params/analyze.ts +0 -192
  333. package/src/search-params/builtin-codecs.ts +0 -228
  334. package/src/search-params/create.ts +0 -321
  335. package/src/server/prerender.ts +0 -139
  336. package/src/server/response-cache.ts +0 -277
@@ -0,0 +1,153 @@
1
+ /**
2
+ * defineSearchParams — factory for SearchParamsDefinition<T>.
3
+ *
4
+ * Creates a typed, composable definition for a route's search parameters.
5
+ * Accepts both SearchParamCodec values and Standard Schema objects (Zod,
6
+ * Valibot, ArkType) with auto-detection. Supports URL key aliasing via
7
+ * withUrlKey(), default-omission serialization, and composition via
8
+ * .extend() / .pick().
9
+ *
10
+ * Design doc: design/23-search-params.md §"defineSearchParams — The Factory"
11
+ */
12
+ import type { Codec } from '#/codec.js';
13
+ /**
14
+ * A codec that converts between URL string values and typed values.
15
+ *
16
+ * nuqs parsers implement this interface natively — no adapter needed.
17
+ * Standard Schema objects (Zod, Valibot, ArkType) are auto-detected
18
+ * by defineSearchParams and wrapped via fromSchema.
19
+ */
20
+ export interface SearchParamCodec<T> extends Codec<T> {
21
+ /** Optional URL key alias, set by withUrlKey(). */
22
+ urlKey?: string;
23
+ }
24
+ /** A codec with a URL key alias attached via withUrlKey(). */
25
+ export interface SearchParamCodecWithUrlKey<T> extends SearchParamCodec<T> {
26
+ urlKey: string;
27
+ }
28
+ /** Infer the output type of a codec. */
29
+ export type InferCodec<C> = C extends SearchParamCodec<infer T> ? T : never;
30
+ /** Map of property names to codecs. */
31
+ export type CodecMap<T extends Record<string, unknown>> = {
32
+ [K in keyof T]: SearchParamCodec<T[K]>;
33
+ };
34
+ /** Options for useQueryStates setter. */
35
+ export interface SetParamsOptions {
36
+ /** Update URL without server roundtrip (default: false). */
37
+ shallow?: boolean;
38
+ /** Scroll to top after update (default: true). */
39
+ scroll?: boolean;
40
+ /** 'push' (default) or 'replace' for history state. */
41
+ history?: 'push' | 'replace';
42
+ }
43
+ /** Setter function returned by useQueryStates. */
44
+ export type SetParams<T> = (values: Partial<T>, options?: SetParamsOptions) => void;
45
+ /** Options for useQueryStates hook. */
46
+ export interface QueryStatesOptions {
47
+ /** Update URL without server roundtrip (default: false). */
48
+ shallow?: boolean;
49
+ /** Scroll to top after update (default: true). */
50
+ scroll?: boolean;
51
+ /** 'push' (default) or 'replace' for history state. */
52
+ history?: 'push' | 'replace';
53
+ }
54
+ /**
55
+ * A fully typed, composable search params definition.
56
+ *
57
+ * Returned by defineSearchParams(). Carries a phantom _type property
58
+ * for build-time type extraction.
59
+ */
60
+ export interface SearchParamsDefinition<T extends Record<string, unknown>> {
61
+ /** Parse raw URL search params into typed values. */
62
+ parse(raw: URLSearchParams | Record<string, string | string[] | undefined>): T;
63
+ /** Parse a Promise of URLSearchParams (e.g., from the ALS `searchParams()` API). */
64
+ parse(raw: Promise<URLSearchParams | Record<string, string | string[] | undefined>>): Promise<T>;
65
+ /**
66
+ * Load typed search params from the current request context (ALS-backed).
67
+ *
68
+ * Server-only — reads rawSearchParams() from ALS and parses through codecs.
69
+ * Throws on client. Eliminates the naming conflict between the definition
70
+ * export and the server helper.
71
+ *
72
+ * ```tsx
73
+ * // app/products/page.tsx
74
+ * import { searchParams } from './params'
75
+ * export default async function Page() {
76
+ * const { page, category } = await searchParams.load()
77
+ * }
78
+ * ```
79
+ */
80
+ load(): Promise<T>;
81
+ /** Client hook — reads current URL params and returns typed values + setter. */
82
+ useQueryStates(options?: QueryStatesOptions): [T, SetParams<T>];
83
+ /** Extend with additional codecs or Standard Schema objects. */
84
+ extend<U extends Record<string, SearchParamCodec<unknown> | StandardSchemaV1<unknown>>>(codecs: U): SearchParamsDefinition<T & {
85
+ [K in keyof U]: InferField<U[K]>;
86
+ }>;
87
+ /** Pick a subset of keys. Preserves codecs and aliases. */
88
+ pick<K extends keyof T & string>(...keys: K[]): SearchParamsDefinition<Pick<T, K>>;
89
+ /** Serialize values to a query string (no leading '?'), omitting defaults. */
90
+ serialize(values: Partial<T>): string;
91
+ /** Build a full path with query string, omitting defaults. */
92
+ href(pathname: string, values: Partial<T>): string;
93
+ /** Build a URLSearchParams instance, omitting defaults. */
94
+ toSearchParams(values: Partial<T>): URLSearchParams;
95
+ /** Read-only codec map for spreading into .extend(). */
96
+ codecs: {
97
+ [K in keyof T]: SearchParamCodec<T[K]>;
98
+ };
99
+ /** Read-only URL key alias map. Maps property names to URL query parameter keys. */
100
+ readonly urlKeys: Readonly<Record<string, string>>;
101
+ /**
102
+ * Phantom property for build-time type extraction.
103
+ * Never set at runtime — exists only in the type system.
104
+ */
105
+ readonly _type?: T;
106
+ }
107
+ /** Minimal Standard Schema interface for auto-detection. */
108
+ export interface StandardSchemaV1<Output = unknown> {
109
+ '~standard': {
110
+ validate(value: unknown): {
111
+ value: Output;
112
+ issues?: undefined;
113
+ } | {
114
+ value?: undefined;
115
+ issues: ReadonlyArray<{
116
+ message: string;
117
+ }>;
118
+ } | Promise<{
119
+ value: Output;
120
+ issues?: undefined;
121
+ } | {
122
+ value?: undefined;
123
+ issues: ReadonlyArray<{
124
+ message: string;
125
+ }>;
126
+ }>;
127
+ };
128
+ }
129
+ /** Infer the output type from either a SearchParamCodec or a StandardSchemaV1. */
130
+ export type InferField<V> = V extends SearchParamCodec<infer T> ? T : V extends StandardSchemaV1<infer T> ? T : never;
131
+ /** Acceptable field value for defineSearchParams: a codec or a Standard Schema. */
132
+ export type SearchParamField<T = unknown> = SearchParamCodec<T> | StandardSchemaV1<T>;
133
+ /**
134
+ * Create a SearchParamsDefinition from a map of codecs and/or Standard Schema
135
+ * objects. Accepts both SearchParamCodec values and raw Zod/Valibot/ArkType
136
+ * schemas with auto-detection.
137
+ *
138
+ * ```ts
139
+ * import { defineSearchParams, withDefault, withUrlKey } from '@timber-js/app/search-params'
140
+ * import { parseAsString, parseAsStringEnum } from 'nuqs'
141
+ * import { z } from 'zod/v4'
142
+ *
143
+ * export const searchParams = defineSearchParams({
144
+ * page: z.coerce.number().int().min(1).default(1), // Standard Schema — auto-wrapped
145
+ * q: withUrlKey(parseAsString, 'search'), // nuqs codec with URL alias
146
+ * sort: withDefault(parseAsStringEnum(['price', 'name']), 'price'),
147
+ * })
148
+ * ```
149
+ */
150
+ export declare function defineSearchParams<C extends Record<string, SearchParamField>>(codecs: C): SearchParamsDefinition<{
151
+ [K in keyof C]: InferField<C[K]>;
152
+ }>;
153
+ //# sourceMappingURL=define.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"define.d.ts","sourceRoot":"","sources":["../../src/search-params/define.ts"],"names":[],"mappings":"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"}
@@ -1,8 +1,7 @@
1
- export type { SearchParamCodec, InferCodec, SearchParamsDefinition, SetParams, SetParamsOptions, QueryStatesOptions, SearchParamsOptions, } from './create.js';
2
- export { createSearchParams } from './create.js';
1
+ export type { Codec } from '#/codec.js';
2
+ export type { SearchParamCodec, SearchParamCodecWithUrlKey, InferCodec, InferField, CodecMap, SearchParamsDefinition, SetParams, SetParamsOptions, QueryStatesOptions, StandardSchemaV1, } from './define.js';
3
+ export { defineSearchParams } from './define.js';
3
4
  export { fromSchema, fromArraySchema } from './codecs.js';
4
- export { parseAsString, parseAsInteger, parseAsFloat, parseAsBoolean, parseAsStringEnum, parseAsStringLiteral, withDefault, } from './builtin-codecs.js';
5
+ export { withDefault, withUrlKey } from './wrappers.js';
5
6
  export { registerSearchParams, getSearchParams } from './registry.js';
6
- export type { AnalyzeResult, AnalyzeError } from './analyze.js';
7
- export { analyzeSearchParams, formatAnalyzeError } from './analyze.js';
8
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/search-params/index.ts"],"names":[],"mappings":"AAGA,YAAY,EACV,gBAAgB,EAChB,UAAU,EACV,sBAAsB,EACtB,SAAS,EACT,gBAAgB,EAChB,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGjD,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAG1D,OAAO,EACL,aAAa,EACb,cAAc,EACd,YAAY,EACZ,cAAc,EACd,iBAAiB,EACjB,oBAAoB,EACpB,WAAW,GACZ,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,oBAAoB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAGtE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAChE,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/search-params/index.ts"],"names":[],"mappings":"AAGA,YAAY,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAGxC,YAAY,EACV,gBAAgB,EAChB,0BAA0B,EAC1B,UAAU,EACV,UAAU,EACV,QAAQ,EACR,sBAAsB,EACtB,SAAS,EACT,gBAAgB,EAChB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGjD,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAGxD,OAAO,EAAE,oBAAoB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
@@ -1,474 +1,3 @@
1
- import { i as registerSearchParams, n as useQueryStates, r as getSearchParams } from "../_chunks/use-query-states-D5KaffOK.js";
2
- //#region src/search-params/create.ts
3
- /**
4
- * createSearchParams — factory for SearchParamsDefinition<T>.
5
- *
6
- * Creates a typed, composable definition for a route's search parameters.
7
- * Supports codec protocol, URL key aliasing, default-omission serialization,
8
- * and composition via .extend() / .pick().
9
- *
10
- * Design doc: design/09-typescript.md §"Typed searchParams — search-params.ts"
11
- */
12
- /**
13
- * Convert URLSearchParams or a plain record to a normalized record
14
- * where repeated keys produce arrays.
15
- */
16
- function normalizeRaw(raw) {
17
- if (raw instanceof URLSearchParams) {
18
- const result = {};
19
- for (const key of new Set(raw.keys())) {
20
- const values = raw.getAll(key);
21
- result[key] = values.length === 1 ? values[0] : values;
22
- }
23
- return result;
24
- }
25
- return raw;
26
- }
27
- /**
28
- * Compute the serialized default value for a codec. Used for
29
- * default-omission: when serialize(value) === serialize(parse(undefined)),
30
- * the field is omitted from the URL.
31
- */
32
- function getDefaultSerialized(codec) {
33
- return codec.serialize(codec.parse(void 0));
34
- }
35
- /**
36
- * Create a SearchParamsDefinition from a codec map and optional URL key aliases.
37
- *
38
- * ```ts
39
- * import { createSearchParams, fromSchema } from '@timber-js/app/search-params'
40
- * import { z } from 'zod/v4'
41
- *
42
- * export default createSearchParams({
43
- * page: fromSchema(z.coerce.number().int().min(1).default(1)),
44
- * q: { parse: (v) => v ?? null, serialize: (v) => v },
45
- * }, {
46
- * urlKeys: { q: 'search' },
47
- * })
48
- * ```
49
- */
50
- function createSearchParams(codecs, options) {
51
- const urlKeys = {};
52
- if (options?.urlKeys) {
53
- for (const [k, v] of Object.entries(options.urlKeys)) if (v !== void 0) urlKeys[k] = v;
54
- }
55
- return buildDefinition(codecs, urlKeys);
56
- }
57
- /**
58
- * Internal: build a SearchParamsDefinition from a typed codec map and url keys.
59
- */
60
- function buildDefinition(codecMap, urlKeys) {
61
- const defaultSerialized = {};
62
- for (const key of Object.keys(codecMap)) defaultSerialized[key] = getDefaultSerialized(codecMap[key]);
63
- function getUrlKey(prop) {
64
- return urlKeys[prop] ?? prop;
65
- }
66
- function parse(raw) {
67
- const normalized = normalizeRaw(raw);
68
- const result = {};
69
- for (const prop of Object.keys(codecMap)) {
70
- const rawValue = normalized[getUrlKey(prop)];
71
- result[prop] = codecMap[prop].parse(rawValue);
72
- }
73
- return result;
74
- }
75
- function serialize(values) {
76
- const parts = [];
77
- for (const prop of Object.keys(codecMap)) {
78
- if (!(prop in values)) continue;
79
- const serialized = codecMap[prop].serialize(values[prop]);
80
- if (serialized === defaultSerialized[prop]) continue;
81
- if (serialized === null) continue;
82
- parts.push(`${encodeURIComponent(getUrlKey(prop))}=${encodeURIComponent(serialized)}`);
83
- }
84
- return parts.join("&");
85
- }
86
- function href(pathname, values) {
87
- const qs = serialize(values);
88
- return qs ? `${pathname}?${qs}` : pathname;
89
- }
90
- function toSearchParams(values) {
91
- const usp = new URLSearchParams();
92
- for (const prop of Object.keys(codecMap)) {
93
- if (!(prop in values)) continue;
94
- const serialized = codecMap[prop].serialize(values[prop]);
95
- if (serialized === defaultSerialized[prop]) continue;
96
- if (serialized === null) continue;
97
- usp.set(getUrlKey(prop), serialized);
98
- }
99
- return usp;
100
- }
101
- function extend(newCodecs, extendOptions) {
102
- const combinedCodecs = {
103
- ...codecMap,
104
- ...newCodecs
105
- };
106
- const combinedUrlKeys = { ...urlKeys };
107
- if (extendOptions?.urlKeys) {
108
- for (const [k, v] of Object.entries(extendOptions.urlKeys)) if (v !== void 0) combinedUrlKeys[k] = v;
109
- }
110
- return buildDefinition(combinedCodecs, combinedUrlKeys);
111
- }
112
- function pick(...keys) {
113
- const pickedCodecs = {};
114
- const pickedUrlKeys = {};
115
- for (const key of keys) {
116
- pickedCodecs[key] = codecMap[key];
117
- if (key in urlKeys) pickedUrlKeys[key] = urlKeys[key];
118
- }
119
- return buildDefinition(pickedCodecs, pickedUrlKeys);
120
- }
121
- function useQueryStates$1(options) {
122
- return useQueryStates(codecMap, options, Object.freeze({ ...urlKeys }));
123
- }
124
- return {
125
- parse,
126
- useQueryStates: useQueryStates$1,
127
- extend,
128
- pick,
129
- serialize,
130
- href,
131
- toSearchParams,
132
- codecs: codecMap,
133
- urlKeys: Object.freeze({ ...urlKeys })
134
- };
135
- }
136
- //#endregion
137
- //#region src/search-params/codecs.ts
138
- /**
139
- * Zod v4's ~standard.validate() signature includes Promise in the return union
140
- * to satisfy the Standard Schema spec, but in practice Zod always validates
141
- * synchronously for the schema types we use. We assert the result is sync and
142
- * throw if it isn't — search params parsing must be synchronous.
143
- */
144
- function validateSync(schema, value) {
145
- const result = schema["~standard"].validate(value);
146
- if (result instanceof Promise) throw new Error("[timber] fromSchema: schema returned a Promise — only sync schemas are supported for search params.");
147
- return result;
148
- }
149
- /**
150
- * Bridge a Standard Schema-compatible schema (Zod, Valibot, ArkType) to a
151
- * SearchParamCodec.
152
- *
153
- * Parse: coerces the raw URL string through the schema. On validation failure,
154
- * parses `undefined` to get the schema's default value (the schema should have
155
- * a `.default()` call). If that also fails, returns `undefined`.
156
- *
157
- * Serialize: uses `String()` for primitives, `null` for null/undefined.
158
- *
159
- * ```ts
160
- * import { fromSchema } from '@timber-js/app/search-params'
161
- * import { z } from 'zod/v4'
162
- *
163
- * const pageCodec = fromSchema(z.coerce.number().int().min(1).default(1))
164
- * ```
165
- */
166
- function fromSchema(schema) {
167
- return {
168
- parse(value) {
169
- const result = validateSync(schema, Array.isArray(value) ? value[value.length - 1] : value);
170
- if (!result.issues) return result.value;
171
- const defaultResult = validateSync(schema, void 0);
172
- if (!defaultResult.issues) return defaultResult.value;
173
- },
174
- serialize(value) {
175
- if (value === null || value === void 0) return null;
176
- return String(value);
177
- }
178
- };
179
- }
180
- /**
181
- * Bridge a Standard Schema for array values. Handles both single strings
182
- * and repeated query keys (`?tag=a&tag=b`).
183
- *
184
- * ```ts
185
- * import { fromArraySchema } from '@timber-js/app/search-params'
186
- * import { z } from 'zod/v4'
187
- *
188
- * const tagsCodec = fromArraySchema(z.array(z.string()).default([]))
189
- * ```
190
- */
191
- function fromArraySchema(schema) {
192
- return {
193
- parse(value) {
194
- let input = value;
195
- if (typeof value === "string") input = [value];
196
- else if (value === void 0) input = void 0;
197
- const result = validateSync(schema, input);
198
- if (!result.issues) return result.value;
199
- const defaultResult = validateSync(schema, void 0);
200
- if (!defaultResult.issues) return defaultResult.value;
201
- },
202
- serialize(value) {
203
- if (value === null || value === void 0) return null;
204
- if (Array.isArray(value)) return value.length === 0 ? null : value.join(",");
205
- return String(value);
206
- }
207
- };
208
- }
209
- //#endregion
210
- //#region src/search-params/builtin-codecs.ts
211
- /**
212
- * Normalize array inputs to a single string (last value wins, matching
213
- * URLSearchParams.get() semantics). Returns undefined if absent or empty.
214
- */
215
- function normalizeInput(value) {
216
- if (Array.isArray(value)) return value.length > 0 ? value[value.length - 1] : void 0;
217
- return value;
218
- }
219
- /**
220
- * String codec. Returns the raw string value, or null if absent.
221
- *
222
- * ```ts
223
- * import { parseAsString } from '@timber-js/app/search-params'
224
- *
225
- * const def = createSearchParams({ q: parseAsString })
226
- * // ?q=shoes → { q: 'shoes' }
227
- * // (absent) → { q: null }
228
- * ```
229
- */
230
- var parseAsString = {
231
- parse(value) {
232
- const v = normalizeInput(value);
233
- return v !== void 0 ? v : null;
234
- },
235
- serialize(value) {
236
- return value;
237
- }
238
- };
239
- /**
240
- * Integer codec. Parses a base-10 integer, or returns null if absent or
241
- * not a valid integer. Rejects floats, NaN, Infinity, and non-numeric strings.
242
- *
243
- * ```ts
244
- * import { parseAsInteger, withDefault } from '@timber-js/app/search-params'
245
- *
246
- * const def = createSearchParams({ page: withDefault(parseAsInteger, 1) })
247
- * // ?page=2 → { page: 2 }
248
- * // ?page=abc → { page: 1 }
249
- * // (absent) → { page: 1 }
250
- * ```
251
- */
252
- var parseAsInteger = {
253
- parse(value) {
254
- const v = normalizeInput(value);
255
- if (v === void 0 || v === "") return null;
256
- const n = Number(v);
257
- if (!Number.isFinite(n) || !Number.isInteger(n)) return null;
258
- return n;
259
- },
260
- serialize(value) {
261
- return value === null ? null : String(value);
262
- }
263
- };
264
- /**
265
- * Float codec. Parses a finite number, or returns null if absent or invalid.
266
- * Rejects NaN and Infinity.
267
- *
268
- * ```ts
269
- * import { parseAsFloat, withDefault } from '@timber-js/app/search-params'
270
- *
271
- * const def = createSearchParams({ price: withDefault(parseAsFloat, 0) })
272
- * ```
273
- */
274
- var parseAsFloat = {
275
- parse(value) {
276
- const v = normalizeInput(value);
277
- if (v === void 0 || v === "") return null;
278
- const n = Number(v);
279
- if (!Number.isFinite(n)) return null;
280
- return n;
281
- },
282
- serialize(value) {
283
- return value === null ? null : String(value);
284
- }
285
- };
286
- /**
287
- * Boolean codec. Accepts "true"/"1" as true, "false"/"0" as false.
288
- * Returns null for absent or unrecognized values.
289
- *
290
- * ```ts
291
- * import { parseAsBoolean, withDefault } from '@timber-js/app/search-params'
292
- *
293
- * const def = createSearchParams({ debug: withDefault(parseAsBoolean, false) })
294
- * // ?debug=true → { debug: true }
295
- * // ?debug=0 → { debug: false }
296
- * ```
297
- */
298
- var parseAsBoolean = {
299
- parse(value) {
300
- const v = normalizeInput(value);
301
- if (v === void 0) return null;
302
- if (v === "true" || v === "1") return true;
303
- if (v === "false" || v === "0") return false;
304
- return null;
305
- },
306
- serialize(value) {
307
- return value === null ? null : String(value);
308
- }
309
- };
310
- /**
311
- * String enum codec. Accepts only values in the provided list.
312
- * Returns null for absent or invalid values.
313
- *
314
- * ```ts
315
- * import { parseAsStringEnum, withDefault } from '@timber-js/app/search-params'
316
- *
317
- * const sortCodec = withDefault(
318
- * parseAsStringEnum(['price', 'name', 'date']),
319
- * 'date'
320
- * )
321
- * ```
322
- */
323
- function parseAsStringEnum(values) {
324
- const allowed = new Set(values);
325
- return {
326
- parse(value) {
327
- const v = normalizeInput(value);
328
- if (v === void 0) return null;
329
- return allowed.has(v) ? v : null;
330
- },
331
- serialize(value) {
332
- return value;
333
- }
334
- };
335
- }
336
- /**
337
- * String literal codec. Functionally identical to parseAsStringEnum but
338
- * accepts `as const` tuples for narrower type inference.
339
- *
340
- * ```ts
341
- * import { parseAsStringLiteral } from '@timber-js/app/search-params'
342
- *
343
- * const sizes = ['sm', 'md', 'lg', 'xl'] as const
344
- * const codec = parseAsStringLiteral(sizes)
345
- * // Type: SearchParamCodec<'sm' | 'md' | 'lg' | 'xl' | null>
346
- * ```
347
- */
348
- function parseAsStringLiteral(values) {
349
- return parseAsStringEnum(values);
350
- }
351
- /**
352
- * Wrap a nullable codec with a default value. When the inner codec returns
353
- * null, the default is used instead. The output type becomes non-nullable.
354
- *
355
- * ```ts
356
- * import { parseAsInteger, withDefault } from '@timber-js/app/search-params'
357
- *
358
- * const page = withDefault(parseAsInteger, 1)
359
- * // page.parse(undefined) → 1 (not null)
360
- * // page.parse('5') → 5
361
- * ```
362
- */
363
- function withDefault(codec, defaultValue) {
364
- return {
365
- parse(value) {
366
- const result = codec.parse(value);
367
- return result === null ? defaultValue : result;
368
- },
369
- serialize(value) {
370
- return codec.serialize(value);
371
- }
372
- };
373
- }
374
- //#endregion
375
- //#region src/search-params/analyze.ts
376
- /**
377
- * Patterns that indicate a valid default export:
378
- *
379
- * 1. `export default createSearchParams(...)`
380
- * 2. `export default someVar.extend(...)`
381
- * 3. `export default someVar.pick(...)`
382
- * 4. `export default someVar.extend(...).extend(...)` (chained)
383
- * 5. `export default someVar.extend(...).pick(...)` (chained)
384
- * 6. `export default createSearchParams(...).extend(...)`
385
- *
386
- * Invalid patterns:
387
- * - `export default someFunction(...)` (arbitrary factory)
388
- * - `export default condition ? a : b` (runtime conditional)
389
- * - `export default variable` (opaque reference without call)
390
- */
391
- /**
392
- * Analyze a search-params.ts file source for static analyzability.
393
- *
394
- * @param source - The file content as a string
395
- * @param filePath - Absolute path to the file (for diagnostics)
396
- */
397
- function analyzeSearchParams(source, filePath) {
398
- const defaultExport = extractDefaultExport(stripComments(source));
399
- if (!defaultExport) return {
400
- valid: false,
401
- error: {
402
- filePath,
403
- expression: "(no default export found)",
404
- suggestion: "search-params.ts must have a default export. Use: export default createSearchParams({ ... })"
405
- }
406
- };
407
- if (isValidExpression(defaultExport.trim())) return { valid: true };
408
- return {
409
- valid: false,
410
- error: {
411
- filePath,
412
- expression: defaultExport.trim(),
413
- suggestion: "The default export must be a createSearchParams() call, or a chain of .extend() / .pick() calls on a SearchParamsDefinition. Arbitrary factory functions and runtime conditionals are not supported."
414
- }
415
- };
416
- }
417
- /** Strip single-line and multi-line comments from source. */
418
- function stripComments(source) {
419
- let result = source.replace(/\/\*[\s\S]*?\*\//g, "");
420
- result = result.replace(/\/\/.*$/gm, "");
421
- return result;
422
- }
423
- /**
424
- * Extract the expression from `export default <expr>`.
425
- *
426
- * Handles both:
427
- * export default createSearchParams(...)
428
- * export default expr\n (terminated by newline or semicolon before next statement)
429
- */
430
- function extractDefaultExport(source) {
431
- const match = source.match(/export\s+default\s+([\s\S]+?)(?:;|\n(?=export|import|const|let|var|function|class|type|interface|declare))/);
432
- if (match) return match[1];
433
- const fallback = source.match(/export\s+default\s+([\s\S]+)$/);
434
- if (fallback) return fallback[1].replace(/;\s*$/, "");
435
- }
436
- /**
437
- * Check if an expression is a valid statically-analyzable pattern.
438
- *
439
- * Valid patterns:
440
- * - Starts with `createSearchParams(`
441
- * - Contains `.extend(` or `.pick(` chains (possibly starting with createSearchParams or a variable)
442
- * - A variable identifier followed by chaining
443
- */
444
- function isValidExpression(expr) {
445
- const normalized = expr.replace(/\s+/g, " ").trim();
446
- if (normalized.startsWith("createSearchParams(")) return true;
447
- if (/\.(extend|pick)\s*\(/.test(normalized)) {
448
- if (/\?/.test(normalized) && /:/.test(normalized)) return false;
449
- if (/^\s*(function|=>|\()/.test(normalized)) return false;
450
- return true;
451
- }
452
- return false;
453
- }
454
- /**
455
- * Format an AnalyzeError into a human-readable build error message.
456
- */
457
- function formatAnalyzeError(error) {
458
- return [
459
- `[timber] Non-analyzable search-params.ts`,
460
- ``,
461
- ` File: ${error.filePath}`,
462
- ` Expression: ${error.expression}`,
463
- ``,
464
- ` ${error.suggestion}`,
465
- ``,
466
- ` The framework must be able to statically extract the type from your`,
467
- ` search-params.ts at build time. Dynamic values, conditionals, and`,
468
- ` arbitrary factory functions prevent this analysis.`
469
- ].join("\n");
470
- }
471
- //#endregion
472
- export { analyzeSearchParams, createSearchParams, formatAnalyzeError, fromArraySchema, fromSchema, getSearchParams, parseAsBoolean, parseAsFloat, parseAsInteger, parseAsString, parseAsStringEnum, parseAsStringLiteral, registerSearchParams, withDefault };
473
-
474
- //# sourceMappingURL=index.js.map
1
+ import { i as registerSearchParams, r as getSearchParams } from "../_chunks/use-query-states-BvW0TKDn.js";
2
+ import { a as fromSchema, i as fromArraySchema, n as withUrlKey, r as defineSearchParams, t as withDefault } from "../_chunks/wrappers-C6J0nNji.js";
3
+ export { defineSearchParams, fromArraySchema, fromSchema, getSearchParams, registerSearchParams, withDefault, withUrlKey };
@@ -6,7 +6,7 @@
6
6
  *
7
7
  * Design doc: design/23-search-params.md §"Runtime: Registration at Route Load"
8
8
  */
9
- import type { SearchParamsDefinition } from './create.js';
9
+ import type { SearchParamsDefinition } from './define.js';
10
10
  /**
11
11
  * Register a route's search params definition.
12
12
  * Called by the generated route manifest loader when a route's modules load.