@tanstack/react-query 5.0.0-alpha.61 → 5.0.0-alpha.63

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 (62) hide show
  1. package/build/lib/HydrationBoundary.legacy.cjs +50 -0
  2. package/build/lib/HydrationBoundary.legacy.cjs.map +1 -0
  3. package/build/lib/HydrationBoundary.legacy.js +29 -0
  4. package/build/lib/HydrationBoundary.legacy.js.map +1 -0
  5. package/build/lib/QueryClientProvider.legacy.cjs +54 -0
  6. package/build/lib/QueryClientProvider.legacy.cjs.map +1 -0
  7. package/build/lib/QueryClientProvider.legacy.js +31 -0
  8. package/build/lib/QueryClientProvider.legacy.js.map +1 -0
  9. package/build/lib/QueryErrorResetBoundary.legacy.cjs +60 -0
  10. package/build/lib/QueryErrorResetBoundary.legacy.cjs.map +1 -0
  11. package/build/lib/QueryErrorResetBoundary.legacy.js +38 -0
  12. package/build/lib/QueryErrorResetBoundary.legacy.js.map +1 -0
  13. package/build/lib/errorBoundaryUtils.legacy.cjs +51 -0
  14. package/build/lib/errorBoundaryUtils.legacy.cjs.map +1 -0
  15. package/build/lib/errorBoundaryUtils.legacy.js +28 -0
  16. package/build/lib/errorBoundaryUtils.legacy.js.map +1 -0
  17. package/build/lib/index.legacy.cjs +39 -0
  18. package/build/lib/index.legacy.cjs.map +1 -0
  19. package/build/lib/index.legacy.js +12 -0
  20. package/build/lib/index.legacy.js.map +1 -0
  21. package/build/lib/isRestoring.legacy.cjs +31 -0
  22. package/build/lib/isRestoring.legacy.cjs.map +1 -0
  23. package/build/lib/isRestoring.legacy.js +9 -0
  24. package/build/lib/isRestoring.legacy.js.map +1 -0
  25. package/build/lib/suspense.legacy.cjs +22 -0
  26. package/build/lib/suspense.legacy.cjs.map +1 -0
  27. package/build/lib/suspense.legacy.js +17 -0
  28. package/build/lib/suspense.legacy.js.map +1 -0
  29. package/build/lib/useBaseQuery.legacy.cjs +80 -0
  30. package/build/lib/useBaseQuery.legacy.cjs.map +1 -0
  31. package/build/lib/useBaseQuery.legacy.js +59 -0
  32. package/build/lib/useBaseQuery.legacy.js.map +1 -0
  33. package/build/lib/useInfiniteQuery.legacy.cjs +15 -0
  34. package/build/lib/useInfiniteQuery.legacy.cjs.map +1 -0
  35. package/build/lib/useInfiniteQuery.legacy.js +13 -0
  36. package/build/lib/useInfiniteQuery.legacy.js.map +1 -0
  37. package/build/lib/useIsFetching.legacy.cjs +34 -0
  38. package/build/lib/useIsFetching.legacy.cjs.map +1 -0
  39. package/build/lib/useIsFetching.legacy.js +13 -0
  40. package/build/lib/useIsFetching.legacy.js.map +1 -0
  41. package/build/lib/useMutation.legacy.cjs +54 -0
  42. package/build/lib/useMutation.legacy.cjs.map +1 -0
  43. package/build/lib/useMutation.legacy.js +33 -0
  44. package/build/lib/useMutation.legacy.js.map +1 -0
  45. package/build/lib/useMutationState.legacy.cjs +60 -0
  46. package/build/lib/useMutationState.legacy.cjs.map +1 -0
  47. package/build/lib/useMutationState.legacy.js +38 -0
  48. package/build/lib/useMutationState.legacy.js.map +1 -0
  49. package/build/lib/useQueries.legacy.cjs +102 -0
  50. package/build/lib/useQueries.legacy.cjs.map +1 -0
  51. package/build/lib/useQueries.legacy.js +81 -0
  52. package/build/lib/useQueries.legacy.js.map +1 -0
  53. package/build/lib/useQuery.legacy.cjs +19 -0
  54. package/build/lib/useQuery.legacy.cjs.map +1 -0
  55. package/build/lib/useQuery.legacy.js +16 -0
  56. package/build/lib/useQuery.legacy.js.map +1 -0
  57. package/build/lib/utils.legacy.cjs +12 -0
  58. package/build/lib/utils.legacy.cjs.map +1 -0
  59. package/build/lib/utils.legacy.js +10 -0
  60. package/build/lib/utils.legacy.js.map +1 -0
  61. package/package.json +3 -3
  62. package/src/__tests__/useQueries.test.tsx +3 -3
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useBaseQuery.legacy.cjs","sources":["../../src/useBaseQuery.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type { QueryClient, QueryKey, QueryObserver } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\nimport { useQueryErrorResetBoundary } from './QueryErrorResetBoundary'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { UseBaseQueryOptions } from './types'\nimport { useIsRestoring } from './isRestoring'\nimport {\n ensurePreventErrorBoundaryRetry,\n getHasError,\n useClearResetErrorBoundary,\n} from './errorBoundaryUtils'\nimport { ensureStaleTime, shouldSuspend, fetchOptimistic } from './suspense'\n\nexport function useBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: UseBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >,\n Observer: typeof QueryObserver,\n queryClient?: QueryClient,\n) {\n const client = useQueryClient(queryClient)\n const isRestoring = useIsRestoring()\n const errorResetBoundary = useQueryErrorResetBoundary()\n const defaultedOptions = client.defaultQueryOptions(options)\n\n // Make sure results are optimistically set in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = isRestoring\n ? 'isRestoring'\n : 'optimistic'\n\n ensureStaleTime(defaultedOptions)\n ensurePreventErrorBoundaryRetry(defaultedOptions, errorResetBoundary)\n\n useClearResetErrorBoundary(errorResetBoundary)\n\n const [observer] = React.useState(\n () =>\n new Observer<TQueryFnData, TError, TData, TQueryData, TQueryKey>(\n client,\n defaultedOptions,\n ),\n )\n\n const result = observer.getOptimisticResult(defaultedOptions)\n\n React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) => {\n const unsubscribe = isRestoring\n ? () => undefined\n : observer.subscribe(notifyManager.batchCalls(onStoreChange))\n\n // Update result to make sure we did not miss any query updates\n // between creating the observer and subscribing to it.\n observer.updateResult()\n\n return unsubscribe\n },\n [observer, isRestoring],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n React.useEffect(() => {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n observer.setOptions(defaultedOptions, { listeners: false })\n }, [defaultedOptions, observer])\n\n // Handle suspense\n if (shouldSuspend(defaultedOptions, result, isRestoring)) {\n throw fetchOptimistic(defaultedOptions, observer, errorResetBoundary)\n }\n\n // Handle error boundary\n if (\n getHasError({\n result,\n errorResetBoundary,\n throwOnError: defaultedOptions.throwOnError,\n query: observer.getCurrentQuery(),\n })\n ) {\n throw result.error\n }\n\n // Handle result property usage tracking\n return !defaultedOptions.notifyOnChangeProps\n ? observer.trackResult(result)\n : result\n}\n"],"names":["defaultedOptions","ensurePreventErrorBoundaryRetry","observer","listeners","query"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgBO;AAiBL;AACA;AACA;AACA;;AAEA;AACAA;;AAKAC;;AAIA;AAQA;;AAKM;;AAIA;AACA;;AAGA;;;AASJ;AACA;AACAC;AAAwCC;AAAiB;AAC3D;;AAEA;;AAEE;AACF;;AAEA;AACA;;;;AAKIC;AACF;;AAGF;;AAEA;AACA;AAGF;;"}
@@ -0,0 +1,59 @@
1
+ 'use client';
2
+ import * as React from 'react';
3
+ import { notifyManager } from '@tanstack/query-core';
4
+ import { useQueryErrorResetBoundary } from './QueryErrorResetBoundary.legacy.js';
5
+ import { useQueryClient } from './QueryClientProvider.legacy.js';
6
+ import { useIsRestoring } from './isRestoring.legacy.js';
7
+ import { ensurePreventErrorBoundaryRetry, useClearResetErrorBoundary, getHasError } from './errorBoundaryUtils.legacy.js';
8
+ import { ensureStaleTime, shouldSuspend, fetchOptimistic } from './suspense.legacy.js';
9
+
10
+ function useBaseQuery(options, Observer, queryClient) {
11
+ const client = useQueryClient(queryClient);
12
+ const isRestoring = useIsRestoring();
13
+ const errorResetBoundary = useQueryErrorResetBoundary();
14
+ const defaultedOptions = client.defaultQueryOptions(options);
15
+
16
+ // Make sure results are optimistically set in fetching state before subscribing or updating options
17
+ defaultedOptions._optimisticResults = isRestoring ? 'isRestoring' : 'optimistic';
18
+ ensureStaleTime(defaultedOptions);
19
+ ensurePreventErrorBoundaryRetry(defaultedOptions, errorResetBoundary);
20
+ useClearResetErrorBoundary(errorResetBoundary);
21
+ const [observer] = React.useState(() => new Observer(client, defaultedOptions));
22
+ const result = observer.getOptimisticResult(defaultedOptions);
23
+ React.useSyncExternalStore(React.useCallback(onStoreChange => {
24
+ const unsubscribe = isRestoring ? () => undefined : observer.subscribe(notifyManager.batchCalls(onStoreChange));
25
+
26
+ // Update result to make sure we did not miss any query updates
27
+ // between creating the observer and subscribing to it.
28
+ observer.updateResult();
29
+ return unsubscribe;
30
+ }, [observer, isRestoring]), () => observer.getCurrentResult(), () => observer.getCurrentResult());
31
+ React.useEffect(() => {
32
+ // Do not notify on updates because of changes in the options because
33
+ // these changes should already be reflected in the optimistic result.
34
+ observer.setOptions(defaultedOptions, {
35
+ listeners: false
36
+ });
37
+ }, [defaultedOptions, observer]);
38
+
39
+ // Handle suspense
40
+ if (shouldSuspend(defaultedOptions, result, isRestoring)) {
41
+ throw fetchOptimistic(defaultedOptions, observer, errorResetBoundary);
42
+ }
43
+
44
+ // Handle error boundary
45
+ if (getHasError({
46
+ result,
47
+ errorResetBoundary,
48
+ throwOnError: defaultedOptions.throwOnError,
49
+ query: observer.getCurrentQuery()
50
+ })) {
51
+ throw result.error;
52
+ }
53
+
54
+ // Handle result property usage tracking
55
+ return !defaultedOptions.notifyOnChangeProps ? observer.trackResult(result) : result;
56
+ }
57
+
58
+ export { useBaseQuery };
59
+ //# sourceMappingURL=useBaseQuery.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useBaseQuery.legacy.js","sources":["../../src/useBaseQuery.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type { QueryClient, QueryKey, QueryObserver } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\nimport { useQueryErrorResetBoundary } from './QueryErrorResetBoundary'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { UseBaseQueryOptions } from './types'\nimport { useIsRestoring } from './isRestoring'\nimport {\n ensurePreventErrorBoundaryRetry,\n getHasError,\n useClearResetErrorBoundary,\n} from './errorBoundaryUtils'\nimport { ensureStaleTime, shouldSuspend, fetchOptimistic } from './suspense'\n\nexport function useBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: UseBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >,\n Observer: typeof QueryObserver,\n queryClient?: QueryClient,\n) {\n const client = useQueryClient(queryClient)\n const isRestoring = useIsRestoring()\n const errorResetBoundary = useQueryErrorResetBoundary()\n const defaultedOptions = client.defaultQueryOptions(options)\n\n // Make sure results are optimistically set in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = isRestoring\n ? 'isRestoring'\n : 'optimistic'\n\n ensureStaleTime(defaultedOptions)\n ensurePreventErrorBoundaryRetry(defaultedOptions, errorResetBoundary)\n\n useClearResetErrorBoundary(errorResetBoundary)\n\n const [observer] = React.useState(\n () =>\n new Observer<TQueryFnData, TError, TData, TQueryData, TQueryKey>(\n client,\n defaultedOptions,\n ),\n )\n\n const result = observer.getOptimisticResult(defaultedOptions)\n\n React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) => {\n const unsubscribe = isRestoring\n ? () => undefined\n : observer.subscribe(notifyManager.batchCalls(onStoreChange))\n\n // Update result to make sure we did not miss any query updates\n // between creating the observer and subscribing to it.\n observer.updateResult()\n\n return unsubscribe\n },\n [observer, isRestoring],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n React.useEffect(() => {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n observer.setOptions(defaultedOptions, { listeners: false })\n }, [defaultedOptions, observer])\n\n // Handle suspense\n if (shouldSuspend(defaultedOptions, result, isRestoring)) {\n throw fetchOptimistic(defaultedOptions, observer, errorResetBoundary)\n }\n\n // Handle error boundary\n if (\n getHasError({\n result,\n errorResetBoundary,\n throwOnError: defaultedOptions.throwOnError,\n query: observer.getCurrentQuery(),\n })\n ) {\n throw result.error\n }\n\n // Handle result property usage tracking\n return !defaultedOptions.notifyOnChangeProps\n ? observer.trackResult(result)\n : result\n}\n"],"names":["defaultedOptions","ensurePreventErrorBoundaryRetry","observer","listeners","query"],"mappings":";;;;;;;;;AAgBO;AAiBL;AACA;AACA;AACA;;AAEA;AACAA;;AAKAC;;AAIA;AAQA;;AAKM;;AAIA;AACA;;AAGA;;;AASJ;AACA;AACAC;AAAwCC;AAAiB;AAC3D;;AAEA;;AAEE;AACF;;AAEA;AACA;;;;AAKIC;AACF;;AAGF;;AAEA;AACA;AAGF;;"}
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var queryCore = require('@tanstack/query-core');
5
+ var useBaseQuery = require('./useBaseQuery.legacy.cjs');
6
+
7
+ // HOOK
8
+ function useInfiniteQuery(options, queryClient) {
9
+ return useBaseQuery.useBaseQuery(options,
10
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
11
+ queryCore.InfiniteQueryObserver, queryClient);
12
+ }
13
+
14
+ exports.useInfiniteQuery = useInfiniteQuery;
15
+ //# sourceMappingURL=useInfiniteQuery.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useInfiniteQuery.legacy.cjs","sources":["../../src/useInfiniteQuery.ts"],"sourcesContent":["'use client'\nimport type {\n QueryObserver,\n QueryKey,\n QueryClient,\n DefaultError,\n InfiniteData,\n} from '@tanstack/query-core'\nimport { InfiniteQueryObserver } from '@tanstack/query-core'\nimport type { UseInfiniteQueryOptions, UseInfiniteQueryResult } from './types'\nimport { useBaseQuery } from './useBaseQuery'\n\n// HOOK\nexport function useInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: UseInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n >,\n queryClient?: QueryClient,\n): UseInfiniteQueryResult<TData, TError> {\n return useBaseQuery(\n options,\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n ) as UseInfiniteQueryResult<TData, TError>\n}\n"],"names":[],"mappings":";;;;;;AAYA;AACO;;AAmBH;;AAIJ;;"}
@@ -0,0 +1,13 @@
1
+ 'use client';
2
+ import { InfiniteQueryObserver } from '@tanstack/query-core';
3
+ import { useBaseQuery } from './useBaseQuery.legacy.js';
4
+
5
+ // HOOK
6
+ function useInfiniteQuery(options, queryClient) {
7
+ return useBaseQuery(options,
8
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
9
+ InfiniteQueryObserver, queryClient);
10
+ }
11
+
12
+ export { useInfiniteQuery };
13
+ //# sourceMappingURL=useInfiniteQuery.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useInfiniteQuery.legacy.js","sources":["../../src/useInfiniteQuery.ts"],"sourcesContent":["'use client'\nimport type {\n QueryObserver,\n QueryKey,\n QueryClient,\n DefaultError,\n InfiniteData,\n} from '@tanstack/query-core'\nimport { InfiniteQueryObserver } from '@tanstack/query-core'\nimport type { UseInfiniteQueryOptions, UseInfiniteQueryResult } from './types'\nimport { useBaseQuery } from './useBaseQuery'\n\n// HOOK\nexport function useInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: UseInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n >,\n queryClient?: QueryClient,\n): UseInfiniteQueryResult<TData, TError> {\n return useBaseQuery(\n options,\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n ) as UseInfiniteQueryResult<TData, TError>\n}\n"],"names":[],"mappings":";;;;AAYA;AACO;;AAmBH;;AAIJ;;"}
@@ -0,0 +1,34 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var queryCore = require('@tanstack/query-core');
6
+ var QueryClientProvider = require('./QueryClientProvider.legacy.cjs');
7
+
8
+ function _interopNamespaceDefault(e) {
9
+ var n = Object.create(null);
10
+ if (e) {
11
+ Object.keys(e).forEach(function (k) {
12
+ if (k !== 'default') {
13
+ var d = Object.getOwnPropertyDescriptor(e, k);
14
+ Object.defineProperty(n, k, d.get ? d : {
15
+ enumerable: true,
16
+ get: function () { return e[k]; }
17
+ });
18
+ }
19
+ });
20
+ }
21
+ n.default = e;
22
+ return Object.freeze(n);
23
+ }
24
+
25
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
26
+
27
+ function useIsFetching(filters, queryClient) {
28
+ const client = QueryClientProvider.useQueryClient(queryClient);
29
+ const queryCache = client.getQueryCache();
30
+ return React__namespace.useSyncExternalStore(React__namespace.useCallback(onStoreChange => queryCache.subscribe(queryCore.notifyManager.batchCalls(onStoreChange)), [queryCache]), () => client.isFetching(filters), () => client.isFetching(filters));
31
+ }
32
+
33
+ exports.useIsFetching = useIsFetching;
34
+ //# sourceMappingURL=useIsFetching.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIsFetching.legacy.cjs","sources":["../../src/useIsFetching.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\nimport type { QueryClient, QueryFilters } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\n\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsFetching(\n filters?: QueryFilters,\n queryClient?: QueryClient,\n): number {\n const client = useQueryClient(queryClient)\n const queryCache = client.getQueryCache()\n\n return React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n queryCache.subscribe(notifyManager.batchCalls(onStoreChange)),\n [queryCache],\n ),\n () => client.isFetching(filters),\n () => client.isFetching(filters),\n )\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAOO;AAIL;AACA;AAEA;AASF;;"}
@@ -0,0 +1,13 @@
1
+ 'use client';
2
+ import * as React from 'react';
3
+ import { notifyManager } from '@tanstack/query-core';
4
+ import { useQueryClient } from './QueryClientProvider.legacy.js';
5
+
6
+ function useIsFetching(filters, queryClient) {
7
+ const client = useQueryClient(queryClient);
8
+ const queryCache = client.getQueryCache();
9
+ return React.useSyncExternalStore(React.useCallback(onStoreChange => queryCache.subscribe(notifyManager.batchCalls(onStoreChange)), [queryCache]), () => client.isFetching(filters), () => client.isFetching(filters));
10
+ }
11
+
12
+ export { useIsFetching };
13
+ //# sourceMappingURL=useIsFetching.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIsFetching.legacy.js","sources":["../../src/useIsFetching.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\nimport type { QueryClient, QueryFilters } from '@tanstack/query-core'\nimport { notifyManager } from '@tanstack/query-core'\n\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsFetching(\n filters?: QueryFilters,\n queryClient?: QueryClient,\n): number {\n const client = useQueryClient(queryClient)\n const queryCache = client.getQueryCache()\n\n return React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n queryCache.subscribe(notifyManager.batchCalls(onStoreChange)),\n [queryCache],\n ),\n () => client.isFetching(filters),\n () => client.isFetching(filters),\n )\n}\n"],"names":[],"mappings":";;;;;AAOO;AAIL;AACA;AAEA;AASF;;"}
@@ -0,0 +1,54 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var queryCore = require('@tanstack/query-core');
6
+ var QueryClientProvider = require('./QueryClientProvider.legacy.cjs');
7
+ var utils = require('./utils.legacy.cjs');
8
+
9
+ function _interopNamespaceDefault(e) {
10
+ var n = Object.create(null);
11
+ if (e) {
12
+ Object.keys(e).forEach(function (k) {
13
+ if (k !== 'default') {
14
+ var d = Object.getOwnPropertyDescriptor(e, k);
15
+ Object.defineProperty(n, k, d.get ? d : {
16
+ enumerable: true,
17
+ get: function () { return e[k]; }
18
+ });
19
+ }
20
+ });
21
+ }
22
+ n.default = e;
23
+ return Object.freeze(n);
24
+ }
25
+
26
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
27
+
28
+ // HOOK
29
+
30
+ function useMutation(options, queryClient) {
31
+ const client = QueryClientProvider.useQueryClient(queryClient);
32
+ const [observer] = React__namespace.useState(() => new queryCore.MutationObserver(client, options));
33
+ React__namespace.useEffect(() => {
34
+ observer.setOptions(options);
35
+ }, [observer, options]);
36
+ const result = React__namespace.useSyncExternalStore(React__namespace.useCallback(onStoreChange => observer.subscribe(queryCore.notifyManager.batchCalls(onStoreChange)), [observer]), () => observer.getCurrentResult(), () => observer.getCurrentResult());
37
+ const mutate = React__namespace.useCallback((variables, mutateOptions) => {
38
+ observer.mutate(variables, mutateOptions).catch(noop);
39
+ }, [observer]);
40
+ if (result.error && utils.shouldThrowError(observer.options.throwOnError, [result.error])) {
41
+ throw result.error;
42
+ }
43
+ return {
44
+ ...result,
45
+ mutate,
46
+ mutateAsync: result.mutate
47
+ };
48
+ }
49
+
50
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
51
+ function noop() {}
52
+
53
+ exports.useMutation = useMutation;
54
+ //# sourceMappingURL=useMutation.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMutation.legacy.cjs","sources":["../../src/useMutation.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\nimport type { QueryClient, DefaultError } from '@tanstack/query-core'\nimport { notifyManager, MutationObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type {\n UseMutateFunction,\n UseMutationOptions,\n UseMutationResult,\n} from './types'\nimport { shouldThrowError } from './utils'\n\n// HOOK\n\nexport function useMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: UseMutationOptions<TData, TError, TVariables, TContext>,\n queryClient?: QueryClient,\n): UseMutationResult<TData, TError, TVariables, TContext> {\n const client = useQueryClient(queryClient)\n\n const [observer] = React.useState(\n () =>\n new MutationObserver<TData, TError, TVariables, TContext>(\n client,\n options,\n ),\n )\n\n React.useEffect(() => {\n observer.setOptions(options)\n }, [observer, options])\n\n const result = React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n observer.subscribe(notifyManager.batchCalls(onStoreChange)),\n [observer],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n const mutate = React.useCallback<\n UseMutateFunction<TData, TError, TVariables, TContext>\n >(\n (variables, mutateOptions) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n },\n [observer],\n )\n\n if (\n result.error &&\n shouldThrowError(observer.options.throwOnError, [result.error])\n ) {\n throw result.error\n }\n\n return { ...result, mutate, mutateAsync: result.mutate }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["observer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA;;AAEO;AASL;AAEA;;AASEA;AACF;AAEA;;;AAeE;AAIF;;AAKA;;AAES;;;;AACX;;AAEA;AACA;;"}
@@ -0,0 +1,33 @@
1
+ 'use client';
2
+ import * as React from 'react';
3
+ import { MutationObserver, notifyManager } from '@tanstack/query-core';
4
+ import { useQueryClient } from './QueryClientProvider.legacy.js';
5
+ import { shouldThrowError } from './utils.legacy.js';
6
+
7
+ // HOOK
8
+
9
+ function useMutation(options, queryClient) {
10
+ const client = useQueryClient(queryClient);
11
+ const [observer] = React.useState(() => new MutationObserver(client, options));
12
+ React.useEffect(() => {
13
+ observer.setOptions(options);
14
+ }, [observer, options]);
15
+ const result = React.useSyncExternalStore(React.useCallback(onStoreChange => observer.subscribe(notifyManager.batchCalls(onStoreChange)), [observer]), () => observer.getCurrentResult(), () => observer.getCurrentResult());
16
+ const mutate = React.useCallback((variables, mutateOptions) => {
17
+ observer.mutate(variables, mutateOptions).catch(noop);
18
+ }, [observer]);
19
+ if (result.error && shouldThrowError(observer.options.throwOnError, [result.error])) {
20
+ throw result.error;
21
+ }
22
+ return {
23
+ ...result,
24
+ mutate,
25
+ mutateAsync: result.mutate
26
+ };
27
+ }
28
+
29
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
30
+ function noop() {}
31
+
32
+ export { useMutation };
33
+ //# sourceMappingURL=useMutation.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMutation.legacy.js","sources":["../../src/useMutation.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\nimport type { QueryClient, DefaultError } from '@tanstack/query-core'\nimport { notifyManager, MutationObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type {\n UseMutateFunction,\n UseMutationOptions,\n UseMutationResult,\n} from './types'\nimport { shouldThrowError } from './utils'\n\n// HOOK\n\nexport function useMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: UseMutationOptions<TData, TError, TVariables, TContext>,\n queryClient?: QueryClient,\n): UseMutationResult<TData, TError, TVariables, TContext> {\n const client = useQueryClient(queryClient)\n\n const [observer] = React.useState(\n () =>\n new MutationObserver<TData, TError, TVariables, TContext>(\n client,\n options,\n ),\n )\n\n React.useEffect(() => {\n observer.setOptions(options)\n }, [observer, options])\n\n const result = React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n observer.subscribe(notifyManager.batchCalls(onStoreChange)),\n [observer],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n const mutate = React.useCallback<\n UseMutateFunction<TData, TError, TVariables, TContext>\n >(\n (variables, mutateOptions) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n },\n [observer],\n )\n\n if (\n result.error &&\n shouldThrowError(observer.options.throwOnError, [result.error])\n ) {\n throw result.error\n }\n\n return { ...result, mutate, mutateAsync: result.mutate }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["observer"],"mappings":";;;;;;AAYA;;AAEO;AASL;AAEA;;AASEA;AACF;AAEA;;;AAeE;AAIF;;AAKA;;AAES;;;;AACX;;AAEA;AACA;;"}
@@ -0,0 +1,60 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var queryCore = require('@tanstack/query-core');
6
+ var QueryClientProvider = require('./QueryClientProvider.legacy.cjs');
7
+
8
+ function _interopNamespaceDefault(e) {
9
+ var n = Object.create(null);
10
+ if (e) {
11
+ Object.keys(e).forEach(function (k) {
12
+ if (k !== 'default') {
13
+ var d = Object.getOwnPropertyDescriptor(e, k);
14
+ Object.defineProperty(n, k, d.get ? d : {
15
+ enumerable: true,
16
+ get: function () { return e[k]; }
17
+ });
18
+ }
19
+ });
20
+ }
21
+ n.default = e;
22
+ return Object.freeze(n);
23
+ }
24
+
25
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
26
+
27
+ function useIsMutating(filters, queryClient) {
28
+ const client = QueryClientProvider.useQueryClient(queryClient);
29
+ return useMutationState({
30
+ filters: {
31
+ ...filters,
32
+ status: 'pending'
33
+ }
34
+ }, client).length;
35
+ }
36
+ function getResult(mutationCache, options) {
37
+ return mutationCache.findAll(options.filters).map(mutation => options.select ? options.select(mutation) : mutation.state);
38
+ }
39
+ function useMutationState(options = {}, queryClient) {
40
+ const mutationCache = QueryClientProvider.useQueryClient(queryClient).getMutationCache();
41
+ const optionsRef = React__namespace.useRef(options);
42
+ const result = React__namespace.useRef();
43
+ if (!result.current) {
44
+ result.current = getResult(mutationCache, options);
45
+ }
46
+ React__namespace.useEffect(() => {
47
+ optionsRef.current = options;
48
+ });
49
+ return React__namespace.useSyncExternalStore(React__namespace.useCallback(onStoreChange => mutationCache.subscribe(() => {
50
+ const nextResult = queryCore.replaceEqualDeep(result.current, getResult(mutationCache, optionsRef.current));
51
+ if (result.current !== nextResult) {
52
+ result.current = nextResult;
53
+ queryCore.notifyManager.schedule(onStoreChange);
54
+ }
55
+ }), [mutationCache]), () => result.current, () => result.current);
56
+ }
57
+
58
+ exports.useIsMutating = useIsMutating;
59
+ exports.useMutationState = useMutationState;
60
+ //# sourceMappingURL=useMutationState.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMutationState.legacy.cjs","sources":["../../src/useMutationState.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type {\n MutationFilters,\n QueryClient,\n Mutation,\n MutationCache,\n DefaultError,\n MutationState,\n} from '@tanstack/query-core'\nimport { notifyManager, replaceEqualDeep } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsMutating(\n filters?: MutationFilters,\n queryClient?: QueryClient,\n): number {\n const client = useQueryClient(queryClient)\n return useMutationState(\n { filters: { ...filters, status: 'pending' } },\n client,\n ).length\n}\n\ntype MutationStateOptions<TResult = MutationState> = {\n filters?: MutationFilters\n select?: (\n mutation: Mutation<unknown, DefaultError, unknown, unknown>,\n ) => TResult\n}\n\nfunction getResult<TResult = MutationState>(\n mutationCache: MutationCache,\n options: MutationStateOptions<TResult>,\n): Array<TResult> {\n return mutationCache\n .findAll(options.filters)\n .map(\n (mutation): TResult =>\n (options.select\n ? options.select(\n mutation as Mutation<unknown, DefaultError, unknown, unknown>,\n )\n : mutation.state) as TResult,\n )\n}\n\nexport function useMutationState<TResult = MutationState>(\n options: MutationStateOptions<TResult> = {},\n queryClient?: QueryClient,\n): Array<TResult> {\n const mutationCache = useQueryClient(queryClient).getMutationCache()\n const optionsRef = React.useRef(options)\n const result = React.useRef<Array<TResult>>()\n if (!result.current) {\n result.current = getResult(mutationCache, options)\n }\n\n React.useEffect(() => {\n optionsRef.current = options\n })\n\n return React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n mutationCache.subscribe(() => {\n const nextResult = replaceEqualDeep(\n result.current,\n getResult(mutationCache, optionsRef.current),\n )\n if (result.current !== nextResult) {\n result.current = nextResult\n notifyManager.schedule(onStoreChange)\n }\n }),\n [mutationCache],\n ),\n () => result.current,\n () => result.current,\n )!\n}\n"],"names":["filters","status","notifyManager"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAcO;AAIL;AACA;AACIA;AAAW;AAAYC;AAAkB;AAAE;AAGjD;AASA;;AAcA;AAEO;;AAKL;AACA;AACA;;AAEA;;;AAIA;AAEA;AAIQ;AAIA;;AAEEC;AACF;AACF;AAMR;;;"}
@@ -0,0 +1,38 @@
1
+ 'use client';
2
+ import * as React from 'react';
3
+ import { replaceEqualDeep, notifyManager } from '@tanstack/query-core';
4
+ import { useQueryClient } from './QueryClientProvider.legacy.js';
5
+
6
+ function useIsMutating(filters, queryClient) {
7
+ const client = useQueryClient(queryClient);
8
+ return useMutationState({
9
+ filters: {
10
+ ...filters,
11
+ status: 'pending'
12
+ }
13
+ }, client).length;
14
+ }
15
+ function getResult(mutationCache, options) {
16
+ return mutationCache.findAll(options.filters).map(mutation => options.select ? options.select(mutation) : mutation.state);
17
+ }
18
+ function useMutationState(options = {}, queryClient) {
19
+ const mutationCache = useQueryClient(queryClient).getMutationCache();
20
+ const optionsRef = React.useRef(options);
21
+ const result = React.useRef();
22
+ if (!result.current) {
23
+ result.current = getResult(mutationCache, options);
24
+ }
25
+ React.useEffect(() => {
26
+ optionsRef.current = options;
27
+ });
28
+ return React.useSyncExternalStore(React.useCallback(onStoreChange => mutationCache.subscribe(() => {
29
+ const nextResult = replaceEqualDeep(result.current, getResult(mutationCache, optionsRef.current));
30
+ if (result.current !== nextResult) {
31
+ result.current = nextResult;
32
+ notifyManager.schedule(onStoreChange);
33
+ }
34
+ }), [mutationCache]), () => result.current, () => result.current);
35
+ }
36
+
37
+ export { useIsMutating, useMutationState };
38
+ //# sourceMappingURL=useMutationState.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMutationState.legacy.js","sources":["../../src/useMutationState.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type {\n MutationFilters,\n QueryClient,\n Mutation,\n MutationCache,\n DefaultError,\n MutationState,\n} from '@tanstack/query-core'\nimport { notifyManager, replaceEqualDeep } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\n\nexport function useIsMutating(\n filters?: MutationFilters,\n queryClient?: QueryClient,\n): number {\n const client = useQueryClient(queryClient)\n return useMutationState(\n { filters: { ...filters, status: 'pending' } },\n client,\n ).length\n}\n\ntype MutationStateOptions<TResult = MutationState> = {\n filters?: MutationFilters\n select?: (\n mutation: Mutation<unknown, DefaultError, unknown, unknown>,\n ) => TResult\n}\n\nfunction getResult<TResult = MutationState>(\n mutationCache: MutationCache,\n options: MutationStateOptions<TResult>,\n): Array<TResult> {\n return mutationCache\n .findAll(options.filters)\n .map(\n (mutation): TResult =>\n (options.select\n ? options.select(\n mutation as Mutation<unknown, DefaultError, unknown, unknown>,\n )\n : mutation.state) as TResult,\n )\n}\n\nexport function useMutationState<TResult = MutationState>(\n options: MutationStateOptions<TResult> = {},\n queryClient?: QueryClient,\n): Array<TResult> {\n const mutationCache = useQueryClient(queryClient).getMutationCache()\n const optionsRef = React.useRef(options)\n const result = React.useRef<Array<TResult>>()\n if (!result.current) {\n result.current = getResult(mutationCache, options)\n }\n\n React.useEffect(() => {\n optionsRef.current = options\n })\n\n return React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n mutationCache.subscribe(() => {\n const nextResult = replaceEqualDeep(\n result.current,\n getResult(mutationCache, optionsRef.current),\n )\n if (result.current !== nextResult) {\n result.current = nextResult\n notifyManager.schedule(onStoreChange)\n }\n }),\n [mutationCache],\n ),\n () => result.current,\n () => result.current,\n )!\n}\n"],"names":["filters","status","notifyManager"],"mappings":";;;;;AAcO;AAIL;AACA;AACIA;AAAW;AAAYC;AAAkB;AAAE;AAGjD;AASA;;AAcA;AAEO;;AAKL;AACA;AACA;;AAEA;;;AAIA;AAEA;AAIQ;AAIA;;AAEEC;AACF;AACF;AAMR;;"}
@@ -0,0 +1,102 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var queryCore = require('@tanstack/query-core');
6
+ var QueryClientProvider = require('./QueryClientProvider.legacy.cjs');
7
+ var isRestoring = require('./isRestoring.legacy.cjs');
8
+ var QueryErrorResetBoundary = require('./QueryErrorResetBoundary.legacy.cjs');
9
+ var errorBoundaryUtils = require('./errorBoundaryUtils.legacy.cjs');
10
+ var suspense = require('./suspense.legacy.cjs');
11
+
12
+ function _interopNamespaceDefault(e) {
13
+ var n = Object.create(null);
14
+ if (e) {
15
+ Object.keys(e).forEach(function (k) {
16
+ if (k !== 'default') {
17
+ var d = Object.getOwnPropertyDescriptor(e, k);
18
+ Object.defineProperty(n, k, d.get ? d : {
19
+ enumerable: true,
20
+ get: function () { return e[k]; }
21
+ });
22
+ }
23
+ });
24
+ }
25
+ n.default = e;
26
+ return Object.freeze(n);
27
+ }
28
+
29
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
30
+
31
+ // This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.
32
+ // `placeholderData` function does not have a parameter
33
+ // Avoid TS depth-limit error in case of large array literal
34
+ /**
35
+ * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param
36
+ */
37
+ /**
38
+ * QueriesResults reducer recursively maps type param to results
39
+ */
40
+ function useQueries({
41
+ queries,
42
+ ...options
43
+ }, queryClient) {
44
+ const client = QueryClientProvider.useQueryClient(queryClient);
45
+ const isRestoring$1 = isRestoring.useIsRestoring();
46
+ const errorResetBoundary = QueryErrorResetBoundary.useQueryErrorResetBoundary();
47
+ const defaultedQueries = React__namespace.useMemo(() => queries.map(opts => {
48
+ const defaultedOptions = client.defaultQueryOptions(opts);
49
+
50
+ // Make sure the results are already in fetching state before subscribing or updating options
51
+ defaultedOptions._optimisticResults = isRestoring$1 ? 'isRestoring' : 'optimistic';
52
+ return defaultedOptions;
53
+ }), [queries, client, isRestoring$1]);
54
+ defaultedQueries.forEach(query => {
55
+ suspense.ensureStaleTime(query);
56
+ errorBoundaryUtils.ensurePreventErrorBoundaryRetry(query, errorResetBoundary);
57
+ });
58
+ errorBoundaryUtils.useClearResetErrorBoundary(errorResetBoundary);
59
+ const [observer] = React__namespace.useState(() => new queryCore.QueriesObserver(client, defaultedQueries, options));
60
+ const [optimisticResult, getCombinedResult, trackResult] = observer.getOptimisticResult(defaultedQueries);
61
+ React__namespace.useSyncExternalStore(React__namespace.useCallback(onStoreChange => isRestoring$1 ? () => undefined : observer.subscribe(queryCore.notifyManager.batchCalls(onStoreChange)), [observer, isRestoring$1]), () => observer.getCurrentResult(), () => observer.getCurrentResult());
62
+ React__namespace.useEffect(() => {
63
+ // Do not notify on updates because of changes in the options because
64
+ // these changes should already be reflected in the optimistic result.
65
+ observer.setQueries(defaultedQueries, options, {
66
+ listeners: false
67
+ });
68
+ }, [defaultedQueries, options, observer]);
69
+ const shouldAtLeastOneSuspend = optimisticResult.some((result, index) => suspense.shouldSuspend(defaultedQueries[index], result, isRestoring$1));
70
+ const suspensePromises = shouldAtLeastOneSuspend ? optimisticResult.flatMap((result, index) => {
71
+ const opts = defaultedQueries[index];
72
+ const queryObserver = observer.getObservers()[index];
73
+ if (opts && queryObserver) {
74
+ if (suspense.shouldSuspend(opts, result, isRestoring$1)) {
75
+ return suspense.fetchOptimistic(opts, queryObserver, errorResetBoundary);
76
+ } else if (suspense.willFetch(result, isRestoring$1)) {
77
+ void suspense.fetchOptimistic(opts, queryObserver, errorResetBoundary);
78
+ }
79
+ }
80
+ return [];
81
+ }) : [];
82
+ if (suspensePromises.length > 0) {
83
+ throw Promise.all(suspensePromises);
84
+ }
85
+ const observerQueries = observer.getQueries();
86
+ const firstSingleResultWhichShouldThrow = optimisticResult.find((result, index) => {
87
+ var _defaultedQueries$ind, _defaultedQueries$ind2;
88
+ return errorBoundaryUtils.getHasError({
89
+ result,
90
+ errorResetBoundary,
91
+ throwOnError: (_defaultedQueries$ind = (_defaultedQueries$ind2 = defaultedQueries[index]) == null ? void 0 : _defaultedQueries$ind2.throwOnError) != null ? _defaultedQueries$ind : false,
92
+ query: observerQueries[index]
93
+ });
94
+ });
95
+ if (firstSingleResultWhichShouldThrow != null && firstSingleResultWhichShouldThrow.error) {
96
+ throw firstSingleResultWhichShouldThrow.error;
97
+ }
98
+ return getCombinedResult(trackResult());
99
+ }
100
+
101
+ exports.useQueries = useQueries;
102
+ //# sourceMappingURL=useQueries.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useQueries.legacy.cjs","sources":["../../src/useQueries.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type {\n QueryKey,\n QueryFunction,\n QueriesPlaceholderDataFunction,\n QueryClient,\n DefaultError,\n QueriesObserverOptions,\n} from '@tanstack/query-core'\nimport { notifyManager, QueriesObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { UseQueryOptions, UseQueryResult } from './types'\nimport { useIsRestoring } from './isRestoring'\nimport { useQueryErrorResetBoundary } from './QueryErrorResetBoundary'\nimport {\n ensurePreventErrorBoundaryRetry,\n getHasError,\n useClearResetErrorBoundary,\n} from './errorBoundaryUtils'\nimport {\n ensureStaleTime,\n shouldSuspend,\n fetchOptimistic,\n willFetch,\n} from './suspense'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype UseQueryOptionsForUseQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n UseQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? UseQueryOptionsForUseQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? UseQueryOptionsForUseQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n }\n ? UseQueryOptionsForUseQueries<TQueryFnData, Error, TData, TQueryKey>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? UseQueryOptionsForUseQueries<TQueryFnData, Error, TQueryFnData, TQueryKey>\n : // Fallback\n UseQueryOptionsForUseQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? UseQueryResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? UseQueryResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? UseQueryResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? UseQueryResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? UseQueryResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? UseQueryResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n }\n ? UseQueryResult<TData>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, any> }\n ? UseQueryResult<TQueryFnData>\n : // Fallback\n UseQueryResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? UseQueryOptionsForUseQueries[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<[...Tail], [...Result, GetOptions<Head>], [...Depth, 1]>\n : unknown[] extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends UseQueryOptionsForUseQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >[]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData, TQueryKey>[]\n : // Fallback\n UseQueryOptionsForUseQueries[]\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? UseQueryResult[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<[...Tail], [...Result, GetResults<Head>], [...Depth, 1]>\n : T extends UseQueryOptionsForUseQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >[]\n ? // Dynamic-size (homogenous) UseQueryOptions array: map directly to array of results\n UseQueryResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >[]\n : // Fallback\n UseQueryResult[]\n\nexport function useQueries<\n T extends any[],\n TCombinedResult = QueriesResults<T>,\n>(\n {\n queries,\n ...options\n }: {\n queries: readonly [...QueriesOptions<T>]\n combine?: (result: QueriesResults<T>) => TCombinedResult\n },\n queryClient?: QueryClient,\n): TCombinedResult {\n const client = useQueryClient(queryClient)\n const isRestoring = useIsRestoring()\n const errorResetBoundary = useQueryErrorResetBoundary()\n\n const defaultedQueries = React.useMemo(\n () =>\n queries.map((opts) => {\n const defaultedOptions = client.defaultQueryOptions(opts)\n\n // Make sure the results are already in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = isRestoring\n ? 'isRestoring'\n : 'optimistic'\n\n return defaultedOptions\n }),\n [queries, client, isRestoring],\n )\n\n defaultedQueries.forEach((query) => {\n ensureStaleTime(query)\n ensurePreventErrorBoundaryRetry(query, errorResetBoundary)\n })\n\n useClearResetErrorBoundary(errorResetBoundary)\n\n const [observer] = React.useState(\n () =>\n new QueriesObserver<TCombinedResult>(\n client,\n defaultedQueries,\n options as QueriesObserverOptions<TCombinedResult>,\n ),\n )\n\n const [optimisticResult, getCombinedResult, trackResult] =\n observer.getOptimisticResult(defaultedQueries)\n\n React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n isRestoring\n ? () => undefined\n : observer.subscribe(notifyManager.batchCalls(onStoreChange)),\n [observer, isRestoring],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n React.useEffect(() => {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n observer.setQueries(\n defaultedQueries,\n options as QueriesObserverOptions<TCombinedResult>,\n {\n listeners: false,\n },\n )\n }, [defaultedQueries, options, observer])\n\n const shouldAtLeastOneSuspend = optimisticResult.some((result, index) =>\n shouldSuspend(defaultedQueries[index], result, isRestoring),\n )\n\n const suspensePromises = shouldAtLeastOneSuspend\n ? optimisticResult.flatMap((result, index) => {\n const opts = defaultedQueries[index]\n const queryObserver = observer.getObservers()[index]\n\n if (opts && queryObserver) {\n if (shouldSuspend(opts, result, isRestoring)) {\n return fetchOptimistic(opts, queryObserver, errorResetBoundary)\n } else if (willFetch(result, isRestoring)) {\n void fetchOptimistic(opts, queryObserver, errorResetBoundary)\n }\n }\n return []\n })\n : []\n\n if (suspensePromises.length > 0) {\n throw Promise.all(suspensePromises)\n }\n const observerQueries = observer.getQueries()\n const firstSingleResultWhichShouldThrow = optimisticResult.find(\n (result, index) =>\n getHasError({\n result,\n errorResetBoundary,\n throwOnError: defaultedQueries[index]?.throwOnError ?? false,\n query: observerQueries[index]!,\n }),\n )\n\n if (firstSingleResultWhichShouldThrow?.error) {\n throw firstSingleResultWhichShouldThrow.error\n }\n\n return getCombinedResult(trackResult())\n}\n"],"names":["defaultedOptions","defaultedQueries","ensurePreventErrorBoundaryRetry","observer","listeners","throwOnError"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BA;AACA;AAaA;AA2DA;AACA;AACA;AA2BA;AACA;AACA;AA2BO;;;AAUL;AAGA;AACA;AACA;AAEA;AAGM;;AAEA;AACAA;AAIA;;AAKNC;;AAEEC;AACF;;AAIA;AASA;;;AAgBE;AACA;AACAC;AAIIC;AACF;;;AAQJ;AAEM;;;;AAKI;;AAEA;AACF;AACF;AACA;;AAIN;AACE;AACF;AACA;;;AAEgB;;;AAIVC;;AAEF;AAAE;AAGN;;AAEA;AAEA;AACF;;"}
@@ -0,0 +1,81 @@
1
+ 'use client';
2
+ import * as React from 'react';
3
+ import { QueriesObserver, notifyManager } from '@tanstack/query-core';
4
+ import { useQueryClient } from './QueryClientProvider.legacy.js';
5
+ import { useIsRestoring } from './isRestoring.legacy.js';
6
+ import { useQueryErrorResetBoundary } from './QueryErrorResetBoundary.legacy.js';
7
+ import { ensurePreventErrorBoundaryRetry, useClearResetErrorBoundary, getHasError } from './errorBoundaryUtils.legacy.js';
8
+ import { ensureStaleTime, shouldSuspend, fetchOptimistic, willFetch } from './suspense.legacy.js';
9
+
10
+ // This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.
11
+ // `placeholderData` function does not have a parameter
12
+ // Avoid TS depth-limit error in case of large array literal
13
+ /**
14
+ * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param
15
+ */
16
+ /**
17
+ * QueriesResults reducer recursively maps type param to results
18
+ */
19
+ function useQueries({
20
+ queries,
21
+ ...options
22
+ }, queryClient) {
23
+ const client = useQueryClient(queryClient);
24
+ const isRestoring = useIsRestoring();
25
+ const errorResetBoundary = useQueryErrorResetBoundary();
26
+ const defaultedQueries = React.useMemo(() => queries.map(opts => {
27
+ const defaultedOptions = client.defaultQueryOptions(opts);
28
+
29
+ // Make sure the results are already in fetching state before subscribing or updating options
30
+ defaultedOptions._optimisticResults = isRestoring ? 'isRestoring' : 'optimistic';
31
+ return defaultedOptions;
32
+ }), [queries, client, isRestoring]);
33
+ defaultedQueries.forEach(query => {
34
+ ensureStaleTime(query);
35
+ ensurePreventErrorBoundaryRetry(query, errorResetBoundary);
36
+ });
37
+ useClearResetErrorBoundary(errorResetBoundary);
38
+ const [observer] = React.useState(() => new QueriesObserver(client, defaultedQueries, options));
39
+ const [optimisticResult, getCombinedResult, trackResult] = observer.getOptimisticResult(defaultedQueries);
40
+ React.useSyncExternalStore(React.useCallback(onStoreChange => isRestoring ? () => undefined : observer.subscribe(notifyManager.batchCalls(onStoreChange)), [observer, isRestoring]), () => observer.getCurrentResult(), () => observer.getCurrentResult());
41
+ React.useEffect(() => {
42
+ // Do not notify on updates because of changes in the options because
43
+ // these changes should already be reflected in the optimistic result.
44
+ observer.setQueries(defaultedQueries, options, {
45
+ listeners: false
46
+ });
47
+ }, [defaultedQueries, options, observer]);
48
+ const shouldAtLeastOneSuspend = optimisticResult.some((result, index) => shouldSuspend(defaultedQueries[index], result, isRestoring));
49
+ const suspensePromises = shouldAtLeastOneSuspend ? optimisticResult.flatMap((result, index) => {
50
+ const opts = defaultedQueries[index];
51
+ const queryObserver = observer.getObservers()[index];
52
+ if (opts && queryObserver) {
53
+ if (shouldSuspend(opts, result, isRestoring)) {
54
+ return fetchOptimistic(opts, queryObserver, errorResetBoundary);
55
+ } else if (willFetch(result, isRestoring)) {
56
+ void fetchOptimistic(opts, queryObserver, errorResetBoundary);
57
+ }
58
+ }
59
+ return [];
60
+ }) : [];
61
+ if (suspensePromises.length > 0) {
62
+ throw Promise.all(suspensePromises);
63
+ }
64
+ const observerQueries = observer.getQueries();
65
+ const firstSingleResultWhichShouldThrow = optimisticResult.find((result, index) => {
66
+ var _defaultedQueries$ind, _defaultedQueries$ind2;
67
+ return getHasError({
68
+ result,
69
+ errorResetBoundary,
70
+ throwOnError: (_defaultedQueries$ind = (_defaultedQueries$ind2 = defaultedQueries[index]) == null ? void 0 : _defaultedQueries$ind2.throwOnError) != null ? _defaultedQueries$ind : false,
71
+ query: observerQueries[index]
72
+ });
73
+ });
74
+ if (firstSingleResultWhichShouldThrow != null && firstSingleResultWhichShouldThrow.error) {
75
+ throw firstSingleResultWhichShouldThrow.error;
76
+ }
77
+ return getCombinedResult(trackResult());
78
+ }
79
+
80
+ export { useQueries };
81
+ //# sourceMappingURL=useQueries.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useQueries.legacy.js","sources":["../../src/useQueries.ts"],"sourcesContent":["'use client'\nimport * as React from 'react'\n\nimport type {\n QueryKey,\n QueryFunction,\n QueriesPlaceholderDataFunction,\n QueryClient,\n DefaultError,\n QueriesObserverOptions,\n} from '@tanstack/query-core'\nimport { notifyManager, QueriesObserver } from '@tanstack/query-core'\nimport { useQueryClient } from './QueryClientProvider'\nimport type { UseQueryOptions, UseQueryResult } from './types'\nimport { useIsRestoring } from './isRestoring'\nimport { useQueryErrorResetBoundary } from './QueryErrorResetBoundary'\nimport {\n ensurePreventErrorBoundaryRetry,\n getHasError,\n useClearResetErrorBoundary,\n} from './errorBoundaryUtils'\nimport {\n ensureStaleTime,\n shouldSuspend,\n fetchOptimistic,\n willFetch,\n} from './suspense'\n\n// This defines the `UseQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype UseQueryOptionsForUseQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n UseQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? UseQueryOptionsForUseQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? UseQueryOptionsForUseQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n }\n ? UseQueryOptionsForUseQueries<TQueryFnData, Error, TData, TQueryKey>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey> }\n ? UseQueryOptionsForUseQueries<TQueryFnData, Error, TQueryFnData, TQueryKey>\n : // Fallback\n UseQueryOptionsForUseQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? UseQueryResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? UseQueryResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? UseQueryResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? UseQueryResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? UseQueryResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? UseQueryResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n }\n ? UseQueryResult<TData>\n : T extends { queryFn?: QueryFunction<infer TQueryFnData, any> }\n ? UseQueryResult<TQueryFnData>\n : // Fallback\n UseQueryResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? UseQueryOptionsForUseQueries[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<[...Tail], [...Result, GetOptions<Head>], [...Depth, 1]>\n : unknown[] extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends UseQueryOptionsForUseQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >[]\n ? UseQueryOptionsForUseQueries<TQueryFnData, TError, TData, TQueryKey>[]\n : // Fallback\n UseQueryOptionsForUseQueries[]\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends any[],\n Result extends any[] = [],\n Depth extends ReadonlyArray<number> = [],\n> = Depth['length'] extends MAXIMUM_DEPTH\n ? UseQueryResult[]\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...Result, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<[...Tail], [...Result, GetResults<Head>], [...Depth, 1]>\n : T extends UseQueryOptionsForUseQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >[]\n ? // Dynamic-size (homogenous) UseQueryOptions array: map directly to array of results\n UseQueryResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >[]\n : // Fallback\n UseQueryResult[]\n\nexport function useQueries<\n T extends any[],\n TCombinedResult = QueriesResults<T>,\n>(\n {\n queries,\n ...options\n }: {\n queries: readonly [...QueriesOptions<T>]\n combine?: (result: QueriesResults<T>) => TCombinedResult\n },\n queryClient?: QueryClient,\n): TCombinedResult {\n const client = useQueryClient(queryClient)\n const isRestoring = useIsRestoring()\n const errorResetBoundary = useQueryErrorResetBoundary()\n\n const defaultedQueries = React.useMemo(\n () =>\n queries.map((opts) => {\n const defaultedOptions = client.defaultQueryOptions(opts)\n\n // Make sure the results are already in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = isRestoring\n ? 'isRestoring'\n : 'optimistic'\n\n return defaultedOptions\n }),\n [queries, client, isRestoring],\n )\n\n defaultedQueries.forEach((query) => {\n ensureStaleTime(query)\n ensurePreventErrorBoundaryRetry(query, errorResetBoundary)\n })\n\n useClearResetErrorBoundary(errorResetBoundary)\n\n const [observer] = React.useState(\n () =>\n new QueriesObserver<TCombinedResult>(\n client,\n defaultedQueries,\n options as QueriesObserverOptions<TCombinedResult>,\n ),\n )\n\n const [optimisticResult, getCombinedResult, trackResult] =\n observer.getOptimisticResult(defaultedQueries)\n\n React.useSyncExternalStore(\n React.useCallback(\n (onStoreChange) =>\n isRestoring\n ? () => undefined\n : observer.subscribe(notifyManager.batchCalls(onStoreChange)),\n [observer, isRestoring],\n ),\n () => observer.getCurrentResult(),\n () => observer.getCurrentResult(),\n )\n\n React.useEffect(() => {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n observer.setQueries(\n defaultedQueries,\n options as QueriesObserverOptions<TCombinedResult>,\n {\n listeners: false,\n },\n )\n }, [defaultedQueries, options, observer])\n\n const shouldAtLeastOneSuspend = optimisticResult.some((result, index) =>\n shouldSuspend(defaultedQueries[index], result, isRestoring),\n )\n\n const suspensePromises = shouldAtLeastOneSuspend\n ? optimisticResult.flatMap((result, index) => {\n const opts = defaultedQueries[index]\n const queryObserver = observer.getObservers()[index]\n\n if (opts && queryObserver) {\n if (shouldSuspend(opts, result, isRestoring)) {\n return fetchOptimistic(opts, queryObserver, errorResetBoundary)\n } else if (willFetch(result, isRestoring)) {\n void fetchOptimistic(opts, queryObserver, errorResetBoundary)\n }\n }\n return []\n })\n : []\n\n if (suspensePromises.length > 0) {\n throw Promise.all(suspensePromises)\n }\n const observerQueries = observer.getQueries()\n const firstSingleResultWhichShouldThrow = optimisticResult.find(\n (result, index) =>\n getHasError({\n result,\n errorResetBoundary,\n throwOnError: defaultedQueries[index]?.throwOnError ?? false,\n query: observerQueries[index]!,\n }),\n )\n\n if (firstSingleResultWhichShouldThrow?.error) {\n throw firstSingleResultWhichShouldThrow.error\n }\n\n return getCombinedResult(trackResult())\n}\n"],"names":["defaultedOptions","defaultedQueries","ensurePreventErrorBoundaryRetry","observer","listeners","throwOnError"],"mappings":";;;;;;;;;AA4BA;AACA;AAaA;AA2DA;AACA;AACA;AA2BA;AACA;AACA;AA2BO;;;AAUL;AAGA;AACA;AACA;AAEA;AAGM;;AAEA;AACAA;AAIA;;AAKNC;;AAEEC;AACF;;AAIA;AASA;;;AAgBE;AACA;AACAC;AAIIC;AACF;;;AAQJ;AAEM;;;;AAKI;;AAEA;AACF;AACF;AACA;;AAIN;AACE;AACF;AACA;;;AAEgB;;;AAIVC;;AAEF;AAAE;AAGN;;AAEA;AAEA;AACF;;"}