@tanstack/preact-query 0.0.1 → 5.91.0

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 (338) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +48 -45
  3. package/build/codemods/src/utils/index.cjs +208 -0
  4. package/build/codemods/src/utils/transformers/query-cache-transformer.cjs +124 -0
  5. package/build/codemods/src/utils/transformers/query-client-transformer.cjs +53 -0
  6. package/build/codemods/src/utils/transformers/use-query-like-transformer.cjs +38 -0
  7. package/build/codemods/src/v4/key-transformation.cjs +181 -0
  8. package/build/codemods/src/v4/replace-import-specifier.cjs +25 -0
  9. package/build/codemods/src/v4/utils/replacers/key-replacer.cjs +164 -0
  10. package/build/codemods/src/v5/is-loading/is-loading.cjs +244 -0
  11. package/build/codemods/src/v5/keep-previous-data/README.md +32 -0
  12. package/build/codemods/src/v5/keep-previous-data/keep-previous-data.cjs +271 -0
  13. package/build/codemods/src/v5/keep-previous-data/utils/already-has-placeholder-data-property.cjs +26 -0
  14. package/build/codemods/src/v5/remove-overloads/remove-overloads.cjs +58 -0
  15. package/build/codemods/src/v5/remove-overloads/transformers/filter-aware-usage-transformer.cjs +271 -0
  16. package/build/codemods/src/v5/remove-overloads/transformers/query-fn-aware-usage-transformer.cjs +185 -0
  17. package/build/codemods/src/v5/remove-overloads/utils/index.cjs +123 -0
  18. package/build/codemods/src/v5/remove-overloads/utils/unknown-usage-error.cjs +27 -0
  19. package/build/codemods/src/v5/rename-hydrate/rename-hydrate.cjs +55 -0
  20. package/build/codemods/src/v5/rename-properties/rename-properties.cjs +41 -0
  21. package/build/legacy/HydrationBoundary.cjs +80 -0
  22. package/build/legacy/HydrationBoundary.cjs.map +1 -0
  23. package/build/legacy/HydrationBoundary.d.cts +14 -0
  24. package/build/legacy/HydrationBoundary.d.ts +14 -0
  25. package/build/legacy/HydrationBoundary.js +55 -0
  26. package/build/legacy/HydrationBoundary.js.map +1 -0
  27. package/build/legacy/IsRestoringProvider.cjs +37 -0
  28. package/build/legacy/IsRestoringProvider.cjs.map +1 -0
  29. package/build/legacy/IsRestoringProvider.d.cts +6 -0
  30. package/build/legacy/IsRestoringProvider.d.ts +6 -0
  31. package/build/legacy/IsRestoringProvider.js +11 -0
  32. package/build/legacy/IsRestoringProvider.js.map +1 -0
  33. package/build/legacy/QueryClientProvider.cjs +62 -0
  34. package/build/legacy/QueryClientProvider.cjs.map +1 -0
  35. package/build/legacy/QueryClientProvider.d.cts +13 -0
  36. package/build/legacy/QueryClientProvider.d.ts +13 -0
  37. package/build/legacy/QueryClientProvider.js +35 -0
  38. package/build/legacy/QueryClientProvider.js.map +1 -0
  39. package/build/legacy/QueryErrorResetBoundary.cjs +57 -0
  40. package/build/legacy/QueryErrorResetBoundary.cjs.map +1 -0
  41. package/build/legacy/QueryErrorResetBoundary.d.cts +19 -0
  42. package/build/legacy/QueryErrorResetBoundary.d.ts +19 -0
  43. package/build/legacy/QueryErrorResetBoundary.js +31 -0
  44. package/build/legacy/QueryErrorResetBoundary.js.map +1 -0
  45. package/build/legacy/errorBoundaryUtils.cjs +57 -0
  46. package/build/legacy/errorBoundaryUtils.cjs.map +1 -0
  47. package/build/legacy/errorBoundaryUtils.d.cts +15 -0
  48. package/build/legacy/errorBoundaryUtils.d.ts +15 -0
  49. package/build/legacy/errorBoundaryUtils.js +30 -0
  50. package/build/legacy/errorBoundaryUtils.js.map +1 -0
  51. package/build/legacy/index.cjs +97 -0
  52. package/build/legacy/index.cjs.map +1 -0
  53. package/build/legacy/index.d.cts +21 -0
  54. package/build/legacy/index.d.ts +21 -0
  55. package/build/legacy/index.js +54 -0
  56. package/build/legacy/index.js.map +1 -0
  57. package/build/legacy/infiniteQueryOptions.cjs +33 -0
  58. package/build/legacy/infiniteQueryOptions.cjs.map +1 -0
  59. package/build/legacy/infiniteQueryOptions.d.cts +23 -0
  60. package/build/legacy/infiniteQueryOptions.d.ts +23 -0
  61. package/build/legacy/infiniteQueryOptions.js +8 -0
  62. package/build/legacy/infiniteQueryOptions.js.map +1 -0
  63. package/build/legacy/mutationOptions.cjs +33 -0
  64. package/build/legacy/mutationOptions.cjs.map +1 -0
  65. package/build/legacy/mutationOptions.d.cts +7 -0
  66. package/build/legacy/mutationOptions.d.ts +7 -0
  67. package/build/legacy/mutationOptions.js +8 -0
  68. package/build/legacy/mutationOptions.js.map +1 -0
  69. package/build/legacy/queryOptions.cjs +33 -0
  70. package/build/legacy/queryOptions.cjs.map +1 -0
  71. package/build/legacy/queryOptions.d.cts +24 -0
  72. package/build/legacy/queryOptions.d.ts +24 -0
  73. package/build/legacy/queryOptions.js +8 -0
  74. package/build/legacy/queryOptions.js.map +1 -0
  75. package/build/legacy/suspense.cjs +58 -0
  76. package/build/legacy/suspense.cjs.map +1 -0
  77. package/build/legacy/suspense.d.cts +11 -0
  78. package/build/legacy/suspense.d.ts +11 -0
  79. package/build/legacy/suspense.js +29 -0
  80. package/build/legacy/suspense.js.map +1 -0
  81. package/build/legacy/types.cjs +19 -0
  82. package/build/legacy/types.cjs.map +1 -0
  83. package/build/legacy/types.d.cts +52 -0
  84. package/build/legacy/types.d.ts +52 -0
  85. package/build/legacy/types.js +1 -0
  86. package/build/legacy/types.js.map +1 -0
  87. package/build/legacy/useBaseQuery.cjs +121 -0
  88. package/build/legacy/useBaseQuery.cjs.map +1 -0
  89. package/build/legacy/useBaseQuery.d.cts +6 -0
  90. package/build/legacy/useBaseQuery.d.ts +6 -0
  91. package/build/legacy/useBaseQuery.js +105 -0
  92. package/build/legacy/useBaseQuery.js.map +1 -0
  93. package/build/legacy/useInfiniteQuery.cjs +39 -0
  94. package/build/legacy/useInfiniteQuery.cjs.map +1 -0
  95. package/build/legacy/useInfiniteQuery.d.cts +9 -0
  96. package/build/legacy/useInfiniteQuery.d.ts +9 -0
  97. package/build/legacy/useInfiniteQuery.js +14 -0
  98. package/build/legacy/useInfiniteQuery.js.map +1 -0
  99. package/build/legacy/useIsFetching.cjs +45 -0
  100. package/build/legacy/useIsFetching.cjs.map +1 -0
  101. package/build/legacy/useIsFetching.d.cts +5 -0
  102. package/build/legacy/useIsFetching.d.ts +5 -0
  103. package/build/legacy/useIsFetching.js +20 -0
  104. package/build/legacy/useIsFetching.js.map +1 -0
  105. package/build/legacy/useMutation.cjs +63 -0
  106. package/build/legacy/useMutation.cjs.map +1 -0
  107. package/build/legacy/useMutation.d.cts +6 -0
  108. package/build/legacy/useMutation.d.ts +6 -0
  109. package/build/legacy/useMutation.js +43 -0
  110. package/build/legacy/useMutation.js.map +1 -0
  111. package/build/legacy/useMutationState.cjs +75 -0
  112. package/build/legacy/useMutationState.cjs.map +1 -0
  113. package/build/legacy/useMutationState.d.cts +10 -0
  114. package/build/legacy/useMutationState.d.ts +10 -0
  115. package/build/legacy/useMutationState.js +49 -0
  116. package/build/legacy/useMutationState.js.map +1 -0
  117. package/build/legacy/usePrefetchInfiniteQuery.cjs +37 -0
  118. package/build/legacy/usePrefetchInfiniteQuery.cjs.map +1 -0
  119. package/build/legacy/usePrefetchInfiniteQuery.d.cts +5 -0
  120. package/build/legacy/usePrefetchInfiniteQuery.d.ts +5 -0
  121. package/build/legacy/usePrefetchInfiniteQuery.js +12 -0
  122. package/build/legacy/usePrefetchInfiniteQuery.js.map +1 -0
  123. package/build/legacy/usePrefetchQuery.cjs +37 -0
  124. package/build/legacy/usePrefetchQuery.cjs.map +1 -0
  125. package/build/legacy/usePrefetchQuery.d.cts +6 -0
  126. package/build/legacy/usePrefetchQuery.d.ts +6 -0
  127. package/build/legacy/usePrefetchQuery.js +12 -0
  128. package/build/legacy/usePrefetchQuery.js.map +1 -0
  129. package/build/legacy/useQueries.cjs +120 -0
  130. package/build/legacy/useQueries.cjs.map +1 -0
  131. package/build/legacy/useQueries.d.cts +76 -0
  132. package/build/legacy/useQueries.d.ts +76 -0
  133. package/build/legacy/useQueries.js +109 -0
  134. package/build/legacy/useQueries.js.map +1 -0
  135. package/build/legacy/useQuery.cjs +35 -0
  136. package/build/legacy/useQuery.cjs.map +1 -0
  137. package/build/legacy/useQuery.d.cts +9 -0
  138. package/build/legacy/useQuery.d.ts +9 -0
  139. package/build/legacy/useQuery.js +10 -0
  140. package/build/legacy/useQuery.js.map +1 -0
  141. package/build/legacy/useSuspenseInfiniteQuery.cjs +50 -0
  142. package/build/legacy/useSuspenseInfiniteQuery.cjs.map +1 -0
  143. package/build/legacy/useSuspenseInfiniteQuery.d.cts +6 -0
  144. package/build/legacy/useSuspenseInfiniteQuery.d.ts +6 -0
  145. package/build/legacy/useSuspenseInfiniteQuery.js +25 -0
  146. package/build/legacy/useSuspenseInfiniteQuery.js.map +1 -0
  147. package/build/legacy/useSuspenseQueries.cjs +55 -0
  148. package/build/legacy/useSuspenseQueries.cjs.map +1 -0
  149. package/build/legacy/useSuspenseQueries.d.cts +79 -0
  150. package/build/legacy/useSuspenseQueries.d.ts +79 -0
  151. package/build/legacy/useSuspenseQueries.js +30 -0
  152. package/build/legacy/useSuspenseQueries.js.map +1 -0
  153. package/build/legacy/useSuspenseQuery.cjs +51 -0
  154. package/build/legacy/useSuspenseQuery.cjs.map +1 -0
  155. package/build/legacy/useSuspenseQuery.d.cts +6 -0
  156. package/build/legacy/useSuspenseQuery.d.ts +6 -0
  157. package/build/legacy/useSuspenseQuery.js +26 -0
  158. package/build/legacy/useSuspenseQuery.js.map +1 -0
  159. package/build/legacy/utils.cjs +79 -0
  160. package/build/legacy/utils.cjs.map +1 -0
  161. package/build/legacy/utils.d.cts +4 -0
  162. package/build/legacy/utils.d.ts +4 -0
  163. package/build/legacy/utils.js +53 -0
  164. package/build/legacy/utils.js.map +1 -0
  165. package/build/modern/HydrationBoundary.cjs +80 -0
  166. package/build/modern/HydrationBoundary.cjs.map +1 -0
  167. package/build/modern/HydrationBoundary.d.cts +14 -0
  168. package/build/modern/HydrationBoundary.d.ts +14 -0
  169. package/build/modern/HydrationBoundary.js +55 -0
  170. package/build/modern/HydrationBoundary.js.map +1 -0
  171. package/build/modern/IsRestoringProvider.cjs +37 -0
  172. package/build/modern/IsRestoringProvider.cjs.map +1 -0
  173. package/build/modern/IsRestoringProvider.d.cts +6 -0
  174. package/build/modern/IsRestoringProvider.d.ts +6 -0
  175. package/build/modern/IsRestoringProvider.js +11 -0
  176. package/build/modern/IsRestoringProvider.js.map +1 -0
  177. package/build/modern/QueryClientProvider.cjs +62 -0
  178. package/build/modern/QueryClientProvider.cjs.map +1 -0
  179. package/build/modern/QueryClientProvider.d.cts +13 -0
  180. package/build/modern/QueryClientProvider.d.ts +13 -0
  181. package/build/modern/QueryClientProvider.js +35 -0
  182. package/build/modern/QueryClientProvider.js.map +1 -0
  183. package/build/modern/QueryErrorResetBoundary.cjs +57 -0
  184. package/build/modern/QueryErrorResetBoundary.cjs.map +1 -0
  185. package/build/modern/QueryErrorResetBoundary.d.cts +19 -0
  186. package/build/modern/QueryErrorResetBoundary.d.ts +19 -0
  187. package/build/modern/QueryErrorResetBoundary.js +31 -0
  188. package/build/modern/QueryErrorResetBoundary.js.map +1 -0
  189. package/build/modern/errorBoundaryUtils.cjs +57 -0
  190. package/build/modern/errorBoundaryUtils.cjs.map +1 -0
  191. package/build/modern/errorBoundaryUtils.d.cts +15 -0
  192. package/build/modern/errorBoundaryUtils.d.ts +15 -0
  193. package/build/modern/errorBoundaryUtils.js +30 -0
  194. package/build/modern/errorBoundaryUtils.js.map +1 -0
  195. package/build/modern/index.cjs +97 -0
  196. package/build/modern/index.cjs.map +1 -0
  197. package/build/modern/index.d.cts +21 -0
  198. package/build/modern/index.d.ts +21 -0
  199. package/build/modern/index.js +54 -0
  200. package/build/modern/index.js.map +1 -0
  201. package/build/modern/infiniteQueryOptions.cjs +33 -0
  202. package/build/modern/infiniteQueryOptions.cjs.map +1 -0
  203. package/build/modern/infiniteQueryOptions.d.cts +23 -0
  204. package/build/modern/infiniteQueryOptions.d.ts +23 -0
  205. package/build/modern/infiniteQueryOptions.js +8 -0
  206. package/build/modern/infiniteQueryOptions.js.map +1 -0
  207. package/build/modern/mutationOptions.cjs +33 -0
  208. package/build/modern/mutationOptions.cjs.map +1 -0
  209. package/build/modern/mutationOptions.d.cts +7 -0
  210. package/build/modern/mutationOptions.d.ts +7 -0
  211. package/build/modern/mutationOptions.js +8 -0
  212. package/build/modern/mutationOptions.js.map +1 -0
  213. package/build/modern/queryOptions.cjs +33 -0
  214. package/build/modern/queryOptions.cjs.map +1 -0
  215. package/build/modern/queryOptions.d.cts +24 -0
  216. package/build/modern/queryOptions.d.ts +24 -0
  217. package/build/modern/queryOptions.js +8 -0
  218. package/build/modern/queryOptions.js.map +1 -0
  219. package/build/modern/suspense.cjs +58 -0
  220. package/build/modern/suspense.cjs.map +1 -0
  221. package/build/modern/suspense.d.cts +11 -0
  222. package/build/modern/suspense.d.ts +11 -0
  223. package/build/modern/suspense.js +29 -0
  224. package/build/modern/suspense.js.map +1 -0
  225. package/build/modern/types.cjs +19 -0
  226. package/build/modern/types.cjs.map +1 -0
  227. package/build/modern/types.d.cts +52 -0
  228. package/build/modern/types.d.ts +52 -0
  229. package/build/modern/types.js +1 -0
  230. package/build/modern/types.js.map +1 -0
  231. package/build/modern/useBaseQuery.cjs +118 -0
  232. package/build/modern/useBaseQuery.cjs.map +1 -0
  233. package/build/modern/useBaseQuery.d.cts +6 -0
  234. package/build/modern/useBaseQuery.d.ts +6 -0
  235. package/build/modern/useBaseQuery.js +102 -0
  236. package/build/modern/useBaseQuery.js.map +1 -0
  237. package/build/modern/useInfiniteQuery.cjs +39 -0
  238. package/build/modern/useInfiniteQuery.cjs.map +1 -0
  239. package/build/modern/useInfiniteQuery.d.cts +9 -0
  240. package/build/modern/useInfiniteQuery.d.ts +9 -0
  241. package/build/modern/useInfiniteQuery.js +14 -0
  242. package/build/modern/useInfiniteQuery.js.map +1 -0
  243. package/build/modern/useIsFetching.cjs +45 -0
  244. package/build/modern/useIsFetching.cjs.map +1 -0
  245. package/build/modern/useIsFetching.d.cts +5 -0
  246. package/build/modern/useIsFetching.d.ts +5 -0
  247. package/build/modern/useIsFetching.js +20 -0
  248. package/build/modern/useIsFetching.js.map +1 -0
  249. package/build/modern/useMutation.cjs +63 -0
  250. package/build/modern/useMutation.cjs.map +1 -0
  251. package/build/modern/useMutation.d.cts +6 -0
  252. package/build/modern/useMutation.d.ts +6 -0
  253. package/build/modern/useMutation.js +43 -0
  254. package/build/modern/useMutation.js.map +1 -0
  255. package/build/modern/useMutationState.cjs +75 -0
  256. package/build/modern/useMutationState.cjs.map +1 -0
  257. package/build/modern/useMutationState.d.cts +10 -0
  258. package/build/modern/useMutationState.d.ts +10 -0
  259. package/build/modern/useMutationState.js +49 -0
  260. package/build/modern/useMutationState.js.map +1 -0
  261. package/build/modern/usePrefetchInfiniteQuery.cjs +37 -0
  262. package/build/modern/usePrefetchInfiniteQuery.cjs.map +1 -0
  263. package/build/modern/usePrefetchInfiniteQuery.d.cts +5 -0
  264. package/build/modern/usePrefetchInfiniteQuery.d.ts +5 -0
  265. package/build/modern/usePrefetchInfiniteQuery.js +12 -0
  266. package/build/modern/usePrefetchInfiniteQuery.js.map +1 -0
  267. package/build/modern/usePrefetchQuery.cjs +37 -0
  268. package/build/modern/usePrefetchQuery.cjs.map +1 -0
  269. package/build/modern/usePrefetchQuery.d.cts +6 -0
  270. package/build/modern/usePrefetchQuery.d.ts +6 -0
  271. package/build/modern/usePrefetchQuery.js +12 -0
  272. package/build/modern/usePrefetchQuery.js.map +1 -0
  273. package/build/modern/useQueries.cjs +120 -0
  274. package/build/modern/useQueries.cjs.map +1 -0
  275. package/build/modern/useQueries.d.cts +76 -0
  276. package/build/modern/useQueries.d.ts +76 -0
  277. package/build/modern/useQueries.js +109 -0
  278. package/build/modern/useQueries.js.map +1 -0
  279. package/build/modern/useQuery.cjs +35 -0
  280. package/build/modern/useQuery.cjs.map +1 -0
  281. package/build/modern/useQuery.d.cts +9 -0
  282. package/build/modern/useQuery.d.ts +9 -0
  283. package/build/modern/useQuery.js +10 -0
  284. package/build/modern/useQuery.js.map +1 -0
  285. package/build/modern/useSuspenseInfiniteQuery.cjs +50 -0
  286. package/build/modern/useSuspenseInfiniteQuery.cjs.map +1 -0
  287. package/build/modern/useSuspenseInfiniteQuery.d.cts +6 -0
  288. package/build/modern/useSuspenseInfiniteQuery.d.ts +6 -0
  289. package/build/modern/useSuspenseInfiniteQuery.js +25 -0
  290. package/build/modern/useSuspenseInfiniteQuery.js.map +1 -0
  291. package/build/modern/useSuspenseQueries.cjs +55 -0
  292. package/build/modern/useSuspenseQueries.cjs.map +1 -0
  293. package/build/modern/useSuspenseQueries.d.cts +79 -0
  294. package/build/modern/useSuspenseQueries.d.ts +79 -0
  295. package/build/modern/useSuspenseQueries.js +30 -0
  296. package/build/modern/useSuspenseQueries.js.map +1 -0
  297. package/build/modern/useSuspenseQuery.cjs +51 -0
  298. package/build/modern/useSuspenseQuery.cjs.map +1 -0
  299. package/build/modern/useSuspenseQuery.d.cts +6 -0
  300. package/build/modern/useSuspenseQuery.d.ts +6 -0
  301. package/build/modern/useSuspenseQuery.js +26 -0
  302. package/build/modern/useSuspenseQuery.js.map +1 -0
  303. package/build/modern/utils.cjs +79 -0
  304. package/build/modern/utils.cjs.map +1 -0
  305. package/build/modern/utils.d.cts +4 -0
  306. package/build/modern/utils.d.ts +4 -0
  307. package/build/modern/utils.js +53 -0
  308. package/build/modern/utils.js.map +1 -0
  309. package/build/query-codemods/eslint.config.js +18 -0
  310. package/build/query-codemods/package.json +38 -0
  311. package/build/query-codemods/root.eslint.config.js +64 -0
  312. package/build/query-codemods/tsconfig.json +8 -0
  313. package/build/query-codemods/vite.config.ts +30 -0
  314. package/package.json +82 -8
  315. package/src/HydrationBoundary.tsx +108 -0
  316. package/src/IsRestoringProvider.ts +7 -0
  317. package/src/QueryClientProvider.tsx +45 -0
  318. package/src/QueryErrorResetBoundary.tsx +57 -0
  319. package/src/errorBoundaryUtils.ts +76 -0
  320. package/src/index.ts +56 -0
  321. package/src/infiniteQueryOptions.ts +150 -0
  322. package/src/mutationOptions.ts +42 -0
  323. package/src/queryOptions.ts +88 -0
  324. package/src/suspense.ts +81 -0
  325. package/src/types.ts +241 -0
  326. package/src/useBaseQuery.ts +169 -0
  327. package/src/useInfiniteQuery.ts +81 -0
  328. package/src/useIsFetching.ts +23 -0
  329. package/src/useMutation.ts +69 -0
  330. package/src/useMutationState.ts +74 -0
  331. package/src/usePrefetchInfiniteQuery.tsx +31 -0
  332. package/src/usePrefetchQuery.tsx +20 -0
  333. package/src/useQueries.ts +331 -0
  334. package/src/useQuery.ts +52 -0
  335. package/src/useSuspenseInfiniteQuery.ts +50 -0
  336. package/src/useSuspenseQueries.ts +211 -0
  337. package/src/useSuspenseQuery.ts +34 -0
  338. package/src/utils.ts +88 -0
