@tanstack/query-core 5.0.0-alpha.61 → 5.0.0-alpha.66

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 (98) hide show
  1. package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.cjs +16 -0
  2. package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.cjs.map +1 -0
  3. package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.js +13 -0
  4. package/build/lib/_virtual/_rollupPluginBabelHelpers.legacy.js.map +1 -0
  5. package/build/lib/focusManager.legacy.cjs +90 -0
  6. package/build/lib/focusManager.legacy.cjs.map +1 -0
  7. package/build/lib/focusManager.legacy.js +87 -0
  8. package/build/lib/focusManager.legacy.js.map +1 -0
  9. package/build/lib/hydration.legacy.cjs +92 -0
  10. package/build/lib/hydration.legacy.cjs.map +1 -0
  11. package/build/lib/hydration.legacy.js +87 -0
  12. package/build/lib/hydration.legacy.js.map +1 -0
  13. package/build/lib/index.legacy.cjs +40 -0
  14. package/build/lib/index.legacy.cjs.map +1 -0
  15. package/build/lib/index.legacy.js +14 -0
  16. package/build/lib/index.legacy.js.map +1 -0
  17. package/build/lib/infiniteQueryBehavior.cjs +6 -13
  18. package/build/lib/infiniteQueryBehavior.cjs.map +1 -1
  19. package/build/lib/infiniteQueryBehavior.d.ts +1 -1
  20. package/build/lib/infiniteQueryBehavior.d.ts.map +1 -1
  21. package/build/lib/infiniteQueryBehavior.js +6 -13
  22. package/build/lib/infiniteQueryBehavior.js.map +1 -1
  23. package/build/lib/infiniteQueryBehavior.legacy.cjs +125 -0
  24. package/build/lib/infiniteQueryBehavior.legacy.cjs.map +1 -0
  25. package/build/lib/infiniteQueryBehavior.legacy.js +121 -0
  26. package/build/lib/infiniteQueryBehavior.legacy.js.map +1 -0
  27. package/build/lib/infiniteQueryObserver.legacy.cjs +78 -0
  28. package/build/lib/infiniteQueryObserver.legacy.cjs.map +1 -0
  29. package/build/lib/infiniteQueryObserver.legacy.js +76 -0
  30. package/build/lib/infiniteQueryObserver.legacy.js.map +1 -0
  31. package/build/lib/mutation.legacy.cjs +262 -0
  32. package/build/lib/mutation.legacy.cjs.map +1 -0
  33. package/build/lib/mutation.legacy.js +259 -0
  34. package/build/lib/mutation.legacy.js.map +1 -0
  35. package/build/lib/mutationCache.legacy.cjs +98 -0
  36. package/build/lib/mutationCache.legacy.cjs.map +1 -0
  37. package/build/lib/mutationCache.legacy.js +96 -0
  38. package/build/lib/mutationCache.legacy.js.map +1 -0
  39. package/build/lib/mutationObserver.legacy.cjs +128 -0
  40. package/build/lib/mutationObserver.legacy.cjs.map +1 -0
  41. package/build/lib/mutationObserver.legacy.js +126 -0
  42. package/build/lib/mutationObserver.legacy.js.map +1 -0
  43. package/build/lib/notifyManager.legacy.cjs +92 -0
  44. package/build/lib/notifyManager.legacy.cjs.map +1 -0
  45. package/build/lib/notifyManager.legacy.js +89 -0
  46. package/build/lib/notifyManager.legacy.js.map +1 -0
  47. package/build/lib/onlineManager.legacy.cjs +94 -0
  48. package/build/lib/onlineManager.legacy.cjs.map +1 -0
  49. package/build/lib/onlineManager.legacy.js +91 -0
  50. package/build/lib/onlineManager.legacy.js.map +1 -0
  51. package/build/lib/queriesObserver.legacy.cjs +207 -0
  52. package/build/lib/queriesObserver.legacy.cjs.map +1 -0
  53. package/build/lib/queriesObserver.legacy.js +205 -0
  54. package/build/lib/queriesObserver.legacy.js.map +1 -0
  55. package/build/lib/query.legacy.cjs +471 -0
  56. package/build/lib/query.legacy.cjs.map +1 -0
  57. package/build/lib/query.legacy.js +469 -0
  58. package/build/lib/query.legacy.js.map +1 -0
  59. package/build/lib/queryCache.legacy.cjs +111 -0
  60. package/build/lib/queryCache.legacy.cjs.map +1 -0
  61. package/build/lib/queryCache.legacy.js +109 -0
  62. package/build/lib/queryCache.legacy.js.map +1 -0
  63. package/build/lib/queryClient.cjs +1 -1
  64. package/build/lib/queryClient.cjs.map +1 -1
  65. package/build/lib/queryClient.d.ts.map +1 -1
  66. package/build/lib/queryClient.js +1 -1
  67. package/build/lib/queryClient.js.map +1 -1
  68. package/build/lib/queryClient.legacy.cjs +322 -0
  69. package/build/lib/queryClient.legacy.cjs.map +1 -0
  70. package/build/lib/queryClient.legacy.js +320 -0
  71. package/build/lib/queryClient.legacy.js.map +1 -0
  72. package/build/lib/queryObserver.legacy.cjs +526 -0
  73. package/build/lib/queryObserver.legacy.cjs.map +1 -0
  74. package/build/lib/queryObserver.legacy.js +524 -0
  75. package/build/lib/queryObserver.legacy.js.map +1 -0
  76. package/build/lib/removable.legacy.cjs +38 -0
  77. package/build/lib/removable.legacy.cjs.map +1 -0
  78. package/build/lib/removable.legacy.js +36 -0
  79. package/build/lib/removable.legacy.js.map +1 -0
  80. package/build/lib/retryer.legacy.cjs +158 -0
  81. package/build/lib/retryer.legacy.cjs.map +1 -0
  82. package/build/lib/retryer.legacy.js +153 -0
  83. package/build/lib/retryer.legacy.js.map +1 -0
  84. package/build/lib/subscribable.legacy.cjs +28 -0
  85. package/build/lib/subscribable.legacy.cjs.map +1 -0
  86. package/build/lib/subscribable.legacy.js +26 -0
  87. package/build/lib/subscribable.legacy.js.map +1 -0
  88. package/build/lib/types.d.ts +8 -2
  89. package/build/lib/types.d.ts.map +1 -1
  90. package/build/lib/utils.legacy.cjs +248 -0
  91. package/build/lib/utils.legacy.cjs.map +1 -0
  92. package/build/lib/utils.legacy.js +227 -0
  93. package/build/lib/utils.legacy.js.map +1 -0
  94. package/package.json +3 -3
  95. package/src/infiniteQueryBehavior.ts +12 -17
  96. package/src/queryClient.ts +3 -1
  97. package/src/tests/queryClient.test.tsx +40 -0
  98. package/src/types.ts +17 -9
