@tanstack/query-core 5.0.0-alpha.7 → 5.0.0-alpha.70
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.
- package/build/lib/_virtual/{_rollupPluginBabelHelpers.js → _rollupPluginBabelHelpers.legacy.cjs} +1 -1
- package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.cjs.map +1 -0
- package/build/lib/_virtual/{_rollupPluginBabelHelpers.esm.js → _rollupPluginBabelHelpers.legacy.js} +1 -1
- package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.js.map +1 -0
- package/build/lib/{focusManager.mjs → focusManager.cjs} +9 -6
- package/build/lib/{focusManager.mjs.map → focusManager.cjs.map} +1 -1
- package/build/lib/focusManager.d.ts +2 -1
- package/build/lib/focusManager.d.ts.map +1 -0
- package/build/lib/focusManager.js +20 -39
- package/build/lib/focusManager.js.map +1 -1
- package/build/lib/focusManager.legacy.cjs +90 -0
- package/build/lib/focusManager.legacy.cjs.map +1 -0
- package/build/lib/{focusManager.esm.js → focusManager.legacy.js} +4 -4
- package/build/lib/focusManager.legacy.js.map +1 -0
- package/build/lib/{hydration.mjs → hydration.cjs} +11 -20
- package/build/lib/hydration.cjs.map +1 -0
- package/build/lib/hydration.d.ts +3 -6
- package/build/lib/hydration.d.ts.map +1 -0
- package/build/lib/hydration.js +7 -28
- package/build/lib/hydration.js.map +1 -1
- package/build/lib/hydration.legacy.cjs +92 -0
- package/build/lib/hydration.legacy.cjs.map +1 -0
- package/build/lib/{hydration.esm.js → hydration.legacy.js} +6 -19
- package/build/lib/hydration.legacy.js.map +1 -0
- package/build/lib/index.cjs +40 -0
- package/build/lib/index.cjs.map +1 -0
- package/build/lib/index.d.ts +5 -2
- package/build/lib/index.d.ts.map +1 -0
- package/build/lib/index.js +13 -39
- package/build/lib/index.js.map +1 -1
- package/build/lib/index.legacy.cjs +40 -0
- package/build/lib/index.legacy.cjs.map +1 -0
- package/build/lib/index.legacy.js +14 -0
- package/build/lib/index.legacy.js.map +1 -0
- package/build/lib/{infiniteQueryBehavior.mjs → infiniteQueryBehavior.cjs} +15 -18
- package/build/lib/infiniteQueryBehavior.cjs.map +1 -0
- package/build/lib/infiniteQueryBehavior.d.ts +2 -1
- package/build/lib/infiniteQueryBehavior.d.ts.map +1 -0
- package/build/lib/infiniteQueryBehavior.js +14 -26
- package/build/lib/infiniteQueryBehavior.js.map +1 -1
- package/build/lib/infiniteQueryBehavior.legacy.cjs +125 -0
- package/build/lib/infiniteQueryBehavior.legacy.cjs.map +1 -0
- package/build/lib/{infiniteQueryBehavior.esm.js → infiniteQueryBehavior.legacy.js} +10 -16
- package/build/lib/infiniteQueryBehavior.legacy.js.map +1 -0
- package/build/lib/{infiniteQueryObserver.mjs → infiniteQueryObserver.cjs} +11 -9
- package/build/lib/{infiniteQueryObserver.mjs.map → infiniteQueryObserver.cjs.map} +1 -1
- package/build/lib/infiniteQueryObserver.d.ts +2 -1
- package/build/lib/infiniteQueryObserver.d.ts.map +1 -0
- package/build/lib/infiniteQueryObserver.js +10 -13
- package/build/lib/infiniteQueryObserver.js.map +1 -1
- package/build/lib/infiniteQueryObserver.legacy.cjs +78 -0
- package/build/lib/infiniteQueryObserver.legacy.cjs.map +1 -0
- package/build/lib/{infiniteQueryObserver.esm.js → infiniteQueryObserver.legacy.js} +3 -3
- package/build/lib/infiniteQueryObserver.legacy.js.map +1 -0
- package/build/lib/{mutation.mjs → mutation.cjs} +13 -10
- package/build/lib/mutation.cjs.map +1 -0
- package/build/lib/mutation.d.ts +2 -1
- package/build/lib/mutation.d.ts.map +1 -0
- package/build/lib/mutation.js +107 -135
- package/build/lib/mutation.js.map +1 -1
- package/build/lib/mutation.legacy.cjs +262 -0
- package/build/lib/mutation.legacy.cjs.map +1 -0
- package/build/lib/{mutation.esm.js → mutation.legacy.js} +6 -6
- package/build/lib/mutation.legacy.js.map +1 -0
- package/build/lib/{mutationCache.mjs → mutationCache.cjs} +21 -18
- package/build/lib/mutationCache.cjs.map +1 -0
- package/build/lib/mutationCache.d.ts +3 -2
- package/build/lib/mutationCache.d.ts.map +1 -0
- package/build/lib/mutationCache.js +33 -47
- package/build/lib/mutationCache.js.map +1 -1
- package/build/lib/mutationCache.legacy.cjs +98 -0
- package/build/lib/mutationCache.legacy.cjs.map +1 -0
- package/build/lib/{mutationCache.esm.js → mutationCache.legacy.js} +11 -10
- package/build/lib/mutationCache.legacy.js.map +1 -0
- package/build/lib/{mutationObserver.mjs → mutationObserver.cjs} +13 -11
- package/build/lib/mutationObserver.cjs.map +1 -0
- package/build/lib/mutationObserver.d.ts +2 -1
- package/build/lib/mutationObserver.d.ts.map +1 -0
- package/build/lib/mutationObserver.js +59 -91
- package/build/lib/mutationObserver.js.map +1 -1
- package/build/lib/mutationObserver.legacy.cjs +128 -0
- package/build/lib/mutationObserver.legacy.cjs.map +1 -0
- package/build/lib/{mutationObserver.esm.js → mutationObserver.legacy.js} +7 -7
- package/build/lib/mutationObserver.legacy.js.map +1 -0
- package/build/lib/{notifyManager.mjs → notifyManager.cjs} +8 -5
- package/build/lib/notifyManager.cjs.map +1 -0
- package/build/lib/notifyManager.d.ts +7 -5
- package/build/lib/notifyManager.d.ts.map +1 -0
- package/build/lib/notifyManager.js +4 -7
- package/build/lib/notifyManager.js.map +1 -1
- package/build/lib/notifyManager.legacy.cjs +92 -0
- package/build/lib/notifyManager.legacy.cjs.map +1 -0
- package/build/lib/{notifyManager.esm.js → notifyManager.legacy.js} +2 -2
- package/build/lib/notifyManager.legacy.js.map +1 -0
- package/build/lib/{onlineManager.mjs → onlineManager.cjs} +16 -10
- package/build/lib/onlineManager.cjs.map +1 -0
- package/build/lib/onlineManager.d.ts +2 -1
- package/build/lib/onlineManager.d.ts.map +1 -0
- package/build/lib/onlineManager.js +26 -41
- package/build/lib/onlineManager.js.map +1 -1
- package/build/lib/onlineManager.legacy.cjs +94 -0
- package/build/lib/onlineManager.legacy.cjs.map +1 -0
- package/build/lib/{onlineManager.esm.js → onlineManager.legacy.js} +11 -8
- package/build/lib/onlineManager.legacy.js.map +1 -0
- package/build/lib/{queriesObserver.mjs → queriesObserver.cjs} +51 -26
- package/build/lib/queriesObserver.cjs.map +1 -0
- package/build/lib/queriesObserver.d.ts +14 -6
- package/build/lib/queriesObserver.d.ts.map +1 -0
- package/build/lib/queriesObserver.js +99 -107
- package/build/lib/queriesObserver.js.map +1 -1
- package/build/lib/queriesObserver.legacy.cjs +207 -0
- package/build/lib/queriesObserver.legacy.cjs.map +1 -0
- package/build/lib/{queriesObserver.esm.js → queriesObserver.legacy.js} +62 -22
- package/build/lib/queriesObserver.legacy.js.map +1 -0
- package/build/lib/{query.mjs → query.cjs} +23 -21
- package/build/lib/query.cjs.map +1 -0
- package/build/lib/query.d.ts +3 -2
- package/build/lib/query.d.ts.map +1 -0
- package/build/lib/query.js +174 -225
- package/build/lib/query.js.map +1 -1
- package/build/lib/query.legacy.cjs +471 -0
- package/build/lib/query.legacy.cjs.map +1 -0
- package/build/lib/{query.esm.js → query.legacy.js} +11 -11
- package/build/lib/query.legacy.js.map +1 -0
- package/build/lib/{queryCache.mjs → queryCache.cjs} +28 -23
- package/build/lib/queryCache.cjs.map +1 -0
- package/build/lib/queryCache.d.ts +3 -3
- package/build/lib/queryCache.d.ts.map +1 -0
- package/build/lib/queryCache.js +31 -37
- package/build/lib/queryCache.js.map +1 -1
- package/build/lib/queryCache.legacy.cjs +111 -0
- package/build/lib/queryCache.legacy.cjs.map +1 -0
- package/build/lib/{queryCache.esm.js → queryCache.legacy.js} +13 -12
- package/build/lib/queryCache.legacy.js.map +1 -0
- package/build/lib/{queryClient.mjs → queryClient.cjs} +50 -42
- package/build/lib/queryClient.cjs.map +1 -0
- package/build/lib/queryClient.d.ts +2 -2
- package/build/lib/queryClient.d.ts.map +1 -0
- package/build/lib/queryClient.js +98 -134
- package/build/lib/queryClient.js.map +1 -1
- package/build/lib/queryClient.legacy.cjs +322 -0
- package/build/lib/queryClient.legacy.cjs.map +1 -0
- package/build/lib/{queryClient.esm.js → queryClient.legacy.js} +29 -26
- package/build/lib/queryClient.legacy.js.map +1 -0
- package/build/lib/{queryObserver.mjs → queryObserver.cjs} +40 -50
- package/build/lib/queryObserver.cjs.map +1 -0
- package/build/lib/queryObserver.d.ts +6 -7
- package/build/lib/queryObserver.d.ts.map +1 -0
- package/build/lib/queryObserver.js +208 -323
- package/build/lib/queryObserver.js.map +1 -1
- package/build/lib/queryObserver.legacy.cjs +526 -0
- package/build/lib/queryObserver.legacy.cjs.map +1 -0
- package/build/lib/{queryObserver.esm.js → queryObserver.legacy.js} +71 -88
- package/build/lib/queryObserver.legacy.js.map +1 -0
- package/build/lib/{removable.mjs → removable.cjs} +7 -5
- package/build/lib/{removable.mjs.map → removable.cjs.map} +1 -1
- package/build/lib/removable.d.ts +1 -0
- package/build/lib/removable.d.ts.map +1 -0
- package/build/lib/removable.js +9 -18
- package/build/lib/removable.js.map +1 -1
- package/build/lib/removable.legacy.cjs +38 -0
- package/build/lib/removable.legacy.cjs.map +1 -0
- package/build/lib/{removable.esm.js → removable.legacy.js} +3 -3
- package/build/lib/removable.legacy.js.map +1 -0
- package/build/lib/{retryer.mjs → retryer.cjs} +15 -8
- package/build/lib/{retryer.mjs.map → retryer.cjs.map} +1 -1
- package/build/lib/retryer.d.ts +5 -4
- package/build/lib/retryer.d.ts.map +1 -0
- package/build/lib/retryer.js +21 -25
- package/build/lib/retryer.js.map +1 -1
- package/build/lib/retryer.legacy.cjs +158 -0
- package/build/lib/retryer.legacy.cjs.map +1 -0
- package/build/lib/{retryer.esm.js → retryer.legacy.js} +6 -4
- package/build/lib/retryer.legacy.js.map +1 -0
- package/build/lib/{subscribable.esm.js → subscribable.cjs} +8 -6
- package/build/lib/subscribable.cjs.map +1 -0
- package/build/lib/subscribable.d.ts +3 -2
- package/build/lib/subscribable.d.ts.map +1 -0
- package/build/lib/subscribable.js +5 -7
- package/build/lib/subscribable.js.map +1 -1
- package/build/lib/subscribable.legacy.cjs +28 -0
- package/build/lib/subscribable.legacy.cjs.map +1 -0
- package/build/lib/{subscribable.mjs → subscribable.legacy.js} +5 -5
- package/build/lib/subscribable.legacy.js.map +1 -0
- package/build/lib/tests/focusManager.test.d.ts +1 -0
- package/build/lib/tests/focusManager.test.d.ts.map +1 -0
- package/build/lib/tests/hydration.test.d.ts +1 -0
- package/build/lib/tests/hydration.test.d.ts.map +1 -0
- package/build/lib/tests/infiniteQueryBehavior.test.d.ts +1 -0
- package/build/lib/tests/infiniteQueryBehavior.test.d.ts.map +1 -0
- package/build/lib/tests/infiniteQueryObserver.test.d.ts +1 -0
- package/build/lib/tests/infiniteQueryObserver.test.d.ts.map +1 -0
- package/build/lib/tests/mutationCache.test.d.ts +1 -0
- package/build/lib/tests/mutationCache.test.d.ts.map +1 -0
- package/build/lib/tests/mutationObserver.test.d.ts +1 -0
- package/build/lib/tests/mutationObserver.test.d.ts.map +1 -0
- package/build/lib/tests/mutations.test.d.ts +1 -0
- package/build/lib/tests/mutations.test.d.ts.map +1 -0
- package/build/lib/tests/notifyManager.test.d.ts +1 -0
- package/build/lib/tests/notifyManager.test.d.ts.map +1 -0
- package/build/lib/tests/onlineManager.test.d.ts +1 -0
- package/build/lib/tests/onlineManager.test.d.ts.map +1 -0
- package/build/lib/tests/queriesObserver.test.d.ts +1 -0
- package/build/lib/tests/queriesObserver.test.d.ts.map +1 -0
- package/build/lib/tests/query.test.d.ts +1 -0
- package/build/lib/tests/query.test.d.ts.map +1 -0
- package/build/lib/tests/queryCache.test.d.ts +1 -0
- package/build/lib/tests/queryCache.test.d.ts.map +1 -0
- package/build/lib/tests/queryClient.test.d.ts +1 -0
- package/build/lib/tests/queryClient.test.d.ts.map +1 -0
- package/build/lib/tests/queryObserver.test.d.ts +1 -0
- package/build/lib/tests/queryObserver.test.d.ts.map +1 -0
- package/build/lib/tests/utils.d.ts +1 -0
- package/build/lib/tests/utils.d.ts.map +1 -0
- package/build/lib/tests/utils.test.d.ts +1 -0
- package/build/lib/tests/utils.test.d.ts.map +1 -0
- package/build/lib/types.d.ts +42 -48
- package/build/lib/types.d.ts.map +1 -0
- package/build/lib/{utils.mjs → utils.cjs} +23 -2
- package/build/lib/{utils.mjs.map → utils.cjs.map} +1 -1
- package/build/lib/utils.d.ts +4 -3
- package/build/lib/utils.d.ts.map +1 -0
- package/build/lib/utils.js +2 -23
- package/build/lib/utils.js.map +1 -1
- package/build/lib/utils.legacy.cjs +248 -0
- package/build/lib/utils.legacy.cjs.map +1 -0
- package/build/lib/{utils.esm.js → utils.legacy.js} +1 -1
- package/build/lib/utils.legacy.js.map +1 -0
- package/package.json +13 -9
- package/src/hydration.ts +18 -37
- package/src/index.ts +3 -3
- package/src/infiniteQueryBehavior.ts +16 -18
- package/src/mutation.ts +1 -1
- package/src/mutationCache.ts +4 -4
- package/src/mutationObserver.ts +1 -1
- package/src/notifyManager.ts +7 -3
- package/src/onlineManager.ts +8 -4
- package/src/queriesObserver.ts +75 -25
- package/src/query.ts +7 -5
- package/src/queryCache.ts +6 -9
- package/src/queryClient.ts +23 -21
- package/src/queryObserver.ts +47 -55
- package/src/subscribable.ts +5 -5
- package/src/tests/hydration.test.tsx +7 -3
- package/src/tests/infiniteQueryBehavior.test.tsx +5 -2
- package/src/tests/notifyManager.test.tsx +15 -0
- package/src/tests/query.test.tsx +4 -2
- package/src/tests/queryCache.test.tsx +1 -19
- package/src/tests/queryClient.test.tsx +79 -3
- package/src/tests/queryObserver.test.tsx +121 -0
- package/src/types.ts +31 -30
- package/build/lib/_virtual/_rollupPluginBabelHelpers.esm.js.map +0 -1
- package/build/lib/_virtual/_rollupPluginBabelHelpers.js.map +0 -1
- package/build/lib/focusManager.esm.js.map +0 -1
- package/build/lib/hydration.esm.js.map +0 -1
- package/build/lib/hydration.mjs.map +0 -1
- package/build/lib/index.esm.js +0 -14
- package/build/lib/index.esm.js.map +0 -1
- package/build/lib/index.mjs +0 -14
- package/build/lib/index.mjs.map +0 -1
- package/build/lib/infiniteQueryBehavior.esm.js.map +0 -1
- package/build/lib/infiniteQueryBehavior.mjs.map +0 -1
- package/build/lib/infiniteQueryObserver.esm.js.map +0 -1
- package/build/lib/mutation.esm.js.map +0 -1
- package/build/lib/mutation.mjs.map +0 -1
- package/build/lib/mutationCache.esm.js.map +0 -1
- package/build/lib/mutationCache.mjs.map +0 -1
- package/build/lib/mutationObserver.esm.js.map +0 -1
- package/build/lib/mutationObserver.mjs.map +0 -1
- package/build/lib/notifyManager.esm.js.map +0 -1
- package/build/lib/notifyManager.mjs.map +0 -1
- package/build/lib/onlineManager.esm.js.map +0 -1
- package/build/lib/onlineManager.mjs.map +0 -1
- package/build/lib/queriesObserver.esm.js.map +0 -1
- package/build/lib/queriesObserver.mjs.map +0 -1
- package/build/lib/query.esm.js.map +0 -1
- package/build/lib/query.mjs.map +0 -1
- package/build/lib/queryCache.esm.js.map +0 -1
- package/build/lib/queryCache.mjs.map +0 -1
- package/build/lib/queryClient.esm.js.map +0 -1
- package/build/lib/queryClient.mjs.map +0 -1
- package/build/lib/queryObserver.esm.js.map +0 -1
- package/build/lib/queryObserver.mjs.map +0 -1
- package/build/lib/removable.esm.js.map +0 -1
- package/build/lib/retryer.esm.js.map +0 -1
- package/build/lib/subscribable.esm.js.map +0 -1
- package/build/lib/subscribable.mjs.map +0 -1
- package/build/lib/utils.esm.js.map +0 -1
- package/build/umd/index.development.js +0 -2683
- package/build/umd/index.development.js.map +0 -1
- package/build/umd/index.production.js +0 -2
- package/build/umd/index.production.js.map +0 -1
|
@@ -7,11 +7,9 @@ import type {
|
|
|
7
7
|
QueryKey,
|
|
8
8
|
} from './types'
|
|
9
9
|
|
|
10
|
-
export function infiniteQueryBehavior<
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
TData,
|
|
14
|
-
>(): QueryBehavior<TQueryFnData, TError, InfiniteData<TData>> {
|
|
10
|
+
export function infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
11
|
+
pages?: number,
|
|
12
|
+
): QueryBehavior<TQueryFnData, TError, InfiniteData<TData>> {
|
|
15
13
|
return {
|
|
16
14
|
onFetch: (context) => {
|
|
17
15
|
context.fetchFn = async () => {
|
|
@@ -41,7 +39,10 @@ export function infiniteQueryBehavior<
|
|
|
41
39
|
// Get query function
|
|
42
40
|
const queryFn =
|
|
43
41
|
context.options.queryFn ||
|
|
44
|
-
(() =>
|
|
42
|
+
(() =>
|
|
43
|
+
Promise.reject(
|
|
44
|
+
new Error(`Missing queryFn: '${context.options.queryHash}'`),
|
|
45
|
+
))
|
|
45
46
|
|
|
46
47
|
// Create function to fetch a page
|
|
47
48
|
const fetchPage = async (
|
|
@@ -84,13 +85,8 @@ export function infiniteQueryBehavior<
|
|
|
84
85
|
|
|
85
86
|
let result: InfiniteData<unknown>
|
|
86
87
|
|
|
87
|
-
// Fetch first page?
|
|
88
|
-
if (!oldPages.length) {
|
|
89
|
-
result = await fetchPage(empty, options.defaultPageParam)
|
|
90
|
-
}
|
|
91
|
-
|
|
92
88
|
// fetch next / previous page?
|
|
93
|
-
|
|
89
|
+
if (direction && oldPages.length) {
|
|
94
90
|
const previous = direction === 'backward'
|
|
95
91
|
const pageParamFn = previous ? getPreviousPageParam : getNextPageParam
|
|
96
92
|
const oldData = {
|
|
@@ -100,15 +96,17 @@ export function infiniteQueryBehavior<
|
|
|
100
96
|
const param = pageParamFn(options, oldData)
|
|
101
97
|
|
|
102
98
|
result = await fetchPage(oldData, param, previous)
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// Refetch pages
|
|
106
|
-
else {
|
|
99
|
+
} else {
|
|
107
100
|
// Fetch first page
|
|
108
|
-
result = await fetchPage(
|
|
101
|
+
result = await fetchPage(
|
|
102
|
+
empty,
|
|
103
|
+
oldPageParams[0] ?? options.defaultPageParam,
|
|
104
|
+
)
|
|
105
|
+
|
|
106
|
+
const remainingPages = pages ?? oldPages.length
|
|
109
107
|
|
|
110
108
|
// Fetch remaining pages
|
|
111
|
-
for (let i = 1; i <
|
|
109
|
+
for (let i = 1; i < remainingPages; i++) {
|
|
112
110
|
const param = getNextPageParam(options, result)
|
|
113
111
|
result = await fetchPage(result, param)
|
|
114
112
|
}
|
package/src/mutation.ts
CHANGED
|
@@ -119,7 +119,7 @@ export class Mutation<
|
|
|
119
119
|
}
|
|
120
120
|
|
|
121
121
|
addObserver(observer: MutationObserver<any, any, any, any>): void {
|
|
122
|
-
if (this.#observers.
|
|
122
|
+
if (!this.#observers.includes(observer)) {
|
|
123
123
|
this.#observers.push(observer)
|
|
124
124
|
|
|
125
125
|
// Stop the mutation from being garbage collected
|
package/src/mutationCache.ts
CHANGED
|
@@ -139,11 +139,11 @@ export class MutationCache extends Subscribable<MutationCacheListener> {
|
|
|
139
139
|
>(
|
|
140
140
|
filters: MutationFilters,
|
|
141
141
|
): Mutation<TData, TError, TVariables, TContext> | undefined {
|
|
142
|
-
|
|
143
|
-
filters.exact = true
|
|
144
|
-
}
|
|
142
|
+
const defaultedFilters = { exact: true, ...filters }
|
|
145
143
|
|
|
146
|
-
return this.#mutations.find((mutation) =>
|
|
144
|
+
return this.#mutations.find((mutation) =>
|
|
145
|
+
matchMutation(defaultedFilters, mutation),
|
|
146
|
+
)
|
|
147
147
|
}
|
|
148
148
|
|
|
149
149
|
findAll(filters: MutationFilters = {}): Mutation[] {
|
package/src/mutationObserver.ts
CHANGED
package/src/notifyManager.ts
CHANGED
|
@@ -8,6 +8,8 @@ type NotifyFunction = (callback: () => void) => void
|
|
|
8
8
|
|
|
9
9
|
type BatchNotifyFunction = (callback: () => void) => void
|
|
10
10
|
|
|
11
|
+
type BatchCallsCallback<T extends unknown[]> = (...args: T) => void
|
|
12
|
+
|
|
11
13
|
export function createNotifyManager() {
|
|
12
14
|
let queue: NotifyCallback[] = []
|
|
13
15
|
let transactions = 0
|
|
@@ -45,12 +47,14 @@ export function createNotifyManager() {
|
|
|
45
47
|
/**
|
|
46
48
|
* All calls to the wrapped function will be batched.
|
|
47
49
|
*/
|
|
48
|
-
const batchCalls = <T extends
|
|
49
|
-
|
|
50
|
+
const batchCalls = <T extends unknown[]>(
|
|
51
|
+
callback: BatchCallsCallback<T>,
|
|
52
|
+
): BatchCallsCallback<T> => {
|
|
53
|
+
return (...args) => {
|
|
50
54
|
schedule(() => {
|
|
51
55
|
callback(...args)
|
|
52
56
|
})
|
|
53
|
-
}
|
|
57
|
+
}
|
|
54
58
|
}
|
|
55
59
|
|
|
56
60
|
const flush = (): void => {
|
package/src/onlineManager.ts
CHANGED
|
@@ -5,6 +5,8 @@ type SetupFn = (
|
|
|
5
5
|
setOnline: (online?: boolean) => void,
|
|
6
6
|
) => (() => void) | undefined
|
|
7
7
|
|
|
8
|
+
const onlineEvents = ['online', 'offline'] as const
|
|
9
|
+
|
|
8
10
|
export class OnlineManager extends Subscribable {
|
|
9
11
|
#online?: boolean
|
|
10
12
|
#cleanup?: () => void
|
|
@@ -19,13 +21,15 @@ export class OnlineManager extends Subscribable {
|
|
|
19
21
|
if (!isServer && window.addEventListener) {
|
|
20
22
|
const listener = () => onOnline()
|
|
21
23
|
// Listen to online
|
|
22
|
-
|
|
23
|
-
|
|
24
|
+
onlineEvents.forEach((event) => {
|
|
25
|
+
window.addEventListener(event, listener, false)
|
|
26
|
+
})
|
|
24
27
|
|
|
25
28
|
return () => {
|
|
26
29
|
// Be sure to unsubscribe if a new handler is set
|
|
27
|
-
|
|
28
|
-
|
|
30
|
+
onlineEvents.forEach((event) => {
|
|
31
|
+
window.removeEventListener(event, listener)
|
|
32
|
+
})
|
|
29
33
|
}
|
|
30
34
|
}
|
|
31
35
|
|
package/src/queriesObserver.ts
CHANGED
|
@@ -8,9 +8,10 @@ import type { QueryClient } from './queryClient'
|
|
|
8
8
|
import type { NotifyOptions } from './queryObserver'
|
|
9
9
|
import { QueryObserver } from './queryObserver'
|
|
10
10
|
import { Subscribable } from './subscribable'
|
|
11
|
+
import { replaceEqualDeep } from './utils'
|
|
11
12
|
|
|
12
13
|
function difference<T>(array1: T[], array2: T[]): T[] {
|
|
13
|
-
return array1.filter((x) => array2.
|
|
14
|
+
return array1.filter((x) => !array2.includes(x))
|
|
14
15
|
}
|
|
15
16
|
|
|
16
17
|
function replaceAt<T>(array: T[], index: number, value: T): T[] {
|
|
@@ -21,27 +22,44 @@ function replaceAt<T>(array: T[], index: number, value: T): T[] {
|
|
|
21
22
|
|
|
22
23
|
type QueriesObserverListener = (result: QueryObserverResult[]) => void
|
|
23
24
|
|
|
24
|
-
export
|
|
25
|
+
export interface QueriesObserverOptions<
|
|
26
|
+
TCombinedResult = QueryObserverResult[],
|
|
27
|
+
> {
|
|
28
|
+
combine?: (result: QueryObserverResult[]) => TCombinedResult
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export class QueriesObserver<
|
|
32
|
+
TCombinedResult = QueryObserverResult[],
|
|
33
|
+
> extends Subscribable<QueriesObserverListener> {
|
|
25
34
|
#client: QueryClient
|
|
26
|
-
#result
|
|
35
|
+
#result!: QueryObserverResult[]
|
|
27
36
|
#queries: QueryObserverOptions[]
|
|
28
37
|
#observers: QueryObserver[]
|
|
38
|
+
#options?: QueriesObserverOptions<TCombinedResult>
|
|
39
|
+
#combinedResult!: TCombinedResult
|
|
29
40
|
|
|
30
|
-
constructor(
|
|
41
|
+
constructor(
|
|
42
|
+
client: QueryClient,
|
|
43
|
+
queries: QueryObserverOptions[],
|
|
44
|
+
options?: QueriesObserverOptions<TCombinedResult>,
|
|
45
|
+
) {
|
|
31
46
|
super()
|
|
32
47
|
|
|
33
48
|
this.#client = client
|
|
34
49
|
this.#queries = []
|
|
35
|
-
this.#result = []
|
|
36
50
|
this.#observers = []
|
|
37
51
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
52
|
+
this.#setResult([])
|
|
53
|
+
this.setQueries(queries, options)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
#setResult(value: QueryObserverResult[]) {
|
|
57
|
+
this.#result = value
|
|
58
|
+
this.#combinedResult = this.#combineResult(value)
|
|
41
59
|
}
|
|
42
60
|
|
|
43
61
|
protected onSubscribe(): void {
|
|
44
|
-
if (this.listeners.
|
|
62
|
+
if (this.listeners.size === 1) {
|
|
45
63
|
this.#observers.forEach((observer) => {
|
|
46
64
|
observer.subscribe((result) => {
|
|
47
65
|
this.#onUpdate(observer, result)
|
|
@@ -51,13 +69,13 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
51
69
|
}
|
|
52
70
|
|
|
53
71
|
protected onUnsubscribe(): void {
|
|
54
|
-
if (!this.listeners.
|
|
72
|
+
if (!this.listeners.size) {
|
|
55
73
|
this.destroy()
|
|
56
74
|
}
|
|
57
75
|
}
|
|
58
76
|
|
|
59
77
|
destroy(): void {
|
|
60
|
-
this.listeners =
|
|
78
|
+
this.listeners = new Set()
|
|
61
79
|
this.#observers.forEach((observer) => {
|
|
62
80
|
observer.destroy()
|
|
63
81
|
})
|
|
@@ -65,9 +83,11 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
65
83
|
|
|
66
84
|
setQueries(
|
|
67
85
|
queries: QueryObserverOptions[],
|
|
86
|
+
options?: QueriesObserverOptions<TCombinedResult>,
|
|
68
87
|
notifyOptions?: NotifyOptions,
|
|
69
88
|
): void {
|
|
70
89
|
this.#queries = queries
|
|
90
|
+
this.#options = options
|
|
71
91
|
|
|
72
92
|
notifyManager.batch(() => {
|
|
73
93
|
const prevObservers = this.#observers
|
|
@@ -92,7 +112,7 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
92
112
|
}
|
|
93
113
|
|
|
94
114
|
this.#observers = newObservers
|
|
95
|
-
this.#
|
|
115
|
+
this.#setResult(newResult)
|
|
96
116
|
|
|
97
117
|
if (!this.hasListeners()) {
|
|
98
118
|
return
|
|
@@ -112,8 +132,8 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
112
132
|
})
|
|
113
133
|
}
|
|
114
134
|
|
|
115
|
-
getCurrentResult():
|
|
116
|
-
return this.#
|
|
135
|
+
getCurrentResult(): TCombinedResult {
|
|
136
|
+
return this.#combinedResult
|
|
117
137
|
}
|
|
118
138
|
|
|
119
139
|
getQueries() {
|
|
@@ -124,38 +144,68 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
124
144
|
return this.#observers
|
|
125
145
|
}
|
|
126
146
|
|
|
127
|
-
getOptimisticResult(
|
|
128
|
-
|
|
147
|
+
getOptimisticResult(
|
|
148
|
+
queries: QueryObserverOptions[],
|
|
149
|
+
): [
|
|
150
|
+
rawResult: QueryObserverResult[],
|
|
151
|
+
combineResult: (r?: QueryObserverResult[]) => TCombinedResult,
|
|
152
|
+
trackResult: () => QueryObserverResult[],
|
|
153
|
+
] {
|
|
154
|
+
const matches = this.#findMatchingObservers(queries)
|
|
155
|
+
const result = matches.map((match) =>
|
|
129
156
|
match.observer.getOptimisticResult(match.defaultedQueryOptions),
|
|
130
157
|
)
|
|
158
|
+
|
|
159
|
+
return [
|
|
160
|
+
result,
|
|
161
|
+
(r?: QueryObserverResult[]) => {
|
|
162
|
+
return this.#combineResult(r ?? result)
|
|
163
|
+
},
|
|
164
|
+
() => {
|
|
165
|
+
return matches.map((match, index) => {
|
|
166
|
+
const observerResult = result[index]!
|
|
167
|
+
return !match.defaultedQueryOptions.notifyOnChangeProps
|
|
168
|
+
? match.observer.trackResult(observerResult)
|
|
169
|
+
: observerResult
|
|
170
|
+
})
|
|
171
|
+
},
|
|
172
|
+
]
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
#combineResult(input: QueryObserverResult[]): TCombinedResult {
|
|
176
|
+
const combine = this.#options?.combine
|
|
177
|
+
if (combine) {
|
|
178
|
+
return replaceEqualDeep(this.#combinedResult, combine(input))
|
|
179
|
+
}
|
|
180
|
+
return input as any
|
|
131
181
|
}
|
|
132
182
|
|
|
133
183
|
#findMatchingObservers(
|
|
134
184
|
queries: QueryObserverOptions[],
|
|
135
185
|
): QueryObserverMatch[] {
|
|
136
186
|
const prevObservers = this.#observers
|
|
187
|
+
const prevObserversMap = new Map(
|
|
188
|
+
prevObservers.map((observer) => [observer.options.queryHash, observer]),
|
|
189
|
+
)
|
|
190
|
+
|
|
137
191
|
const defaultedQueryOptions = queries.map((options) =>
|
|
138
192
|
this.#client.defaultQueryOptions(options),
|
|
139
193
|
)
|
|
140
194
|
|
|
141
195
|
const matchingObservers: QueryObserverMatch[] =
|
|
142
196
|
defaultedQueryOptions.flatMap((defaultedOptions) => {
|
|
143
|
-
const match =
|
|
144
|
-
(observer) =>
|
|
145
|
-
observer.options.queryHash === defaultedOptions.queryHash,
|
|
146
|
-
)
|
|
197
|
+
const match = prevObserversMap.get(defaultedOptions.queryHash)
|
|
147
198
|
if (match != null) {
|
|
148
199
|
return [{ defaultedQueryOptions: defaultedOptions, observer: match }]
|
|
149
200
|
}
|
|
150
201
|
return []
|
|
151
202
|
})
|
|
152
203
|
|
|
153
|
-
const matchedQueryHashes =
|
|
154
|
-
(match) => match.defaultedQueryOptions.queryHash,
|
|
204
|
+
const matchedQueryHashes = new Set(
|
|
205
|
+
matchingObservers.map((match) => match.defaultedQueryOptions.queryHash),
|
|
155
206
|
)
|
|
156
207
|
const unmatchedQueries = defaultedQueryOptions.filter(
|
|
157
|
-
(defaultedOptions) =>
|
|
158
|
-
!matchedQueryHashes.includes(defaultedOptions.queryHash),
|
|
208
|
+
(defaultedOptions) => !matchedQueryHashes.has(defaultedOptions.queryHash),
|
|
159
209
|
)
|
|
160
210
|
|
|
161
211
|
const getObserver = (options: QueryObserverOptions): QueryObserver => {
|
|
@@ -192,7 +242,7 @@ export class QueriesObserver extends Subscribable<QueriesObserverListener> {
|
|
|
192
242
|
#onUpdate(observer: QueryObserver, result: QueryObserverResult): void {
|
|
193
243
|
const index = this.#observers.indexOf(observer)
|
|
194
244
|
if (index !== -1) {
|
|
195
|
-
this.#
|
|
245
|
+
this.#setResult(replaceAt(this.#result, index, result))
|
|
196
246
|
this.#notify()
|
|
197
247
|
}
|
|
198
248
|
}
|
package/src/query.ts
CHANGED
|
@@ -281,7 +281,7 @@ export class Query<
|
|
|
281
281
|
}
|
|
282
282
|
|
|
283
283
|
addObserver(observer: QueryObserver<any, any, any, any, any>): void {
|
|
284
|
-
if (this.#observers.
|
|
284
|
+
if (!this.#observers.includes(observer)) {
|
|
285
285
|
this.#observers.push(observer)
|
|
286
286
|
|
|
287
287
|
// Stop the query from being garbage collected
|
|
@@ -292,7 +292,7 @@ export class Query<
|
|
|
292
292
|
}
|
|
293
293
|
|
|
294
294
|
removeObserver(observer: QueryObserver<any, any, any, any, any>): void {
|
|
295
|
-
if (this.#observers.
|
|
295
|
+
if (this.#observers.includes(observer)) {
|
|
296
296
|
this.#observers = this.#observers.filter((x) => x !== observer)
|
|
297
297
|
|
|
298
298
|
if (!this.#observers.length) {
|
|
@@ -387,7 +387,9 @@ export class Query<
|
|
|
387
387
|
// Create fetch function
|
|
388
388
|
const fetchFn = () => {
|
|
389
389
|
if (!this.options.queryFn) {
|
|
390
|
-
return Promise.reject(
|
|
390
|
+
return Promise.reject(
|
|
391
|
+
new Error(`Missing queryFn: '${this.options.queryHash}'`),
|
|
392
|
+
)
|
|
391
393
|
}
|
|
392
394
|
this.#abortSignalConsumed = false
|
|
393
395
|
return this.options.queryFn(
|
|
@@ -464,7 +466,7 @@ export class Query<
|
|
|
464
466
|
`Query data cannot be undefined. Please make sure to return a value other than undefined from your query function. Affected query key: ${this.queryHash}`,
|
|
465
467
|
)
|
|
466
468
|
}
|
|
467
|
-
onError(new Error(
|
|
469
|
+
onError(new Error(`${this.queryHash} data is undefined`) as any)
|
|
468
470
|
return
|
|
469
471
|
}
|
|
470
472
|
|
|
@@ -588,7 +590,7 @@ export class Query<
|
|
|
588
590
|
|
|
589
591
|
notifyManager.batch(() => {
|
|
590
592
|
this.#observers.forEach((observer) => {
|
|
591
|
-
observer.onQueryUpdate(
|
|
593
|
+
observer.onQueryUpdate()
|
|
592
594
|
})
|
|
593
595
|
|
|
594
596
|
this.#cache.notify({ query: this, type: 'updated', action })
|
package/src/queryCache.ts
CHANGED
|
@@ -27,7 +27,6 @@ interface QueryCacheConfig {
|
|
|
27
27
|
error: DefaultError | null,
|
|
28
28
|
query: Query<unknown, unknown, unknown>,
|
|
29
29
|
) => void
|
|
30
|
-
createStore?: () => QueryStore
|
|
31
30
|
}
|
|
32
31
|
|
|
33
32
|
interface NotifyEventQueryAdded extends NotifyEvent {
|
|
@@ -69,7 +68,7 @@ interface NotifyEventQueryObserverOptionsUpdated extends NotifyEvent {
|
|
|
69
68
|
observer: QueryObserver<any, any, any, any, any>
|
|
70
69
|
}
|
|
71
70
|
|
|
72
|
-
type QueryCacheNotifyEvent =
|
|
71
|
+
export type QueryCacheNotifyEvent =
|
|
73
72
|
| NotifyEventQueryAdded
|
|
74
73
|
| NotifyEventQueryRemoved
|
|
75
74
|
| NotifyEventQueryUpdated
|
|
@@ -95,7 +94,7 @@ export class QueryCache extends Subscribable<QueryCacheListener> {
|
|
|
95
94
|
|
|
96
95
|
constructor(public config: QueryCacheConfig = {}) {
|
|
97
96
|
super()
|
|
98
|
-
this.#queries =
|
|
97
|
+
this.#queries = new Map<string, Query>()
|
|
99
98
|
}
|
|
100
99
|
|
|
101
100
|
build<TQueryFnData, TError, TData, TQueryKey extends QueryKey>(
|
|
@@ -176,13 +175,11 @@ export class QueryCache extends Subscribable<QueryCacheListener> {
|
|
|
176
175
|
find<TQueryFnData = unknown, TError = DefaultError, TData = TQueryFnData>(
|
|
177
176
|
filters: WithRequired<QueryFilters, 'queryKey'>,
|
|
178
177
|
): Query<TQueryFnData, TError, TData> | undefined {
|
|
179
|
-
|
|
180
|
-
filters.exact = true
|
|
181
|
-
}
|
|
178
|
+
const defaultedFilters = { exact: true, ...filters }
|
|
182
179
|
|
|
183
|
-
return this.getAll().find((query) =>
|
|
184
|
-
|
|
185
|
-
|
|
180
|
+
return this.getAll().find((query) =>
|
|
181
|
+
matchQuery(defaultedFilters, query),
|
|
182
|
+
) as Query<TQueryFnData, TError, TData> | undefined
|
|
186
183
|
}
|
|
187
184
|
|
|
188
185
|
findAll(filters: QueryFilters = {}): Query[] {
|
package/src/queryClient.ts
CHANGED
|
@@ -25,6 +25,8 @@ import type {
|
|
|
25
25
|
ResetOptions,
|
|
26
26
|
SetDataOptions,
|
|
27
27
|
DefaultError,
|
|
28
|
+
CancelOptions,
|
|
29
|
+
DefaultedQueryObserverOptions,
|
|
28
30
|
} from './types'
|
|
29
31
|
import type { QueryState } from './query'
|
|
30
32
|
import { QueryCache } from './queryCache'
|
|
@@ -33,7 +35,6 @@ import { focusManager } from './focusManager'
|
|
|
33
35
|
import { onlineManager } from './onlineManager'
|
|
34
36
|
import { notifyManager } from './notifyManager'
|
|
35
37
|
import { infiniteQueryBehavior } from './infiniteQueryBehavior'
|
|
36
|
-
import type { CancelOptions, DefaultedQueryObserverOptions } from './types'
|
|
37
38
|
|
|
38
39
|
// TYPES
|
|
39
40
|
|
|
@@ -212,14 +213,12 @@ export class QueryClient {
|
|
|
212
213
|
filters: QueryFilters = {},
|
|
213
214
|
cancelOptions: CancelOptions = {},
|
|
214
215
|
): Promise<void> {
|
|
215
|
-
|
|
216
|
-
cancelOptions.revert = true
|
|
217
|
-
}
|
|
216
|
+
const defaultedCancelOptions = { revert: true, ...cancelOptions }
|
|
218
217
|
|
|
219
218
|
const promises = notifyManager.batch(() =>
|
|
220
219
|
this.#queryCache
|
|
221
220
|
.findAll(filters)
|
|
222
|
-
.map((query) => query.cancel(
|
|
221
|
+
.map((query) => query.cancel(defaultedCancelOptions)),
|
|
223
222
|
)
|
|
224
223
|
|
|
225
224
|
return Promise.all(promises).then(noop).catch(noop)
|
|
@@ -249,25 +248,26 @@ export class QueryClient {
|
|
|
249
248
|
filters: RefetchQueryFilters = {},
|
|
250
249
|
options?: RefetchOptions,
|
|
251
250
|
): Promise<void> {
|
|
251
|
+
const fetchOptions = {
|
|
252
|
+
...options,
|
|
253
|
+
cancelRefetch: options?.cancelRefetch ?? true,
|
|
254
|
+
}
|
|
252
255
|
const promises = notifyManager.batch(() =>
|
|
253
256
|
this.#queryCache
|
|
254
257
|
.findAll(filters)
|
|
255
258
|
.filter((query) => !query.isDisabled())
|
|
256
|
-
.map((query) =>
|
|
257
|
-
query.fetch(undefined,
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
}
|
|
261
|
-
|
|
259
|
+
.map((query) => {
|
|
260
|
+
let promise = query.fetch(undefined, fetchOptions)
|
|
261
|
+
if (!fetchOptions.throwOnError) {
|
|
262
|
+
promise = promise.catch(noop)
|
|
263
|
+
}
|
|
264
|
+
return query.state.fetchStatus === 'paused'
|
|
265
|
+
? Promise.resolve()
|
|
266
|
+
: promise
|
|
267
|
+
}),
|
|
262
268
|
)
|
|
263
269
|
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
if (!options?.throwOnError) {
|
|
267
|
-
promise = promise.catch(noop)
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
return promise
|
|
270
|
+
return Promise.all(promises).then(noop)
|
|
271
271
|
}
|
|
272
272
|
|
|
273
273
|
fetchQuery<
|
|
@@ -325,7 +325,9 @@ export class QueryClient {
|
|
|
325
325
|
TPageParam
|
|
326
326
|
>,
|
|
327
327
|
): Promise<InfiniteData<TData>> {
|
|
328
|
-
options.behavior = infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
328
|
+
options.behavior = infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
329
|
+
options.pages,
|
|
330
|
+
)
|
|
329
331
|
return this.fetchQuery(options)
|
|
330
332
|
}
|
|
331
333
|
|
|
@@ -480,8 +482,8 @@ export class QueryClient {
|
|
|
480
482
|
defaultedOptions.refetchOnReconnect =
|
|
481
483
|
defaultedOptions.networkMode !== 'always'
|
|
482
484
|
}
|
|
483
|
-
if (typeof defaultedOptions.
|
|
484
|
-
defaultedOptions.
|
|
485
|
+
if (typeof defaultedOptions.throwOnError === 'undefined') {
|
|
486
|
+
defaultedOptions.throwOnError = !!defaultedOptions.suspense
|
|
485
487
|
}
|
|
486
488
|
|
|
487
489
|
return defaultedOptions as DefaultedQueryObserverOptions<
|