@@ -0,0 +1,211 @@
1
+ import { skipToken } from '@tanstack/query-core'
2
+ import type {
3
+ DefaultError,
4
+ QueryClient,
5
+ QueryFunction,
6
+ ThrowOnError,
7
+ } from '@tanstack/query-core'
8
+
9
+ import { defaultThrowOnError } from './suspense'
10
+ import type { UseSuspenseQueryOptions, UseSuspenseQueryResult } from './types'
11
+ import { useQueries } from './useQueries'
12
+
13
+ // Avoid TS depth-limit error in case of large array literal
14
+ type MAXIMUM_DEPTH = 20
15
+
16
+ // Widen the type of the symbol to enable type inference even if skipToken is not immutable.
17
+ type SkipTokenForUseQueries = symbol
18
+
19
+ type GetUseSuspenseQueryOptions<T> =
20
+ // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }
21
+ T extends {
22
+ queryFnData: infer TQueryFnData
23
+ error?: infer TError
24
+ data: infer TData
25
+ }
26
+ ? UseSuspenseQueryOptions<TQueryFnData, TError, TData>
27
+ : T extends { queryFnData: infer TQueryFnData; error?: infer TError }
28
+ ? UseSuspenseQueryOptions<TQueryFnData, TError>
29
+ : T extends { data: infer TData; error?: infer TError }
30
+ ? UseSuspenseQueryOptions<unknown, TError, TData>
31
+ : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]
32
+ T extends [infer TQueryFnData, infer TError, infer TData]
33
+ ? UseSuspenseQueryOptions<TQueryFnData, TError, TData>
34
+ : T extends [infer TQueryFnData, infer TError]
35
+ ? UseSuspenseQueryOptions<TQueryFnData, TError>
36
+ : T extends [infer TQueryFnData]
37
+ ? UseSuspenseQueryOptions<TQueryFnData>
38
+ : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided
39
+ T extends {
40
+ queryFn?:
41
+ | QueryFunction<infer TQueryFnData, infer TQueryKey>
42
+ | SkipTokenForUseQueries
43
+ select?: (data: any) => infer TData
44
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
45
+ }
46
+ ? UseSuspenseQueryOptions<
47
+ TQueryFnData,
48
+ TError,
49
+ TData,
50
+ TQueryKey
51
+ >
52
+ : T extends {
53
+ queryFn?:
54
+ | QueryFunction<infer TQueryFnData, infer TQueryKey>
55
+ | SkipTokenForUseQueries
56
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
57
+ }
58
+ ? UseSuspenseQueryOptions<
59
+ TQueryFnData,
60
+ TError,
61
+ TQueryFnData,
62
+ TQueryKey
63
+ >
64
+ : // Fallback
65
+ UseSuspenseQueryOptions
66
+
67
+ type GetUseSuspenseQueryResult<T> =
68
+ // Part 1: responsible for mapping explicit type parameter to function result, if object
69
+ T extends { queryFnData: any; error?: infer TError; data: infer TData }
70
+ ? UseSuspenseQueryResult<TData, TError>
71
+ : T extends { queryFnData: infer TQueryFnData; error?: infer TError }
72
+ ? UseSuspenseQueryResult<TQueryFnData, TError>
73
+ : T extends { data: infer TData; error?: infer TError }
74
+ ? UseSuspenseQueryResult<TData, TError>
75
+ : // Part 2: responsible for mapping explicit type parameter to function result, if tuple
76
+ T extends [any, infer TError, infer TData]
77
+ ? UseSuspenseQueryResult<TData, TError>
78
+ : T extends [infer TQueryFnData, infer TError]
79
+ ? UseSuspenseQueryResult<TQueryFnData, TError>
80
+ : T extends [infer TQueryFnData]
81
+ ? UseSuspenseQueryResult<TQueryFnData>
82
+ : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided
83
+ T extends {
84
+ queryFn?:
85
+ | QueryFunction<infer TQueryFnData, any>
86
+ | SkipTokenForUseQueries
87
+ select?: (data: any) => infer TData
88
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
89
+ }
90
+ ? UseSuspenseQueryResult<
91
+ unknown extends TData ? TQueryFnData : TData,
92
+ unknown extends TError ? DefaultError : TError
93
+ >
94
+ : T extends {
95
+ queryFn?:
96
+ | QueryFunction<infer TQueryFnData, any>
97
+ | SkipTokenForUseQueries
98
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
99
+ }
100
+ ? UseSuspenseQueryResult<
101
+ TQueryFnData,
102
+ unknown extends TError ? DefaultError : TError
103
+ >
104
+ : // Fallback
105
+ UseSuspenseQueryResult
106
+
107
+ /**
108
+ * SuspenseQueriesOptions reducer recursively unwraps function arguments to infer/enforce type param
109
+ */
110
+ export type SuspenseQueriesOptions<
111
+ T extends Array<any>,
112
+ TResults extends Array<any> = [],
113
+ TDepth extends ReadonlyArray<number> = [],
114
+ > = TDepth['length'] extends MAXIMUM_DEPTH
115
+ ? Array<UseSuspenseQueryOptions>
116
+ : T extends []
117
+ ? []
118
+ : T extends [infer Head]
119
+ ? [...TResults, GetUseSuspenseQueryOptions<Head>]
120
+ : T extends [infer Head, ...infer Tails]
121
+ ? SuspenseQueriesOptions<
122
+ [...Tails],
123
+ [...TResults, GetUseSuspenseQueryOptions<Head>],
124
+ [...TDepth, 1]
125
+ >
126
+ : Array<unknown> extends T
127
+ ? T
128
+ : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!
129
+ // use this to infer the param types in the case of Array.map() argument
130
+ T extends Array<
131
+ UseSuspenseQueryOptions<
132
+ infer TQueryFnData,
133
+ infer TError,
134
+ infer TData,
135
+ infer TQueryKey
136
+ >
137
+ >
138
+ ? Array<
139
+ UseSuspenseQueryOptions<TQueryFnData, TError, TData, TQueryKey>
140
+ >
141
+ : // Fallback
142
+ Array<UseSuspenseQueryOptions>
143
+
144
+ /**
145
+ * SuspenseQueriesResults reducer recursively maps type param to results
146
+ */
147
+ export type SuspenseQueriesResults<
148
+ T extends Array<any>,
149
+ TResults extends Array<any> = [],
150
+ TDepth extends ReadonlyArray<number> = [],
151
+ > = TDepth['length'] extends MAXIMUM_DEPTH
152
+ ? Array<UseSuspenseQueryResult>
153
+ : T extends []
154
+ ? []
155
+ : T extends [infer Head]
156
+ ? [...TResults, GetUseSuspenseQueryResult<Head>]
157
+ : T extends [infer Head, ...infer Tails]
158
+ ? SuspenseQueriesResults<
159
+ [...Tails],
160
+ [...TResults, GetUseSuspenseQueryResult<Head>],
161
+ [...TDepth, 1]
162
+ >
163
+ : { [K in keyof T]: GetUseSuspenseQueryResult<T[K]> }
164
+
165
+ export function useSuspenseQueries<
166
+ T extends Array<any>,
167
+ TCombinedResult = SuspenseQueriesResults<T>,
168
+ >(
169
+ options: {
170
+ queries:
171
+ | readonly [...SuspenseQueriesOptions<T>]
172
+ | readonly [...{ [K in keyof T]: GetUseSuspenseQueryOptions<T[K]> }]
173
+ combine?: (result: SuspenseQueriesResults<T>) => TCombinedResult
174
+ },
175
+ queryClient?: QueryClient,
176
+ ): TCombinedResult
177
+
178
+ export function useSuspenseQueries<
179
+ T extends Array<any>,
180
+ TCombinedResult = SuspenseQueriesResults<T>,
181
+ >(
182
+ options: {
183
+ queries: readonly [...SuspenseQueriesOptions<T>]
184
+ combine?: (result: SuspenseQueriesResults<T>) => TCombinedResult
185
+ },
186
+ queryClient?: QueryClient,
187
+ ): TCombinedResult
188
+
189
+ export function useSuspenseQueries(options: any, queryClient?: QueryClient) {
190
+ return useQueries(
191
+ {
192
+ ...options,
193
+ queries: options.queries.map((query: any) => {
194
+ if (process.env.NODE_ENV !== 'production') {
195
+ if (query.queryFn === skipToken) {
196
+ console.error('skipToken is not allowed for useSuspenseQueries')
197
+ }
198
+ }
199
+
200
+ return {
201
+ ...query,
202
+ suspense: true,
203
+ throwOnError: defaultThrowOnError,
204
+ enabled: true,
205
+ placeholderData: undefined,
206
+ }
207
+ }),
208
+ },
209
+ queryClient,
210
+ )
211
+ }
@@ -0,0 +1,34 @@
1
+ import { QueryObserver, skipToken } from '@tanstack/query-core'
2
+ import type { DefaultError, QueryClient, QueryKey } from '@tanstack/query-core'
3
+
4
+ import { defaultThrowOnError } from './suspense'
5
+ import type { UseSuspenseQueryOptions, UseSuspenseQueryResult } from './types'
6
+ import { useBaseQuery } from './useBaseQuery'
7
+
8
+ export function useSuspenseQuery<
9
+ TQueryFnData = unknown,
10
+ TError = DefaultError,
11
+ TData = TQueryFnData,
12
+ TQueryKey extends QueryKey = QueryKey,
13
+ >(
14
+ options: UseSuspenseQueryOptions<TQueryFnData, TError, TData, TQueryKey>,
15
+ queryClient?: QueryClient,
16
+ ): UseSuspenseQueryResult<TData, TError> {
17
+ if (process.env.NODE_ENV !== 'production') {
18
+ if ((options.queryFn as any) === skipToken) {
19
+ console.error('skipToken is not allowed for useSuspenseQuery')
20
+ }
21
+ }
22
+
23
+ return useBaseQuery(
24
+ {
25
+ ...options,
26
+ enabled: true,
27
+ suspense: true,
28
+ throwOnError: defaultThrowOnError,
29
+ placeholderData: undefined,
30
+ },
31
+ QueryObserver,
32
+ queryClient,
33
+ ) as UseSuspenseQueryResult<TData, TError>
34
+ }
package/src/utils.ts ADDED
@@ -0,0 +1,88 @@
1
+ import { useEffect, useLayoutEffect, useRef, useState } from 'preact/hooks'
2
+
3
+ /**
4
+ * This is taken from https://github.com/preactjs/preact/blob/main/compat/src/hooks.js#L8-L54
5
+ * which is taken from https://github.com/facebook/react/blob/main/packages/use-sync-external-store/src/useSyncExternalStoreShimClient.js#L84
6
+ * on a high level this cuts out the warnings, ... and attempts a smaller implementation.
7
+ * This way we don't have to import preact/compat with side effects
8
+ */
9
+ type InternalStore = {
10
+ _value: any
11
+ _getSnapshot: () => any
12
+ }
13
+ type StoreRef = {
14
+ _instance: InternalStore
15
+ }
16
+ export function useSyncExternalStore(
17
+ subscribe: (onStoreChange: () => void) => () => void,
18
+ getSnapshot: () => any,
19
+ ) {
20
+ const value = getSnapshot()
21
+
22
+ const [{ _instance }, forceUpdate] = useState<StoreRef>({
23
+ _instance: { _value: value, _getSnapshot: getSnapshot },
24
+ })
25
+
26
+ useLayoutEffect(() => {
27
+ _instance._value = value
28
+ _instance._getSnapshot = getSnapshot
29
+
30
+ if (didSnapshotChange(_instance)) {
31
+ forceUpdate({ _instance })
32
+ }
33
+ }, [subscribe, value, getSnapshot])
34
+
35
+ useEffect(() => {
36
+ if (didSnapshotChange(_instance)) {
37
+ forceUpdate({ _instance })
38
+ }
39
+
40
+ return subscribe(() => {
41
+ if (didSnapshotChange(_instance)) {
42
+ forceUpdate({ _instance })
43
+ }
44
+ })
45
+ }, [subscribe])
46
+
47
+ return value
48
+ }
49
+
50
+ function didSnapshotChange(inst: {
51
+ _getSnapshot: () => any
52
+ _value: any
53
+ }): boolean {
54
+ const latestGetSnapshot = inst._getSnapshot
55
+ const prevValue = inst._value
56
+ try {
57
+ const nextValue = latestGetSnapshot()
58
+ return !Object.is(prevValue, nextValue)
59
+ // eslint-disable-next-line no-unused-vars
60
+ } catch (_error) {
61
+ return true
62
+ }
63
+ }
64
+
65
+ export function useSyncExternalStoreWithSelector<TSnapshot, TSelected>(
66
+ subscribe: (onStoreChange: () => void) => () => void,
67
+ getSnapshot: () => TSnapshot,
68
+ selector: (snapshot: TSnapshot) => TSelected,
69
+ isEqual: (a: TSelected, b: TSelected) => boolean,
70
+ ): TSelected {
71
+ const selectedSnapshotRef = useRef<TSelected | undefined>()
72
+
73
+ const getSelectedSnapshot = () => {
74
+ const snapshot = getSnapshot()
75
+ const selected = selector(snapshot)
76
+
77
+ if (
78
+ selectedSnapshotRef.current === undefined ||
79
+ !isEqual(selectedSnapshotRef.current, selected)
80
+ ) {
81
+ selectedSnapshotRef.current = selected
82
+ }
83
+
84
+ return selectedSnapshotRef.current
85
+ }
86
+
87
+ return useSyncExternalStore(subscribe, getSelectedSnapshot)
88
+ }