@tanstack/query-core 5.0.0-beta.6 → 5.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/legacy/hydration.cjs.map +1 -1
- package/build/legacy/hydration.d.cts +3 -3
- package/build/legacy/hydration.d.ts +3 -3
- package/build/legacy/hydration.js.map +1 -1
- package/build/legacy/index.cjs +3 -0
- package/build/legacy/index.cjs.map +1 -1
- package/build/legacy/index.d.cts +1 -1
- package/build/legacy/index.d.ts +1 -1
- package/build/legacy/index.js +2 -0
- package/build/legacy/index.js.map +1 -1
- package/build/legacy/infiniteQueryBehavior.cjs +23 -6
- package/build/legacy/infiniteQueryBehavior.cjs.map +1 -1
- package/build/legacy/infiniteQueryBehavior.d.cts +2 -2
- package/build/legacy/infiniteQueryBehavior.d.ts +2 -2
- package/build/legacy/infiniteQueryBehavior.js +23 -6
- package/build/legacy/infiniteQueryBehavior.js.map +1 -1
- package/build/legacy/infiniteQueryObserver.cjs.map +1 -1
- package/build/legacy/infiniteQueryObserver.d.cts +3 -3
- package/build/legacy/infiniteQueryObserver.d.ts +3 -3
- package/build/legacy/infiniteQueryObserver.js.map +1 -1
- package/build/legacy/mutation.cjs.map +1 -1
- package/build/legacy/mutation.d.cts +1 -1
- package/build/legacy/mutation.d.ts +1 -1
- package/build/legacy/mutation.js.map +1 -1
- package/build/legacy/mutationCache.cjs.map +1 -1
- package/build/legacy/mutationCache.d.cts +1 -1
- package/build/legacy/mutationCache.d.ts +1 -1
- package/build/legacy/mutationCache.js.map +1 -1
- package/build/legacy/mutationObserver.d.cts +1 -1
- package/build/legacy/mutationObserver.d.ts +1 -1
- package/build/legacy/notifyManager.cjs.map +1 -1
- package/build/legacy/notifyManager.d.cts +1 -1
- package/build/legacy/notifyManager.d.ts +1 -1
- package/build/legacy/notifyManager.js.map +1 -1
- package/build/legacy/queriesObserver.cjs +6 -8
- package/build/legacy/queriesObserver.cjs.map +1 -1
- package/build/legacy/queriesObserver.d.cts +11 -11
- package/build/legacy/queriesObserver.d.ts +11 -11
- package/build/legacy/queriesObserver.js +6 -8
- package/build/legacy/queriesObserver.js.map +1 -1
- package/build/legacy/query.cjs +10 -2
- package/build/legacy/query.cjs.map +1 -1
- package/build/legacy/query.d.cts +1 -1
- package/build/legacy/query.d.ts +1 -1
- package/build/legacy/query.js +10 -2
- package/build/legacy/query.js.map +1 -1
- package/build/legacy/queryCache.cjs.map +1 -1
- package/build/legacy/queryCache.d.cts +1 -1
- package/build/legacy/queryCache.d.ts +1 -1
- package/build/legacy/queryCache.js.map +1 -1
- package/build/legacy/{queryClient-9264ae39.d.ts → queryClient-230e991e.d.ts} +28 -25
- package/build/legacy/{queryClient-7060338a.d.ts → queryClient-64e47985.d.ts} +28 -25
- package/build/legacy/queryClient.cjs +4 -3
- package/build/legacy/queryClient.cjs.map +1 -1
- package/build/legacy/queryClient.d.cts +1 -1
- package/build/legacy/queryClient.d.ts +1 -1
- package/build/legacy/queryClient.js +4 -3
- package/build/legacy/queryClient.js.map +1 -1
- package/build/legacy/queryObserver.cjs +1 -1
- package/build/legacy/queryObserver.cjs.map +1 -1
- package/build/legacy/queryObserver.d.cts +1 -1
- package/build/legacy/queryObserver.d.ts +1 -1
- package/build/legacy/queryObserver.js +1 -1
- package/build/legacy/queryObserver.js.map +1 -1
- package/build/legacy/retryer.d.cts +1 -1
- package/build/legacy/retryer.d.ts +1 -1
- package/build/legacy/types.cjs.map +1 -1
- package/build/legacy/types.d.cts +1 -1
- package/build/legacy/types.d.ts +1 -1
- package/build/legacy/utils.cjs.map +1 -1
- package/build/legacy/utils.d.cts +1 -1
- package/build/legacy/utils.d.ts +1 -1
- package/build/legacy/utils.js.map +1 -1
- package/build/modern/hydration.cjs.map +1 -1
- package/build/modern/hydration.d.cts +3 -3
- package/build/modern/hydration.d.ts +3 -3
- package/build/modern/hydration.js.map +1 -1
- package/build/modern/index.cjs +3 -0
- package/build/modern/index.cjs.map +1 -1
- package/build/modern/index.d.cts +1 -1
- package/build/modern/index.d.ts +1 -1
- package/build/modern/index.js +2 -0
- package/build/modern/index.js.map +1 -1
- package/build/modern/infiniteQueryBehavior.cjs +21 -6
- package/build/modern/infiniteQueryBehavior.cjs.map +1 -1
- package/build/modern/infiniteQueryBehavior.d.cts +2 -2
- package/build/modern/infiniteQueryBehavior.d.ts +2 -2
- package/build/modern/infiniteQueryBehavior.js +21 -6
- package/build/modern/infiniteQueryBehavior.js.map +1 -1
- package/build/modern/infiniteQueryObserver.cjs.map +1 -1
- package/build/modern/infiniteQueryObserver.d.cts +3 -3
- package/build/modern/infiniteQueryObserver.d.ts +3 -3
- package/build/modern/infiniteQueryObserver.js.map +1 -1
- package/build/modern/mutation.cjs.map +1 -1
- package/build/modern/mutation.d.cts +1 -1
- package/build/modern/mutation.d.ts +1 -1
- package/build/modern/mutation.js.map +1 -1
- package/build/modern/mutationCache.cjs.map +1 -1
- package/build/modern/mutationCache.d.cts +1 -1
- package/build/modern/mutationCache.d.ts +1 -1
- package/build/modern/mutationCache.js.map +1 -1
- package/build/modern/mutationObserver.d.cts +1 -1
- package/build/modern/mutationObserver.d.ts +1 -1
- package/build/modern/notifyManager.cjs.map +1 -1
- package/build/modern/notifyManager.d.cts +1 -1
- package/build/modern/notifyManager.d.ts +1 -1
- package/build/modern/notifyManager.js.map +1 -1
- package/build/modern/queriesObserver.cjs +6 -8
- package/build/modern/queriesObserver.cjs.map +1 -1
- package/build/modern/queriesObserver.d.cts +11 -11
- package/build/modern/queriesObserver.d.ts +11 -11
- package/build/modern/queriesObserver.js +6 -8
- package/build/modern/queriesObserver.js.map +1 -1
- package/build/modern/query.cjs +10 -2
- package/build/modern/query.cjs.map +1 -1
- package/build/modern/query.d.cts +1 -1
- package/build/modern/query.d.ts +1 -1
- package/build/modern/query.js +10 -2
- package/build/modern/query.js.map +1 -1
- package/build/modern/queryCache.cjs.map +1 -1
- package/build/modern/queryCache.d.cts +1 -1
- package/build/modern/queryCache.d.ts +1 -1
- package/build/modern/queryCache.js.map +1 -1
- package/build/modern/{queryClient-9264ae39.d.ts → queryClient-230e991e.d.ts} +28 -25
- package/build/modern/{queryClient-7060338a.d.ts → queryClient-64e47985.d.ts} +28 -25
- package/build/modern/queryClient.cjs +4 -3
- package/build/modern/queryClient.cjs.map +1 -1
- package/build/modern/queryClient.d.cts +1 -1
- package/build/modern/queryClient.d.ts +1 -1
- package/build/modern/queryClient.js +4 -3
- package/build/modern/queryClient.js.map +1 -1
- package/build/modern/queryObserver.cjs +1 -1
- package/build/modern/queryObserver.cjs.map +1 -1
- package/build/modern/queryObserver.d.cts +1 -1
- package/build/modern/queryObserver.d.ts +1 -1
- package/build/modern/queryObserver.js +1 -1
- package/build/modern/queryObserver.js.map +1 -1
- package/build/modern/retryer.d.cts +1 -1
- package/build/modern/retryer.d.ts +1 -1
- package/build/modern/types.cjs.map +1 -1
- package/build/modern/types.d.cts +1 -1
- package/build/modern/types.d.ts +1 -1
- package/build/modern/utils.cjs.map +1 -1
- package/build/modern/utils.d.cts +1 -1
- package/build/modern/utils.d.ts +1 -1
- package/build/modern/utils.js.map +1 -1
- package/package.json +6 -2
- package/src/hydration.ts +2 -2
- package/src/index.ts +2 -1
- package/src/infiniteQueryBehavior.ts +23 -8
- package/src/infiniteQueryObserver.ts +7 -2
- package/src/mutation.ts +1 -1
- package/src/mutationCache.ts +3 -3
- package/src/notifyManager.ts +3 -3
- package/src/queriesObserver.ts +24 -25
- package/src/query.ts +12 -2
- package/src/queryCache.ts +2 -2
- package/src/queryClient.ts +17 -7
- package/src/queryObserver.ts +1 -1
- package/src/tests/hydration.test.tsx +2 -2
- package/src/tests/infiniteQueryBehavior.test.tsx +4 -4
- package/src/tests/infiniteQueryObserver.test.tsx +36 -7
- package/src/tests/mutations.test.tsx +2 -2
- package/src/tests/queriesObserver.test.tsx +4 -4
- package/src/tests/query.test.tsx +55 -3
- package/src/tests/queryClient.test.tsx +77 -38
- package/src/tests/queryObserver.test.tsx +22 -22
- package/src/tests/utils.test.tsx +2 -2
- package/src/tests/utils.ts +0 -5
- package/src/types.ts +41 -20
- package/src/utils.ts +2 -2
|
@@ -7,12 +7,12 @@ import type {
|
|
|
7
7
|
QueryKey,
|
|
8
8
|
} from './types'
|
|
9
9
|
|
|
10
|
-
export function infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
10
|
+
export function infiniteQueryBehavior<TQueryFnData, TError, TData, TPageParam>(
|
|
11
11
|
pages?: number,
|
|
12
|
-
): QueryBehavior<TQueryFnData, TError, InfiniteData<TData>> {
|
|
12
|
+
): QueryBehavior<TQueryFnData, TError, InfiniteData<TData, TPageParam>> {
|
|
13
13
|
return {
|
|
14
|
-
onFetch: (context) => {
|
|
15
|
-
|
|
14
|
+
onFetch: (context, query) => {
|
|
15
|
+
const fetchFn = async () => {
|
|
16
16
|
const options = context.options as InfiniteQueryPageParamsOptions<TData>
|
|
17
17
|
const direction = context.fetchOptions?.meta?.fetchMore?.direction
|
|
18
18
|
const oldPages = context.state.data?.pages || []
|
|
@@ -54,7 +54,7 @@ export function infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
|
54
54
|
return Promise.reject()
|
|
55
55
|
}
|
|
56
56
|
|
|
57
|
-
if (
|
|
57
|
+
if (param == null && data.pages.length) {
|
|
58
58
|
return Promise.resolve(data)
|
|
59
59
|
}
|
|
60
60
|
|
|
@@ -100,7 +100,7 @@ export function infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
|
100
100
|
// Fetch first page
|
|
101
101
|
result = await fetchPage(
|
|
102
102
|
empty,
|
|
103
|
-
oldPageParams[0] ?? options.
|
|
103
|
+
oldPageParams[0] ?? options.initialPageParam,
|
|
104
104
|
)
|
|
105
105
|
|
|
106
106
|
const remainingPages = pages ?? oldPages.length
|
|
@@ -114,6 +114,21 @@ export function infiniteQueryBehavior<TQueryFnData, TError, TData>(
|
|
|
114
114
|
|
|
115
115
|
return result
|
|
116
116
|
}
|
|
117
|
+
if (context.options.persister) {
|
|
118
|
+
context.fetchFn = () => {
|
|
119
|
+
return context.options.persister?.(
|
|
120
|
+
fetchFn as any,
|
|
121
|
+
{
|
|
122
|
+
queryKey: context.queryKey,
|
|
123
|
+
meta: context.options.meta,
|
|
124
|
+
signal: context.signal,
|
|
125
|
+
},
|
|
126
|
+
query,
|
|
127
|
+
)
|
|
128
|
+
}
|
|
129
|
+
} else {
|
|
130
|
+
context.fetchFn = fetchFn
|
|
131
|
+
}
|
|
117
132
|
},
|
|
118
133
|
}
|
|
119
134
|
}
|
|
@@ -151,7 +166,7 @@ export function hasNextPage(
|
|
|
151
166
|
data?: InfiniteData<unknown>,
|
|
152
167
|
): boolean {
|
|
153
168
|
if (!data) return false
|
|
154
|
-
return
|
|
169
|
+
return getNextPageParam(options, data) != null
|
|
155
170
|
}
|
|
156
171
|
|
|
157
172
|
/**
|
|
@@ -162,5 +177,5 @@ export function hasPreviousPage(
|
|
|
162
177
|
data?: InfiniteData<unknown>,
|
|
163
178
|
): boolean {
|
|
164
179
|
if (!data || !options.getPreviousPageParam) return false
|
|
165
|
-
return
|
|
180
|
+
return getPreviousPageParam(options, data) != null
|
|
166
181
|
}
|
|
@@ -33,7 +33,7 @@ export class InfiniteQueryObserver<
|
|
|
33
33
|
TQueryFnData,
|
|
34
34
|
TError,
|
|
35
35
|
TData,
|
|
36
|
-
InfiniteData<TQueryData>,
|
|
36
|
+
InfiniteData<TQueryData, TPageParam>,
|
|
37
37
|
TQueryKey
|
|
38
38
|
> {
|
|
39
39
|
// Type override
|
|
@@ -130,7 +130,12 @@ export class InfiniteQueryObserver<
|
|
|
130
130
|
}
|
|
131
131
|
|
|
132
132
|
protected createResult(
|
|
133
|
-
query: Query<
|
|
133
|
+
query: Query<
|
|
134
|
+
TQueryFnData,
|
|
135
|
+
TError,
|
|
136
|
+
InfiniteData<TQueryData, TPageParam>,
|
|
137
|
+
TQueryKey
|
|
138
|
+
>,
|
|
134
139
|
options: InfiniteQueryObserverOptions<
|
|
135
140
|
TQueryFnData,
|
|
136
141
|
TError,
|
package/src/mutation.ts
CHANGED
|
@@ -88,7 +88,7 @@ export class Mutation<
|
|
|
88
88
|
options!: MutationOptions<TData, TError, TVariables, TContext>
|
|
89
89
|
readonly mutationId: number
|
|
90
90
|
|
|
91
|
-
#observers: MutationObserver<TData, TError, TVariables, TContext
|
|
91
|
+
#observers: Array<MutationObserver<TData, TError, TVariables, TContext>>
|
|
92
92
|
#defaultOptions?: MutationOptions<TData, TError, TVariables, TContext>
|
|
93
93
|
#mutationCache: MutationCache
|
|
94
94
|
#retryer?: Retryer<TData>
|
package/src/mutationCache.ts
CHANGED
|
@@ -82,7 +82,7 @@ type MutationCacheListener = (event: MutationCacheNotifyEvent) => void
|
|
|
82
82
|
// CLASS
|
|
83
83
|
|
|
84
84
|
export class MutationCache extends Subscribable<MutationCacheListener> {
|
|
85
|
-
#mutations: Mutation<any, any, any, any
|
|
85
|
+
#mutations: Array<Mutation<any, any, any, any>>
|
|
86
86
|
#mutationId: number
|
|
87
87
|
#resuming: Promise<unknown> | undefined
|
|
88
88
|
|
|
@@ -127,7 +127,7 @@ export class MutationCache extends Subscribable<MutationCacheListener> {
|
|
|
127
127
|
})
|
|
128
128
|
}
|
|
129
129
|
|
|
130
|
-
getAll(): Mutation
|
|
130
|
+
getAll(): Array<Mutation> {
|
|
131
131
|
return this.#mutations
|
|
132
132
|
}
|
|
133
133
|
|
|
@@ -146,7 +146,7 @@ export class MutationCache extends Subscribable<MutationCacheListener> {
|
|
|
146
146
|
)
|
|
147
147
|
}
|
|
148
148
|
|
|
149
|
-
findAll(filters: MutationFilters = {}): Mutation
|
|
149
|
+
findAll(filters: MutationFilters = {}): Array<Mutation> {
|
|
150
150
|
return this.#mutations.filter((mutation) =>
|
|
151
151
|
matchMutation(filters, mutation),
|
|
152
152
|
)
|
package/src/notifyManager.ts
CHANGED
|
@@ -8,10 +8,10 @@ type NotifyFunction = (callback: () => void) => void
|
|
|
8
8
|
|
|
9
9
|
type BatchNotifyFunction = (callback: () => void) => void
|
|
10
10
|
|
|
11
|
-
type BatchCallsCallback<T extends unknown
|
|
11
|
+
type BatchCallsCallback<T extends Array<unknown>> = (...args: T) => void
|
|
12
12
|
|
|
13
13
|
export function createNotifyManager() {
|
|
14
|
-
let queue: NotifyCallback
|
|
14
|
+
let queue: Array<NotifyCallback> = []
|
|
15
15
|
let transactions = 0
|
|
16
16
|
let notifyFn: NotifyFunction = (callback) => {
|
|
17
17
|
callback()
|
|
@@ -47,7 +47,7 @@ export function createNotifyManager() {
|
|
|
47
47
|
/**
|
|
48
48
|
* All calls to the wrapped function will be batched.
|
|
49
49
|
*/
|
|
50
|
-
const batchCalls = <T extends unknown
|
|
50
|
+
const batchCalls = <T extends Array<unknown>>(
|
|
51
51
|
callback: BatchCallsCallback<T>,
|
|
52
52
|
): BatchCallsCallback<T> => {
|
|
53
53
|
return (...args) => {
|
package/src/queriesObserver.ts
CHANGED
|
@@ -10,37 +10,37 @@ import type {
|
|
|
10
10
|
import type { QueryClient } from './queryClient'
|
|
11
11
|
import type { NotifyOptions } from './queryObserver'
|
|
12
12
|
|
|
13
|
-
function difference<T>(array1: T
|
|
13
|
+
function difference<T>(array1: Array<T>, array2: Array<T>): Array<T> {
|
|
14
14
|
return array1.filter((x) => !array2.includes(x))
|
|
15
15
|
}
|
|
16
16
|
|
|
17
|
-
function replaceAt<T>(array: T
|
|
17
|
+
function replaceAt<T>(array: Array<T>, index: number, value: T): Array<T> {
|
|
18
18
|
const copy = array.slice(0)
|
|
19
19
|
copy[index] = value
|
|
20
20
|
return copy
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
-
type QueriesObserverListener = (result: QueryObserverResult
|
|
23
|
+
type QueriesObserverListener = (result: Array<QueryObserverResult>) => void
|
|
24
24
|
|
|
25
25
|
export interface QueriesObserverOptions<
|
|
26
|
-
TCombinedResult = QueryObserverResult
|
|
26
|
+
TCombinedResult = Array<QueryObserverResult>,
|
|
27
27
|
> {
|
|
28
|
-
combine?: (result: QueryObserverResult
|
|
28
|
+
combine?: (result: Array<QueryObserverResult>) => TCombinedResult
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
export class QueriesObserver<
|
|
32
|
-
TCombinedResult = QueryObserverResult
|
|
32
|
+
TCombinedResult = Array<QueryObserverResult>,
|
|
33
33
|
> extends Subscribable<QueriesObserverListener> {
|
|
34
34
|
#client: QueryClient
|
|
35
|
-
#result!: QueryObserverResult
|
|
36
|
-
#queries: QueryObserverOptions
|
|
37
|
-
#observers: QueryObserver
|
|
35
|
+
#result!: Array<QueryObserverResult>
|
|
36
|
+
#queries: Array<QueryObserverOptions>
|
|
37
|
+
#observers: Array<QueryObserver>
|
|
38
38
|
#options?: QueriesObserverOptions<TCombinedResult>
|
|
39
39
|
#combinedResult!: TCombinedResult
|
|
40
40
|
|
|
41
41
|
constructor(
|
|
42
42
|
client: QueryClient,
|
|
43
|
-
queries: QueryObserverOptions
|
|
43
|
+
queries: Array<QueryObserverOptions>,
|
|
44
44
|
options?: QueriesObserverOptions<TCombinedResult>,
|
|
45
45
|
) {
|
|
46
46
|
super()
|
|
@@ -53,7 +53,7 @@ export class QueriesObserver<
|
|
|
53
53
|
this.setQueries(queries, options)
|
|
54
54
|
}
|
|
55
55
|
|
|
56
|
-
#setResult(value: QueryObserverResult
|
|
56
|
+
#setResult(value: Array<QueryObserverResult>) {
|
|
57
57
|
this.#result = value
|
|
58
58
|
this.#combinedResult = this.#combineResult(value)
|
|
59
59
|
}
|
|
@@ -82,7 +82,7 @@ export class QueriesObserver<
|
|
|
82
82
|
}
|
|
83
83
|
|
|
84
84
|
setQueries(
|
|
85
|
-
queries: QueryObserverOptions
|
|
85
|
+
queries: Array<QueryObserverOptions>,
|
|
86
86
|
options?: QueriesObserverOptions<TCombinedResult>,
|
|
87
87
|
notifyOptions?: NotifyOptions,
|
|
88
88
|
): void {
|
|
@@ -145,11 +145,11 @@ export class QueriesObserver<
|
|
|
145
145
|
}
|
|
146
146
|
|
|
147
147
|
getOptimisticResult(
|
|
148
|
-
queries: QueryObserverOptions
|
|
148
|
+
queries: Array<QueryObserverOptions>,
|
|
149
149
|
): [
|
|
150
|
-
rawResult: QueryObserverResult
|
|
151
|
-
combineResult: (r?: QueryObserverResult
|
|
152
|
-
trackResult: () => QueryObserverResult
|
|
150
|
+
rawResult: Array<QueryObserverResult>,
|
|
151
|
+
combineResult: (r?: Array<QueryObserverResult>) => TCombinedResult,
|
|
152
|
+
trackResult: () => Array<QueryObserverResult>,
|
|
153
153
|
] {
|
|
154
154
|
const matches = this.#findMatchingObservers(queries)
|
|
155
155
|
const result = matches.map((match) =>
|
|
@@ -158,7 +158,7 @@ export class QueriesObserver<
|
|
|
158
158
|
|
|
159
159
|
return [
|
|
160
160
|
result,
|
|
161
|
-
(r?: QueryObserverResult
|
|
161
|
+
(r?: Array<QueryObserverResult>) => {
|
|
162
162
|
return this.#combineResult(r ?? result)
|
|
163
163
|
},
|
|
164
164
|
() => {
|
|
@@ -172,7 +172,7 @@ export class QueriesObserver<
|
|
|
172
172
|
]
|
|
173
173
|
}
|
|
174
174
|
|
|
175
|
-
#combineResult(input: QueryObserverResult
|
|
175
|
+
#combineResult(input: Array<QueryObserverResult>): TCombinedResult {
|
|
176
176
|
const combine = this.#options?.combine
|
|
177
177
|
if (combine) {
|
|
178
178
|
return replaceEqualDeep(this.#combinedResult, combine(input))
|
|
@@ -181,8 +181,8 @@ export class QueriesObserver<
|
|
|
181
181
|
}
|
|
182
182
|
|
|
183
183
|
#findMatchingObservers(
|
|
184
|
-
queries: QueryObserverOptions
|
|
185
|
-
): QueryObserverMatch
|
|
184
|
+
queries: Array<QueryObserverOptions>,
|
|
185
|
+
): Array<QueryObserverMatch> {
|
|
186
186
|
const prevObservers = this.#observers
|
|
187
187
|
const prevObserversMap = new Map(
|
|
188
188
|
prevObservers.map((observer) => [observer.options.queryHash, observer]),
|
|
@@ -192,7 +192,7 @@ export class QueriesObserver<
|
|
|
192
192
|
this.#client.defaultQueryOptions(options),
|
|
193
193
|
)
|
|
194
194
|
|
|
195
|
-
const matchingObservers: QueryObserverMatch
|
|
195
|
+
const matchingObservers: Array<QueryObserverMatch> =
|
|
196
196
|
defaultedQueryOptions.flatMap((defaultedOptions) => {
|
|
197
197
|
const match = prevObserversMap.get(defaultedOptions.queryHash)
|
|
198
198
|
if (match != null) {
|
|
@@ -218,14 +218,13 @@ export class QueriesObserver<
|
|
|
218
218
|
)
|
|
219
219
|
}
|
|
220
220
|
|
|
221
|
-
const newOrReusedObservers: QueryObserverMatch
|
|
222
|
-
(options) => {
|
|
221
|
+
const newOrReusedObservers: Array<QueryObserverMatch> =
|
|
222
|
+
unmatchedQueries.map((options) => {
|
|
223
223
|
return {
|
|
224
224
|
defaultedQueryOptions: options,
|
|
225
225
|
observer: getObserver(options),
|
|
226
226
|
}
|
|
227
|
-
}
|
|
228
|
-
)
|
|
227
|
+
})
|
|
229
228
|
|
|
230
229
|
const sortMatchesByOrderOfQueries = (
|
|
231
230
|
a: QueryObserverMatch,
|
package/src/query.ts
CHANGED
|
@@ -71,6 +71,7 @@ export interface QueryBehavior<
|
|
|
71
71
|
> {
|
|
72
72
|
onFetch: (
|
|
73
73
|
context: FetchContext<TQueryFnData, TError, TData, TQueryKey>,
|
|
74
|
+
query: Query,
|
|
74
75
|
) => void
|
|
75
76
|
}
|
|
76
77
|
|
|
@@ -159,7 +160,7 @@ export class Query<
|
|
|
159
160
|
#cache: QueryCache
|
|
160
161
|
#promise?: Promise<TData>
|
|
161
162
|
#retryer?: Retryer<TData>
|
|
162
|
-
#observers: QueryObserver<any, any, any, any, any
|
|
163
|
+
#observers: Array<QueryObserver<any, any, any, any, any>>
|
|
163
164
|
#defaultOptions?: QueryOptions<TQueryFnData, TError, TData, TQueryKey>
|
|
164
165
|
#abortSignalConsumed: boolean
|
|
165
166
|
|
|
@@ -392,6 +393,14 @@ export class Query<
|
|
|
392
393
|
)
|
|
393
394
|
}
|
|
394
395
|
this.#abortSignalConsumed = false
|
|
396
|
+
if (this.options.persister) {
|
|
397
|
+
return this.options.persister(
|
|
398
|
+
this.options.queryFn,
|
|
399
|
+
queryFnContext as QueryFunctionContext<TQueryKey>,
|
|
400
|
+
this as unknown as Query,
|
|
401
|
+
)
|
|
402
|
+
}
|
|
403
|
+
|
|
395
404
|
return this.options.queryFn(
|
|
396
405
|
queryFnContext as QueryFunctionContext<TQueryKey>,
|
|
397
406
|
)
|
|
@@ -413,6 +422,7 @@ export class Query<
|
|
|
413
422
|
|
|
414
423
|
this.options.behavior?.onFetch(
|
|
415
424
|
context as FetchContext<TQueryFnData, TError, TData, TQueryKey>,
|
|
425
|
+
this as unknown as Query,
|
|
416
426
|
)
|
|
417
427
|
|
|
418
428
|
// Store state in case the current fetch needs to be reverted
|
|
@@ -560,7 +570,7 @@ export class Query<
|
|
|
560
570
|
const error = action.error as unknown
|
|
561
571
|
|
|
562
572
|
if (isCancelledError(error) && error.revert && this.#revertState) {
|
|
563
|
-
return { ...this.#revertState }
|
|
573
|
+
return { ...this.#revertState, fetchStatus: 'idle' }
|
|
564
574
|
}
|
|
565
575
|
|
|
566
576
|
return {
|
package/src/queryCache.ts
CHANGED
|
@@ -168,7 +168,7 @@ export class QueryCache extends Subscribable<QueryCacheListener> {
|
|
|
168
168
|
| undefined
|
|
169
169
|
}
|
|
170
170
|
|
|
171
|
-
getAll(): Query
|
|
171
|
+
getAll(): Array<Query> {
|
|
172
172
|
return [...this.#queries.values()]
|
|
173
173
|
}
|
|
174
174
|
|
|
@@ -182,7 +182,7 @@ export class QueryCache extends Subscribable<QueryCacheListener> {
|
|
|
182
182
|
) as Query<TQueryFnData, TError, TData> | undefined
|
|
183
183
|
}
|
|
184
184
|
|
|
185
|
-
findAll(filters: QueryFilters = {}): Query
|
|
185
|
+
findAll(filters: QueryFilters = {}): Array<Query> {
|
|
186
186
|
const queries = this.getAll()
|
|
187
187
|
return Object.keys(filters).length > 0
|
|
188
188
|
? queries.filter((query) => matchQuery(filters, query))
|
package/src/queryClient.ts
CHANGED
|
@@ -115,7 +115,7 @@ export class QueryClient {
|
|
|
115
115
|
|
|
116
116
|
ensureQueryData<
|
|
117
117
|
TQueryFnData,
|
|
118
|
-
TError,
|
|
118
|
+
TError = DefaultError,
|
|
119
119
|
TData = TQueryFnData,
|
|
120
120
|
TQueryKey extends QueryKey = QueryKey,
|
|
121
121
|
>(
|
|
@@ -128,7 +128,7 @@ export class QueryClient {
|
|
|
128
128
|
|
|
129
129
|
getQueriesData<TQueryFnData = unknown>(
|
|
130
130
|
filters: QueryFilters,
|
|
131
|
-
): [QueryKey, TQueryFnData | undefined]
|
|
131
|
+
): Array<[QueryKey, TQueryFnData | undefined]> {
|
|
132
132
|
return this.getQueryCache()
|
|
133
133
|
.findAll(filters)
|
|
134
134
|
.map(({ queryKey, state }) => {
|
|
@@ -167,7 +167,7 @@ export class QueryClient {
|
|
|
167
167
|
filters: QueryFilters,
|
|
168
168
|
updater: Updater<TQueryFnData | undefined, TQueryFnData | undefined>,
|
|
169
169
|
options?: SetDataOptions,
|
|
170
|
-
): [QueryKey, TQueryFnData | undefined]
|
|
170
|
+
): Array<[QueryKey, TQueryFnData | undefined]> {
|
|
171
171
|
return notifyManager.batch(() =>
|
|
172
172
|
this.getQueryCache()
|
|
173
173
|
.findAll(filters)
|
|
@@ -324,10 +324,13 @@ export class QueryClient {
|
|
|
324
324
|
TQueryKey,
|
|
325
325
|
TPageParam
|
|
326
326
|
>,
|
|
327
|
-
): Promise<InfiniteData<TData>> {
|
|
328
|
-
options.behavior = infiniteQueryBehavior<
|
|
329
|
-
|
|
330
|
-
|
|
327
|
+
): Promise<InfiniteData<TData, TPageParam>> {
|
|
328
|
+
options.behavior = infiniteQueryBehavior<
|
|
329
|
+
TQueryFnData,
|
|
330
|
+
TError,
|
|
331
|
+
TData,
|
|
332
|
+
TPageParam
|
|
333
|
+
>(options.pages)
|
|
331
334
|
return this.fetchQuery(options)
|
|
332
335
|
}
|
|
333
336
|
|
|
@@ -486,6 +489,13 @@ export class QueryClient {
|
|
|
486
489
|
defaultedOptions.throwOnError = !!defaultedOptions.suspense
|
|
487
490
|
}
|
|
488
491
|
|
|
492
|
+
if (
|
|
493
|
+
typeof defaultedOptions.networkMode === 'undefined' &&
|
|
494
|
+
defaultedOptions.persister
|
|
495
|
+
) {
|
|
496
|
+
defaultedOptions.networkMode = 'offlineFirst'
|
|
497
|
+
}
|
|
498
|
+
|
|
489
499
|
return defaultedOptions as DefaultedQueryObserverOptions<
|
|
490
500
|
TQueryFnData,
|
|
491
501
|
TError,
|
package/src/queryObserver.ts
CHANGED
|
@@ -763,7 +763,7 @@ function shouldAssignObserverCurrentProperties<
|
|
|
763
763
|
) {
|
|
764
764
|
// if the newly created result isn't what the observer is holding as current,
|
|
765
765
|
// then we'll need to update the properties as well
|
|
766
|
-
if (observer.getCurrentResult()
|
|
766
|
+
if (!shallowEqualObjects(observer.getCurrentResult(), optimisticResult)) {
|
|
767
767
|
return true
|
|
768
768
|
}
|
|
769
769
|
|
|
@@ -69,7 +69,7 @@ describe('dehydration and rehydration', () => {
|
|
|
69
69
|
key: [{ nestedKey: 1 }],
|
|
70
70
|
})
|
|
71
71
|
|
|
72
|
-
const fetchDataAfterHydration = vi.fn<unknown
|
|
72
|
+
const fetchDataAfterHydration = vi.fn<Array<unknown>, unknown>()
|
|
73
73
|
await hydrationClient.prefetchQuery({
|
|
74
74
|
queryKey: ['string'],
|
|
75
75
|
queryFn: fetchDataAfterHydration,
|
|
@@ -196,7 +196,7 @@ describe('dehydration and rehydration', () => {
|
|
|
196
196
|
})?.state.data,
|
|
197
197
|
).toBe('string')
|
|
198
198
|
|
|
199
|
-
const fetchDataAfterHydration = vi.fn<unknown
|
|
199
|
+
const fetchDataAfterHydration = vi.fn<Array<unknown>, unknown>()
|
|
200
200
|
await hydrationClient.prefetchQuery({
|
|
201
201
|
queryKey: ['string', { key: ['string'], key2: 0 }],
|
|
202
202
|
queryFn: fetchDataAfterHydration,
|
|
@@ -24,7 +24,7 @@ describe('InfiniteQueryBehavior', () => {
|
|
|
24
24
|
const observer = new InfiniteQueryObserver(queryClient, {
|
|
25
25
|
queryKey: key,
|
|
26
26
|
retry: false,
|
|
27
|
-
|
|
27
|
+
initialPageParam: 1,
|
|
28
28
|
getNextPageParam: () => 2,
|
|
29
29
|
})
|
|
30
30
|
|
|
@@ -62,7 +62,7 @@ describe('InfiniteQueryBehavior', () => {
|
|
|
62
62
|
getNextPageParam: (lastPage) => lastPage + 1,
|
|
63
63
|
getPreviousPageParam: (firstPage) => firstPage - 1,
|
|
64
64
|
maxPages: 2,
|
|
65
|
-
|
|
65
|
+
initialPageParam: 1,
|
|
66
66
|
})
|
|
67
67
|
|
|
68
68
|
let observerResult:
|
|
@@ -204,7 +204,7 @@ describe('InfiniteQueryBehavior', () => {
|
|
|
204
204
|
queryFn: queryFnSpy,
|
|
205
205
|
getNextPageParam: (lastPage) => lastPage + 1,
|
|
206
206
|
getPreviousPageParam: (firstPage) => firstPage - 1,
|
|
207
|
-
|
|
207
|
+
initialPageParam: 1,
|
|
208
208
|
})
|
|
209
209
|
|
|
210
210
|
let observerResult:
|
|
@@ -255,7 +255,7 @@ describe('InfiniteQueryBehavior', () => {
|
|
|
255
255
|
queryFn: queryFnSpy,
|
|
256
256
|
getNextPageParam: (lastPage) => lastPage + 1,
|
|
257
257
|
getPreviousPageParam: (firstPage) => firstPage - 1,
|
|
258
|
-
|
|
258
|
+
initialPageParam: 1,
|
|
259
259
|
})
|
|
260
260
|
|
|
261
261
|
let observerResult:
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { vi } from 'vitest'
|
|
1
|
+
import { expect, vi } from 'vitest'
|
|
2
2
|
import { InfiniteQueryObserver } from '..'
|
|
3
3
|
import { createQueryClient, queryKey, sleep } from './utils'
|
|
4
4
|
import type { QueryClient } from '..'
|
|
@@ -24,7 +24,7 @@ describe('InfiniteQueryObserver', () => {
|
|
|
24
24
|
pages: data.pages.map((x) => `${x}`),
|
|
25
25
|
pageParams: data.pageParams,
|
|
26
26
|
}),
|
|
27
|
-
|
|
27
|
+
initialPageParam: 1,
|
|
28
28
|
getNextPageParam: () => 2,
|
|
29
29
|
})
|
|
30
30
|
let observerResult
|
|
@@ -53,7 +53,7 @@ describe('InfiniteQueryObserver', () => {
|
|
|
53
53
|
pages: data.pages.map((x) => `${x}`),
|
|
54
54
|
pageParams: data.pageParams,
|
|
55
55
|
}),
|
|
56
|
-
|
|
56
|
+
initialPageParam: 1,
|
|
57
57
|
getNextPageParam: () => 2,
|
|
58
58
|
})
|
|
59
59
|
let observerResult
|
|
@@ -70,12 +70,12 @@ describe('InfiniteQueryObserver', () => {
|
|
|
70
70
|
|
|
71
71
|
test('getNextPagParam and getPreviousPageParam should receive current pageParams', async () => {
|
|
72
72
|
const key = queryKey()
|
|
73
|
-
let single: string
|
|
74
|
-
let all: string
|
|
73
|
+
let single: Array<string> = []
|
|
74
|
+
let all: Array<string> = []
|
|
75
75
|
const observer = new InfiniteQueryObserver(queryClient, {
|
|
76
76
|
queryKey: key,
|
|
77
77
|
queryFn: ({ pageParam }) => String(pageParam),
|
|
78
|
-
|
|
78
|
+
initialPageParam: 1,
|
|
79
79
|
getNextPageParam: (_, __, lastPageParam, allPageParams) => {
|
|
80
80
|
single.push('next' + lastPageParam)
|
|
81
81
|
all.push('next' + allPageParams.join(','))
|
|
@@ -110,7 +110,7 @@ describe('InfiniteQueryObserver', () => {
|
|
|
110
110
|
const observer = new InfiniteQueryObserver(queryClient, {
|
|
111
111
|
queryKey: key,
|
|
112
112
|
queryFn,
|
|
113
|
-
|
|
113
|
+
initialPageParam: 1,
|
|
114
114
|
getNextPageParam: () => next,
|
|
115
115
|
})
|
|
116
116
|
|
|
@@ -119,6 +119,7 @@ describe('InfiniteQueryObserver', () => {
|
|
|
119
119
|
|
|
120
120
|
expect(observer.getCurrentResult().data?.pages).toEqual(['1', '2'])
|
|
121
121
|
expect(queryFn).toBeCalledTimes(2)
|
|
122
|
+
expect(observer.getCurrentResult().hasNextPage).toBe(true)
|
|
122
123
|
|
|
123
124
|
next = undefined
|
|
124
125
|
|
|
@@ -126,5 +127,33 @@ describe('InfiniteQueryObserver', () => {
|
|
|
126
127
|
|
|
127
128
|
expect(observer.getCurrentResult().data?.pages).toEqual(['1'])
|
|
128
129
|
expect(queryFn).toBeCalledTimes(3)
|
|
130
|
+
expect(observer.getCurrentResult().hasNextPage).toBe(false)
|
|
131
|
+
})
|
|
132
|
+
|
|
133
|
+
test('should stop refetching if null is returned from getNextPageParam', async () => {
|
|
134
|
+
const key = queryKey()
|
|
135
|
+
let next: number | null = 2
|
|
136
|
+
const queryFn = vi.fn<any, any>(({ pageParam }) => String(pageParam))
|
|
137
|
+
const observer = new InfiniteQueryObserver(queryClient, {
|
|
138
|
+
queryKey: key,
|
|
139
|
+
queryFn,
|
|
140
|
+
initialPageParam: 1,
|
|
141
|
+
getNextPageParam: () => next,
|
|
142
|
+
})
|
|
143
|
+
|
|
144
|
+
await observer.fetchNextPage()
|
|
145
|
+
await observer.fetchNextPage()
|
|
146
|
+
|
|
147
|
+
expect(observer.getCurrentResult().data?.pages).toEqual(['1', '2'])
|
|
148
|
+
expect(queryFn).toBeCalledTimes(2)
|
|
149
|
+
expect(observer.getCurrentResult().hasNextPage).toBe(true)
|
|
150
|
+
|
|
151
|
+
next = null
|
|
152
|
+
|
|
153
|
+
await observer.refetch()
|
|
154
|
+
|
|
155
|
+
expect(observer.getCurrentResult().data?.pages).toEqual(['1'])
|
|
156
|
+
expect(queryFn).toBeCalledTimes(3)
|
|
157
|
+
expect(observer.getCurrentResult().hasNextPage).toBe(false)
|
|
129
158
|
})
|
|
130
159
|
})
|
|
@@ -79,7 +79,7 @@ describe('mutations', () => {
|
|
|
79
79
|
submittedAt: 0,
|
|
80
80
|
})
|
|
81
81
|
|
|
82
|
-
const states: MutationState<string, unknown, string, string
|
|
82
|
+
const states: Array<MutationState<string, unknown, string, string>> = []
|
|
83
83
|
|
|
84
84
|
mutation.subscribe((state) => {
|
|
85
85
|
states.push(state)
|
|
@@ -159,7 +159,7 @@ describe('mutations', () => {
|
|
|
159
159
|
retryDelay: 1,
|
|
160
160
|
})
|
|
161
161
|
|
|
162
|
-
const states: MutationState<string, unknown, string, string
|
|
162
|
+
const states: Array<MutationState<string, unknown, string, string>> = []
|
|
163
163
|
|
|
164
164
|
mutation.subscribe((state) => {
|
|
165
165
|
states.push(state)
|
|
@@ -68,7 +68,7 @@ describe('queriesObserver', () => {
|
|
|
68
68
|
{ queryKey: key1, queryFn: queryFn1 },
|
|
69
69
|
{ queryKey: key2, queryFn: queryFn2 },
|
|
70
70
|
])
|
|
71
|
-
const results: QueryObserverResult
|
|
71
|
+
const results: Array<Array<QueryObserverResult>> = []
|
|
72
72
|
results.push(observer.getCurrentResult())
|
|
73
73
|
const unsubscribe = observer.subscribe((result) => {
|
|
74
74
|
results.push(result)
|
|
@@ -113,7 +113,7 @@ describe('queriesObserver', () => {
|
|
|
113
113
|
{ queryKey: key1, queryFn: queryFn1 },
|
|
114
114
|
{ queryKey: key2, queryFn: queryFn2 },
|
|
115
115
|
])
|
|
116
|
-
const results: QueryObserverResult
|
|
116
|
+
const results: Array<Array<QueryObserverResult>> = []
|
|
117
117
|
results.push(observer.getCurrentResult())
|
|
118
118
|
const unsubscribe = observer.subscribe((result) => {
|
|
119
119
|
results.push(result)
|
|
@@ -160,7 +160,7 @@ describe('queriesObserver', () => {
|
|
|
160
160
|
{ queryKey: key1, queryFn: queryFn1 },
|
|
161
161
|
{ queryKey: key2, queryFn: queryFn2 },
|
|
162
162
|
])
|
|
163
|
-
const results: QueryObserverResult
|
|
163
|
+
const results: Array<Array<QueryObserverResult>> = []
|
|
164
164
|
results.push(observer.getCurrentResult())
|
|
165
165
|
const unsubscribe = observer.subscribe((result) => {
|
|
166
166
|
results.push(result)
|
|
@@ -208,7 +208,7 @@ describe('queriesObserver', () => {
|
|
|
208
208
|
{ queryKey: key1, queryFn: queryFn1 },
|
|
209
209
|
{ queryKey: key2, queryFn: queryFn2 },
|
|
210
210
|
])
|
|
211
|
-
const results: QueryObserverResult
|
|
211
|
+
const results: Array<Array<QueryObserverResult>> = []
|
|
212
212
|
results.push(observer.getCurrentResult())
|
|
213
213
|
const unsubscribe = observer.subscribe((result) => {
|
|
214
214
|
results.push(result)
|