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