@@ -0,0 +1,248 @@
1
+ 'use strict';
2
+
3
+ // TYPES
4
+
5
+ // UTILS
6
+
7
+ const isServer = typeof window === 'undefined' || 'Deno' in window;
8
+ function noop() {
9
+ return undefined;
10
+ }
11
+ function functionalUpdate(updater, input) {
12
+ return typeof updater === 'function' ? updater(input) : updater;
13
+ }
14
+ function isValidTimeout(value) {
15
+ return typeof value === 'number' && value >= 0 && value !== Infinity;
16
+ }
17
+ function timeUntilStale(updatedAt, staleTime) {
18
+ return Math.max(updatedAt + (staleTime || 0) - Date.now(), 0);
19
+ }
20
+ function matchQuery(filters, query) {
21
+ const {
22
+ type = 'all',
23
+ exact,
24
+ fetchStatus,
25
+ predicate,
26
+ queryKey,
27
+ stale
28
+ } = filters;
29
+ if (queryKey) {
30
+ if (exact) {
31
+ if (query.queryHash !== hashQueryKeyByOptions(queryKey, query.options)) {
32
+ return false;
33
+ }
34
+ } else if (!partialMatchKey(query.queryKey, queryKey)) {
35
+ return false;
36
+ }
37
+ }
38
+ if (type !== 'all') {
39
+ const isActive = query.isActive();
40
+ if (type === 'active' && !isActive) {
41
+ return false;
42
+ }
43
+ if (type === 'inactive' && isActive) {
44
+ return false;
45
+ }
46
+ }
47
+ if (typeof stale === 'boolean' && query.isStale() !== stale) {
48
+ return false;
49
+ }
50
+ if (typeof fetchStatus !== 'undefined' && fetchStatus !== query.state.fetchStatus) {
51
+ return false;
52
+ }
53
+ if (predicate && !predicate(query)) {
54
+ return false;
55
+ }
56
+ return true;
57
+ }
58
+ function matchMutation(filters, mutation) {
59
+ const {
60
+ exact,
61
+ status,
62
+ predicate,
63
+ mutationKey
64
+ } = filters;
65
+ if (mutationKey) {
66
+ if (!mutation.options.mutationKey) {
67
+ return false;
68
+ }
69
+ if (exact) {
70
+ if (hashKey(mutation.options.mutationKey) !== hashKey(mutationKey)) {
71
+ return false;
72
+ }
73
+ } else if (!partialMatchKey(mutation.options.mutationKey, mutationKey)) {
74
+ return false;
75
+ }
76
+ }
77
+ if (status && mutation.state.status !== status) {
78
+ return false;
79
+ }
80
+ if (predicate && !predicate(mutation)) {
81
+ return false;
82
+ }
83
+ return true;
84
+ }
85
+ function hashQueryKeyByOptions(queryKey, options) {
86
+ const hashFn = (options == null ? void 0 : options.queryKeyHashFn) || hashKey;
87
+ return hashFn(queryKey);
88
+ }
89
+
90
+ /**
91
+ * Default query & mutation keys hash function.
92
+ * Hashes the value into a stable hash.
93
+ */
94
+ function hashKey(queryKey) {
95
+ return JSON.stringify(queryKey, (_, val) => isPlainObject(val) ? Object.keys(val).sort().reduce((result, key) => {
96
+ result[key] = val[key];
97
+ return result;
98
+ }, {}) : val);
99
+ }
100
+
101
+ /**
102
+ * Checks if key `b` partially matches with key `a`.
103
+ */
104
+
105
+ function partialMatchKey(a, b) {
106
+ if (a === b) {
107
+ return true;
108
+ }
109
+ if (typeof a !== typeof b) {
110
+ return false;
111
+ }
112
+ if (a && b && typeof a === 'object' && typeof b === 'object') {
113
+ return !Object.keys(b).some(key => !partialMatchKey(a[key], b[key]));
114
+ }
115
+ return false;
116
+ }
117
+
118
+ /**
119
+ * This function returns `a` if `b` is deeply equal.
120
+ * If not, it will replace any deeply equal children of `b` with those of `a`.
121
+ * This can be used for structural sharing between JSON values for example.
122
+ */
123
+
124
+ function replaceEqualDeep(a, b) {
125
+ if (a === b) {
126
+ return a;
127
+ }
128
+ const array = isPlainArray(a) && isPlainArray(b);
129
+ if (array || isPlainObject(a) && isPlainObject(b)) {
130
+ const aSize = array ? a.length : Object.keys(a).length;
131
+ const bItems = array ? b : Object.keys(b);
132
+ const bSize = bItems.length;
133
+ const copy = array ? [] : {};
134
+ let equalItems = 0;
135
+ for (let i = 0; i < bSize; i++) {
136
+ const key = array ? i : bItems[i];
137
+ copy[key] = replaceEqualDeep(a[key], b[key]);
138
+ if (copy[key] === a[key]) {
139
+ equalItems++;
140
+ }
141
+ }
142
+ return aSize === bSize && equalItems === aSize ? a : copy;
143
+ }
144
+ return b;
145
+ }
146
+
147
+ /**
148
+ * Shallow compare objects. Only works with objects that always have the same properties.
149
+ */
150
+ function shallowEqualObjects(a, b) {
151
+ if (a && !b || b && !a) {
152
+ return false;
153
+ }
154
+ for (const key in a) {
155
+ if (a[key] !== b[key]) {
156
+ return false;
157
+ }
158
+ }
159
+ return true;
160
+ }
161
+ function isPlainArray(value) {
162
+ return Array.isArray(value) && value.length === Object.keys(value).length;
163
+ }
164
+
165
+ // Copied from: https://github.com/jonschlinkert/is-plain-object
166
+ function isPlainObject(o) {
167
+ if (!hasObjectPrototype(o)) {
168
+ return false;
169
+ }
170
+
171
+ // If has modified constructor
172
+ const ctor = o.constructor;
173
+ if (typeof ctor === 'undefined') {
174
+ return true;
175
+ }
176
+
177
+ // If has modified prototype
178
+ const prot = ctor.prototype;
179
+ if (!hasObjectPrototype(prot)) {
180
+ return false;
181
+ }
182
+
183
+ // If constructor does not have an Object-specific method
184
+ if (!prot.hasOwnProperty('isPrototypeOf')) {
185
+ return false;
186
+ }
187
+
188
+ // Most likely a plain Object
189
+ return true;
190
+ }
191
+ function hasObjectPrototype(o) {
192
+ return Object.prototype.toString.call(o) === '[object Object]';
193
+ }
194
+ function sleep(timeout) {
195
+ return new Promise(resolve => {
196
+ setTimeout(resolve, timeout);
197
+ });
198
+ }
199
+
200
+ /**
201
+ * Schedules a microtask.
202
+ * This can be useful to schedule state updates after rendering.
203
+ */
204
+ function scheduleMicrotask(callback) {
205
+ sleep(0).then(callback);
206
+ }
207
+ function replaceData(prevData, data, options) {
208
+ if (typeof options.structuralSharing === 'function') {
209
+ return options.structuralSharing(prevData, data);
210
+ } else if (options.structuralSharing !== false) {
211
+ // Structurally share data between prev and new data if needed
212
+ return replaceEqualDeep(prevData, data);
213
+ }
214
+ return data;
215
+ }
216
+ function keepPreviousData(previousData) {
217
+ return previousData;
218
+ }
219
+ function addToEnd(items, item, max = 0) {
220
+ const newItems = [...items, item];
221
+ return max && newItems.length > max ? newItems.slice(1) : newItems;
222
+ }
223
+ function addToStart(items, item, max = 0) {
224
+ const newItems = [item, ...items];
225
+ return max && newItems.length > max ? newItems.slice(0, -1) : newItems;
226
+ }
227
+
228
+ exports.addToEnd = addToEnd;
229
+ exports.addToStart = addToStart;
230
+ exports.functionalUpdate = functionalUpdate;
231
+ exports.hashKey = hashKey;
232
+ exports.hashQueryKeyByOptions = hashQueryKeyByOptions;
233
+ exports.isPlainArray = isPlainArray;
234
+ exports.isPlainObject = isPlainObject;
235
+ exports.isServer = isServer;
236
+ exports.isValidTimeout = isValidTimeout;
237
+ exports.keepPreviousData = keepPreviousData;
238
+ exports.matchMutation = matchMutation;
239
+ exports.matchQuery = matchQuery;
240
+ exports.noop = noop;
241
+ exports.partialMatchKey = partialMatchKey;
242
+ exports.replaceData = replaceData;
243
+ exports.replaceEqualDeep = replaceEqualDeep;
244
+ exports.scheduleMicrotask = scheduleMicrotask;
245
+ exports.shallowEqualObjects = shallowEqualObjects;
246
+ exports.sleep = sleep;
247
+ exports.timeUntilStale = timeUntilStale;
248
+ //# sourceMappingURL=utils.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.legacy.cjs","sources":["../../src/utils.ts"],"sourcesContent":["import type { Mutation } from './mutation'\nimport type { Query } from './query'\nimport type {\n FetchStatus,\n MutationKey,\n MutationStatus,\n QueryKey,\n QueryOptions,\n} from './types'\n\n// TYPES\n\nexport interface QueryFilters {\n /**\n * Filter to active queries, inactive queries or all queries\n */\n type?: QueryTypeFilter\n /**\n * Match query key exactly\n */\n exact?: boolean\n /**\n * Include queries matching this predicate function\n */\n predicate?: (query: Query) => boolean\n /**\n * Include queries matching this query key\n */\n queryKey?: QueryKey\n /**\n * Include or exclude stale queries\n */\n stale?: boolean\n /**\n * Include queries matching their fetchStatus\n */\n fetchStatus?: FetchStatus\n}\n\nexport interface MutationFilters {\n /**\n * Match mutation key exactly\n */\n exact?: boolean\n /**\n * Include mutations matching this predicate function\n */\n predicate?: (mutation: Mutation<any, any, any>) => boolean\n /**\n * Include mutations matching this mutation key\n */\n mutationKey?: MutationKey\n /**\n * Filter by mutation status\n */\n status?: MutationStatus\n}\n\nexport type DataUpdateFunction<TInput, TOutput> = (input: TInput) => TOutput\n\nexport type Updater<TInput, TOutput> =\n | TOutput\n | DataUpdateFunction<TInput, TOutput>\n\nexport type QueryTypeFilter = 'all' | 'active' | 'inactive'\n\n// UTILS\n\nexport const isServer = typeof window === 'undefined' || 'Deno' in window\n\nexport function noop(): undefined {\n return undefined\n}\n\nexport function functionalUpdate<TInput, TOutput>(\n updater: Updater<TInput, TOutput>,\n input: TInput,\n): TOutput {\n return typeof updater === 'function'\n ? (updater as DataUpdateFunction<TInput, TOutput>)(input)\n : updater\n}\n\nexport function isValidTimeout(value: unknown): value is number {\n return typeof value === 'number' && value >= 0 && value !== Infinity\n}\n\nexport function timeUntilStale(updatedAt: number, staleTime?: number): number {\n return Math.max(updatedAt + (staleTime || 0) - Date.now(), 0)\n}\n\nexport function matchQuery(\n filters: QueryFilters,\n query: Query<any, any, any, any>,\n): boolean {\n const {\n type = 'all',\n exact,\n fetchStatus,\n predicate,\n queryKey,\n stale,\n } = filters\n\n if (queryKey) {\n if (exact) {\n if (query.queryHash !== hashQueryKeyByOptions(queryKey, query.options)) {\n return false\n }\n } else if (!partialMatchKey(query.queryKey, queryKey)) {\n return false\n }\n }\n\n if (type !== 'all') {\n const isActive = query.isActive()\n if (type === 'active' && !isActive) {\n return false\n }\n if (type === 'inactive' && isActive) {\n return false\n }\n }\n\n if (typeof stale === 'boolean' && query.isStale() !== stale) {\n return false\n }\n\n if (\n typeof fetchStatus !== 'undefined' &&\n fetchStatus !== query.state.fetchStatus\n ) {\n return false\n }\n\n if (predicate && !predicate(query)) {\n return false\n }\n\n return true\n}\n\nexport function matchMutation(\n filters: MutationFilters,\n mutation: Mutation<any, any>,\n): boolean {\n const { exact, status, predicate, mutationKey } = filters\n if (mutationKey) {\n if (!mutation.options.mutationKey) {\n return false\n }\n if (exact) {\n if (hashKey(mutation.options.mutationKey) !== hashKey(mutationKey)) {\n return false\n }\n } else if (!partialMatchKey(mutation.options.mutationKey, mutationKey)) {\n return false\n }\n }\n\n if (status && mutation.state.status !== status) {\n return false\n }\n\n if (predicate && !predicate(mutation)) {\n return false\n }\n\n return true\n}\n\nexport function hashQueryKeyByOptions<TQueryKey extends QueryKey = QueryKey>(\n queryKey: TQueryKey,\n options?: QueryOptions<any, any, any, TQueryKey>,\n): string {\n const hashFn = options?.queryKeyHashFn || hashKey\n return hashFn(queryKey)\n}\n\n/**\n * Default query & mutation keys hash function.\n * Hashes the value into a stable hash.\n */\nexport function hashKey(queryKey: QueryKey | MutationKey): string {\n return JSON.stringify(queryKey, (_, val) =>\n isPlainObject(val)\n ? Object.keys(val)\n .sort()\n .reduce((result, key) => {\n result[key] = val[key]\n return result\n }, {} as any)\n : val,\n )\n}\n\n/**\n * Checks if key `b` partially matches with key `a`.\n */\nexport function partialMatchKey(a: QueryKey, b: QueryKey): boolean\nexport function partialMatchKey(a: any, b: any): boolean {\n if (a === b) {\n return true\n }\n\n if (typeof a !== typeof b) {\n return false\n }\n\n if (a && b && typeof a === 'object' && typeof b === 'object') {\n return !Object.keys(b).some((key) => !partialMatchKey(a[key], b[key]))\n }\n\n return false\n}\n\n/**\n * This function returns `a` if `b` is deeply equal.\n * If not, it will replace any deeply equal children of `b` with those of `a`.\n * This can be used for structural sharing between JSON values for example.\n */\nexport function replaceEqualDeep<T>(a: unknown, b: T): T\nexport function replaceEqualDeep(a: any, b: any): any {\n if (a === b) {\n return a\n }\n\n const array = isPlainArray(a) && isPlainArray(b)\n\n if (array || (isPlainObject(a) && isPlainObject(b))) {\n const aSize = array ? a.length : Object.keys(a).length\n const bItems = array ? b : Object.keys(b)\n const bSize = bItems.length\n const copy: any = array ? [] : {}\n\n let equalItems = 0\n\n for (let i = 0; i < bSize; i++) {\n const key = array ? i : bItems[i]\n copy[key] = replaceEqualDeep(a[key], b[key])\n if (copy[key] === a[key]) {\n equalItems++\n }\n }\n\n return aSize === bSize && equalItems === aSize ? a : copy\n }\n\n return b\n}\n\n/**\n * Shallow compare objects. Only works with objects that always have the same properties.\n */\nexport function shallowEqualObjects<T>(a: T, b: T): boolean {\n if ((a && !b) || (b && !a)) {\n return false\n }\n\n for (const key in a) {\n if (a[key] !== b[key]) {\n return false\n }\n }\n\n return true\n}\n\nexport function isPlainArray(value: unknown) {\n return Array.isArray(value) && value.length === Object.keys(value).length\n}\n\n// Copied from: https://github.com/jonschlinkert/is-plain-object\nexport function isPlainObject(o: any): o is Object {\n if (!hasObjectPrototype(o)) {\n return false\n }\n\n // If has modified constructor\n const ctor = o.constructor\n if (typeof ctor === 'undefined') {\n return true\n }\n\n // If has modified prototype\n const prot = ctor.prototype\n if (!hasObjectPrototype(prot)) {\n return false\n }\n\n // If constructor does not have an Object-specific method\n if (!prot.hasOwnProperty('isPrototypeOf')) {\n return false\n }\n\n // Most likely a plain Object\n return true\n}\n\nfunction hasObjectPrototype(o: any): boolean {\n return Object.prototype.toString.call(o) === '[object Object]'\n}\n\nexport function sleep(timeout: number): Promise<void> {\n return new Promise((resolve) => {\n setTimeout(resolve, timeout)\n })\n}\n\n/**\n * Schedules a microtask.\n * This can be useful to schedule state updates after rendering.\n */\nexport function scheduleMicrotask(callback: () => void) {\n sleep(0).then(callback)\n}\n\nexport function replaceData<\n TData,\n TOptions extends QueryOptions<any, any, any, any>,\n>(prevData: TData | undefined, data: TData, options: TOptions): TData {\n if (typeof options.structuralSharing === 'function') {\n return options.structuralSharing(prevData, data)\n } else if (options.structuralSharing !== false) {\n // Structurally share data between prev and new data if needed\n return replaceEqualDeep(prevData, data)\n }\n return data\n}\n\nexport function keepPreviousData<T>(\n previousData: T | undefined,\n): T | undefined {\n return previousData\n}\n\nexport function addToEnd<T>(items: T[], item: T, max = 0): T[] {\n const newItems = [...items, item]\n return max && newItems.length > max ? newItems.slice(1) : newItems\n}\n\nexport function addToStart<T>(items: T[], item: T, max = 0): T[] {\n const newItems = [item, ...items]\n return max && newItems.length > max ? newItems.slice(0, -1) : newItems\n}\n"],"names":["isServer","window","noop","undefined","functionalUpdate","updater","input","isValidTimeout","value","Infinity","timeUntilStale","updatedAt","staleTime","Math","max","Date","now","matchQuery","filters","query","type","exact","fetchStatus","predicate","queryKey","stale","queryHash","hashQueryKeyByOptions","options","partialMatchKey","isActive","isStale","state","matchMutation","mutation","status","mutationKey","hashKey","hashFn","queryKeyHashFn","JSON","stringify","_","val","isPlainObject","Object","keys","sort","reduce","result","key","a","b","some","replaceEqualDeep","array","isPlainArray","aSize","length","bItems","bSize","copy","equalItems","i","shallowEqualObjects","Array","isArray","o","hasObjectPrototype","ctor","constructor","prot","prototype","hasOwnProperty","toString","call","sleep","timeout","Promise","resolve","setTimeout","scheduleMicrotask","callback","then","replaceData","prevData","data","structuralSharing","keepPreviousData","previousData","addToEnd","items","item","newItems","slice","addToStart"],"mappings":";;AAUA;;AAwDA;;AAEO,MAAMA,QAAQ,GAAG,OAAOC,MAAM,KAAK,WAAW,IAAI,MAAM,IAAIA,OAAM;AAElE,SAASC,IAAIA,GAAc;AAChC,EAAA,OAAOC,SAAS,CAAA;AAClB,CAAA;AAEO,SAASC,gBAAgBA,CAC9BC,OAAiC,EACjCC,KAAa,EACJ;EACT,OAAO,OAAOD,OAAO,KAAK,UAAU,GAC/BA,OAAO,CAAyCC,KAAK,CAAC,GACvDD,OAAO,CAAA;AACb,CAAA;AAEO,SAASE,cAAcA,CAACC,KAAc,EAAmB;EAC9D,OAAO,OAAOA,KAAK,KAAK,QAAQ,IAAIA,KAAK,IAAI,CAAC,IAAIA,KAAK,KAAKC,QAAQ,CAAA;AACtE,CAAA;AAEO,SAASC,cAAcA,CAACC,SAAiB,EAAEC,SAAkB,EAAU;AAC5E,EAAA,OAAOC,IAAI,CAACC,GAAG,CAACH,SAAS,IAAIC,SAAS,IAAI,CAAC,CAAC,GAAGG,IAAI,CAACC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAA;AAC/D,CAAA;AAEO,SAASC,UAAUA,CACxBC,OAAqB,EACrBC,KAAgC,EACvB;EACT,MAAM;AACJC,IAAAA,IAAI,GAAG,KAAK;IACZC,KAAK;IACLC,WAAW;IACXC,SAAS;IACTC,QAAQ;AACRC,IAAAA,KAAAA;AACF,GAAC,GAAGP,OAAO,CAAA;AAEX,EAAA,IAAIM,QAAQ,EAAE;AACZ,IAAA,IAAIH,KAAK,EAAE;AACT,MAAA,IAAIF,KAAK,CAACO,SAAS,KAAKC,qBAAqB,CAACH,QAAQ,EAAEL,KAAK,CAACS,OAAO,CAAC,EAAE;AACtE,QAAA,OAAO,KAAK,CAAA;AACd,OAAA;KACD,MAAM,IAAI,CAACC,eAAe,CAACV,KAAK,CAACK,QAAQ,EAAEA,QAAQ,CAAC,EAAE;AACrD,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACF,GAAA;EAEA,IAAIJ,IAAI,KAAK,KAAK,EAAE;AAClB,IAAA,MAAMU,QAAQ,GAAGX,KAAK,CAACW,QAAQ,EAAE,CAAA;AACjC,IAAA,IAAIV,IAAI,KAAK,QAAQ,IAAI,CAACU,QAAQ,EAAE;AAClC,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACA,IAAA,IAAIV,IAAI,KAAK,UAAU,IAAIU,QAAQ,EAAE;AACnC,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACF,GAAA;AAEA,EAAA,IAAI,OAAOL,KAAK,KAAK,SAAS,IAAIN,KAAK,CAACY,OAAO,EAAE,KAAKN,KAAK,EAAE;AAC3D,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,IACE,OAAOH,WAAW,KAAK,WAAW,IAClCA,WAAW,KAAKH,KAAK,CAACa,KAAK,CAACV,WAAW,EACvC;AACA,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,IAAIC,SAAS,IAAI,CAACA,SAAS,CAACJ,KAAK,CAAC,EAAE;AAClC,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,OAAO,IAAI,CAAA;AACb,CAAA;AAEO,SAASc,aAAaA,CAC3Bf,OAAwB,EACxBgB,QAA4B,EACnB;EACT,MAAM;IAAEb,KAAK;IAAEc,MAAM;IAAEZ,SAAS;AAAEa,IAAAA,WAAAA;AAAY,GAAC,GAAGlB,OAAO,CAAA;AACzD,EAAA,IAAIkB,WAAW,EAAE;AACf,IAAA,IAAI,CAACF,QAAQ,CAACN,OAAO,CAACQ,WAAW,EAAE;AACjC,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACA,IAAA,IAAIf,KAAK,EAAE;AACT,MAAA,IAAIgB,OAAO,CAACH,QAAQ,CAACN,OAAO,CAACQ,WAAW,CAAC,KAAKC,OAAO,CAACD,WAAW,CAAC,EAAE;AAClE,QAAA,OAAO,KAAK,CAAA;AACd,OAAA;AACF,KAAC,MAAM,IAAI,CAACP,eAAe,CAACK,QAAQ,CAACN,OAAO,CAACQ,WAAW,EAAEA,WAAW,CAAC,EAAE;AACtE,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACF,GAAA;EAEA,IAAID,MAAM,IAAID,QAAQ,CAACF,KAAK,CAACG,MAAM,KAAKA,MAAM,EAAE;AAC9C,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,IAAIZ,SAAS,IAAI,CAACA,SAAS,CAACW,QAAQ,CAAC,EAAE;AACrC,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,OAAO,IAAI,CAAA;AACb,CAAA;AAEO,SAASP,qBAAqBA,CACnCH,QAAmB,EACnBI,OAAgD,EACxC;EACR,MAAMU,MAAM,GAAG,CAAAV,OAAO,oBAAPA,OAAO,CAAEW,cAAc,KAAIF,OAAO,CAAA;EACjD,OAAOC,MAAM,CAACd,QAAQ,CAAC,CAAA;AACzB,CAAA;;AAEA;AACA;AACA;AACA;AACO,SAASa,OAAOA,CAACb,QAAgC,EAAU;AAChE,EAAA,OAAOgB,IAAI,CAACC,SAAS,CAACjB,QAAQ,EAAE,CAACkB,CAAC,EAAEC,GAAG,KACrCC,aAAa,CAACD,GAAG,CAAC,GACdE,MAAM,CAACC,IAAI,CAACH,GAAG,CAAC,CACbI,IAAI,EAAE,CACNC,MAAM,CAAC,CAACC,MAAM,EAAEC,GAAG,KAAK;AACvBD,IAAAA,MAAM,CAACC,GAAG,CAAC,GAAGP,GAAG,CAACO,GAAG,CAAC,CAAA;AACtB,IAAA,OAAOD,MAAM,CAAA;AACf,GAAC,EAAE,EAAS,CAAC,GACfN,GACN,CAAC,CAAA;AACH,CAAA;;AAEA;AACA;AACA;;AAEO,SAASd,eAAeA,CAACsB,CAAM,EAAEC,CAAM,EAAW;EACvD,IAAID,CAAC,KAAKC,CAAC,EAAE;AACX,IAAA,OAAO,IAAI,CAAA;AACb,GAAA;AAEA,EAAA,IAAI,OAAOD,CAAC,KAAK,OAAOC,CAAC,EAAE;AACzB,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,IAAID,CAAC,IAAIC,CAAC,IAAI,OAAOD,CAAC,KAAK,QAAQ,IAAI,OAAOC,CAAC,KAAK,QAAQ,EAAE;IAC5D,OAAO,CAACP,MAAM,CAACC,IAAI,CAACM,CAAC,CAAC,CAACC,IAAI,CAAEH,GAAG,IAAK,CAACrB,eAAe,CAACsB,CAAC,CAACD,GAAG,CAAC,EAAEE,CAAC,CAACF,GAAG,CAAC,CAAC,CAAC,CAAA;AACxE,GAAA;AAEA,EAAA,OAAO,KAAK,CAAA;AACd,CAAA;;AAEA;AACA;AACA;AACA;AACA;;AAEO,SAASI,gBAAgBA,CAACH,CAAM,EAAEC,CAAM,EAAO;EACpD,IAAID,CAAC,KAAKC,CAAC,EAAE;AACX,IAAA,OAAOD,CAAC,CAAA;AACV,GAAA;EAEA,MAAMI,KAAK,GAAGC,YAAY,CAACL,CAAC,CAAC,IAAIK,YAAY,CAACJ,CAAC,CAAC,CAAA;EAEhD,IAAIG,KAAK,IAAKX,aAAa,CAACO,CAAC,CAAC,IAAIP,aAAa,CAACQ,CAAC,CAAE,EAAE;AACnD,IAAA,MAAMK,KAAK,GAAGF,KAAK,GAAGJ,CAAC,CAACO,MAAM,GAAGb,MAAM,CAACC,IAAI,CAACK,CAAC,CAAC,CAACO,MAAM,CAAA;IACtD,MAAMC,MAAM,GAAGJ,KAAK,GAAGH,CAAC,GAAGP,MAAM,CAACC,IAAI,CAACM,CAAC,CAAC,CAAA;AACzC,IAAA,MAAMQ,KAAK,GAAGD,MAAM,CAACD,MAAM,CAAA;AAC3B,IAAA,MAAMG,IAAS,GAAGN,KAAK,GAAG,EAAE,GAAG,EAAE,CAAA;IAEjC,IAAIO,UAAU,GAAG,CAAC,CAAA;IAElB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGH,KAAK,EAAEG,CAAC,EAAE,EAAE;MAC9B,MAAMb,GAAG,GAAGK,KAAK,GAAGQ,CAAC,GAAGJ,MAAM,CAACI,CAAC,CAAC,CAAA;AACjCF,MAAAA,IAAI,CAACX,GAAG,CAAC,GAAGI,gBAAgB,CAACH,CAAC,CAACD,GAAG,CAAC,EAAEE,CAAC,CAACF,GAAG,CAAC,CAAC,CAAA;MAC5C,IAAIW,IAAI,CAACX,GAAG,CAAC,KAAKC,CAAC,CAACD,GAAG,CAAC,EAAE;AACxBY,QAAAA,UAAU,EAAE,CAAA;AACd,OAAA;AACF,KAAA;IAEA,OAAOL,KAAK,KAAKG,KAAK,IAAIE,UAAU,KAAKL,KAAK,GAAGN,CAAC,GAAGU,IAAI,CAAA;AAC3D,GAAA;AAEA,EAAA,OAAOT,CAAC,CAAA;AACV,CAAA;;AAEA;AACA;AACA;AACO,SAASY,mBAAmBA,CAAIb,CAAI,EAAEC,CAAI,EAAW;EAC1D,IAAKD,CAAC,IAAI,CAACC,CAAC,IAAMA,CAAC,IAAI,CAACD,CAAE,EAAE;AAC1B,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;AAEA,EAAA,KAAK,MAAMD,GAAG,IAAIC,CAAC,EAAE;IACnB,IAAIA,CAAC,CAACD,GAAG,CAAC,KAAKE,CAAC,CAACF,GAAG,CAAC,EAAE;AACrB,MAAA,OAAO,KAAK,CAAA;AACd,KAAA;AACF,GAAA;AAEA,EAAA,OAAO,IAAI,CAAA;AACb,CAAA;AAEO,SAASM,YAAYA,CAAChD,KAAc,EAAE;AAC3C,EAAA,OAAOyD,KAAK,CAACC,OAAO,CAAC1D,KAAK,CAAC,IAAIA,KAAK,CAACkD,MAAM,KAAKb,MAAM,CAACC,IAAI,CAACtC,KAAK,CAAC,CAACkD,MAAM,CAAA;AAC3E,CAAA;;AAEA;AACO,SAASd,aAAaA,CAACuB,CAAM,EAAe;AACjD,EAAA,IAAI,CAACC,kBAAkB,CAACD,CAAC,CAAC,EAAE;AAC1B,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;;AAEA;AACA,EAAA,MAAME,IAAI,GAAGF,CAAC,CAACG,WAAW,CAAA;AAC1B,EAAA,IAAI,OAAOD,IAAI,KAAK,WAAW,EAAE;AAC/B,IAAA,OAAO,IAAI,CAAA;AACb,GAAA;;AAEA;AACA,EAAA,MAAME,IAAI,GAAGF,IAAI,CAACG,SAAS,CAAA;AAC3B,EAAA,IAAI,CAACJ,kBAAkB,CAACG,IAAI,CAAC,EAAE;AAC7B,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;;AAEA;AACA,EAAA,IAAI,CAACA,IAAI,CAACE,cAAc,CAAC,eAAe,CAAC,EAAE;AACzC,IAAA,OAAO,KAAK,CAAA;AACd,GAAA;;AAEA;AACA,EAAA,OAAO,IAAI,CAAA;AACb,CAAA;AAEA,SAASL,kBAAkBA,CAACD,CAAM,EAAW;EAC3C,OAAOtB,MAAM,CAAC2B,SAAS,CAACE,QAAQ,CAACC,IAAI,CAACR,CAAC,CAAC,KAAK,iBAAiB,CAAA;AAChE,CAAA;AAEO,SAASS,KAAKA,CAACC,OAAe,EAAiB;AACpD,EAAA,OAAO,IAAIC,OAAO,CAAEC,OAAO,IAAK;AAC9BC,IAAAA,UAAU,CAACD,OAAO,EAAEF,OAAO,CAAC,CAAA;AAC9B,GAAC,CAAC,CAAA;AACJ,CAAA;;AAEA;AACA;AACA;AACA;AACO,SAASI,iBAAiBA,CAACC,QAAoB,EAAE;AACtDN,EAAAA,KAAK,CAAC,CAAC,CAAC,CAACO,IAAI,CAACD,QAAQ,CAAC,CAAA;AACzB,CAAA;AAEO,SAASE,WAAWA,CAGzBC,QAA2B,EAAEC,IAAW,EAAE1D,OAAiB,EAAS;AACpE,EAAA,IAAI,OAAOA,OAAO,CAAC2D,iBAAiB,KAAK,UAAU,EAAE;AACnD,IAAA,OAAO3D,OAAO,CAAC2D,iBAAiB,CAACF,QAAQ,EAAEC,IAAI,CAAC,CAAA;AAClD,GAAC,MAAM,IAAI1D,OAAO,CAAC2D,iBAAiB,KAAK,KAAK,EAAE;AAC9C;AACA,IAAA,OAAOjC,gBAAgB,CAAC+B,QAAQ,EAAEC,IAAI,CAAC,CAAA;AACzC,GAAA;AACA,EAAA,OAAOA,IAAI,CAAA;AACb,CAAA;AAEO,SAASE,gBAAgBA,CAC9BC,YAA2B,EACZ;AACf,EAAA,OAAOA,YAAY,CAAA;AACrB,CAAA;AAEO,SAASC,QAAQA,CAAIC,KAAU,EAAEC,IAAO,EAAE9E,GAAG,GAAG,CAAC,EAAO;AAC7D,EAAA,MAAM+E,QAAQ,GAAG,CAAC,GAAGF,KAAK,EAAEC,IAAI,CAAC,CAAA;AACjC,EAAA,OAAO9E,GAAG,IAAI+E,QAAQ,CAACnC,MAAM,GAAG5C,GAAG,GAAG+E,QAAQ,CAACC,KAAK,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAA;AACpE,CAAA;AAEO,SAASE,UAAUA,CAAIJ,KAAU,EAAEC,IAAO,EAAE9E,GAAG,GAAG,CAAC,EAAO;AAC/D,EAAA,MAAM+E,QAAQ,GAAG,CAACD,IAAI,EAAE,GAAGD,KAAK,CAAC,CAAA;AACjC,EAAA,OAAO7E,GAAG,IAAI+E,QAAQ,CAACnC,MAAM,GAAG5C,GAAG,GAAG+E,QAAQ,CAACC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAGD,QAAQ,CAAA;AACxE;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,227 @@
1
+ // TYPES
2
+
3
+ // UTILS
4
+
5
+ const isServer = typeof window === 'undefined' || 'Deno' in window;
6
+ function noop() {
7
+ return undefined;
8
+ }
9
+ function functionalUpdate(updater, input) {
10
+ return typeof updater === 'function' ? updater(input) : updater;
11
+ }
12
+ function isValidTimeout(value) {
13
+ return typeof value === 'number' && value >= 0 && value !== Infinity;
14
+ }
15
+ function timeUntilStale(updatedAt, staleTime) {
16
+ return Math.max(updatedAt + (staleTime || 0) - Date.now(), 0);
17
+ }
18
+ function matchQuery(filters, query) {
19
+ const {
20
+ type = 'all',
21
+ exact,
22
+ fetchStatus,
23
+ predicate,
24
+ queryKey,
25
+ stale
26
+ } = filters;
27
+ if (queryKey) {
28
+ if (exact) {
29
+ if (query.queryHash !== hashQueryKeyByOptions(queryKey, query.options)) {
30
+ return false;
31
+ }
32
+ } else if (!partialMatchKey(query.queryKey, queryKey)) {
33
+ return false;
34
+ }
35
+ }
36
+ if (type !== 'all') {
37
+ const isActive = query.isActive();
38
+ if (type === 'active' && !isActive) {
39
+ return false;
40
+ }
41
+ if (type === 'inactive' && isActive) {
42
+ return false;
43
+ }
44
+ }
45
+ if (typeof stale === 'boolean' && query.isStale() !== stale) {
46
+ return false;
47
+ }
48
+ if (typeof fetchStatus !== 'undefined' && fetchStatus !== query.state.fetchStatus) {
49
+ return false;
50
+ }
51
+ if (predicate && !predicate(query)) {
52
+ return false;
53
+ }
54
+ return true;
55
+ }
56
+ function matchMutation(filters, mutation) {
57
+ const {
58
+ exact,
59
+ status,
60
+ predicate,
61
+ mutationKey
62
+ } = filters;
63
+ if (mutationKey) {
64
+ if (!mutation.options.mutationKey) {
65
+ return false;
66
+ }
67
+ if (exact) {
68
+ if (hashKey(mutation.options.mutationKey) !== hashKey(mutationKey)) {
69
+ return false;
70
+ }
71
+ } else if (!partialMatchKey(mutation.options.mutationKey, mutationKey)) {
72
+ return false;
73
+ }
74
+ }
75
+ if (status && mutation.state.status !== status) {
76
+ return false;
77
+ }
78
+ if (predicate && !predicate(mutation)) {
79
+ return false;
80
+ }
81
+ return true;
82
+ }
83
+ function hashQueryKeyByOptions(queryKey, options) {
84
+ const hashFn = (options == null ? void 0 : options.queryKeyHashFn) || hashKey;
85
+ return hashFn(queryKey);
86
+ }
87
+
88
+ /**
89
+ * Default query & mutation keys hash function.
90
+ * Hashes the value into a stable hash.
91
+ */
92
+ function hashKey(queryKey) {
93
+ return JSON.stringify(queryKey, (_, val) => isPlainObject(val) ? Object.keys(val).sort().reduce((result, key) => {
94
+ result[key] = val[key];
95
+ return result;
96
+ }, {}) : val);
97
+ }
98
+
99
+ /**
100
+ * Checks if key `b` partially matches with key `a`.
101
+ */
102
+
103
+ function partialMatchKey(a, b) {
104
+ if (a === b) {
105
+ return true;
106
+ }
107
+ if (typeof a !== typeof b) {
108
+ return false;
109
+ }
110
+ if (a && b && typeof a === 'object' && typeof b === 'object') {
111
+ return !Object.keys(b).some(key => !partialMatchKey(a[key], b[key]));
112
+ }
113
+ return false;
114
+ }
115
+
116
+ /**
117
+ * This function returns `a` if `b` is deeply equal.
118
+ * If not, it will replace any deeply equal children of `b` with those of `a`.
119
+ * This can be used for structural sharing between JSON values for example.
120
+ */
121
+
122
+ function replaceEqualDeep(a, b) {
123
+ if (a === b) {
124
+ return a;
125
+ }
126
+ const array = isPlainArray(a) && isPlainArray(b);
127
+ if (array || isPlainObject(a) && isPlainObject(b)) {
128
+ const aSize = array ? a.length : Object.keys(a).length;
129
+ const bItems = array ? b : Object.keys(b);
130
+ const bSize = bItems.length;
131
+ const copy = array ? [] : {};
132
+ let equalItems = 0;
133
+ for (let i = 0; i < bSize; i++) {
134
+ const key = array ? i : bItems[i];
135
+ copy[key] = replaceEqualDeep(a[key], b[key]);
136
+ if (copy[key] === a[key]) {
137
+ equalItems++;
138
+ }
139
+ }
140
+ return aSize === bSize && equalItems === aSize ? a : copy;
141
+ }
142
+ return b;
143
+ }
144
+
145
+ /**
146
+ * Shallow compare objects. Only works with objects that always have the same properties.
147
+ */
148
+ function shallowEqualObjects(a, b) {
149
+ if (a && !b || b && !a) {
150
+ return false;
151
+ }
152
+ for (const key in a) {
153
+ if (a[key] !== b[key]) {
154
+ return false;
155
+ }
156
+ }
157
+ return true;
158
+ }
159
+ function isPlainArray(value) {
160
+ return Array.isArray(value) && value.length === Object.keys(value).length;
161
+ }
162
+
163
+ // Copied from: https://github.com/jonschlinkert/is-plain-object
164
+ function isPlainObject(o) {
165
+ if (!hasObjectPrototype(o)) {
166
+ return false;
167
+ }
168
+
169
+ // If has modified constructor
170
+ const ctor = o.constructor;
171
+ if (typeof ctor === 'undefined') {
172
+ return true;
173
+ }
174
+
175
+ // If has modified prototype
176
+ const prot = ctor.prototype;
177
+ if (!hasObjectPrototype(prot)) {
178
+ return false;
179
+ }
180
+
181
+ // If constructor does not have an Object-specific method
182
+ if (!prot.hasOwnProperty('isPrototypeOf')) {
183
+ return false;
184
+ }
185
+
186
+ // Most likely a plain Object
187
+ return true;
188
+ }
189
+ function hasObjectPrototype(o) {
190
+ return Object.prototype.toString.call(o) === '[object Object]';
191
+ }
192
+ function sleep(timeout) {
193
+ return new Promise(resolve => {
194
+ setTimeout(resolve, timeout);
195
+ });
196
+ }
197
+
198
+ /**
199
+ * Schedules a microtask.
200
+ * This can be useful to schedule state updates after rendering.
201
+ */
202
+ function scheduleMicrotask(callback) {
203
+ sleep(0).then(callback);
204
+ }
205
+ function replaceData(prevData, data, options) {
206
+ if (typeof options.structuralSharing === 'function') {
207
+ return options.structuralSharing(prevData, data);
208
+ } else if (options.structuralSharing !== false) {
209
+ // Structurally share data between prev and new data if needed
210
+ return replaceEqualDeep(prevData, data);
211
+ }
212
+ return data;
213
+ }
214
+ function keepPreviousData(previousData) {
215
+ return previousData;
216
+ }
217
+ function addToEnd(items, item, max = 0) {
218
+ const newItems = [...items, item];
219
+ return max && newItems.length > max ? newItems.slice(1) : newItems;
220
+ }
221
+ function addToStart(items, item, max = 0) {
222
+ const newItems = [item, ...items];
223
+ return max && newItems.length > max ? newItems.slice(0, -1) : newItems;
224
+ }
225
+
226
+ export { addToEnd, addToStart, functionalUpdate, hashKey, hashQueryKeyByOptions, isPlainArray, isPlainObject, isServer, isValidTimeout, keepPreviousData, matchMutation, matchQuery, noop, partialMatchKey, replaceData, replaceEqualDeep, scheduleMicrotask, shallowEqualObjects, sleep, timeUntilStale };
227
+ //# sourceMappingURL=utils.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.legacy.js","sources":["../../src/utils.ts"],"sourcesContent":["import type { Mutation } from './mutation'\nimport type { Query } from './query'\nimport type {\n FetchStatus,\n MutationKey,\n MutationStatus,\n QueryKey,\n QueryOptions,\n} from './types'\n\n// TYPES\n\nexport interface QueryFilters {\n /**\n * Filter to active queries, inactive queries or all queries\n */\n type?: QueryTypeFilter\n /**\n * Match query key exactly\n */\n exact?: boolean\n /**\n * Include queries matching this predicate function\n */\n predicate?: (query: Query) => boolean\n /**\n * Include queries matching this query key\n */\n queryKey?: QueryKey\n /**\n * Include or exclude stale queries\n */\n stale?: boolean\n /**\n * Include queries matching their fetchStatus\n */\n fetchStatus?: FetchStatus\n}\n\nexport interface MutationFilters {\n /**\n * Match mutation key exactly\n */\n exact?: boolean\n /**\n * Include mutations matching this predicate function\n */\n predicate?: (mutation: Mutation<any, any, any>) => boolean\n /**\n * Include mutations matching this mutation key\n */\n mutationKey?: MutationKey\n /**\n * Filter by mutation status\n */\n status?: MutationStatus\n}\n\nexport type DataUpdateFunction<TInput, TOutput> = (input: TInput) => TOutput\n\nexport type Updater<TInput, TOutput> =\n | TOutput\n | DataUpdateFunction<TInput, TOutput>\n\nexport type QueryTypeFilter = 'all' | 'active' | 'inactive'\n\n// UTILS\n\nexport const isServer = typeof window === 'undefined' || 'Deno' in window\n\nexport function noop(): undefined {\n return undefined\n}\n\nexport function functionalUpdate<TInput, TOutput>(\n updater: Updater<TInput, TOutput>,\n input: TInput,\n): TOutput {\n return typeof updater === 'function'\n ? (updater as DataUpdateFunction<TInput, TOutput>)(input)\n : updater\n}\n\nexport function isValidTimeout(value: unknown): value is number {\n return typeof value === 'number' && value >= 0 && value !== Infinity\n}\n\nexport function timeUntilStale(updatedAt: number, staleTime?: number): number {\n return Math.max(updatedAt + (staleTime || 0) - Date.now(), 0)\n}\n\nexport function matchQuery(\n filters: QueryFilters,\n query: Query<any, any, any, any>,\n): boolean {\n const {\n type = 'all',\n exact,\n fetchStatus,\n predicate,\n queryKey,\n stale,\n } = filters\n\n if (queryKey) {\n if (exact) {\n if (query.queryHash !== hashQueryKeyByOptions(queryKey, query.options)) {\n return false\n }\n } else if (!partialMatchKey(query.queryKey, queryKey)) {\n return false\n }\n }\n\n if (type !== 'all') {\n const isActive = query.isActive()\n if (type === 'active' && !isActive) {\n return false\n }\n if (type === 'inactive' && isActive) {\n return false\n }\n }\n\n if (typeof stale === 'boolean' && query.isStale() !== stale) {\n return false\n }\n\n if (\n typeof fetchStatus !== 'undefined' &&\n fetchStatus !== query.state.fetchStatus\n ) {\n return false\n }\n\n if (predicate && !predicate(query)) {\n return false\n }\n\n return true\n}\n\nexport function matchMutation(\n filters: MutationFilters,\n mutation: Mutation<any, any>,\n): boolean {\n const { exact, status, predicate, mutationKey } = filters\n if (mutationKey) {\n if (!mutation.options.mutationKey) {\n return false\n }\n if (exact) {\n if (hashKey(mutation.options.mutationKey) !== hashKey(mutationKey)) {\n return false\n }\n } else if (!partialMatchKey(mutation.options.mutationKey, mutationKey)) {\n return false\n }\n }\n\n if (status && mutation.state.status !== status) {\n return false\n }\n\n if (predicate && !predicate(mutation)) {\n return false\n }\n\n return true\n}\n\nexport function hashQueryKeyByOptions<TQueryKey extends QueryKey = QueryKey>(\n queryKey: TQueryKey,\n options?: QueryOptions<any, any, any, TQueryKey>,\n): string {\n const hashFn = options?.queryKeyHashFn || hashKey\n return hashFn(queryKey)\n}\n\n/**\n * Default query & mutation keys hash function.\n * Hashes the value into a stable hash.\n */\nexport function hashKey(queryKey: QueryKey | MutationKey): string {\n return JSON.stringify(queryKey, (_, val) =>\n isPlainObject(val)\n ? Object.keys(val)\n .sort()\n .reduce((result, key) => {\n result[key] = val[key]\n return result\n }, {} as any)\n : val,\n )\n}\n\n/**\n * Checks if key `b` partially matches with key `a`.\n */\nexport function partialMatchKey(a: QueryKey, b: QueryKey): boolean\nexport function partialMatchKey(a: any, b: any): boolean {\n if (a === b) {\n return true\n }\n\n if (typeof a !== typeof b) {\n return false\n }\n\n if (a && b && typeof a === 'object' && typeof b === 'object') {\n return !Object.keys(b).some((key) => !partialMatchKey(a[key], b[key]))\n }\n\n return false\n}\n\n/**\n * This function returns `a` if `b` is deeply equal.\n * If not, it will replace any deeply equal children of `b` with those of `a`.\n * This can be used for structural sharing between JSON values for example.\n */\nexport function replaceEqualDeep<T>(a: unknown, b: T): T\nexport function replaceEqualDeep(a: any, b: any): any {\n if (a === b) {\n return a\n }\n\n const array = isPlainArray(a) && isPlainArray(b)\n\n if (array || (isPlainObject(a) && isPlainObject(b))) {\n const aSize = array ? a.length : Object.keys(a).length\n const bItems = array ? b : Object.keys(b)\n const bSize = bItems.length\n const copy: any = array ? [] : {}\n\n let equalItems = 0\n\n for (let i = 0; i < bSize; i++) {\n const key = array ? i : bItems[i]\n copy[key] = replaceEqualDeep(a[key], b[key])\n if (copy[key] === a[key]) {\n equalItems++\n }\n }\n\n return aSize === bSize && equalItems === aSize ? a : copy\n }\n\n return b\n}\n\n/**\n * Shallow compare objects. Only works with objects that always have the same properties.\n */\nexport function shallowEqualObjects<T>(a: T, b: T): boolean {\n if ((a && !b) || (b && !a)) {\n return false\n }\n\n for (const key in a) {\n if (a[key] !== b[key]) {\n return false\n }\n }\n\n return true\n}\n\nexport function isPlainArray(value: unknown) {\n return Array.isArray(value) && value.length === Object.keys(value).length\n}\n\n// Copied from: https://github.com/jonschlinkert/is-plain-object\nexport function isPlainObject(o: any): o is Object {\n if (!hasObjectPrototype(o)) {\n return false\n }\n\n // If has modified constructor\n const ctor = o.constructor\n if (typeof ctor === 'undefined') {\n return true\n }\n\n // If has modified prototype\n const prot = ctor.prototype\n if (!hasObjectPrototype(prot)) {\n return false\n }\n\n // If constructor does not have an Object-specific method\n if (!prot.hasOwnProperty('isPrototypeOf')) {\n return false\n }\n\n // Most likely a plain Object\n return true\n}\n\nfunction hasObjectPrototype(o: any): boolean {\n return Object.prototype.toString.call(o) === '[object Object]'\n}\n\nexport function sleep(timeout: number): Promise<void> {\n return new Promise((resolve) => {\n setTimeout(resolve, timeout)\n })\n}\n\n/**\n * Schedules a microtask.\n * This can be useful to schedule state updates after rendering.\n */\nexport function scheduleMicrotask(callback: () => void) {\n sleep(0).then(callback)\n}\n\nexport function replaceData<\n TData,\n TOptions extends QueryOptions<any, any, any, any>,\n>(prevData: TData | undefined, data: TData, options: TOptions): TData {\n if (typeof options.structuralSharing === 'function') {\n return options.structuralSharing(prevData, data)\n } else if (options.structuralSharing !== false) {\n // Structurally share data between prev and new data if needed\n return replaceEqualDeep(prevData, data)\n }\n return data\n}\n\nexport function keepPreviousData<T>(\n previousData: T | undefined,\n): T | undefined {\n return previousData\n}\n\nexport function addToEnd<T>(items: T[], item: T, max = 0): T[] {\n const newItems = [...items, item]\n return max && newItems.length > max ? newItems.slice(1) : newItems\n}\n\nexport function addToStart<T>(items: T[], item: T, max = 0): T[] {\n const newItems = [item, ...items]\n return max && newItems.length > max ? newItems.slice(0, -1) : newItems\n}\n"],"names":["isServer","window","noop","undefined","functionalUpdate","updater","input","isValidTimeout","value","Infinity","timeUntilStale","updatedAt","staleTime","Math","max","Date","now","matchQuery","filters","query","type","exact","fetchStatus","predicate","queryKey","stale","queryHash","hashQueryKeyByOptions","options","partialMatchKey","isActive","isStale","state","matchMutation","mutation","status","mutationKey","hashKey","hashFn","queryKeyHashFn","JSON","stringify","_","val","isPlainObject","Object","keys","sort","reduce","result","key","a","b","some","replaceEqualDeep","array","isPlainArray","aSize","length","bItems","bSize","copy","equalItems","i","shallowEqualObjects","Array","isArray","o","hasObjectPrototype","ctor","constructor","prot","prototype","hasOwnProperty","toString","call","sleep","timeout","Promise","resolve","setTimeout","scheduleMicrotask","callback","then","replaceData","prevData","data","structuralSharing","keepPreviousData","previousData","addToEnd","items","item","newItems","slice","addToStart"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/query-core",
3
- "version": "5.0.0-alpha.61",
3
+ "version": "5.0.0-alpha.66",
4
4
  "description": "The framework agnostic core that powers TanStack Query",
