@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.
Files changed (171) hide show
  1. package/build/legacy/hydration.cjs.map +1 -1
  2. package/build/legacy/hydration.d.cts +3 -3
  3. package/build/legacy/hydration.d.ts +3 -3
  4. package/build/legacy/hydration.js.map +1 -1
  5. package/build/legacy/index.cjs +3 -0
  6. package/build/legacy/index.cjs.map +1 -1
  7. package/build/legacy/index.d.cts +1 -1
  8. package/build/legacy/index.d.ts +1 -1
  9. package/build/legacy/index.js +2 -0
  10. package/build/legacy/index.js.map +1 -1
  11. package/build/legacy/infiniteQueryBehavior.cjs +23 -6
  12. package/build/legacy/infiniteQueryBehavior.cjs.map +1 -1
  13. package/build/legacy/infiniteQueryBehavior.d.cts +2 -2
  14. package/build/legacy/infiniteQueryBehavior.d.ts +2 -2
  15. package/build/legacy/infiniteQueryBehavior.js +23 -6
  16. package/build/legacy/infiniteQueryBehavior.js.map +1 -1
  17. package/build/legacy/infiniteQueryObserver.cjs.map +1 -1
  18. package/build/legacy/infiniteQueryObserver.d.cts +3 -3
  19. package/build/legacy/infiniteQueryObserver.d.ts +3 -3
  20. package/build/legacy/infiniteQueryObserver.js.map +1 -1
  21. package/build/legacy/mutation.cjs.map +1 -1
  22. package/build/legacy/mutation.d.cts +1 -1
  23. package/build/legacy/mutation.d.ts +1 -1
  24. package/build/legacy/mutation.js.map +1 -1
  25. package/build/legacy/mutationCache.cjs.map +1 -1
  26. package/build/legacy/mutationCache.d.cts +1 -1
  27. package/build/legacy/mutationCache.d.ts +1 -1
  28. package/build/legacy/mutationCache.js.map +1 -1
  29. package/build/legacy/mutationObserver.d.cts +1 -1
  30. package/build/legacy/mutationObserver.d.ts +1 -1
  31. package/build/legacy/notifyManager.cjs.map +1 -1
  32. package/build/legacy/notifyManager.d.cts +1 -1
  33. package/build/legacy/notifyManager.d.ts +1 -1
  34. package/build/legacy/notifyManager.js.map +1 -1
  35. package/build/legacy/queriesObserver.cjs +6 -8
  36. package/build/legacy/queriesObserver.cjs.map +1 -1
  37. package/build/legacy/queriesObserver.d.cts +11 -11
  38. package/build/legacy/queriesObserver.d.ts +11 -11
  39. package/build/legacy/queriesObserver.js +6 -8
  40. package/build/legacy/queriesObserver.js.map +1 -1
  41. package/build/legacy/query.cjs +10 -2
  42. package/build/legacy/query.cjs.map +1 -1
  43. package/build/legacy/query.d.cts +1 -1
  44. package/build/legacy/query.d.ts +1 -1
  45. package/build/legacy/query.js +10 -2
  46. package/build/legacy/query.js.map +1 -1
  47. package/build/legacy/queryCache.cjs.map +1 -1
  48. package/build/legacy/queryCache.d.cts +1 -1
  49. package/build/legacy/queryCache.d.ts +1 -1
  50. package/build/legacy/queryCache.js.map +1 -1
  51. package/build/legacy/{queryClient-9264ae39.d.ts → queryClient-230e991e.d.ts} +28 -25
  52. package/build/legacy/{queryClient-7060338a.d.ts → queryClient-64e47985.d.ts} +28 -25
  53. package/build/legacy/queryClient.cjs +4 -3
  54. package/build/legacy/queryClient.cjs.map +1 -1
  55. package/build/legacy/queryClient.d.cts +1 -1
  56. package/build/legacy/queryClient.d.ts +1 -1
  57. package/build/legacy/queryClient.js +4 -3
  58. package/build/legacy/queryClient.js.map +1 -1
  59. package/build/legacy/queryObserver.cjs +1 -1
  60. package/build/legacy/queryObserver.cjs.map +1 -1
  61. package/build/legacy/queryObserver.d.cts +1 -1
  62. package/build/legacy/queryObserver.d.ts +1 -1
  63. package/build/legacy/queryObserver.js +1 -1
  64. package/build/legacy/queryObserver.js.map +1 -1
  65. package/build/legacy/retryer.d.cts +1 -1
  66. package/build/legacy/retryer.d.ts +1 -1
  67. package/build/legacy/types.cjs.map +1 -1
  68. package/build/legacy/types.d.cts +1 -1
  69. package/build/legacy/types.d.ts +1 -1
  70. package/build/legacy/utils.cjs.map +1 -1
  71. package/build/legacy/utils.d.cts +1 -1
  72. package/build/legacy/utils.d.ts +1 -1
  73. package/build/legacy/utils.js.map +1 -1
  74. package/build/modern/hydration.cjs.map +1 -1
  75. package/build/modern/hydration.d.cts +3 -3
  76. package/build/modern/hydration.d.ts +3 -3
  77. package/build/modern/hydration.js.map +1 -1
  78. package/build/modern/index.cjs +3 -0
  79. package/build/modern/index.cjs.map +1 -1
  80. package/build/modern/index.d.cts +1 -1
  81. package/build/modern/index.d.ts +1 -1
  82. package/build/modern/index.js +2 -0
  83. package/build/modern/index.js.map +1 -1
  84. package/build/modern/infiniteQueryBehavior.cjs +21 -6
  85. package/build/modern/infiniteQueryBehavior.cjs.map +1 -1
  86. package/build/modern/infiniteQueryBehavior.d.cts +2 -2
  87. package/build/modern/infiniteQueryBehavior.d.ts +2 -2
  88. package/build/modern/infiniteQueryBehavior.js +21 -6
  89. package/build/modern/infiniteQueryBehavior.js.map +1 -1
  90. package/build/modern/infiniteQueryObserver.cjs.map +1 -1
  91. package/build/modern/infiniteQueryObserver.d.cts +3 -3
  92. package/build/modern/infiniteQueryObserver.d.ts +3 -3
  93. package/build/modern/infiniteQueryObserver.js.map +1 -1
  94. package/build/modern/mutation.cjs.map +1 -1
  95. package/build/modern/mutation.d.cts +1 -1
  96. package/build/modern/mutation.d.ts +1 -1
  97. package/build/modern/mutation.js.map +1 -1
  98. package/build/modern/mutationCache.cjs.map +1 -1
  99. package/build/modern/mutationCache.d.cts +1 -1
  100. package/build/modern/mutationCache.d.ts +1 -1
  101. package/build/modern/mutationCache.js.map +1 -1
  102. package/build/modern/mutationObserver.d.cts +1 -1
  103. package/build/modern/mutationObserver.d.ts +1 -1
  104. package/build/modern/notifyManager.cjs.map +1 -1
  105. package/build/modern/notifyManager.d.cts +1 -1
  106. package/build/modern/notifyManager.d.ts +1 -1
  107. package/build/modern/notifyManager.js.map +1 -1
  108. package/build/modern/queriesObserver.cjs +6 -8
  109. package/build/modern/queriesObserver.cjs.map +1 -1
  110. package/build/modern/queriesObserver.d.cts +11 -11
  111. package/build/modern/queriesObserver.d.ts +11 -11
  112. package/build/modern/queriesObserver.js +6 -8
  113. package/build/modern/queriesObserver.js.map +1 -1
  114. package/build/modern/query.cjs +10 -2
  115. package/build/modern/query.cjs.map +1 -1
  116. package/build/modern/query.d.cts +1 -1
  117. package/build/modern/query.d.ts +1 -1
  118. package/build/modern/query.js +10 -2
  119. package/build/modern/query.js.map +1 -1
  120. package/build/modern/queryCache.cjs.map +1 -1
  121. package/build/modern/queryCache.d.cts +1 -1
  122. package/build/modern/queryCache.d.ts +1 -1
  123. package/build/modern/queryCache.js.map +1 -1
  124. package/build/modern/{queryClient-9264ae39.d.ts → queryClient-230e991e.d.ts} +28 -25
  125. package/build/modern/{queryClient-7060338a.d.ts → queryClient-64e47985.d.ts} +28 -25
  126. package/build/modern/queryClient.cjs +4 -3
  127. package/build/modern/queryClient.cjs.map +1 -1
  128. package/build/modern/queryClient.d.cts +1 -1
  129. package/build/modern/queryClient.d.ts +1 -1
  130. package/build/modern/queryClient.js +4 -3
  131. package/build/modern/queryClient.js.map +1 -1
  132. package/build/modern/queryObserver.cjs +1 -1
  133. package/build/modern/queryObserver.cjs.map +1 -1
  134. package/build/modern/queryObserver.d.cts +1 -1
  135. package/build/modern/queryObserver.d.ts +1 -1
  136. package/build/modern/queryObserver.js +1 -1
  137. package/build/modern/queryObserver.js.map +1 -1
  138. package/build/modern/retryer.d.cts +1 -1
  139. package/build/modern/retryer.d.ts +1 -1
  140. package/build/modern/types.cjs.map +1 -1
  141. package/build/modern/types.d.cts +1 -1
  142. package/build/modern/types.d.ts +1 -1
  143. package/build/modern/utils.cjs.map +1 -1
  144. package/build/modern/utils.d.cts +1 -1
  145. package/build/modern/utils.d.ts +1 -1
  146. package/build/modern/utils.js.map +1 -1
  147. package/package.json +6 -2
  148. package/src/hydration.ts +2 -2
  149. package/src/index.ts +2 -1
  150. package/src/infiniteQueryBehavior.ts +23 -8
  151. package/src/infiniteQueryObserver.ts +7 -2
  152. package/src/mutation.ts +1 -1
  153. package/src/mutationCache.ts +3 -3
  154. package/src/notifyManager.ts +3 -3
  155. package/src/queriesObserver.ts +24 -25
  156. package/src/query.ts +12 -2
  157. package/src/queryCache.ts +2 -2
  158. package/src/queryClient.ts +17 -7
  159. package/src/queryObserver.ts +1 -1
  160. package/src/tests/hydration.test.tsx +2 -2
  161. package/src/tests/infiniteQueryBehavior.test.tsx +4 -4
  162. package/src/tests/infiniteQueryObserver.test.tsx +36 -7
  163. package/src/tests/mutations.test.tsx +2 -2
  164. package/src/tests/queriesObserver.test.tsx +4 -4
  165. package/src/tests/query.test.tsx +55 -3
  166. package/src/tests/queryClient.test.tsx +77 -38
  167. package/src/tests/queryObserver.test.tsx +22 -22
  168. package/src/tests/utils.test.tsx +2 -2
  169. package/src/tests/utils.ts +0 -5
  170. package/src/types.ts +41 -20
  171. 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
- context.fetchFn = async () => {
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 (typeof param === 'undefined' && data.pages.length) {
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.defaultPageParam,
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 typeof getNextPageParam(options, data) !== 'undefined'
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 typeof getPreviousPageParam(options, data) !== 'undefined'
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<TQueryFnData, TError, InfiniteData<TQueryData>, TQueryKey>,
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>
@@ -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
  )
@@ -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[]> = (...args: T) => void
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) => {
@@ -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[], array2: T[]): 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[], index: number, value: T): 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[]) => void
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[]) => TCombinedResult
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[]) => TCombinedResult,
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[]): TCombinedResult {
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[] = unmatchedQueries.map(
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))
@@ -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<TQueryFnData, TError, TData>(
329
- options.pages,
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,
@@ -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() !== optimisticResult) {
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[], 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[], 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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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
- defaultPageParam: 1,
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)