@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,69 @@
1
+ import {
2
+ MutationObserver,
3
+ noop,
4
+ notifyManager,
5
+ shouldThrowError,
6
+ } from '@tanstack/query-core'
7
+ import type { DefaultError, QueryClient } from '@tanstack/query-core'
8
+ import { useCallback, useEffect, useState } from 'preact/hooks'
9
+
10
+ import { useQueryClient } from './QueryClientProvider'
11
+ import type {
12
+ UseMutateFunction,
13
+ UseMutationOptions,
14
+ UseMutationResult,
15
+ } from './types'
16
+ import { useSyncExternalStore } from './utils'
17
+
18
+ // HOOK
19
+
20
+ export function useMutation<
21
+ TData = unknown,
22
+ TError = DefaultError,
23
+ TVariables = void,
24
+ TOnMutateResult = unknown,
25
+ >(
26
+ options: UseMutationOptions<TData, TError, TVariables, TOnMutateResult>,
27
+ queryClient?: QueryClient,
28
+ ): UseMutationResult<TData, TError, TVariables, TOnMutateResult> {
29
+ const client = useQueryClient(queryClient)
30
+
31
+ const [observer] = useState(
32
+ () =>
33
+ new MutationObserver<TData, TError, TVariables, TOnMutateResult>(
34
+ client,
35
+ options,
36
+ ),
37
+ )
38
+
39
+ useEffect(() => {
40
+ observer.setOptions(options)
41
+ }, [observer, options])
42
+
43
+ const result = useSyncExternalStore(
44
+ useCallback(
45
+ (onStoreChange) =>
46
+ observer.subscribe(notifyManager.batchCalls(onStoreChange)),
47
+ [observer],
48
+ ),
49
+ () => observer.getCurrentResult(),
50
+ )
51
+
52
+ const mutate = useCallback<
53
+ UseMutateFunction<TData, TError, TVariables, TOnMutateResult>
54
+ >(
55
+ (variables, mutateOptions) => {
56
+ observer.mutate(variables, mutateOptions).catch(noop)
57
+ },
58
+ [observer],
59
+ )
60
+
61
+ if (
62
+ result.error &&
63
+ shouldThrowError(observer.options.throwOnError, [result.error])
64
+ ) {
65
+ throw result.error
66
+ }
67
+
68
+ return { ...result, mutate, mutateAsync: result.mutate }
69
+ }
@@ -0,0 +1,74 @@
1
+ import { notifyManager, replaceEqualDeep } from '@tanstack/query-core'
2
+ import type {
3
+ Mutation,
4
+ MutationCache,
5
+ MutationFilters,
6
+ MutationState,
7
+ QueryClient,
8
+ } from '@tanstack/query-core'
9
+ import { useCallback, useEffect, useRef } from 'preact/hooks'
10
+
11
+ import { useQueryClient } from './QueryClientProvider'
12
+ import { useSyncExternalStore } from './utils'
13
+
14
+ export function useIsMutating(
15
+ filters?: MutationFilters,
16
+ queryClient?: QueryClient,
17
+ ): number {
18
+ const client = useQueryClient(queryClient)
19
+ return useMutationState(
20
+ { filters: { ...filters, status: 'pending' } },
21
+ client,
22
+ ).length
23
+ }
24
+
25
+ type MutationStateOptions<TResult = MutationState> = {
26
+ filters?: MutationFilters
27
+ select?: (mutation: Mutation) => TResult
28
+ }
29
+
30
+ function getResult<TResult = MutationState>(
31
+ mutationCache: MutationCache,
32
+ options: MutationStateOptions<TResult>,
33
+ ): Array<TResult> {
34
+ return mutationCache
35
+ .findAll(options.filters)
36
+ .map(
37
+ (mutation): TResult =>
38
+ (options.select ? options.select(mutation) : mutation.state) as TResult,
39
+ )
40
+ }
41
+
42
+ export function useMutationState<TResult = MutationState>(
43
+ options: MutationStateOptions<TResult> = {},
44
+ queryClient?: QueryClient,
45
+ ): Array<TResult> {
46
+ const mutationCache = useQueryClient(queryClient).getMutationCache()
47
+ const optionsRef = useRef(options)
48
+ const result = useRef<Array<TResult>>(null)
49
+ if (result.current === null) {
50
+ result.current = getResult(mutationCache, options)
51
+ }
52
+
53
+ useEffect(() => {
54
+ optionsRef.current = options
55
+ })
56
+
57
+ return useSyncExternalStore(
58
+ useCallback(
59
+ (onStoreChange) =>
60
+ mutationCache.subscribe(() => {
61
+ const nextResult = replaceEqualDeep(
62
+ result.current,
63
+ getResult(mutationCache, optionsRef.current),
64
+ )
65
+ if (result.current !== nextResult) {
66
+ result.current = nextResult
67
+ notifyManager.schedule(onStoreChange)
68
+ }
69
+ }),
70
+ [mutationCache],
71
+ ),
72
+ () => result.current,
73
+ )!
74
+ }
@@ -0,0 +1,31 @@
1
+ import type {
2
+ DefaultError,
3
+ FetchInfiniteQueryOptions,
4
+ QueryClient,
5
+ QueryKey,
6
+ } from '@tanstack/query-core'
7
+
8
+ import { useQueryClient } from './QueryClientProvider'
9
+
10
+ export function usePrefetchInfiniteQuery<
11
+ TQueryFnData = unknown,
12
+ TError = DefaultError,
13
+ TData = TQueryFnData,
14
+ TQueryKey extends QueryKey = QueryKey,
15
+ TPageParam = unknown,
16
+ >(
17
+ options: FetchInfiniteQueryOptions<
18
+ TQueryFnData,
19
+ TError,
20
+ TData,
21
+ TQueryKey,
22
+ TPageParam
23
+ >,
24
+ queryClient?: QueryClient,
25
+ ) {
26
+ const client = useQueryClient(queryClient)
27
+
28
+ if (!client.getQueryState(options.queryKey)) {
29
+ client.prefetchInfiniteQuery(options)
30
+ }
31
+ }
@@ -0,0 +1,20 @@
1
+ import type { DefaultError, QueryClient, QueryKey } from '@tanstack/query-core'
2
+
3
+ import { useQueryClient } from './QueryClientProvider'
4
+ import type { UsePrefetchQueryOptions } from './types'
5
+
6
+ export function usePrefetchQuery<
7
+ TQueryFnData = unknown,
8
+ TError = DefaultError,
9
+ TData = TQueryFnData,
10
+ TQueryKey extends QueryKey = QueryKey,
11
+ >(
12
+ options: UsePrefetchQueryOptions<TQueryFnData, TError, TData, TQueryKey>,
13
+ queryClient?: QueryClient,
14
+ ) {
15
+ const client = useQueryClient(queryClient)
16
+
17
+ if (!client.getQueryState(options.queryKey)) {
18
+ client.prefetchQuery(options)
19
+ }
20
+ }
@@ -0,0 +1,331 @@
1
+ import {
2
+ QueriesObserver,
3
+ QueryObserver,
4
+ noop,
5
+ notifyManager,
6
+ } from '@tanstack/query-core'
7
+ import type {
8
+ DefaultError,
9
+ OmitKeyof,
10
+ QueriesObserverOptions,
11
+ QueriesPlaceholderDataFunction,
12
+ QueryClient,
13
+ QueryFunction,
14
+ QueryKey,
15
+ QueryObserverOptions,
16
+ ThrowOnError,
17
+ } from '@tanstack/query-core'
18
+ import { useCallback, useEffect, useMemo, useState } from 'preact/hooks'
19
+
20
+ import { useIsRestoring } from './IsRestoringProvider'
21
+ import { useQueryClient } from './QueryClientProvider'
22
+ import { useQueryErrorResetBoundary } from './QueryErrorResetBoundary'
23
+ import {
24
+ ensurePreventErrorBoundaryRetry,
25
+ getHasError,
26
+ useClearResetErrorBoundary,
27
+ } from './errorBoundaryUtils'
28
+ import {
29
+ ensureSuspenseTimers,
30
+ fetchOptimistic,
31
+ shouldSuspend,
32
+ willFetch,
33
+ } from './suspense'
34
+ import type {
35
+ DefinedUseQueryResult,
36
+ UseQueryOptions,
37
+ UseQueryResult,
38
+ } from './types'
39
+ import { useSyncExternalStore } from './utils'
40
+
41
+ // This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.
42
+ // `placeholderData` function always gets undefined passed
43
+ type UseQueryOptionsForUseQueries<
44
+ TQueryFnData = unknown,
45
+ TError = DefaultError,
46
+ TData = TQueryFnData,
47
+ TQueryKey extends QueryKey = QueryKey,
48
+ > = OmitKeyof<
49
+ UseQueryOptions<TQueryFnData, TError, TData, TQueryKey>,
50
+ 'placeholderData' | 'subscribed'
51
+ > & {
52
+ placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>
53
+ }
54
+
55
+ // Avoid TS depth-limit error in case of large array literal
56
+ type MAXIMUM_DEPTH = 20
57
+
58
+ // Widen the type of the symbol to enable type inference even if skipToken is not immutable.
59
+ type SkipTokenForUseQueries = symbol
60
+
61
+ type GetUseQueryOptionsForUseQueries<T> =
62
+ // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }
63
+ T extends {
64
+ queryFnData: infer TQueryFnData
65
+ error?: infer TError
66
+ data: infer TData
67
+ }
68
+ ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>
69
+ : T extends { queryFnData: infer TQueryFnData; error?: infer TError }
70
+ ? UseQueryOptionsForUseQueries<TQueryFnData, TError>
71
+ : T extends { data: infer TData; error?: infer TError }
72
+ ? UseQueryOptionsForUseQueries<unknown, TError, TData>
73
+ : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]
74
+ T extends [infer TQueryFnData, infer TError, infer TData]
75
+ ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>
76
+ : T extends [infer TQueryFnData, infer TError]
77
+ ? UseQueryOptionsForUseQueries<TQueryFnData, TError>
78
+ : T extends [infer TQueryFnData]
79
+ ? UseQueryOptionsForUseQueries<TQueryFnData>
80
+ : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided
81
+ T extends {
82
+ queryFn?:
83
+ | QueryFunction<infer TQueryFnData, infer TQueryKey>
84
+ | SkipTokenForUseQueries
85
+ select?: (data: any) => infer TData
86
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
87
+ }
88
+ ? UseQueryOptionsForUseQueries<
89
+ TQueryFnData,
90
+ unknown extends TError ? DefaultError : TError,
91
+ unknown extends TData ? TQueryFnData : TData,
92
+ TQueryKey
93
+ >
94
+ : // Fallback
95
+ UseQueryOptionsForUseQueries
96
+
97
+ // A defined initialData setting should return a DefinedUseQueryResult rather than UseQueryResult
98
+ type GetDefinedOrUndefinedQueryResult<T, TData, TError = unknown> = T extends {
99
+ initialData?: infer TInitialData
100
+ }
101
+ ? unknown extends TInitialData
102
+ ? UseQueryResult<TData, TError>
103
+ : TInitialData extends TData
104
+ ? DefinedUseQueryResult<TData, TError>
105
+ : TInitialData extends () => infer TInitialDataResult
106
+ ? unknown extends TInitialDataResult
107
+ ? UseQueryResult<TData, TError>
108
+ : TInitialDataResult extends TData
109
+ ? DefinedUseQueryResult<TData, TError>
110
+ : UseQueryResult<TData, TError>
111
+ : UseQueryResult<TData, TError>
112
+ : UseQueryResult<TData, TError>
113
+
114
+ type GetUseQueryResult<T> =
115
+ // Part 1: responsible for mapping explicit type parameter to function result, if object
116
+ T extends { queryFnData: any; error?: infer TError; data: infer TData }
117
+ ? GetDefinedOrUndefinedQueryResult<T, TData, TError>
118
+ : T extends { queryFnData: infer TQueryFnData; error?: infer TError }
119
+ ? GetDefinedOrUndefinedQueryResult<T, TQueryFnData, TError>
120
+ : T extends { data: infer TData; error?: infer TError }
121
+ ? GetDefinedOrUndefinedQueryResult<T, TData, TError>
122
+ : // Part 2: responsible for mapping explicit type parameter to function result, if tuple
123
+ T extends [any, infer TError, infer TData]
124
+ ? GetDefinedOrUndefinedQueryResult<T, TData, TError>
125
+ : T extends [infer TQueryFnData, infer TError]
126
+ ? GetDefinedOrUndefinedQueryResult<T, TQueryFnData, TError>
127
+ : T extends [infer TQueryFnData]
128
+ ? GetDefinedOrUndefinedQueryResult<T, TQueryFnData>
129
+ : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided
130
+ T extends {
131
+ queryFn?:
132
+ | QueryFunction<infer TQueryFnData, any>
133
+ | SkipTokenForUseQueries
134
+ select?: (data: any) => infer TData
135
+ throwOnError?: ThrowOnError<any, infer TError, any, any>
136
+ }
137
+ ? GetDefinedOrUndefinedQueryResult<
138
+ T,
139
+ unknown extends TData ? TQueryFnData : TData,
140
+ unknown extends TError ? DefaultError : TError
141
+ >
142
+ : // Fallback
143
+ UseQueryResult
144
+
145
+ /**
146
+ * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param
147
+ */
148
+ export type QueriesOptions<
149
+ T extends Array<any>,
150
+ TResults extends Array<any> = [],
151
+ TDepth extends ReadonlyArray<number> = [],
152
+ > = TDepth['length'] extends MAXIMUM_DEPTH
153
+ ? Array<UseQueryOptionsForUseQueries>
154
+ : T extends []
155
+ ? []
156
+ : T extends [infer Head]
157
+ ? [...TResults, GetUseQueryOptionsForUseQueries<Head>]
158
+ : T extends [infer Head, ...infer Tails]
159
+ ? QueriesOptions<
160
+ [...Tails],
161
+ [...TResults, GetUseQueryOptionsForUseQueries<Head>],
162
+ [...TDepth, 1]
163
+ >
164
+ : ReadonlyArray<unknown> extends T
165
+ ? T
166
+ : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!
167
+ // use this to infer the param types in the case of Array.map() argument
168
+ T extends Array<
169
+ UseQueryOptionsForUseQueries<
170
+ infer TQueryFnData,
171
+ infer TError,
172
+ infer TData,
173
+ infer TQueryKey
174
+ >
175
+ >
176
+ ? Array<
177
+ UseQueryOptionsForUseQueries<
178
+ TQueryFnData,
179
+ TError,
180
+ TData,
181
+ TQueryKey
182
+ >
183
+ >
184
+ : // Fallback
185
+ Array<UseQueryOptionsForUseQueries>
186
+
187
+ /**
188
+ * QueriesResults reducer recursively maps type param to results
189
+ */
190
+ export type QueriesResults<
191
+ T extends Array<any>,
192
+ TResults extends Array<any> = [],
193
+ TDepth extends ReadonlyArray<number> = [],
194
+ > = TDepth['length'] extends MAXIMUM_DEPTH
195
+ ? Array<UseQueryResult>
196
+ : T extends []
197
+ ? []
198
+ : T extends [infer Head]
199
+ ? [...TResults, GetUseQueryResult<Head>]
200
+ : T extends [infer Head, ...infer Tails]
201
+ ? QueriesResults<
202
+ [...Tails],
203
+ [...TResults, GetUseQueryResult<Head>],
204
+ [...TDepth, 1]
205
+ >
206
+ : { [K in keyof T]: GetUseQueryResult<T[K]> }
207
+
208
+ export function useQueries<
209
+ T extends Array<any>,
210
+ TCombinedResult = QueriesResults<T>,
211
+ >(
212
+ {
213
+ queries,
214
+ ...options
215
+ }: {
216
+ queries:
217
+ | readonly [...QueriesOptions<T>]
218
+ | readonly [...{ [K in keyof T]: GetUseQueryOptionsForUseQueries<T[K]> }]
219
+ combine?: (result: QueriesResults<T>) => TCombinedResult
220
+ subscribed?: boolean
221
+ },
222
+ queryClient?: QueryClient,
223
+ ): TCombinedResult {
224
+ const client = useQueryClient(queryClient)
225
+ const isRestoring = useIsRestoring()
226
+ const errorResetBoundary = useQueryErrorResetBoundary()
227
+
228
+ const defaultedQueries = useMemo(
229
+ () =>
230
+ queries.map((opts) => {
231
+ const defaultedOptions = client.defaultQueryOptions(
232
+ opts as QueryObserverOptions,
233
+ )
234
+
235
+ // Make sure the results are already in fetching state before subscribing or updating options
236
+ defaultedOptions._optimisticResults = isRestoring
237
+ ? 'isRestoring'
238
+ : 'optimistic'
239
+
240
+ return defaultedOptions
241
+ }),
242
+ [queries, client, isRestoring],
243
+ )
244
+
245
+ defaultedQueries.forEach((query) => {
246
+ ensureSuspenseTimers(query)
247
+ ensurePreventErrorBoundaryRetry(query, errorResetBoundary)
248
+ })
249
+
250
+ useClearResetErrorBoundary(errorResetBoundary)
251
+
252
+ const [observer] = useState(
253
+ () =>
254
+ new QueriesObserver<TCombinedResult>(
255
+ client,
256
+ defaultedQueries,
257
+ options as QueriesObserverOptions<TCombinedResult>,
258
+ ),
259
+ )
260
+
261
+ // note: this must be called before useSyncExternalStore
262
+ const [optimisticResult, getCombinedResult, trackResult] =
263
+ observer.getOptimisticResult(
264
+ defaultedQueries,
265
+ (options as QueriesObserverOptions<TCombinedResult>).combine,
266
+ )
267
+
268
+ const shouldSubscribe = !isRestoring && options.subscribed !== false
269
+ useSyncExternalStore(
270
+ useCallback(
271
+ (onStoreChange) =>
272
+ shouldSubscribe
273
+ ? observer.subscribe(notifyManager.batchCalls(onStoreChange))
274
+ : noop,
275
+ [observer, shouldSubscribe],
276
+ ),
277
+ () => observer.getCurrentResult(),
278
+ )
279
+
280
+ useEffect(() => {
281
+ observer.setQueries(
282
+ defaultedQueries,
283
+ options as QueriesObserverOptions<TCombinedResult>,
284
+ )
285
+ }, [defaultedQueries, options, observer])
286
+
287
+ const shouldAtLeastOneSuspend = optimisticResult.some((result, index) =>
288
+ shouldSuspend(defaultedQueries[index], result),
289
+ )
290
+
291
+ const suspensePromises = shouldAtLeastOneSuspend
292
+ ? optimisticResult.flatMap((result, index) => {
293
+ const opts = defaultedQueries[index]
294
+
295
+ if (opts) {
296
+ const queryObserver = new QueryObserver(client, opts)
297
+ if (shouldSuspend(opts, result)) {
298
+ return fetchOptimistic(opts, queryObserver, errorResetBoundary)
299
+ } else if (willFetch(result, isRestoring)) {
300
+ void fetchOptimistic(opts, queryObserver, errorResetBoundary)
301
+ }
302
+ }
303
+ return []
304
+ })
305
+ : []
306
+
307
+ if (suspensePromises.length > 0) {
308
+ throw Promise.all(suspensePromises)
309
+ }
310
+ const firstSingleResultWhichShouldThrow = optimisticResult.find(
311
+ (result, index) => {
312
+ const query = defaultedQueries[index]
313
+ return (
314
+ query &&
315
+ getHasError({
316
+ result,
317
+ errorResetBoundary,
318
+ throwOnError: query.throwOnError,
319
+ query: client.getQueryCache().get(query.queryHash),
320
+ suspense: query.suspense,
321
+ })
322
+ )
323
+ },
324
+ )
325
+
326
+ if (firstSingleResultWhichShouldThrow?.error) {
327
+ throw firstSingleResultWhichShouldThrow.error
328
+ }
329
+
330
+ return getCombinedResult(trackResult())
331
+ }
@@ -0,0 +1,52 @@
1
+ import { QueryObserver } from '@tanstack/query-core'
2
+ import type {
3
+ DefaultError,
4
+ NoInfer,
5
+ QueryClient,
6
+ QueryKey,
7
+ } from '@tanstack/query-core'
8
+
9
+ import type {
10
+ DefinedInitialDataOptions,
11
+ UndefinedInitialDataOptions,
12
+ } from './queryOptions'
13
+ import type {
14
+ DefinedUseQueryResult,
15
+ UseQueryOptions,
16
+ UseQueryResult,
17
+ } from './types'
18
+ import { useBaseQuery } from './useBaseQuery'
19
+
20
+ export function useQuery<
21
+ TQueryFnData = unknown,
22
+ TError = DefaultError,
23
+ TData = TQueryFnData,
24
+ TQueryKey extends QueryKey = QueryKey,
25
+ >(
26
+ options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,
27
+ queryClient?: QueryClient,
28
+ ): DefinedUseQueryResult<NoInfer<TData>, TError>
29
+
30
+ export function useQuery<
31
+ TQueryFnData = unknown,
32
+ TError = DefaultError,
33
+ TData = TQueryFnData,
34
+ TQueryKey extends QueryKey = QueryKey,
35
+ >(
36
+ options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,
37
+ queryClient?: QueryClient,
38
+ ): UseQueryResult<NoInfer<TData>, TError>
39
+
40
+ export function useQuery<
41
+ TQueryFnData = unknown,
42
+ TError = DefaultError,
43
+ TData = TQueryFnData,
44
+ TQueryKey extends QueryKey = QueryKey,
45
+ >(
46
+ options: UseQueryOptions<TQueryFnData, TError, TData, TQueryKey>,
47
+ queryClient?: QueryClient,
48
+ ): UseQueryResult<NoInfer<TData>, TError>
49
+
50
+ export function useQuery(options: UseQueryOptions, queryClient?: QueryClient) {
51
+ return useBaseQuery(options, QueryObserver, queryClient)
52
+ }
@@ -0,0 +1,50 @@
1
+ import { InfiniteQueryObserver, skipToken } from '@tanstack/query-core'
2
+ import type {
3
+ DefaultError,
4
+ InfiniteData,
5
+ InfiniteQueryObserverSuccessResult,
6
+ QueryClient,
7
+ QueryKey,
8
+ QueryObserver,
9
+ } from '@tanstack/query-core'
10
+
11
+ import { defaultThrowOnError } from './suspense'
12
+ import type {
13
+ UseSuspenseInfiniteQueryOptions,
14
+ UseSuspenseInfiniteQueryResult,
15
+ } from './types'
16
+ import { useBaseQuery } from './useBaseQuery'
17
+
18
+ export function useSuspenseInfiniteQuery<
19
+ TQueryFnData,
20
+ TError = DefaultError,
21
+ TData = InfiniteData<TQueryFnData>,
22
+ TQueryKey extends QueryKey = QueryKey,
23
+ TPageParam = unknown,
24
+ >(
25
+ options: UseSuspenseInfiniteQueryOptions<
26
+ TQueryFnData,
27
+ TError,
28
+ TData,
29
+ TQueryKey,
30
+ TPageParam
31
+ >,
32
+ queryClient?: QueryClient,
33
+ ): UseSuspenseInfiniteQueryResult<TData, TError> {
34
+ if (process.env.NODE_ENV !== 'production') {
35
+ if ((options.queryFn as any) === skipToken) {
36
+ console.error('skipToken is not allowed for useSuspenseInfiniteQuery')
37
+ }
38
+ }
39
+
40
+ return useBaseQuery(
41
+ {
42
+ ...options,
43
+ enabled: true,
44
+ suspense: true,
45
+ throwOnError: defaultThrowOnError,
46
+ },
47
+ InfiniteQueryObserver as typeof QueryObserver,
48
+ queryClient,
49
+ ) as InfiniteQueryObserverSuccessResult<TData, TError>
50
+ }