5
5
  "author": "tannerlinsley",
6
6
  "license": "MIT",
@@ -12,8 +12,8 @@
12
12
  },
13
13
  "type": "module",
14
14
  "types": "build/lib/index.d.ts",
15
- "main": "build/lib/index.cjs",
16
- "module": "build/lib/index.js",
15
+ "main": "build/lib/index.legacy.cjs",
16
+ "module": "build/lib/index.legacy.js",
17
17
  "exports": {
18
18
  ".": {
19
19
  "types": "./build/lib/index.d.ts",
@@ -7,11 +7,9 @@ import type {
7
7
  QueryKey,
8
8
  } from './types'
9
9
 
10
- export function infiniteQueryBehavior<
11
- TQueryFnData,
12
- TError,
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 () => {
@@ -84,13 +82,8 @@ export function infiniteQueryBehavior<
84
82
 
85
83
  let result: InfiniteData<unknown>
86
84
 
87
- // Fetch first page?
88
- if (!oldPages.length) {
89
- result = await fetchPage(empty, options.defaultPageParam)
90
- }
91
-
92
85
  // fetch next / previous page?
93
- else if (direction) {
86
+ if (direction && oldPages.length) {
94
87
  const previous = direction === 'backward'
95
88
  const pageParamFn = previous ? getPreviousPageParam : getNextPageParam
96
89
  const oldData = {
@@ -100,15 +93,17 @@ export function infiniteQueryBehavior<
100
93
  const param = pageParamFn(options, oldData)
101
94
 
102
95
  result = await fetchPage(oldData, param, previous)
103
- }
104
-
105
- // Refetch pages
106
- else {
96
+ } else {
107
97
  // Fetch first page
108
- result = await fetchPage(empty, oldPageParams[0])
98
+ result = await fetchPage(
99
+ empty,
100
+ oldPageParams[0] ?? options.defaultPageParam,
101
+ )
102
+
103
+ const remainingPages = pages ?? oldPages.length
109
104
 
110
105
  // Fetch remaining pages
111
- for (let i = 1; i < oldPages.length; i++) {
106
+ for (let i = 1; i < remainingPages; i++) {
112
107
  const param = getNextPageParam(options, result)
113
108
  result = await fetchPage(result, param)
114
109
  }
@@ -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