@zenstackhq/tanstack-query 2.9.4 → 2.10.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/package.json +4 -4
- package/runtime/react.d.mts +266 -2
- package/runtime/react.d.ts +266 -2
- package/runtime/react.js +18 -12
- package/runtime/react.js.map +1 -1
- package/runtime/react.mjs +18 -12
- package/runtime/react.mjs.map +1 -1
- package/runtime/svelte.d.mts +267 -2
- package/runtime/svelte.d.ts +267 -2
- package/runtime/svelte.js +18 -9
- package/runtime/svelte.js.map +1 -1
- package/runtime/svelte.mjs +18 -9
- package/runtime/svelte.mjs.map +1 -1
- package/runtime/vue.d.mts +277 -3
- package/runtime/vue.d.ts +277 -3
- package/runtime/vue.js +16 -14
- package/runtime/vue.js.map +1 -1
- package/runtime/vue.mjs +16 -14
- package/runtime/vue.mjs.map +1 -1
- package/runtime-v5/react.d.mts +398 -4
- package/runtime-v5/react.d.ts +398 -4
- package/runtime-v5/react.js +36 -24
- package/runtime-v5/react.js.map +1 -1
- package/runtime-v5/react.mjs +36 -24
- package/runtime-v5/react.mjs.map +1 -1
- package/runtime-v5/svelte.d.mts +333 -2
- package/runtime-v5/svelte.d.ts +333 -2
- package/runtime-v5/svelte.js +10 -4
- package/runtime-v5/svelte.js.map +1 -1
- package/runtime-v5/svelte.mjs +10 -4
- package/runtime-v5/svelte.mjs.map +1 -1
- package/runtime-v5/vue.d.mts +277 -3
- package/runtime-v5/vue.d.ts +277 -3
- package/runtime-v5/vue.js +23 -19
- package/runtime-v5/vue.js.map +1 -1
- package/runtime-v5/vue.mjs +23 -19
- package/runtime-v5/vue.mjs.map +1 -1
package/runtime-v5/svelte.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as _tanstack_svelte_query_v5 from '@tanstack/svelte-query';
|
|
2
2
|
import { StoreOrVal, CreateQueryOptions, CreateInfiniteQueryOptions, InfiniteData, MutationOptions } from '@tanstack/svelte-query';
|
|
3
3
|
import { ModelMeta } from '@zenstackhq/runtime/cross';
|
|
4
|
+
import { Readable } from 'svelte/store';
|
|
4
5
|
import { A as APIContext, F as FetchFn, a as ExtraQueryOptions, E as ExtraMutationOptions } from './common-CXlL7vTW.js';
|
|
5
6
|
|
|
6
7
|
/**
|
|
@@ -29,7 +30,152 @@ declare function getHooksContext(): {
|
|
|
29
30
|
* @param fetch The fetch function to use for sending the HTTP request
|
|
30
31
|
* @returns useQuery hook
|
|
31
32
|
*/
|
|
32
|
-
declare function useModelQuery<TQueryFnData, TData, TError>(model: string, url: string, args?: unknown, options?: StoreOrVal<Omit<CreateQueryOptions<TQueryFnData, TError, TData>, 'queryKey'>> & ExtraQueryOptions, fetch?: FetchFn):
|
|
33
|
+
declare function useModelQuery<TQueryFnData, TData, TError>(model: string, url: string, args?: unknown, options?: StoreOrVal<Omit<CreateQueryOptions<TQueryFnData, TError, TData>, 'queryKey'>> & ExtraQueryOptions, fetch?: FetchFn): Readable<{
|
|
34
|
+
data: TData;
|
|
35
|
+
error: TError;
|
|
36
|
+
isError: true;
|
|
37
|
+
isPending: false;
|
|
38
|
+
isLoading: false;
|
|
39
|
+
isLoadingError: false;
|
|
40
|
+
isRefetchError: true;
|
|
41
|
+
isSuccess: false;
|
|
42
|
+
status: "error";
|
|
43
|
+
dataUpdatedAt: number;
|
|
44
|
+
errorUpdatedAt: number;
|
|
45
|
+
failureCount: number;
|
|
46
|
+
failureReason: TError | null;
|
|
47
|
+
errorUpdateCount: number;
|
|
48
|
+
isFetched: boolean;
|
|
49
|
+
isFetchedAfterMount: boolean;
|
|
50
|
+
isFetching: boolean;
|
|
51
|
+
isInitialLoading: boolean;
|
|
52
|
+
isPaused: boolean;
|
|
53
|
+
isPlaceholderData: boolean;
|
|
54
|
+
isRefetching: boolean;
|
|
55
|
+
isStale: boolean;
|
|
56
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<TData, TError>>;
|
|
57
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
58
|
+
queryKey: [string, string, string, unknown, {
|
|
59
|
+
infinite: boolean;
|
|
60
|
+
optimisticUpdate: boolean;
|
|
61
|
+
}];
|
|
62
|
+
} | {
|
|
63
|
+
data: TData;
|
|
64
|
+
error: null;
|
|
65
|
+
isError: false;
|
|
66
|
+
isPending: false;
|
|
67
|
+
isLoading: false;
|
|
68
|
+
isLoadingError: false;
|
|
69
|
+
isRefetchError: false;
|
|
70
|
+
isSuccess: true;
|
|
71
|
+
status: "success";
|
|
72
|
+
dataUpdatedAt: number;
|
|
73
|
+
errorUpdatedAt: number;
|
|
74
|
+
failureCount: number;
|
|
75
|
+
failureReason: TError | null;
|
|
76
|
+
errorUpdateCount: number;
|
|
77
|
+
isFetched: boolean;
|
|
78
|
+
isFetchedAfterMount: boolean;
|
|
79
|
+
isFetching: boolean;
|
|
80
|
+
isInitialLoading: boolean;
|
|
81
|
+
isPaused: boolean;
|
|
82
|
+
isPlaceholderData: boolean;
|
|
83
|
+
isRefetching: boolean;
|
|
84
|
+
isStale: boolean;
|
|
85
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<TData, TError>>;
|
|
86
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
87
|
+
queryKey: [string, string, string, unknown, {
|
|
88
|
+
infinite: boolean;
|
|
89
|
+
optimisticUpdate: boolean;
|
|
90
|
+
}];
|
|
91
|
+
} | {
|
|
92
|
+
data: undefined;
|
|
93
|
+
error: TError;
|
|
94
|
+
isError: true;
|
|
95
|
+
isPending: false;
|
|
96
|
+
isLoading: false;
|
|
97
|
+
isLoadingError: true;
|
|
98
|
+
isRefetchError: false;
|
|
99
|
+
isSuccess: false;
|
|
100
|
+
status: "error";
|
|
101
|
+
dataUpdatedAt: number;
|
|
102
|
+
errorUpdatedAt: number;
|
|
103
|
+
failureCount: number;
|
|
104
|
+
failureReason: TError | null;
|
|
105
|
+
errorUpdateCount: number;
|
|
106
|
+
isFetched: boolean;
|
|
107
|
+
isFetchedAfterMount: boolean;
|
|
108
|
+
isFetching: boolean;
|
|
109
|
+
isInitialLoading: boolean;
|
|
110
|
+
isPaused: boolean;
|
|
111
|
+
isPlaceholderData: boolean;
|
|
112
|
+
isRefetching: boolean;
|
|
113
|
+
isStale: boolean;
|
|
114
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<TData, TError>>;
|
|
115
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
116
|
+
queryKey: [string, string, string, unknown, {
|
|
117
|
+
infinite: boolean;
|
|
118
|
+
optimisticUpdate: boolean;
|
|
119
|
+
}];
|
|
120
|
+
} | {
|
|
121
|
+
data: undefined;
|
|
122
|
+
error: null;
|
|
123
|
+
isError: false;
|
|
124
|
+
isPending: true;
|
|
125
|
+
isLoading: true;
|
|
126
|
+
isLoadingError: false;
|
|
127
|
+
isRefetchError: false;
|
|
128
|
+
isSuccess: false;
|
|
129
|
+
status: "pending";
|
|
130
|
+
dataUpdatedAt: number;
|
|
131
|
+
errorUpdatedAt: number;
|
|
132
|
+
failureCount: number;
|
|
133
|
+
failureReason: TError | null;
|
|
134
|
+
errorUpdateCount: number;
|
|
135
|
+
isFetched: boolean;
|
|
136
|
+
isFetchedAfterMount: boolean;
|
|
137
|
+
isFetching: boolean;
|
|
138
|
+
isInitialLoading: boolean;
|
|
139
|
+
isPaused: boolean;
|
|
140
|
+
isPlaceholderData: boolean;
|
|
141
|
+
isRefetching: boolean;
|
|
142
|
+
isStale: boolean;
|
|
143
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<TData, TError>>;
|
|
144
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
145
|
+
queryKey: [string, string, string, unknown, {
|
|
146
|
+
infinite: boolean;
|
|
147
|
+
optimisticUpdate: boolean;
|
|
148
|
+
}];
|
|
149
|
+
} | {
|
|
150
|
+
data: undefined;
|
|
151
|
+
error: null;
|
|
152
|
+
isError: false;
|
|
153
|
+
isPending: true;
|
|
154
|
+
isLoadingError: false;
|
|
155
|
+
isRefetchError: false;
|
|
156
|
+
isSuccess: false;
|
|
157
|
+
status: "pending";
|
|
158
|
+
dataUpdatedAt: number;
|
|
159
|
+
errorUpdatedAt: number;
|
|
160
|
+
failureCount: number;
|
|
161
|
+
failureReason: TError | null;
|
|
162
|
+
errorUpdateCount: number;
|
|
163
|
+
isFetched: boolean;
|
|
164
|
+
isFetchedAfterMount: boolean;
|
|
165
|
+
isFetching: boolean;
|
|
166
|
+
isLoading: boolean;
|
|
167
|
+
isInitialLoading: boolean;
|
|
168
|
+
isPaused: boolean;
|
|
169
|
+
isPlaceholderData: boolean;
|
|
170
|
+
isRefetching: boolean;
|
|
171
|
+
isStale: boolean;
|
|
172
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<TData, TError>>;
|
|
173
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
174
|
+
queryKey: [string, string, string, unknown, {
|
|
175
|
+
infinite: boolean;
|
|
176
|
+
optimisticUpdate: boolean;
|
|
177
|
+
}];
|
|
178
|
+
}>;
|
|
33
179
|
/**
|
|
34
180
|
* Creates a svelte-query infinite query.
|
|
35
181
|
*
|
|
@@ -39,7 +185,192 @@ declare function useModelQuery<TQueryFnData, TData, TError>(model: string, url:
|
|
|
39
185
|
* @param options The svelte-query infinite query options object
|
|
40
186
|
* @returns useQuery hook
|
|
41
187
|
*/
|
|
42
|
-
declare function useInfiniteModelQuery<TQueryFnData, TData, TError>(model: string, url: string, args: unknown, options: StoreOrVal<Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>>, fetch?: FetchFn):
|
|
188
|
+
declare function useInfiniteModelQuery<TQueryFnData, TData, TError>(model: string, url: string, args: unknown, options: StoreOrVal<Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>>, fetch?: FetchFn): Readable<{
|
|
189
|
+
data: InfiniteData<TData, unknown>;
|
|
190
|
+
error: TError;
|
|
191
|
+
isError: true;
|
|
192
|
+
isPending: false;
|
|
193
|
+
isLoading: false;
|
|
194
|
+
isLoadingError: false;
|
|
195
|
+
isRefetchError: true;
|
|
196
|
+
isFetchNextPageError: false;
|
|
197
|
+
isFetchPreviousPageError: false;
|
|
198
|
+
isSuccess: false;
|
|
199
|
+
status: "error";
|
|
200
|
+
fetchNextPage: (options?: _tanstack_svelte_query_v5.FetchNextPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
201
|
+
fetchPreviousPage: (options?: _tanstack_svelte_query_v5.FetchPreviousPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
202
|
+
hasNextPage: boolean;
|
|
203
|
+
hasPreviousPage: boolean;
|
|
204
|
+
isFetchingNextPage: boolean;
|
|
205
|
+
isFetchingPreviousPage: boolean;
|
|
206
|
+
dataUpdatedAt: number;
|
|
207
|
+
errorUpdatedAt: number;
|
|
208
|
+
failureCount: number;
|
|
209
|
+
failureReason: TError | null;
|
|
210
|
+
errorUpdateCount: number;
|
|
211
|
+
isFetched: boolean;
|
|
212
|
+
isFetchedAfterMount: boolean;
|
|
213
|
+
isFetching: boolean;
|
|
214
|
+
isInitialLoading: boolean;
|
|
215
|
+
isPaused: boolean;
|
|
216
|
+
isPlaceholderData: boolean;
|
|
217
|
+
isRefetching: boolean;
|
|
218
|
+
isStale: boolean;
|
|
219
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
220
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
221
|
+
queryKey: [string, string, string, unknown, {
|
|
222
|
+
infinite: boolean;
|
|
223
|
+
optimisticUpdate: boolean;
|
|
224
|
+
}];
|
|
225
|
+
} | {
|
|
226
|
+
data: InfiniteData<TData, unknown>;
|
|
227
|
+
error: null;
|
|
228
|
+
isError: false;
|
|
229
|
+
isPending: false;
|
|
230
|
+
isLoading: false;
|
|
231
|
+
isLoadingError: false;
|
|
232
|
+
isRefetchError: false;
|
|
233
|
+
isFetchNextPageError: false;
|
|
234
|
+
isFetchPreviousPageError: false;
|
|
235
|
+
isSuccess: true;
|
|
236
|
+
status: "success";
|
|
237
|
+
fetchNextPage: (options?: _tanstack_svelte_query_v5.FetchNextPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
238
|
+
fetchPreviousPage: (options?: _tanstack_svelte_query_v5.FetchPreviousPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
239
|
+
hasNextPage: boolean;
|
|
240
|
+
hasPreviousPage: boolean;
|
|
241
|
+
isFetchingNextPage: boolean;
|
|
242
|
+
isFetchingPreviousPage: boolean;
|
|
243
|
+
dataUpdatedAt: number;
|
|
244
|
+
errorUpdatedAt: number;
|
|
245
|
+
failureCount: number;
|
|
246
|
+
failureReason: TError | null;
|
|
247
|
+
errorUpdateCount: number;
|
|
248
|
+
isFetched: boolean;
|
|
249
|
+
isFetchedAfterMount: boolean;
|
|
250
|
+
isFetching: boolean;
|
|
251
|
+
isInitialLoading: boolean;
|
|
252
|
+
isPaused: boolean;
|
|
253
|
+
isPlaceholderData: boolean;
|
|
254
|
+
isRefetching: boolean;
|
|
255
|
+
isStale: boolean;
|
|
256
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
257
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
258
|
+
queryKey: [string, string, string, unknown, {
|
|
259
|
+
infinite: boolean;
|
|
260
|
+
optimisticUpdate: boolean;
|
|
261
|
+
}];
|
|
262
|
+
} | {
|
|
263
|
+
data: undefined;
|
|
264
|
+
error: TError;
|
|
265
|
+
isError: true;
|
|
266
|
+
isPending: false;
|
|
267
|
+
isLoading: false;
|
|
268
|
+
isLoadingError: true;
|
|
269
|
+
isRefetchError: false;
|
|
270
|
+
isFetchNextPageError: false;
|
|
271
|
+
isFetchPreviousPageError: false;
|
|
272
|
+
isSuccess: false;
|
|
273
|
+
status: "error";
|
|
274
|
+
fetchNextPage: (options?: _tanstack_svelte_query_v5.FetchNextPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
275
|
+
fetchPreviousPage: (options?: _tanstack_svelte_query_v5.FetchPreviousPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
276
|
+
hasNextPage: boolean;
|
|
277
|
+
hasPreviousPage: boolean;
|
|
278
|
+
isFetchingNextPage: boolean;
|
|
279
|
+
isFetchingPreviousPage: boolean;
|
|
280
|
+
dataUpdatedAt: number;
|
|
281
|
+
errorUpdatedAt: number;
|
|
282
|
+
failureCount: number;
|
|
283
|
+
failureReason: TError | null;
|
|
284
|
+
errorUpdateCount: number;
|
|
285
|
+
isFetched: boolean;
|
|
286
|
+
isFetchedAfterMount: boolean;
|
|
287
|
+
isFetching: boolean;
|
|
288
|
+
isInitialLoading: boolean;
|
|
289
|
+
isPaused: boolean;
|
|
290
|
+
isPlaceholderData: boolean;
|
|
291
|
+
isRefetching: boolean;
|
|
292
|
+
isStale: boolean;
|
|
293
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
294
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
295
|
+
queryKey: [string, string, string, unknown, {
|
|
296
|
+
infinite: boolean;
|
|
297
|
+
optimisticUpdate: boolean;
|
|
298
|
+
}];
|
|
299
|
+
} | {
|
|
300
|
+
data: undefined;
|
|
301
|
+
error: null;
|
|
302
|
+
isError: false;
|
|
303
|
+
isPending: true;
|
|
304
|
+
isLoading: true;
|
|
305
|
+
isLoadingError: false;
|
|
306
|
+
isRefetchError: false;
|
|
307
|
+
isFetchNextPageError: false;
|
|
308
|
+
isFetchPreviousPageError: false;
|
|
309
|
+
isSuccess: false;
|
|
310
|
+
status: "pending";
|
|
311
|
+
fetchNextPage: (options?: _tanstack_svelte_query_v5.FetchNextPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
312
|
+
fetchPreviousPage: (options?: _tanstack_svelte_query_v5.FetchPreviousPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
313
|
+
hasNextPage: boolean;
|
|
314
|
+
hasPreviousPage: boolean;
|
|
315
|
+
isFetchingNextPage: boolean;
|
|
316
|
+
isFetchingPreviousPage: boolean;
|
|
317
|
+
dataUpdatedAt: number;
|
|
318
|
+
errorUpdatedAt: number;
|
|
319
|
+
failureCount: number;
|
|
320
|
+
failureReason: TError | null;
|
|
321
|
+
errorUpdateCount: number;
|
|
322
|
+
isFetched: boolean;
|
|
323
|
+
isFetchedAfterMount: boolean;
|
|
324
|
+
isFetching: boolean;
|
|
325
|
+
isInitialLoading: boolean;
|
|
326
|
+
isPaused: boolean;
|
|
327
|
+
isPlaceholderData: boolean;
|
|
328
|
+
isRefetching: boolean;
|
|
329
|
+
isStale: boolean;
|
|
330
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
331
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
332
|
+
queryKey: [string, string, string, unknown, {
|
|
333
|
+
infinite: boolean;
|
|
334
|
+
optimisticUpdate: boolean;
|
|
335
|
+
}];
|
|
336
|
+
} | {
|
|
337
|
+
data: undefined;
|
|
338
|
+
error: null;
|
|
339
|
+
isError: false;
|
|
340
|
+
isPending: true;
|
|
341
|
+
isLoadingError: false;
|
|
342
|
+
isRefetchError: false;
|
|
343
|
+
isFetchNextPageError: false;
|
|
344
|
+
isFetchPreviousPageError: false;
|
|
345
|
+
isSuccess: false;
|
|
346
|
+
status: "pending";
|
|
347
|
+
fetchNextPage: (options?: _tanstack_svelte_query_v5.FetchNextPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
348
|
+
fetchPreviousPage: (options?: _tanstack_svelte_query_v5.FetchPreviousPageOptions) => Promise<_tanstack_svelte_query_v5.InfiniteQueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
349
|
+
hasNextPage: boolean;
|
|
350
|
+
hasPreviousPage: boolean;
|
|
351
|
+
isFetchingNextPage: boolean;
|
|
352
|
+
isFetchingPreviousPage: boolean;
|
|
353
|
+
dataUpdatedAt: number;
|
|
354
|
+
errorUpdatedAt: number;
|
|
355
|
+
failureCount: number;
|
|
356
|
+
failureReason: TError | null;
|
|
357
|
+
errorUpdateCount: number;
|
|
358
|
+
isFetched: boolean;
|
|
359
|
+
isFetchedAfterMount: boolean;
|
|
360
|
+
isFetching: boolean;
|
|
361
|
+
isLoading: boolean;
|
|
362
|
+
isInitialLoading: boolean;
|
|
363
|
+
isPaused: boolean;
|
|
364
|
+
isPlaceholderData: boolean;
|
|
365
|
+
isRefetching: boolean;
|
|
366
|
+
isStale: boolean;
|
|
367
|
+
refetch: (options?: _tanstack_svelte_query_v5.RefetchOptions) => Promise<_tanstack_svelte_query_v5.QueryObserverResult<InfiniteData<TData, unknown>, TError>>;
|
|
368
|
+
fetchStatus: _tanstack_svelte_query_v5.FetchStatus;
|
|
369
|
+
queryKey: [string, string, string, unknown, {
|
|
370
|
+
infinite: boolean;
|
|
371
|
+
optimisticUpdate: boolean;
|
|
372
|
+
}];
|
|
373
|
+
}>;
|
|
43
374
|
/**
|
|
44
375
|
* Creates a POST mutation with svelte-query.
|
|
45
376
|
*
|
package/runtime-v5/svelte.js
CHANGED
|
@@ -332,7 +332,7 @@ function useModelQuery(model, url, args, options, fetch2) {
|
|
|
332
332
|
infinite: false,
|
|
333
333
|
optimisticUpdate: (options == null ? void 0 : options.optimisticUpdate) !== false
|
|
334
334
|
});
|
|
335
|
-
const queryFn = () => fetcher(reqUrl,
|
|
335
|
+
const queryFn = ({ signal }) => fetcher(reqUrl, { signal }, fetch2, false);
|
|
336
336
|
let mergedOpt;
|
|
337
337
|
if (isStore(options)) {
|
|
338
338
|
mergedOpt = (0, import_store.derived)([options], ([$opt]) => {
|
|
@@ -347,11 +347,14 @@ function useModelQuery(model, url, args, options, fetch2) {
|
|
|
347
347
|
queryFn
|
|
348
348
|
}, options);
|
|
349
349
|
}
|
|
350
|
-
|
|
350
|
+
const result = (0, import_svelte_query_v5.createQuery)(mergedOpt);
|
|
351
|
+
return (0, import_store.derived)(result, (r) => __spreadValues({
|
|
352
|
+
queryKey
|
|
353
|
+
}, r));
|
|
351
354
|
}
|
|
352
355
|
function useInfiniteModelQuery(model, url, args, options, fetch2) {
|
|
353
356
|
const queryKey = getQueryKey(model, url, args, { infinite: true, optimisticUpdate: false });
|
|
354
|
-
const queryFn = ({ pageParam }) => fetcher(makeUrl(url, pageParam != null ? pageParam : args),
|
|
357
|
+
const queryFn = ({ pageParam, signal }) => fetcher(makeUrl(url, pageParam != null ? pageParam : args), { signal }, fetch2, false);
|
|
355
358
|
let mergedOpt;
|
|
356
359
|
if (isStore(options)) {
|
|
357
360
|
mergedOpt = (0, import_store.derived)([options], ([$opt]) => {
|
|
@@ -368,7 +371,10 @@ function useInfiniteModelQuery(model, url, args, options, fetch2) {
|
|
|
368
371
|
initialPageParam: args
|
|
369
372
|
}, options);
|
|
370
373
|
}
|
|
371
|
-
|
|
374
|
+
const result = (0, import_svelte_query_v5.createInfiniteQuery)(mergedOpt);
|
|
375
|
+
return (0, import_store.derived)(result, (r) => __spreadValues({
|
|
376
|
+
queryKey
|
|
377
|
+
}, r));
|
|
372
378
|
}
|
|
373
379
|
function isStore(opt) {
|
|
374
380
|
return typeof (opt == null ? void 0 : opt.subscribe) === "function";
|
package/runtime-v5/svelte.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/runtime-v5/svelte.ts","../../src/runtime/common.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n createInfiniteQuery,\n createMutation,\n createQuery,\n useQueryClient,\n type CreateInfiniteQueryOptions,\n type CreateQueryOptions,\n type InfiniteData,\n type MutationOptions,\n type StoreOrVal,\n} from '@tanstack/svelte-query-v5';\nimport { ModelMeta } from '@zenstackhq/runtime/cross';\nimport { getContext, setContext } from 'svelte';\nimport { Readable, derived } from 'svelte/store';\nimport {\n APIContext,\n DEFAULT_QUERY_ENDPOINT,\n fetcher,\n getQueryKey,\n makeUrl,\n marshal,\n setupInvalidation,\n setupOptimisticUpdate,\n type ExtraMutationOptions,\n type ExtraQueryOptions,\n type FetchFn,\n} from '../runtime/common';\n\nexport { APIContext as RequestHandlerContext } from '../runtime/common';\n\n/**\n * Key for setting and getting the global query context.\n */\nexport const SvelteQueryContextKey = 'zenstack-svelte-query-context';\n\n/**\n * Set context for the generated TanStack Query hooks.\n */\nexport function setHooksContext(context: APIContext) {\n setContext(SvelteQueryContextKey, context);\n}\n\n/**\n * Hooks context.\n */\nexport function getHooksContext() {\n const { endpoint, ...rest } = getContext<APIContext>(SvelteQueryContextKey);\n return { endpoint: endpoint ?? DEFAULT_QUERY_ENDPOINT, ...rest };\n}\n\n/**\n * Creates a svelte-query query.\n *\n * @param model The name of the model under query.\n * @param url The request URL.\n * @param args The request args object, URL-encoded and appended as \"?q=\" parameter\n * @param options The svelte-query options object\n * @param fetch The fetch function to use for sending the HTTP request\n * @returns useQuery hook\n */\nexport function useModelQuery<TQueryFnData, TData, TError>(\n model: string,\n url: string,\n args?: unknown,\n options?: StoreOrVal<Omit<CreateQueryOptions<TQueryFnData, TError, TData>, 'queryKey'>> & ExtraQueryOptions,\n fetch?: FetchFn\n) {\n const reqUrl = makeUrl(url, args);\n const queryKey = getQueryKey(model, url, args, {\n infinite: false,\n optimisticUpdate: options?.optimisticUpdate !== false,\n });\n const queryFn = () => fetcher<TQueryFnData, false>(reqUrl, undefined, fetch, false);\n\n let mergedOpt: any;\n if (isStore(options)) {\n // options is store\n mergedOpt = derived([options], ([$opt]) => {\n return {\n queryKey,\n queryFn,\n ...($opt as object),\n };\n });\n } else {\n // options is value\n mergedOpt = {\n queryKey,\n queryFn,\n ...options,\n };\n }\n return createQuery<TQueryFnData, TError, TData>(mergedOpt);\n}\n\n/**\n * Creates a svelte-query infinite query.\n *\n * @param model The name of the model under query.\n * @param url The request URL.\n * @param args The initial request args object, URL-encoded and appended as \"?q=\" parameter\n * @param options The svelte-query infinite query options object\n * @returns useQuery hook\n */\nexport function useInfiniteModelQuery<TQueryFnData, TData, TError>(\n model: string,\n url: string,\n args: unknown,\n options: StoreOrVal<\n Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>\n >,\n fetch?: FetchFn\n) {\n const queryKey = getQueryKey(model, url, args, { infinite: true, optimisticUpdate: false });\n const queryFn = ({ pageParam }: { pageParam: unknown }) =>\n fetcher<TQueryFnData, false>(makeUrl(url, pageParam ?? args), undefined, fetch, false);\n\n let mergedOpt: StoreOrVal<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>>;\n if (\n isStore<\n Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>\n >(options)\n ) {\n // options is store\n mergedOpt = derived([options], ([$opt]) => {\n return {\n queryKey,\n queryFn,\n initialPageParam: args,\n ...$opt,\n };\n });\n } else {\n // options is value\n mergedOpt = {\n queryKey,\n queryFn,\n initialPageParam: args,\n ...options,\n };\n }\n return createInfiniteQuery<TQueryFnData, TError, InfiniteData<TData>>(mergedOpt);\n}\n\nfunction isStore<T>(opt: unknown): opt is Readable<T> {\n return typeof (opt as any)?.subscribe === 'function';\n}\n\n/**\n * Creates a POST mutation with svelte-query.\n *\n * @param model The name of the model under mutation.\n * @param method The HTTP method.\n * @param modelMeta The model metadata.\n * @param url The request URL.\n * @param options The svelte-query options.\n * @returns useMutation hooks\n */\nexport function useModelMutation<\n TArgs,\n TError,\n R = any,\n C extends boolean = boolean,\n Result = C extends true ? R | undefined : R\n>(\n model: string,\n method: 'POST' | 'PUT' | 'DELETE',\n url: string,\n modelMeta: ModelMeta,\n options?: Omit<MutationOptions<Result, TError, TArgs>, 'mutationFn'> & ExtraMutationOptions,\n fetch?: FetchFn,\n checkReadBack?: C\n) {\n const queryClient = useQueryClient();\n const mutationFn = (data: any) => {\n const reqUrl = method === 'DELETE' ? makeUrl(url, data) : url;\n const fetchInit: RequestInit = {\n method,\n ...(method !== 'DELETE' && {\n headers: {\n 'content-type': 'application/json',\n },\n body: marshal(data),\n }),\n };\n return fetcher<R, C>(reqUrl, fetchInit, fetch, checkReadBack) as Promise<Result>;\n };\n\n const finalOptions = { ...options, mutationFn };\n const operation = url.split('/').pop();\n const invalidateQueries = options?.invalidateQueries !== false;\n const optimisticUpdate = !!options?.optimisticUpdate;\n\n if (operation) {\n const { logging } = getContext<APIContext>(SvelteQueryContextKey);\n if (invalidateQueries) {\n setupInvalidation(\n model,\n operation,\n modelMeta,\n finalOptions,\n (predicate) => queryClient.invalidateQueries({ predicate }),\n logging\n );\n }\n\n if (optimisticUpdate) {\n setupOptimisticUpdate(\n model,\n operation,\n modelMeta,\n finalOptions,\n queryClient.getQueryCache().getAll(),\n (queryKey, data) => queryClient.setQueryData<unknown>(queryKey, data),\n invalidateQueries ? (predicate) => queryClient.invalidateQueries({ predicate }) : undefined,\n logging\n );\n }\n }\n\n return createMutation(finalOptions);\n}\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { deserialize, serialize } from '@zenstackhq/runtime/browser';\nimport {\n applyMutation,\n getMutatedModels,\n getReadModels,\n type ModelMeta,\n type PrismaWriteActionType,\n} from '@zenstackhq/runtime/cross';\n\n/**\n * The default query endpoint.\n */\nexport const DEFAULT_QUERY_ENDPOINT = '/api/model';\n\n/**\n * Prefix for react-query keys.\n */\nexport const QUERY_KEY_PREFIX = 'zenstack';\n\n/**\n * Function signature for `fetch`.\n */\nexport type FetchFn = (url: string, options?: RequestInit) => Promise<Response>;\n\n/**\n * Type for query and mutation errors.\n */\nexport type QueryError = Error & {\n /**\n * Additional error information.\n */\n info?: unknown;\n\n /**\n * HTTP status code.\n */\n status?: number;\n};\n\n/**\n * Result of optimistic data provider.\n */\nexport type OptimisticDataProviderResult = {\n /**\n * Kind of the result.\n * - Update: use the `data` field to update the query cache.\n * - Skip: skip the optimistic update for this query.\n * - ProceedDefault: proceed with the default optimistic update.\n */\n kind: 'Update' | 'Skip' | 'ProceedDefault';\n\n /**\n * Data to update the query cache. Only applicable if `kind` is 'Update'.\n *\n * If the data is an object with fields updated, it should have a `$optimistic`\n * field set to `true`. If it's an array and an element object is created or updated,\n * the element should have a `$optimistic` field set to `true`.\n */\n data?: any;\n};\n\n/**\n * Optimistic data provider.\n *\n * @param args Arguments.\n * @param args.queryModel The model of the query.\n * @param args.queryOperation The operation of the query, `findMany`, `count`, etc.\n * @param args.queryArgs The arguments of the query.\n * @param args.currentData The current cache data for the query.\n * @param args.mutationArgs The arguments of the mutation.\n */\nexport type OptimisticDataProvider = (args: {\n queryModel: string;\n queryOperation: string;\n queryArgs: any;\n currentData: any;\n mutationArgs: any;\n}) => OptimisticDataProviderResult | Promise<OptimisticDataProviderResult>;\n\n/**\n * Extra mutation options.\n */\nexport type ExtraMutationOptions = {\n /**\n * Whether to automatically invalidate queries potentially affected by the mutation. Defaults to `true`.\n */\n invalidateQueries?: boolean;\n\n /**\n * Whether to optimistically update queries potentially affected by the mutation. Defaults to `false`.\n */\n optimisticUpdate?: boolean;\n\n /**\n * A callback for computing optimistic update data for each query cache entry.\n */\n optimisticDataProvider?: OptimisticDataProvider;\n};\n\n/**\n * Extra query options.\n */\nexport type ExtraQueryOptions = {\n /**\n * Whether to opt-in to optimistic updates for this query. Defaults to `true`.\n */\n optimisticUpdate?: boolean;\n};\n\n/**\n * Context type for configuring the hooks.\n */\nexport type APIContext = {\n /**\n * The endpoint to use for the queries.\n */\n endpoint?: string;\n\n /**\n * A custom fetch function for sending the HTTP requests.\n */\n fetch?: FetchFn;\n\n /**\n * If logging is enabled.\n */\n logging?: boolean;\n};\n\nexport async function fetcher<R, C extends boolean>(\n url: string,\n options?: RequestInit,\n customFetch?: FetchFn,\n checkReadBack?: C\n): Promise<C extends true ? R | undefined : R> {\n // Note: 'cross-fetch' is supposed to handle fetch compatibility\n // but it doesn't work for cloudflare workers\n const _fetch =\n customFetch ??\n // check if fetch is available globally\n (typeof fetch === 'function'\n ? fetch\n : // fallback to 'cross-fetch' if otherwise\n (await import('cross-fetch')).default);\n\n const res = await _fetch(url, options);\n if (!res.ok) {\n const errData = unmarshal(await res.text());\n if (\n checkReadBack !== false &&\n errData.error?.prisma &&\n errData.error?.code === 'P2004' &&\n errData.error?.reason === 'RESULT_NOT_READABLE'\n ) {\n // policy doesn't allow mutation result to be read back, just return undefined\n return undefined as any;\n }\n const error: QueryError = new Error('An error occurred while fetching the data.');\n error.info = errData.error;\n error.status = res.status;\n throw error;\n }\n\n const textResult = await res.text();\n try {\n return unmarshal(textResult).data as R;\n } catch (err) {\n console.error(`Unable to deserialize data:`, textResult);\n throw err;\n }\n}\n\ntype QueryKey = [\n string /* prefix */,\n string /* model */,\n string /* operation */,\n unknown /* args */,\n {\n infinite: boolean;\n optimisticUpdate: boolean;\n } /* flags */\n];\n\n/**\n * Computes query key for the given model, operation and query args.\n * @param model Model name.\n * @param urlOrOperation Prisma operation (e.g, `findMany`) or request URL. If it's a URL, the last path segment will be used as the operation name.\n * @param args Prisma query arguments.\n * @param options Query options, including `infinite` indicating if it's an infinite query (defaults to false), and `optimisticUpdate` indicating if optimistic updates are enabled (defaults to true).\n * @returns Query key\n */\nexport function getQueryKey(\n model: string,\n urlOrOperation: string,\n args: unknown,\n options: { infinite: boolean; optimisticUpdate: boolean } = { infinite: false, optimisticUpdate: true }\n): QueryKey {\n if (!urlOrOperation) {\n throw new Error('Invalid urlOrOperation');\n }\n const operation = urlOrOperation.split('/').pop();\n\n const infinite = options.infinite;\n // infinite query doesn't support optimistic updates\n const optimisticUpdate = options.infinite ? false : options.optimisticUpdate;\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return [QUERY_KEY_PREFIX, model, operation!, args, { infinite, optimisticUpdate }];\n}\n\nexport function marshal(value: unknown) {\n const { data, meta } = serialize(value);\n if (meta) {\n return JSON.stringify({ ...(data as any), meta: { serialization: meta } });\n } else {\n return JSON.stringify(data);\n }\n}\n\nexport function unmarshal(value: string) {\n const parsed = JSON.parse(value);\n if (typeof parsed === 'object' && parsed?.data && parsed?.meta?.serialization) {\n const deserializedData = deserialize(parsed.data, parsed.meta.serialization);\n return { ...parsed, data: deserializedData };\n } else {\n return parsed;\n }\n}\n\nexport function makeUrl(url: string, args: unknown) {\n if (!args) {\n return url;\n }\n\n const { data, meta } = serialize(args);\n let result = `${url}?q=${encodeURIComponent(JSON.stringify(data))}`;\n if (meta) {\n result += `&meta=${encodeURIComponent(JSON.stringify({ serialization: meta }))}`;\n }\n return result;\n}\n\ntype InvalidationPredicate = ({ queryKey }: { queryKey: readonly unknown[] }) => boolean;\ntype InvalidateFunc = (predicate: InvalidationPredicate) => Promise<void>;\ntype MutationOptions = {\n onMutate?: (...args: any[]) => any;\n onSuccess?: (...args: any[]) => any;\n onSettled?: (...args: any[]) => any;\n};\n\n// sets up invalidation hook for a mutation\nexport function setupInvalidation(\n model: string,\n operation: string,\n modelMeta: ModelMeta,\n options: MutationOptions,\n invalidate: InvalidateFunc,\n logging = false\n) {\n const origOnSuccess = options?.onSuccess;\n options.onSuccess = async (...args: unknown[]) => {\n const [_, variables] = args;\n const predicate = await getInvalidationPredicate(\n model,\n operation as PrismaWriteActionType,\n variables,\n modelMeta,\n logging\n );\n await invalidate(predicate);\n return origOnSuccess?.(...args);\n };\n}\n\n// gets a predicate for evaluating whether a query should be invalidated\nasync function getInvalidationPredicate(\n model: string,\n operation: PrismaWriteActionType,\n mutationArgs: any,\n modelMeta: ModelMeta,\n logging = false\n) {\n const mutatedModels = await getMutatedModels(model, operation, mutationArgs, modelMeta);\n\n return ({ queryKey }: { queryKey: readonly unknown[] }) => {\n const [_, queryModel, , args] = queryKey as QueryKey;\n\n if (mutatedModels.includes(queryModel)) {\n // direct match\n if (logging) {\n console.log(`Invalidating query ${JSON.stringify(queryKey)} due to mutation \"${model}.${operation}\"`);\n }\n return true;\n }\n\n if (args) {\n // traverse query args to find nested reads that match the model under mutation\n if (findNestedRead(queryModel, mutatedModels, modelMeta, args)) {\n if (logging) {\n console.log(\n `Invalidating query ${JSON.stringify(queryKey)} due to mutation \"${model}.${operation}\"`\n );\n }\n return true;\n }\n }\n\n return false;\n };\n}\n\n// find nested reads that match the given models\nfunction findNestedRead(visitingModel: string, targetModels: string[], modelMeta: ModelMeta, args: any) {\n const modelsRead = getReadModels(visitingModel, modelMeta, args);\n return targetModels.some((m) => modelsRead.includes(m));\n}\n\ntype QueryCache = {\n queryKey: readonly unknown[];\n state: {\n data: unknown;\n error: unknown;\n };\n}[];\n\ntype SetCacheFunc = (queryKey: readonly unknown[], data: unknown) => void;\n\n/**\n * Sets up optimistic update and invalidation (after settled) for a mutation.\n */\nexport function setupOptimisticUpdate(\n model: string,\n operation: string,\n modelMeta: ModelMeta,\n options: MutationOptions & ExtraMutationOptions,\n queryCache: QueryCache,\n setCache: SetCacheFunc,\n invalidate?: InvalidateFunc,\n logging = false\n) {\n const origOnMutate = options?.onMutate;\n const origOnSettled = options?.onSettled;\n\n // optimistic update on mutate\n options.onMutate = async (...args: unknown[]) => {\n const [variables] = args;\n await optimisticUpdate(\n model,\n operation as PrismaWriteActionType,\n variables,\n options,\n modelMeta,\n queryCache,\n setCache,\n logging\n );\n return origOnMutate?.(...args);\n };\n\n // invalidate on settled\n options.onSettled = async (...args: unknown[]) => {\n if (invalidate) {\n const [, , variables] = args;\n const predicate = await getInvalidationPredicate(\n model,\n operation as PrismaWriteActionType,\n variables,\n modelMeta,\n logging\n );\n await invalidate(predicate);\n }\n return origOnSettled?.(...args);\n };\n}\n\n// optimistically updates query cache\nasync function optimisticUpdate(\n mutationModel: string,\n mutationOp: string,\n mutationArgs: any,\n options: MutationOptions & ExtraMutationOptions,\n modelMeta: ModelMeta,\n queryCache: QueryCache,\n setCache: SetCacheFunc,\n logging = false\n) {\n for (const cacheItem of queryCache) {\n const {\n queryKey,\n state: { data, error },\n } = cacheItem;\n\n if (!isZenStackQueryKey(queryKey)) {\n // skip non-zenstack queries\n continue;\n }\n\n if (error) {\n if (logging) {\n console.warn(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to error:`, error);\n }\n continue;\n }\n\n const [_, queryModel, queryOperation, queryArgs, queryOptions] = queryKey;\n if (!queryOptions?.optimisticUpdate) {\n if (logging) {\n console.log(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to opt-out`);\n }\n continue;\n }\n\n if (options.optimisticDataProvider) {\n const providerResult = await options.optimisticDataProvider({\n queryModel,\n queryOperation,\n queryArgs,\n currentData: data,\n mutationArgs,\n });\n\n if (providerResult?.kind === 'Skip') {\n // skip\n if (logging) {\n console.log(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to provider`);\n }\n continue;\n } else if (providerResult?.kind === 'Update') {\n // update cache\n if (logging) {\n console.log(`Optimistically updating query ${JSON.stringify(queryKey)} due to provider`);\n }\n setCache(queryKey, providerResult.data);\n continue;\n }\n }\n\n // proceed with default optimistic update\n const mutatedData = await applyMutation(\n queryModel,\n queryOperation,\n data,\n mutationModel,\n mutationOp as PrismaWriteActionType,\n mutationArgs,\n modelMeta,\n logging\n );\n\n if (mutatedData !== undefined) {\n // mutation applicable to this query, update cache\n if (logging) {\n console.log(\n `Optimistically updating query ${JSON.stringify(\n queryKey\n )} due to mutation \"${mutationModel}.${mutationOp}\"`\n );\n }\n setCache(queryKey, mutatedData);\n }\n }\n}\n\nfunction isZenStackQueryKey(queryKey: readonly unknown[]): queryKey is QueryKey {\n if (queryKey.length < 5) {\n return false;\n }\n\n if (queryKey[0] !== QUERY_KEY_PREFIX) {\n return false;\n }\n\n return true;\n}\n"],"mappings":"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","names":["optimisticUpdate","fetch","optimisticUpdate"]}
|
|
1
|
+
{"version":3,"sources":["../../src/runtime-v5/svelte.ts","../../src/runtime/common.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { QueryKey } from '@tanstack/react-query-v5';\nimport {\n createInfiniteQuery,\n createMutation,\n createQuery,\n useQueryClient,\n type CreateInfiniteQueryOptions,\n type CreateQueryOptions,\n type InfiniteData,\n type MutationOptions,\n type QueryFunction,\n type StoreOrVal,\n} from '@tanstack/svelte-query-v5';\nimport { ModelMeta } from '@zenstackhq/runtime/cross';\nimport { getContext, setContext } from 'svelte';\nimport { derived, Readable } from 'svelte/store';\nimport {\n APIContext,\n DEFAULT_QUERY_ENDPOINT,\n fetcher,\n getQueryKey,\n makeUrl,\n marshal,\n setupInvalidation,\n setupOptimisticUpdate,\n type ExtraMutationOptions,\n type ExtraQueryOptions,\n type FetchFn,\n} from '../runtime/common';\n\nexport { APIContext as RequestHandlerContext } from '../runtime/common';\n\n/**\n * Key for setting and getting the global query context.\n */\nexport const SvelteQueryContextKey = 'zenstack-svelte-query-context';\n\n/**\n * Set context for the generated TanStack Query hooks.\n */\nexport function setHooksContext(context: APIContext) {\n setContext(SvelteQueryContextKey, context);\n}\n\n/**\n * Hooks context.\n */\nexport function getHooksContext() {\n const { endpoint, ...rest } = getContext<APIContext>(SvelteQueryContextKey);\n return { endpoint: endpoint ?? DEFAULT_QUERY_ENDPOINT, ...rest };\n}\n\n/**\n * Creates a svelte-query query.\n *\n * @param model The name of the model under query.\n * @param url The request URL.\n * @param args The request args object, URL-encoded and appended as \"?q=\" parameter\n * @param options The svelte-query options object\n * @param fetch The fetch function to use for sending the HTTP request\n * @returns useQuery hook\n */\nexport function useModelQuery<TQueryFnData, TData, TError>(\n model: string,\n url: string,\n args?: unknown,\n options?: StoreOrVal<Omit<CreateQueryOptions<TQueryFnData, TError, TData>, 'queryKey'>> & ExtraQueryOptions,\n fetch?: FetchFn\n) {\n const reqUrl = makeUrl(url, args);\n const queryKey = getQueryKey(model, url, args, {\n infinite: false,\n optimisticUpdate: options?.optimisticUpdate !== false,\n });\n const queryFn: QueryFunction<TQueryFnData, QueryKey, unknown> = ({ signal }) =>\n fetcher<TQueryFnData, false>(reqUrl, { signal }, fetch, false);\n\n let mergedOpt: any;\n if (isStore(options)) {\n // options is store\n mergedOpt = derived([options], ([$opt]) => {\n return {\n queryKey,\n queryFn,\n ...($opt as object),\n };\n });\n } else {\n // options is value\n mergedOpt = {\n queryKey,\n queryFn,\n ...options,\n };\n }\n\n const result = createQuery<TQueryFnData, TError, TData>(mergedOpt);\n return derived(result, (r) => ({\n queryKey,\n ...r,\n }));\n}\n\n/**\n * Creates a svelte-query infinite query.\n *\n * @param model The name of the model under query.\n * @param url The request URL.\n * @param args The initial request args object, URL-encoded and appended as \"?q=\" parameter\n * @param options The svelte-query infinite query options object\n * @returns useQuery hook\n */\nexport function useInfiniteModelQuery<TQueryFnData, TData, TError>(\n model: string,\n url: string,\n args: unknown,\n options: StoreOrVal<\n Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>\n >,\n fetch?: FetchFn\n) {\n const queryKey = getQueryKey(model, url, args, { infinite: true, optimisticUpdate: false });\n const queryFn: QueryFunction<TQueryFnData, QueryKey, unknown> = ({ pageParam, signal }) =>\n fetcher<TQueryFnData, false>(makeUrl(url, pageParam ?? args), { signal }, fetch, false);\n\n let mergedOpt: StoreOrVal<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>>;\n if (\n isStore<\n Omit<CreateInfiniteQueryOptions<TQueryFnData, TError, InfiniteData<TData>>, 'queryKey' | 'initialPageParam'>\n >(options)\n ) {\n // options is store\n mergedOpt = derived([options], ([$opt]) => {\n return {\n queryKey,\n queryFn,\n initialPageParam: args,\n ...$opt,\n };\n });\n } else {\n // options is value\n mergedOpt = {\n queryKey,\n queryFn,\n initialPageParam: args,\n ...options,\n };\n }\n\n const result = createInfiniteQuery<TQueryFnData, TError, InfiniteData<TData>>(mergedOpt);\n return derived(result, (r) => ({\n queryKey,\n ...r,\n }));\n}\n\nfunction isStore<T>(opt: unknown): opt is Readable<T> {\n return typeof (opt as any)?.subscribe === 'function';\n}\n\n/**\n * Creates a POST mutation with svelte-query.\n *\n * @param model The name of the model under mutation.\n * @param method The HTTP method.\n * @param modelMeta The model metadata.\n * @param url The request URL.\n * @param options The svelte-query options.\n * @returns useMutation hooks\n */\nexport function useModelMutation<\n TArgs,\n TError,\n R = any,\n C extends boolean = boolean,\n Result = C extends true ? R | undefined : R\n>(\n model: string,\n method: 'POST' | 'PUT' | 'DELETE',\n url: string,\n modelMeta: ModelMeta,\n options?: Omit<MutationOptions<Result, TError, TArgs>, 'mutationFn'> & ExtraMutationOptions,\n fetch?: FetchFn,\n checkReadBack?: C\n) {\n const queryClient = useQueryClient();\n const mutationFn = (data: any) => {\n const reqUrl = method === 'DELETE' ? makeUrl(url, data) : url;\n const fetchInit: RequestInit = {\n method,\n ...(method !== 'DELETE' && {\n headers: {\n 'content-type': 'application/json',\n },\n body: marshal(data),\n }),\n };\n return fetcher<R, C>(reqUrl, fetchInit, fetch, checkReadBack) as Promise<Result>;\n };\n\n const finalOptions = { ...options, mutationFn };\n const operation = url.split('/').pop();\n const invalidateQueries = options?.invalidateQueries !== false;\n const optimisticUpdate = !!options?.optimisticUpdate;\n\n if (operation) {\n const { logging } = getContext<APIContext>(SvelteQueryContextKey);\n if (invalidateQueries) {\n setupInvalidation(\n model,\n operation,\n modelMeta,\n finalOptions,\n (predicate) => queryClient.invalidateQueries({ predicate }),\n logging\n );\n }\n\n if (optimisticUpdate) {\n setupOptimisticUpdate(\n model,\n operation,\n modelMeta,\n finalOptions,\n queryClient.getQueryCache().getAll(),\n (queryKey, data) => queryClient.setQueryData<unknown>(queryKey, data),\n invalidateQueries ? (predicate) => queryClient.invalidateQueries({ predicate }) : undefined,\n logging\n );\n }\n }\n\n return createMutation(finalOptions);\n}\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { deserialize, serialize } from '@zenstackhq/runtime/browser';\nimport {\n applyMutation,\n getMutatedModels,\n getReadModels,\n type ModelMeta,\n type PrismaWriteActionType,\n} from '@zenstackhq/runtime/cross';\n\n/**\n * The default query endpoint.\n */\nexport const DEFAULT_QUERY_ENDPOINT = '/api/model';\n\n/**\n * Prefix for react-query keys.\n */\nexport const QUERY_KEY_PREFIX = 'zenstack';\n\n/**\n * Function signature for `fetch`.\n */\nexport type FetchFn = (url: string, options?: RequestInit) => Promise<Response>;\n\n/**\n * Type for query and mutation errors.\n */\nexport type QueryError = Error & {\n /**\n * Additional error information.\n */\n info?: unknown;\n\n /**\n * HTTP status code.\n */\n status?: number;\n};\n\n/**\n * Result of optimistic data provider.\n */\nexport type OptimisticDataProviderResult = {\n /**\n * Kind of the result.\n * - Update: use the `data` field to update the query cache.\n * - Skip: skip the optimistic update for this query.\n * - ProceedDefault: proceed with the default optimistic update.\n */\n kind: 'Update' | 'Skip' | 'ProceedDefault';\n\n /**\n * Data to update the query cache. Only applicable if `kind` is 'Update'.\n *\n * If the data is an object with fields updated, it should have a `$optimistic`\n * field set to `true`. If it's an array and an element object is created or updated,\n * the element should have a `$optimistic` field set to `true`.\n */\n data?: any;\n};\n\n/**\n * Optimistic data provider.\n *\n * @param args Arguments.\n * @param args.queryModel The model of the query.\n * @param args.queryOperation The operation of the query, `findMany`, `count`, etc.\n * @param args.queryArgs The arguments of the query.\n * @param args.currentData The current cache data for the query.\n * @param args.mutationArgs The arguments of the mutation.\n */\nexport type OptimisticDataProvider = (args: {\n queryModel: string;\n queryOperation: string;\n queryArgs: any;\n currentData: any;\n mutationArgs: any;\n}) => OptimisticDataProviderResult | Promise<OptimisticDataProviderResult>;\n\n/**\n * Extra mutation options.\n */\nexport type ExtraMutationOptions = {\n /**\n * Whether to automatically invalidate queries potentially affected by the mutation. Defaults to `true`.\n */\n invalidateQueries?: boolean;\n\n /**\n * Whether to optimistically update queries potentially affected by the mutation. Defaults to `false`.\n */\n optimisticUpdate?: boolean;\n\n /**\n * A callback for computing optimistic update data for each query cache entry.\n */\n optimisticDataProvider?: OptimisticDataProvider;\n};\n\n/**\n * Extra query options.\n */\nexport type ExtraQueryOptions = {\n /**\n * Whether to opt-in to optimistic updates for this query. Defaults to `true`.\n */\n optimisticUpdate?: boolean;\n};\n\n/**\n * Context type for configuring the hooks.\n */\nexport type APIContext = {\n /**\n * The endpoint to use for the queries.\n */\n endpoint?: string;\n\n /**\n * A custom fetch function for sending the HTTP requests.\n */\n fetch?: FetchFn;\n\n /**\n * If logging is enabled.\n */\n logging?: boolean;\n};\n\nexport async function fetcher<R, C extends boolean>(\n url: string,\n options?: RequestInit,\n customFetch?: FetchFn,\n checkReadBack?: C\n): Promise<C extends true ? R | undefined : R> {\n // Note: 'cross-fetch' is supposed to handle fetch compatibility\n // but it doesn't work for cloudflare workers\n const _fetch =\n customFetch ??\n // check if fetch is available globally\n (typeof fetch === 'function'\n ? fetch\n : // fallback to 'cross-fetch' if otherwise\n (await import('cross-fetch')).default);\n\n const res = await _fetch(url, options);\n if (!res.ok) {\n const errData = unmarshal(await res.text());\n if (\n checkReadBack !== false &&\n errData.error?.prisma &&\n errData.error?.code === 'P2004' &&\n errData.error?.reason === 'RESULT_NOT_READABLE'\n ) {\n // policy doesn't allow mutation result to be read back, just return undefined\n return undefined as any;\n }\n const error: QueryError = new Error('An error occurred while fetching the data.');\n error.info = errData.error;\n error.status = res.status;\n throw error;\n }\n\n const textResult = await res.text();\n try {\n return unmarshal(textResult).data as R;\n } catch (err) {\n console.error(`Unable to deserialize data:`, textResult);\n throw err;\n }\n}\n\ntype QueryKey = [\n string /* prefix */,\n string /* model */,\n string /* operation */,\n unknown /* args */,\n {\n infinite: boolean;\n optimisticUpdate: boolean;\n } /* flags */\n];\n\n/**\n * Computes query key for the given model, operation and query args.\n * @param model Model name.\n * @param urlOrOperation Prisma operation (e.g, `findMany`) or request URL. If it's a URL, the last path segment will be used as the operation name.\n * @param args Prisma query arguments.\n * @param options Query options, including `infinite` indicating if it's an infinite query (defaults to false), and `optimisticUpdate` indicating if optimistic updates are enabled (defaults to true).\n * @returns Query key\n */\nexport function getQueryKey(\n model: string,\n urlOrOperation: string,\n args: unknown,\n options: { infinite: boolean; optimisticUpdate: boolean } = { infinite: false, optimisticUpdate: true }\n): QueryKey {\n if (!urlOrOperation) {\n throw new Error('Invalid urlOrOperation');\n }\n const operation = urlOrOperation.split('/').pop();\n\n const infinite = options.infinite;\n // infinite query doesn't support optimistic updates\n const optimisticUpdate = options.infinite ? false : options.optimisticUpdate;\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return [QUERY_KEY_PREFIX, model, operation!, args, { infinite, optimisticUpdate }];\n}\n\nexport function marshal(value: unknown) {\n const { data, meta } = serialize(value);\n if (meta) {\n return JSON.stringify({ ...(data as any), meta: { serialization: meta } });\n } else {\n return JSON.stringify(data);\n }\n}\n\nexport function unmarshal(value: string) {\n const parsed = JSON.parse(value);\n if (typeof parsed === 'object' && parsed?.data && parsed?.meta?.serialization) {\n const deserializedData = deserialize(parsed.data, parsed.meta.serialization);\n return { ...parsed, data: deserializedData };\n } else {\n return parsed;\n }\n}\n\nexport function makeUrl(url: string, args: unknown) {\n if (!args) {\n return url;\n }\n\n const { data, meta } = serialize(args);\n let result = `${url}?q=${encodeURIComponent(JSON.stringify(data))}`;\n if (meta) {\n result += `&meta=${encodeURIComponent(JSON.stringify({ serialization: meta }))}`;\n }\n return result;\n}\n\ntype InvalidationPredicate = ({ queryKey }: { queryKey: readonly unknown[] }) => boolean;\ntype InvalidateFunc = (predicate: InvalidationPredicate) => Promise<void>;\ntype MutationOptions = {\n onMutate?: (...args: any[]) => any;\n onSuccess?: (...args: any[]) => any;\n onSettled?: (...args: any[]) => any;\n};\n\n// sets up invalidation hook for a mutation\nexport function setupInvalidation(\n model: string,\n operation: string,\n modelMeta: ModelMeta,\n options: MutationOptions,\n invalidate: InvalidateFunc,\n logging = false\n) {\n const origOnSuccess = options?.onSuccess;\n options.onSuccess = async (...args: unknown[]) => {\n const [_, variables] = args;\n const predicate = await getInvalidationPredicate(\n model,\n operation as PrismaWriteActionType,\n variables,\n modelMeta,\n logging\n );\n await invalidate(predicate);\n return origOnSuccess?.(...args);\n };\n}\n\n// gets a predicate for evaluating whether a query should be invalidated\nasync function getInvalidationPredicate(\n model: string,\n operation: PrismaWriteActionType,\n mutationArgs: any,\n modelMeta: ModelMeta,\n logging = false\n) {\n const mutatedModels = await getMutatedModels(model, operation, mutationArgs, modelMeta);\n\n return ({ queryKey }: { queryKey: readonly unknown[] }) => {\n const [_, queryModel, , args] = queryKey as QueryKey;\n\n if (mutatedModels.includes(queryModel)) {\n // direct match\n if (logging) {\n console.log(`Invalidating query ${JSON.stringify(queryKey)} due to mutation \"${model}.${operation}\"`);\n }\n return true;\n }\n\n if (args) {\n // traverse query args to find nested reads that match the model under mutation\n if (findNestedRead(queryModel, mutatedModels, modelMeta, args)) {\n if (logging) {\n console.log(\n `Invalidating query ${JSON.stringify(queryKey)} due to mutation \"${model}.${operation}\"`\n );\n }\n return true;\n }\n }\n\n return false;\n };\n}\n\n// find nested reads that match the given models\nfunction findNestedRead(visitingModel: string, targetModels: string[], modelMeta: ModelMeta, args: any) {\n const modelsRead = getReadModels(visitingModel, modelMeta, args);\n return targetModels.some((m) => modelsRead.includes(m));\n}\n\ntype QueryCache = {\n queryKey: readonly unknown[];\n state: {\n data: unknown;\n error: unknown;\n };\n}[];\n\ntype SetCacheFunc = (queryKey: readonly unknown[], data: unknown) => void;\n\n/**\n * Sets up optimistic update and invalidation (after settled) for a mutation.\n */\nexport function setupOptimisticUpdate(\n model: string,\n operation: string,\n modelMeta: ModelMeta,\n options: MutationOptions & ExtraMutationOptions,\n queryCache: QueryCache,\n setCache: SetCacheFunc,\n invalidate?: InvalidateFunc,\n logging = false\n) {\n const origOnMutate = options?.onMutate;\n const origOnSettled = options?.onSettled;\n\n // optimistic update on mutate\n options.onMutate = async (...args: unknown[]) => {\n const [variables] = args;\n await optimisticUpdate(\n model,\n operation as PrismaWriteActionType,\n variables,\n options,\n modelMeta,\n queryCache,\n setCache,\n logging\n );\n return origOnMutate?.(...args);\n };\n\n // invalidate on settled\n options.onSettled = async (...args: unknown[]) => {\n if (invalidate) {\n const [, , variables] = args;\n const predicate = await getInvalidationPredicate(\n model,\n operation as PrismaWriteActionType,\n variables,\n modelMeta,\n logging\n );\n await invalidate(predicate);\n }\n return origOnSettled?.(...args);\n };\n}\n\n// optimistically updates query cache\nasync function optimisticUpdate(\n mutationModel: string,\n mutationOp: string,\n mutationArgs: any,\n options: MutationOptions & ExtraMutationOptions,\n modelMeta: ModelMeta,\n queryCache: QueryCache,\n setCache: SetCacheFunc,\n logging = false\n) {\n for (const cacheItem of queryCache) {\n const {\n queryKey,\n state: { data, error },\n } = cacheItem;\n\n if (!isZenStackQueryKey(queryKey)) {\n // skip non-zenstack queries\n continue;\n }\n\n if (error) {\n if (logging) {\n console.warn(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to error:`, error);\n }\n continue;\n }\n\n const [_, queryModel, queryOperation, queryArgs, queryOptions] = queryKey;\n if (!queryOptions?.optimisticUpdate) {\n if (logging) {\n console.log(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to opt-out`);\n }\n continue;\n }\n\n if (options.optimisticDataProvider) {\n const providerResult = await options.optimisticDataProvider({\n queryModel,\n queryOperation,\n queryArgs,\n currentData: data,\n mutationArgs,\n });\n\n if (providerResult?.kind === 'Skip') {\n // skip\n if (logging) {\n console.log(`Skipping optimistic update for ${JSON.stringify(queryKey)} due to provider`);\n }\n continue;\n } else if (providerResult?.kind === 'Update') {\n // update cache\n if (logging) {\n console.log(`Optimistically updating query ${JSON.stringify(queryKey)} due to provider`);\n }\n setCache(queryKey, providerResult.data);\n continue;\n }\n }\n\n // proceed with default optimistic update\n const mutatedData = await applyMutation(\n queryModel,\n queryOperation,\n data,\n mutationModel,\n mutationOp as PrismaWriteActionType,\n mutationArgs,\n modelMeta,\n logging\n );\n\n if (mutatedData !== undefined) {\n // mutation applicable to this query, update cache\n if (logging) {\n console.log(\n `Optimistically updating query ${JSON.stringify(\n queryKey\n )} due to mutation \"${mutationModel}.${mutationOp}\"`\n );\n }\n setCache(queryKey, mutatedData);\n }\n }\n}\n\nfunction isZenStackQueryKey(queryKey: readonly unknown[]): queryKey is QueryKey {\n if (queryKey.length < 5) {\n return false;\n }\n\n if (queryKey[0] !== QUERY_KEY_PREFIX) {\n return false;\n }\n\n return true;\n}\n"],"mappings":"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","names":["optimisticUpdate","fetch","optimisticUpdate"]}
|
package/runtime-v5/svelte.mjs
CHANGED
|
@@ -305,7 +305,7 @@ function useModelQuery(model, url, args, options, fetch2) {
|
|
|
305
305
|
infinite: false,
|
|
306
306
|
optimisticUpdate: (options == null ? void 0 : options.optimisticUpdate) !== false
|
|
307
307
|
});
|
|
308
|
-
const queryFn = () => fetcher(reqUrl,
|
|
308
|
+
const queryFn = ({ signal }) => fetcher(reqUrl, { signal }, fetch2, false);
|
|
309
309
|
let mergedOpt;
|
|
310
310
|
if (isStore(options)) {
|
|
311
311
|
mergedOpt = derived([options], ([$opt]) => {
|
|
@@ -320,11 +320,14 @@ function useModelQuery(model, url, args, options, fetch2) {
|
|
|
320
320
|
queryFn
|
|
321
321
|
}, options);
|
|
322
322
|
}
|
|
323
|
-
|
|
323
|
+
const result = createQuery(mergedOpt);
|
|
324
|
+
return derived(result, (r) => __spreadValues({
|
|
325
|
+
queryKey
|
|
326
|
+
}, r));
|
|
324
327
|
}
|
|
325
328
|
function useInfiniteModelQuery(model, url, args, options, fetch2) {
|
|
326
329
|
const queryKey = getQueryKey(model, url, args, { infinite: true, optimisticUpdate: false });
|
|
327
|
-
const queryFn = ({ pageParam }) => fetcher(makeUrl(url, pageParam != null ? pageParam : args),
|
|
330
|
+
const queryFn = ({ pageParam, signal }) => fetcher(makeUrl(url, pageParam != null ? pageParam : args), { signal }, fetch2, false);
|
|
328
331
|
let mergedOpt;
|
|
329
332
|
if (isStore(options)) {
|
|
330
333
|
mergedOpt = derived([options], ([$opt]) => {
|
|
@@ -341,7 +344,10 @@ function useInfiniteModelQuery(model, url, args, options, fetch2) {
|
|
|
341
344
|
initialPageParam: args
|
|
342
345
|
}, options);
|
|
343
346
|
}
|
|
344
|
-
|
|
347
|
+
const result = createInfiniteQuery(mergedOpt);
|
|
348
|
+
return derived(result, (r) => __spreadValues({
|
|
349
|
+
queryKey
|
|
350
|
+
}, r));
|
|
345
351
|
}
|
|
346
352
|
function isStore(opt) {
|
|
347
353
|
return typeof (opt == null ? void 0 : opt.subscribe) === "function";
|