@tanstack/angular-query-experimental 5.59.20 → 5.60.2

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 (54) hide show
  1. package/README.md +6 -6
  2. package/build/index.d.ts +680 -0
  3. package/build/index.js +616 -0
  4. package/build/index.js.map +1 -0
  5. package/package.json +13 -14
  6. package/src/create-base-query.ts +119 -0
  7. package/src/index.ts +28 -0
  8. package/src/infinite-query-options.ts +125 -0
  9. package/src/inject-infinite-query.ts +119 -0
  10. package/src/inject-is-fetching.ts +50 -0
  11. package/src/inject-is-mutating.ts +49 -0
  12. package/src/inject-mutation-state.ts +99 -0
  13. package/src/inject-mutation.ts +122 -0
  14. package/src/inject-queries.ts +243 -0
  15. package/src/inject-query-client.ts +27 -0
  16. package/src/inject-query.ts +207 -0
  17. package/src/providers.ts +344 -0
  18. package/src/query-options.ts +125 -0
  19. package/src/signal-proxy.ts +46 -0
  20. package/src/test-setup.ts +12 -0
  21. package/src/types.ts +328 -0
  22. package/src/util/assert-injector/assert-injector.test.ts +74 -0
  23. package/src/util/assert-injector/assert-injector.ts +81 -0
  24. package/src/util/create-injection-token/create-injection-token.test.ts +32 -0
  25. package/src/util/create-injection-token/create-injection-token.ts +183 -0
  26. package/src/util/index.ts +13 -0
  27. package/src/util/is-dev-mode/is-dev-mode.ts +3 -0
  28. package/src/util/lazy-init/lazy-init.ts +34 -0
  29. package/src/util/lazy-signal-initializer/lazy-signal-initializer.ts +23 -0
  30. package/build/README.md +0 -133
  31. package/build/esm2022/create-base-query.mjs +0 -62
  32. package/build/esm2022/index.mjs +0 -16
  33. package/build/esm2022/infinite-query-options.mjs +0 -12
  34. package/build/esm2022/inject-infinite-query.mjs +0 -15
  35. package/build/esm2022/inject-is-fetching.mjs +0 -38
  36. package/build/esm2022/inject-is-mutating.mjs +0 -37
  37. package/build/esm2022/inject-mutation-state.mjs +0 -47
  38. package/build/esm2022/inject-mutation.mjs +0 -51
  39. package/build/esm2022/inject-queries.mjs +0 -33
  40. package/build/esm2022/inject-query-client.mjs +0 -22
  41. package/build/esm2022/inject-query.mjs +0 -44
  42. package/build/esm2022/providers.mjs +0 -56
  43. package/build/esm2022/query-options.mjs +0 -26
  44. package/build/esm2022/signal-proxy.mjs +0 -38
  45. package/build/esm2022/tanstack-angular-query-experimental.mjs +0 -5
  46. package/build/esm2022/types.mjs +0 -3
  47. package/build/esm2022/util/assert-injector/assert-injector.mjs +0 -21
  48. package/build/esm2022/util/create-injection-token/create-injection-token.mjs +0 -61
  49. package/build/esm2022/util/index.mjs +0 -9
  50. package/build/esm2022/util/lazy-init/lazy-init.mjs +0 -31
  51. package/build/esm2022/util/lazy-signal-initializer/lazy-signal-initializer.mjs +0 -14
  52. package/build/fesm2022/tanstack-angular-query-experimental.mjs +0 -587
  53. package/build/fesm2022/tanstack-angular-query-experimental.mjs.map +0 -1
  54. package/build/rollup.d.ts +0 -605
@@ -0,0 +1,183 @@
1
+ /* eslint-disable cspell/spellchecker */
2
+ /**
3
+ * The code in this file is adapted from NG Extension Platform at https://ngxtension.netlify.app.
4
+ *
5
+ * Original Author: Chau Tran
6
+ *
7
+ * NG Extension Platform is an open-source project licensed under the MIT license.
8
+ *
9
+ * For more information about the original code, see
10
+ * https://github.com/nartc/ngxtension-platform
11
+ */
12
+ /* eslint-enable */
13
+
14
+ import { InjectionToken, inject, runInInjectionContext } from '@angular/core'
15
+ import { assertInjector } from '../assert-injector/assert-injector'
16
+ import type {
17
+ EnvironmentProviders,
18
+ FactoryProvider,
19
+ Host,
20
+ InjectOptions,
21
+ Injector,
22
+ Optional,
23
+ Provider,
24
+ Self,
25
+ SkipSelf,
26
+ Type,
27
+ } from '@angular/core'
28
+
29
+ type CreateInjectionTokenDep<TTokenType> =
30
+ | Type<TTokenType>
31
+ // NOTE: we don't have an AbstractType
32
+ | (abstract new (...args: Array<any>) => TTokenType)
33
+ | InjectionToken<TTokenType>
34
+
35
+ type CreateInjectionTokenDeps<
36
+ TFactory extends (...args: Array<any>) => any,
37
+ TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,
38
+ > = {
39
+ [Index in keyof TFactoryDeps]:
40
+ | CreateInjectionTokenDep<TFactoryDeps[Index]>
41
+ | [
42
+ ...modifiers: Array<Optional | Self | SkipSelf | Host>,
43
+ token: CreateInjectionTokenDep<TFactoryDeps[Index]>,
44
+ ]
45
+ } & { length: TFactoryDeps['length'] }
46
+
47
+ type CreateInjectionTokenOptions<
48
+ TFactory extends (...args: Array<any>) => any,
49
+ TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,
50
+ > =
51
+ // this means TFunction has no parameters
52
+ (TFactoryDeps[0] extends undefined
53
+ ? { deps?: never }
54
+ : { deps: CreateInjectionTokenDeps<TFactory, TFactoryDeps> }) & {
55
+ isRoot?: boolean
56
+ multi?: boolean
57
+ token?: InjectionToken<ReturnType<TFactory>>
58
+ extraProviders?: Provider | EnvironmentProviders
59
+ }
60
+
61
+ type CreateProvideFnOptions<
62
+ TFactory extends (...args: Array<any>) => any,
63
+ TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,
64
+ > = Pick<
65
+ CreateInjectionTokenOptions<TFactory, TFactoryDeps>,
66
+ 'deps' | 'extraProviders' | 'multi'
67
+ >
68
+
69
+ type InjectFn<TFactoryReturn> = {
70
+ (): TFactoryReturn
71
+ (
72
+ injectOptions: InjectOptions & { optional?: false } & {
73
+ injector?: Injector
74
+ },
75
+ ): TFactoryReturn
76
+ (
77
+ injectOptions: InjectOptions & { injector?: Injector },
78
+ ): TFactoryReturn | null
79
+ }
80
+
81
+ type ProvideFn<
82
+ TNoop extends boolean,
83
+ TFactoryReturn,
84
+ TReturn = TFactoryReturn extends Array<infer Item> ? Item : TFactoryReturn,
85
+ > = (TNoop extends true
86
+ ? (value: TReturn | (() => TReturn)) => Provider
87
+ : () => Provider) &
88
+ (TReturn extends Function
89
+ ? (value: TReturn | (() => TReturn), isFunctionValue: boolean) => Provider
90
+ : (value: TReturn | (() => TReturn)) => Provider)
91
+
92
+ type CreateInjectionTokenReturn<
93
+ TFactoryReturn,
94
+ TNoop extends boolean = false,
95
+ > = [
96
+ InjectFn<TFactoryReturn>,
97
+ ProvideFn<TNoop, TFactoryReturn>,
98
+ InjectionToken<TFactoryReturn>,
99
+ () => Provider,
100
+ ]
101
+
102
+ function createInjectFn<TValue>(token: InjectionToken<TValue>) {
103
+ return function (
104
+ this: Function,
105
+ {
106
+ injector,
107
+ ...injectOptions
108
+ }: InjectOptions & { injector?: Injector } = {},
109
+ ) {
110
+ injector = assertInjector(this, injector)
111
+ return runInInjectionContext(injector, () =>
112
+ inject(token, injectOptions as InjectOptions),
113
+ )
114
+ }
115
+ }
116
+
117
+ function createProvideFn<
118
+ TValue,
119
+ TFactory extends (...args: Array<any>) => any = (
120
+ ...args: Array<any>
121
+ ) => TValue,
122
+ TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,
123
+ >(
124
+ token: InjectionToken<TValue>,
125
+ factory: (...args: Array<any>) => TValue,
126
+ opts: CreateProvideFnOptions<TFactory, TFactoryDeps> = {},
127
+ ) {
128
+ const { deps = [], multi = false, extraProviders = [] } = opts
129
+ return (value?: TValue | (() => TValue), isFunctionValue = false) => {
130
+ let provider: Provider
131
+ if (value !== undefined) {
132
+ // eslint-disable-next-line no-shadow
133
+ const factory =
134
+ typeof value === 'function'
135
+ ? isFunctionValue
136
+ ? () => value
137
+ : value
138
+ : () => value
139
+
140
+ provider = {
141
+ provide: token,
142
+ useFactory: factory,
143
+ multi,
144
+ }
145
+ } else {
146
+ provider = {
147
+ provide: token,
148
+ useFactory: factory,
149
+ deps: deps as FactoryProvider['deps'],
150
+ multi,
151
+ }
152
+ }
153
+
154
+ return [extraProviders, provider]
155
+ }
156
+ }
157
+
158
+ export function createNoopInjectionToken<
159
+ TValue,
160
+ TMulti extends boolean = false,
161
+ TOptions = Pick<
162
+ CreateInjectionTokenOptions<() => void, []>,
163
+ 'extraProviders'
164
+ > &
165
+ (TMulti extends true ? { multi: true } : Record<string, never>),
166
+ >(description: string, options?: TOptions) {
167
+ type TReturn = TMulti extends true ? Array<TValue> : TValue
168
+
169
+ const token =
170
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
171
+ (options as CreateInjectionTokenOptions<() => void, []>)?.token ||
172
+ new InjectionToken<TReturn>(description)
173
+ return [
174
+ createInjectFn(token) as CreateInjectionTokenReturn<TReturn, true>[0],
175
+ createProvideFn(
176
+ token,
177
+ () => null!,
178
+ (options || {}) as CreateProvideFnOptions<() => void, []>,
179
+ ) as CreateInjectionTokenReturn<TReturn, true>[1],
180
+ token,
181
+ () => {},
182
+ ] as CreateInjectionTokenReturn<TReturn, true>
183
+ }
@@ -0,0 +1,13 @@
1
+ export function shouldThrowError<T extends (...args: Array<any>) => boolean>(
2
+ throwError: boolean | T | undefined,
3
+ params: Parameters<T>,
4
+ ): boolean {
5
+ // Allow throwError function to override throwing behavior on a per-error basis
6
+ if (typeof throwError === 'function') {
7
+ return throwError(...params)
8
+ }
9
+
10
+ return !!throwError
11
+ }
12
+
13
+ export function noop() {}
@@ -0,0 +1,3 @@
1
+ // Re-export for mocking in tests
2
+
3
+ export { isDevMode } from '@angular/core'
@@ -0,0 +1,34 @@
1
+ import { untracked } from '@angular/core'
2
+
3
+ export function lazyInit<T extends object>(initializer: () => T): T {
4
+ let object: T | null = null
5
+
6
+ const initializeObject = () => {
7
+ if (!object) {
8
+ object = untracked(() => initializer())
9
+ }
10
+ }
11
+
12
+ queueMicrotask(() => initializeObject())
13
+
14
+ return new Proxy<T>({} as T, {
15
+ get(_, prop, receiver) {
16
+ initializeObject()
17
+ return Reflect.get(object as T, prop, receiver)
18
+ },
19
+ has(_, prop) {
20
+ initializeObject()
21
+ return Reflect.has(object as T, prop)
22
+ },
23
+ ownKeys() {
24
+ initializeObject()
25
+ return Reflect.ownKeys(object as T)
26
+ },
27
+ getOwnPropertyDescriptor() {
28
+ return {
29
+ enumerable: true,
30
+ configurable: true,
31
+ }
32
+ },
33
+ })
34
+ }
@@ -0,0 +1,23 @@
1
+ import { Injector, computed, inject, untracked } from '@angular/core'
2
+ import type { Signal } from '@angular/core'
3
+
4
+ type SignalInitializerFn<T> = (injector: Injector) => Signal<T>
5
+
6
+ export function lazySignalInitializer<T>(
7
+ initializerFn: SignalInitializerFn<T>,
8
+ ) {
9
+ const injector = inject(Injector)
10
+
11
+ let source: Signal<T> | null = null
12
+
13
+ const unwrapSignal = () => {
14
+ if (!source) {
15
+ source = untracked(() => initializerFn(injector))
16
+ }
17
+ return source()
18
+ }
19
+
20
+ queueMicrotask(() => unwrapSignal())
21
+
22
+ return computed(unwrapSignal)
23
+ }
package/build/README.md DELETED
@@ -1,133 +0,0 @@
1
- ![TanStack Query Header](https://github.com/TanStack/query/raw/main/media/repo-header.png)
2
-
3
- [![npm version](https://img.shields.io/npm/v/@tanstack/angular-query-experimental)](https://www.npmjs.com/package/@tanstack/angular-query-experimental)
4
- [![npm license](https://img.shields.io/npm/l/@tanstack/angular-query-experimental)](https://github.com/TanStack/query/blob/main/LICENSE)
5
- [![bundle size](https://img.shields.io/bundlephobia/minzip/@tanstack/angular-query-experimental)](https://bundlephobia.com/package/@tanstack/angular-query-experimental)
6
- [![npm](https://img.shields.io/npm/dm/@tanstack/angular-query-experimental)](https://www.npmjs.com/package/@tanstack/angular-query-experimental)
7
-
8
- # Angular Query
9
-
10
- > IMPORTANT: This library is currently in an experimental stage. This means that breaking changes may happen in minor AND patch releases. Upgrade carefully. If you use this in production while in experimental stage, please lock your version to a patch-level version to avoid unexpected breaking changes.
11
-
12
- Functions for fetching, caching and updating asynchronous data in Angular
13
-
14
- # Documentation
15
-
16
- Visit https://tanstack.com/query/latest/docs/framework/angular/overview
17
-
18
- ## Quick Features
19
-
20
- - Transport/protocol/backend agnostic data fetching (REST, GraphQL, promises, whatever!)
21
- - Auto Caching + Refetching (stale-while-revalidate, Window Refocus, Polling/Realtime)
22
- - Parallel + Dependent Queries
23
- - Mutations + Reactive Query Refetching
24
- - Multi-layer Cache + Automatic Garbage Collection
25
- - Paginated + Cursor-based Queries
26
- - Load-More + Infinite Scroll Queries w/ Scroll Recovery
27
- - Request Cancellation
28
- - Dedicated Devtools
29
-
30
- # Quick Start
31
-
32
- > Angular Query requires Angular 16 or higher.
33
-
34
- 1. Install `angular-query`
35
-
36
- ```bash
37
- $ npm i @tanstack/angular-query-experimental
38
- ```
39
-
40
- or
41
-
42
- ```bash
43
- $ pnpm add @tanstack/angular-query-experimental
44
- ```
45
-
46
- or
47
-
48
- ```bash
49
- $ yarn add @tanstack/angular-query-experimental
50
- ```
51
-
52
- or
53
-
54
- ```bash
55
- $ bun add @tanstack/angular-query-experimental
56
- ```
57
-
58
- 2. Initialize **Angular Query** by adding **provideAngularQuery** to your application
59
-
60
- ```ts
61
- import { provideAngularQuery } from '@tanstack/angular-query-experimental'
62
- import { QueryClient } from '@tanstack/angular-query-experimental'
63
-
64
- bootstrapApplication(AppComponent, {
65
- providers: [provideAngularQuery(new QueryClient())],
66
- })
67
- ```
68
-
69
- or in a NgModule-based app
70
-
71
- ```ts
72
- import { provideHttpClient } from '@angular/common/http'
73
- import {
74
- provideAngularQuery,
75
- QueryClient,
76
- } from '@tanstack/angular-query-experimental'
77
-
78
- @NgModule({
79
- declarations: [AppComponent],
80
- imports: [BrowserModule],
81
- providers: [provideAngularQuery(new QueryClient())],
82
- bootstrap: [AppComponent],
83
- })
84
- ```
85
-
86
- 3. Inject query
87
-
88
- ```ts
89
- import { injectQuery } from '@tanstack/angular-query-experimental'
90
- import { Component } from '@angular/core'
91
-
92
- @Component({...})
93
- export class TodosComponent {
94
- info = injectQuery(() => ({ queryKey: ['todos'], queryFn: fetchTodoList }))
95
- }
96
- ```
97
-
98
- 4. If you need to update options on your query dynamically, make sure to pass them as signals. The query will refetch automatically if data for an updated query key is stale or not present.
99
-
100
- [Open in StackBlitz](https://stackblitz.com/github/TanStack/query/tree/main/examples/angular/router)
101
-
102
- ```ts
103
- @Component({})
104
- export class PostComponent {
105
- #postsService = inject(PostsService)
106
- postId = input.required({
107
- transform: numberAttribute,
108
- })
109
-
110
- postQuery = injectQuery(() => ({
111
- queryKey: ['post', this.postId()],
112
- queryFn: () => {
113
- return lastValueFrom(this.#postsService.postById$(this.postId()))
114
- },
115
- }))
116
- }
117
-
118
- @Injectable({
119
- providedIn: 'root',
120
- })
121
- export class PostsService {
122
- #http = inject(HttpClient)
123
-
124
- postById$ = (postId: number) =>
125
- this.#http.get<Post>(`https://jsonplaceholder.typicode.com/posts/${postId}`)
126
- }
127
-
128
- export interface Post {
129
- id: number
130
- title: string
131
- body: string
132
- }
133
- ```
@@ -1,62 +0,0 @@
1
- import { DestroyRef, Injector, NgZone, computed, effect, inject, runInInjectionContext, signal, untracked, } from '@angular/core';
2
- import { notifyManager } from '@tanstack/query-core';
3
- import { signalProxy } from './signal-proxy';
4
- import { shouldThrowError } from './util';
5
- import { lazyInit } from './util/lazy-init/lazy-init';
6
- import { injectQueryClient } from './inject-query-client';
7
- /**
8
- * Base implementation for `injectQuery` and `injectInfiniteQuery`.
9
- */
10
- export function createBaseQuery(optionsFn, Observer) {
11
- const injector = inject(Injector);
12
- return lazyInit(() => {
13
- const ngZone = injector.get(NgZone);
14
- const destroyRef = injector.get(DestroyRef);
15
- const queryClient = injectQueryClient({ injector });
16
- /**
17
- * Signal that has the default options from query client applied
18
- * computed() is used so signals can be inserted into the options
19
- * making it reactive. Wrapping options in a function ensures embedded expressions
20
- * are preserved and can keep being applied after signal changes
21
- */
22
- const defaultedOptionsSignal = computed(() => {
23
- const options = runInInjectionContext(injector, () => optionsFn(queryClient));
24
- const defaultedOptions = queryClient.defaultQueryOptions(options);
25
- defaultedOptions._optimisticResults = 'optimistic';
26
- return defaultedOptions;
27
- });
28
- const observer = new Observer(queryClient, defaultedOptionsSignal());
29
- const resultSignal = signal(observer.getOptimisticResult(defaultedOptionsSignal()));
30
- effect(() => {
31
- const defaultedOptions = defaultedOptionsSignal();
32
- observer.setOptions(defaultedOptions, {
33
- // Do not notify on updates because of changes in the options because
34
- // these changes should already be reflected in the optimistic result.
35
- listeners: false,
36
- });
37
- untracked(() => {
38
- resultSignal.set(observer.getOptimisticResult(defaultedOptions));
39
- });
40
- }, {
41
- injector,
42
- });
43
- // observer.trackResult is not used as this optimization is not needed for Angular
44
- const unsubscribe = observer.subscribe(notifyManager.batchCalls((state) => {
45
- ngZone.run(() => {
46
- if (state.isError &&
47
- !state.isFetching &&
48
- // !isRestoring() && // todo: enable when client persistence is implemented
49
- shouldThrowError(observer.options.throwOnError, [
50
- state.error,
51
- observer.getCurrentQuery(),
52
- ])) {
53
- throw state.error;
54
- }
55
- resultSignal.set(state);
56
- });
57
- }));
58
- destroyRef.onDestroy(unsubscribe);
59
- return signalProxy(resultSignal);
60
- });
61
- }
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJhc2UtcXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY3JlYXRlLWJhc2UtcXVlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFVBQVUsRUFDVixRQUFRLEVBQ1IsTUFBTSxFQUNOLFFBQVEsRUFDUixNQUFNLEVBQ04sTUFBTSxFQUNOLHFCQUFxQixFQUNyQixNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFBO0FBQ3RCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDNUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sUUFBUSxDQUFBO0FBQ3pDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQVN6RDs7R0FFRztBQUNILE1BQU0sVUFBVSxlQUFlLENBTzdCLFNBUUMsRUFDRCxRQUE4QjtJQUU5QixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDakMsT0FBTyxRQUFRLENBQUMsR0FBRyxFQUFFO1FBQ25CLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUE7UUFDbkMsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUMzQyxNQUFNLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUE7UUFFbkQ7Ozs7O1dBS0c7UUFDSCxNQUFNLHNCQUFzQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDM0MsTUFBTSxPQUFPLEdBQUcscUJBQXFCLENBQUMsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUNuRCxTQUFTLENBQUMsV0FBVyxDQUFDLENBQ3ZCLENBQUE7WUFDRCxNQUFNLGdCQUFnQixHQUFHLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUNqRSxnQkFBZ0IsQ0FBQyxrQkFBa0IsR0FBRyxZQUFZLENBQUE7WUFDbEQsT0FBTyxnQkFBZ0IsQ0FBQTtRQUN6QixDQUFDLENBQUMsQ0FBQTtRQUVGLE1BQU0sUUFBUSxHQUFHLElBQUksUUFBUSxDQU0zQixXQUFXLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQyxDQUFBO1FBRXhDLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FDekIsUUFBUSxDQUFDLG1CQUFtQixDQUFDLHNCQUFzQixFQUFFLENBQUMsQ0FDdkQsQ0FBQTtRQUVELE1BQU0sQ0FDSixHQUFHLEVBQUU7WUFDSCxNQUFNLGdCQUFnQixHQUFHLHNCQUFzQixFQUFFLENBQUE7WUFDakQsUUFBUSxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRTtnQkFDcEMscUVBQXFFO2dCQUNyRSxzRUFBc0U7Z0JBQ3RFLFNBQVMsRUFBRSxLQUFLO2FBQ2pCLENBQUMsQ0FBQTtZQUNGLFNBQVMsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2IsWUFBWSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFBO1lBQ2xFLENBQUMsQ0FBQyxDQUFBO1FBQ0osQ0FBQyxFQUNEO1lBQ0UsUUFBUTtTQUNULENBQ0YsQ0FBQTtRQUVELGtGQUFrRjtRQUNsRixNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsU0FBUyxDQUNwQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUMsS0FBeUMsRUFBRSxFQUFFO1lBQ3JFLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQ0UsS0FBSyxDQUFDLE9BQU87b0JBQ2IsQ0FBQyxLQUFLLENBQUMsVUFBVTtvQkFDakIsMkVBQTJFO29CQUMzRSxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRTt3QkFDOUMsS0FBSyxDQUFDLEtBQUs7d0JBQ1gsUUFBUSxDQUFDLGVBQWUsRUFBRTtxQkFDM0IsQ0FBQyxFQUNGLENBQUM7b0JBQ0QsTUFBTSxLQUFLLENBQUMsS0FBSyxDQUFBO2dCQUNuQixDQUFDO2dCQUNELFlBQVksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDekIsQ0FBQyxDQUFDLENBQUE7UUFDSixDQUFDLENBQUMsQ0FDSCxDQUFBO1FBQ0QsVUFBVSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQTtRQUVqQyxPQUFPLFdBQVcsQ0FBQyxZQUFZLENBQXlDLENBQUE7SUFDMUUsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgSW5qZWN0b3IsXG4gIE5nWm9uZSxcbiAgY29tcHV0ZWQsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBydW5JbkluamVjdGlvbkNvbnRleHQsXG4gIHNpZ25hbCxcbiAgdW50cmFja2VkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgbm90aWZ5TWFuYWdlciB9IGZyb20gJ0B0YW5zdGFjay9xdWVyeS1jb3JlJ1xuaW1wb3J0IHsgc2lnbmFsUHJveHkgfSBmcm9tICcuL3NpZ25hbC1wcm94eSdcbmltcG9ydCB7IHNob3VsZFRocm93RXJyb3IgfSBmcm9tICcuL3V0aWwnXG5pbXBvcnQgeyBsYXp5SW5pdCB9IGZyb20gJy4vdXRpbC9sYXp5LWluaXQvbGF6eS1pbml0J1xuaW1wb3J0IHsgaW5qZWN0UXVlcnlDbGllbnQgfSBmcm9tICcuL2luamVjdC1xdWVyeS1jbGllbnQnXG5pbXBvcnQgdHlwZSB7XG4gIFF1ZXJ5Q2xpZW50LFxuICBRdWVyeUtleSxcbiAgUXVlcnlPYnNlcnZlcixcbiAgUXVlcnlPYnNlcnZlclJlc3VsdCxcbn0gZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5pbXBvcnQgdHlwZSB7IENyZWF0ZUJhc2VRdWVyeU9wdGlvbnMsIENyZWF0ZUJhc2VRdWVyeVJlc3VsdCB9IGZyb20gJy4vdHlwZXMnXG5cbi8qKlxuICogQmFzZSBpbXBsZW1lbnRhdGlvbiBmb3IgYGluamVjdFF1ZXJ5YCBhbmQgYGluamVjdEluZmluaXRlUXVlcnlgLlxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQmFzZVF1ZXJ5PFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvcixcbiAgVERhdGEsXG4gIFRRdWVyeURhdGEsXG4gIFRRdWVyeUtleSBleHRlbmRzIFF1ZXJ5S2V5LFxuPihcbiAgb3B0aW9uc0ZuOiAoXG4gICAgY2xpZW50OiBRdWVyeUNsaWVudCxcbiAgKSA9PiBDcmVhdGVCYXNlUXVlcnlPcHRpb25zPFxuICAgIFRRdWVyeUZuRGF0YSxcbiAgICBURXJyb3IsXG4gICAgVERhdGEsXG4gICAgVFF1ZXJ5RGF0YSxcbiAgICBUUXVlcnlLZXlcbiAgPixcbiAgT2JzZXJ2ZXI6IHR5cGVvZiBRdWVyeU9ic2VydmVyLFxuKTogQ3JlYXRlQmFzZVF1ZXJ5UmVzdWx0PFREYXRhLCBURXJyb3I+IHtcbiAgY29uc3QgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpXG4gIHJldHVybiBsYXp5SW5pdCgoKSA9PiB7XG4gICAgY29uc3Qgbmdab25lID0gaW5qZWN0b3IuZ2V0KE5nWm9uZSlcbiAgICBjb25zdCBkZXN0cm95UmVmID0gaW5qZWN0b3IuZ2V0KERlc3Ryb3lSZWYpXG4gICAgY29uc3QgcXVlcnlDbGllbnQgPSBpbmplY3RRdWVyeUNsaWVudCh7IGluamVjdG9yIH0pXG5cbiAgICAvKipcbiAgICAgKiBTaWduYWwgdGhhdCBoYXMgdGhlIGRlZmF1bHQgb3B0aW9ucyBmcm9tIHF1ZXJ5IGNsaWVudCBhcHBsaWVkXG4gICAgICogY29tcHV0ZWQoKSBpcyB1c2VkIHNvIHNpZ25hbHMgY2FuIGJlIGluc2VydGVkIGludG8gdGhlIG9wdGlvbnNcbiAgICAgKiBtYWtpbmcgaXQgcmVhY3RpdmUuIFdyYXBwaW5nIG9wdGlvbnMgaW4gYSBmdW5jdGlvbiBlbnN1cmVzIGVtYmVkZGVkIGV4cHJlc3Npb25zXG4gICAgICogYXJlIHByZXNlcnZlZCBhbmQgY2FuIGtlZXAgYmVpbmcgYXBwbGllZCBhZnRlciBzaWduYWwgY2hhbmdlc1xuICAgICAqL1xuICAgIGNvbnN0IGRlZmF1bHRlZE9wdGlvbnNTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICBjb25zdCBvcHRpb25zID0gcnVuSW5JbmplY3Rpb25Db250ZXh0KGluamVjdG9yLCAoKSA9PlxuICAgICAgICBvcHRpb25zRm4ocXVlcnlDbGllbnQpLFxuICAgICAgKVxuICAgICAgY29uc3QgZGVmYXVsdGVkT3B0aW9ucyA9IHF1ZXJ5Q2xpZW50LmRlZmF1bHRRdWVyeU9wdGlvbnMob3B0aW9ucylcbiAgICAgIGRlZmF1bHRlZE9wdGlvbnMuX29wdGltaXN0aWNSZXN1bHRzID0gJ29wdGltaXN0aWMnXG4gICAgICByZXR1cm4gZGVmYXVsdGVkT3B0aW9uc1xuICAgIH0pXG5cbiAgICBjb25zdCBvYnNlcnZlciA9IG5ldyBPYnNlcnZlcjxcbiAgICAgIFRRdWVyeUZuRGF0YSxcbiAgICAgIFRFcnJvcixcbiAgICAgIFREYXRhLFxuICAgICAgVFF1ZXJ5RGF0YSxcbiAgICAgIFRRdWVyeUtleVxuICAgID4ocXVlcnlDbGllbnQsIGRlZmF1bHRlZE9wdGlvbnNTaWduYWwoKSlcblxuICAgIGNvbnN0IHJlc3VsdFNpZ25hbCA9IHNpZ25hbChcbiAgICAgIG9ic2VydmVyLmdldE9wdGltaXN0aWNSZXN1bHQoZGVmYXVsdGVkT3B0aW9uc1NpZ25hbCgpKSxcbiAgICApXG5cbiAgICBlZmZlY3QoXG4gICAgICAoKSA9PiB7XG4gICAgICAgIGNvbnN0IGRlZmF1bHRlZE9wdGlvbnMgPSBkZWZhdWx0ZWRPcHRpb25zU2lnbmFsKClcbiAgICAgICAgb2JzZXJ2ZXIuc2V0T3B0aW9ucyhkZWZhdWx0ZWRPcHRpb25zLCB7XG4gICAgICAgICAgLy8gRG8gbm90IG5vdGlmeSBvbiB1cGRhdGVzIGJlY2F1c2Ugb2YgY2hhbmdlcyBpbiB0aGUgb3B0aW9ucyBiZWNhdXNlXG4gICAgICAgICAgLy8gdGhlc2UgY2hhbmdlcyBzaG91bGQgYWxyZWFkeSBiZSByZWZsZWN0ZWQgaW4gdGhlIG9wdGltaXN0aWMgcmVzdWx0LlxuICAgICAgICAgIGxpc3RlbmVyczogZmFsc2UsXG4gICAgICAgIH0pXG4gICAgICAgIHVudHJhY2tlZCgoKSA9PiB7XG4gICAgICAgICAgcmVzdWx0U2lnbmFsLnNldChvYnNlcnZlci5nZXRPcHRpbWlzdGljUmVzdWx0KGRlZmF1bHRlZE9wdGlvbnMpKVxuICAgICAgICB9KVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgaW5qZWN0b3IsXG4gICAgICB9LFxuICAgIClcblxuICAgIC8vIG9ic2VydmVyLnRyYWNrUmVzdWx0IGlzIG5vdCB1c2VkIGFzIHRoaXMgb3B0aW1pemF0aW9uIGlzIG5vdCBuZWVkZWQgZm9yIEFuZ3VsYXJcbiAgICBjb25zdCB1bnN1YnNjcmliZSA9IG9ic2VydmVyLnN1YnNjcmliZShcbiAgICAgIG5vdGlmeU1hbmFnZXIuYmF0Y2hDYWxscygoc3RhdGU6IFF1ZXJ5T2JzZXJ2ZXJSZXN1bHQ8VERhdGEsIFRFcnJvcj4pID0+IHtcbiAgICAgICAgbmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgc3RhdGUuaXNFcnJvciAmJlxuICAgICAgICAgICAgIXN0YXRlLmlzRmV0Y2hpbmcgJiZcbiAgICAgICAgICAgIC8vICFpc1Jlc3RvcmluZygpICYmIC8vIHRvZG86IGVuYWJsZSB3aGVuIGNsaWVudCBwZXJzaXN0ZW5jZSBpcyBpbXBsZW1lbnRlZFxuICAgICAgICAgICAgc2hvdWxkVGhyb3dFcnJvcihvYnNlcnZlci5vcHRpb25zLnRocm93T25FcnJvciwgW1xuICAgICAgICAgICAgICBzdGF0ZS5lcnJvcixcbiAgICAgICAgICAgICAgb2JzZXJ2ZXIuZ2V0Q3VycmVudFF1ZXJ5KCksXG4gICAgICAgICAgICBdKVxuICAgICAgICAgICkge1xuICAgICAgICAgICAgdGhyb3cgc3RhdGUuZXJyb3JcbiAgICAgICAgICB9XG4gICAgICAgICAgcmVzdWx0U2lnbmFsLnNldChzdGF0ZSlcbiAgICAgICAgfSlcbiAgICAgIH0pLFxuICAgIClcbiAgICBkZXN0cm95UmVmLm9uRGVzdHJveSh1bnN1YnNjcmliZSlcblxuICAgIHJldHVybiBzaWduYWxQcm94eShyZXN1bHRTaWduYWwpIGFzIENyZWF0ZUJhc2VRdWVyeVJlc3VsdDxURGF0YSwgVEVycm9yPlxuICB9KVxufVxuIl19
@@ -1,16 +0,0 @@
1
- /* istanbul ignore file */
2
- // Re-export core
3
- export * from '@tanstack/query-core';
4
- export * from './types';
5
- export { queryOptions } from './query-options';
6
- export { infiniteQueryOptions } from './infinite-query-options';
7
- export * from './inject-infinite-query';
8
- export * from './inject-is-fetching';
9
- export * from './inject-is-mutating';
10
- export * from './inject-mutation';
11
- export * from './inject-mutation-state';
12
- export * from './inject-queries';
13
- export * from './inject-query';
14
- export { injectQueryClient, provideQueryClient } from './inject-query-client';
15
- export { provideAngularQuery } from './providers';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEJBQTBCO0FBRTFCLGlCQUFpQjtBQUNqQixjQUFjLHNCQUFzQixDQUFBO0FBRXBDLGNBQWMsU0FBUyxDQUFBO0FBTXZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQU05QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUUvRCxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGdCQUFnQixDQUFBO0FBQzlCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBQzdFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5cbi8vIFJlLWV4cG9ydCBjb3JlXG5leHBvcnQgKiBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcydcblxuZXhwb3J0IHR5cGUge1xuICBEZWZpbmVkSW5pdGlhbERhdGFPcHRpb25zLFxuICBVbmRlZmluZWRJbml0aWFsRGF0YU9wdGlvbnMsXG59IGZyb20gJy4vcXVlcnktb3B0aW9ucydcbmV4cG9ydCB7IHF1ZXJ5T3B0aW9ucyB9IGZyb20gJy4vcXVlcnktb3B0aW9ucydcblxuZXhwb3J0IHR5cGUge1xuICBEZWZpbmVkSW5pdGlhbERhdGFJbmZpbml0ZU9wdGlvbnMsXG4gIFVuZGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zLFxufSBmcm9tICcuL2luZmluaXRlLXF1ZXJ5LW9wdGlvbnMnXG5leHBvcnQgeyBpbmZpbml0ZVF1ZXJ5T3B0aW9ucyB9IGZyb20gJy4vaW5maW5pdGUtcXVlcnktb3B0aW9ucydcblxuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtaW5maW5pdGUtcXVlcnknXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1pcy1mZXRjaGluZydcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LWlzLW11dGF0aW5nJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtbXV0YXRpb24nXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1tdXRhdGlvbi1zdGF0ZSdcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LXF1ZXJpZXMnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1xdWVyeSdcbmV4cG9ydCB7IGluamVjdFF1ZXJ5Q2xpZW50LCBwcm92aWRlUXVlcnlDbGllbnQgfSBmcm9tICcuL2luamVjdC1xdWVyeS1jbGllbnQnXG5leHBvcnQgeyBwcm92aWRlQW5ndWxhclF1ZXJ5IH0gZnJvbSAnLi9wcm92aWRlcnMnXG4iXX0=
@@ -1,12 +0,0 @@
1
- /**
2
- * Allows to share and re-use infinite query options in a type-safe way.
3
- *
4
- * The `queryKey` will be tagged with the type from `queryFn`.
5
- * @param options - The infinite query options to tag with the type from `queryFn`.
6
- * @returns The tagged infinite query options.
7
- * @public
8
- */
9
- export function infiniteQueryOptions(options) {
10
- return options;
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5maW5pdGUtcXVlcnktb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbmZpbml0ZS1xdWVyeS1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtIQTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxVQUFVLG9CQUFvQixDQUFDLE9BQWdCO0lBQ25ELE9BQU8sT0FBTyxDQUFBO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIERhdGFUYWcsXG4gIERlZmF1bHRFcnJvcixcbiAgSW5maW5pdGVEYXRhLFxuICBRdWVyeUtleSxcbn0gZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5pbXBvcnQgdHlwZSB7IENyZWF0ZUluZmluaXRlUXVlcnlPcHRpb25zLCBOb25VbmRlZmluZWRHdWFyZCB9IGZyb20gJy4vdHlwZXMnXG5cbi8qKlxuICogQHB1YmxpY1xuICovXG5leHBvcnQgdHlwZSBVbmRlZmluZWRJbml0aWFsRGF0YUluZmluaXRlT3B0aW9uczxcbiAgVFF1ZXJ5Rm5EYXRhLFxuICBURXJyb3IgPSBEZWZhdWx0RXJyb3IsXG4gIFREYXRhID0gSW5maW5pdGVEYXRhPFRRdWVyeUZuRGF0YT4sXG4gIFRRdWVyeUtleSBleHRlbmRzIFF1ZXJ5S2V5ID0gUXVlcnlLZXksXG4gIFRQYWdlUGFyYW0gPSB1bmtub3duLFxuPiA9IENyZWF0ZUluZmluaXRlUXVlcnlPcHRpb25zPFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvcixcbiAgVERhdGEsXG4gIFRRdWVyeUZuRGF0YSxcbiAgVFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtXG4+ICYge1xuICBpbml0aWFsRGF0YT86IHVuZGVmaW5lZFxufVxuXG4vKipcbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IHR5cGUgRGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zPFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvciA9IERlZmF1bHRFcnJvcixcbiAgVERhdGEgPSBJbmZpbml0ZURhdGE8VFF1ZXJ5Rm5EYXRhPixcbiAgVFF1ZXJ5S2V5IGV4dGVuZHMgUXVlcnlLZXkgPSBRdWVyeUtleSxcbiAgVFBhZ2VQYXJhbSA9IHVua25vd24sXG4+ID0gQ3JlYXRlSW5maW5pdGVRdWVyeU9wdGlvbnM8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yLFxuICBURGF0YSxcbiAgVFF1ZXJ5Rm5EYXRhLFxuICBUUXVlcnlLZXksXG4gIFRQYWdlUGFyYW1cbj4gJiB7XG4gIGluaXRpYWxEYXRhOlxuICAgIHwgTm9uVW5kZWZpbmVkR3VhcmQ8SW5maW5pdGVEYXRhPFRRdWVyeUZuRGF0YSwgVFBhZ2VQYXJhbT4+XG4gICAgfCAoKCkgPT4gTm9uVW5kZWZpbmVkR3VhcmQ8SW5maW5pdGVEYXRhPFRRdWVyeUZuRGF0YSwgVFBhZ2VQYXJhbT4+KVxufVxuXG4vKipcbiAqIEFsbG93cyB0byBzaGFyZSBhbmQgcmUtdXNlIGluZmluaXRlIHF1ZXJ5IG9wdGlvbnMgaW4gYSB0eXBlLXNhZmUgd2F5LlxuICpcbiAqIFRoZSBgcXVlcnlLZXlgIHdpbGwgYmUgdGFnZ2VkIHdpdGggdGhlIHR5cGUgZnJvbSBgcXVlcnlGbmAuXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRoZSBpbmZpbml0ZSBxdWVyeSBvcHRpb25zIHRvIHRhZyB3aXRoIHRoZSB0eXBlIGZyb20gYHF1ZXJ5Rm5gLlxuICogQHJldHVybnMgVGhlIHRhZ2dlZCBpbmZpbml0ZSBxdWVyeSBvcHRpb25zLlxuICogQHB1YmxpY1xuICovXG5leHBvcnQgZnVuY3Rpb24gaW5maW5pdGVRdWVyeU9wdGlvbnM8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yID0gRGVmYXVsdEVycm9yLFxuICBURGF0YSA9IEluZmluaXRlRGF0YTxUUXVlcnlGbkRhdGE+LFxuICBUUXVlcnlLZXkgZXh0ZW5kcyBRdWVyeUtleSA9IFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtID0gdW5rbm93bixcbj4oXG4gIG9wdGlvbnM6IERlZmluZWRJbml0aWFsRGF0YUluZmluaXRlT3B0aW9uczxcbiAgICBUUXVlcnlGbkRhdGEsXG4gICAgVEVycm9yLFxuICAgIFREYXRhLFxuICAgIFRRdWVyeUtleSxcbiAgICBUUGFnZVBhcmFtXG4gID4sXG4pOiBEZWZpbmVkSW5pdGlhbERhdGFJbmZpbml0ZU9wdGlvbnM8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yLFxuICBURGF0YSxcbiAgVFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtXG4+ICYge1xuICBxdWVyeUtleTogRGF0YVRhZzxUUXVlcnlLZXksIEluZmluaXRlRGF0YTxUUXVlcnlGbkRhdGE+PlxufVxuXG4vKipcbiAqIEFsbG93cyB0byBzaGFyZSBhbmQgcmUtdXNlIGluZmluaXRlIHF1ZXJ5IG9wdGlvbnMgaW4gYSB0eXBlLXNhZmUgd2F5LlxuICpcbiAqIFRoZSBgcXVlcnlLZXlgIHdpbGwgYmUgdGFnZ2VkIHdpdGggdGhlIHR5cGUgZnJvbSBgcXVlcnlGbmAuXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRoZSBpbmZpbml0ZSBxdWVyeSBvcHRpb25zIHRvIHRhZyB3aXRoIHRoZSB0eXBlIGZyb20gYHF1ZXJ5Rm5gLlxuICogQHJldHVybnMgVGhlIHRhZ2dlZCBpbmZpbml0ZSBxdWVyeSBvcHRpb25zLlxuICogQHB1YmxpY1xuICovXG5leHBvcnQgZnVuY3Rpb24gaW5maW5pdGVRdWVyeU9wdGlvbnM8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yID0gRGVmYXVsdEVycm9yLFxuICBURGF0YSA9IEluZmluaXRlRGF0YTxUUXVlcnlGbkRhdGE+LFxuICBUUXVlcnlLZXkgZXh0ZW5kcyBRdWVyeUtleSA9IFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtID0gdW5rbm93bixcbj4oXG4gIG9wdGlvbnM6IFVuZGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zPFxuICAgIFRRdWVyeUZuRGF0YSxcbiAgICBURXJyb3IsXG4gICAgVERhdGEsXG4gICAgVFF1ZXJ5S2V5LFxuICAgIFRQYWdlUGFyYW1cbiAgPixcbik6IFVuZGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zPFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvcixcbiAgVERhdGEsXG4gIFRRdWVyeUtleSxcbiAgVFBhZ2VQYXJhbVxuPiAmIHtcbiAgcXVlcnlLZXk6IERhdGFUYWc8VFF1ZXJ5S2V5LCBJbmZpbml0ZURhdGE8VFF1ZXJ5Rm5EYXRhPj5cbn1cblxuLyoqXG4gKiBBbGxvd3MgdG8gc2hhcmUgYW5kIHJlLXVzZSBpbmZpbml0ZSBxdWVyeSBvcHRpb25zIGluIGEgdHlwZS1zYWZlIHdheS5cbiAqXG4gKiBUaGUgYHF1ZXJ5S2V5YCB3aWxsIGJlIHRhZ2dlZCB3aXRoIHRoZSB0eXBlIGZyb20gYHF1ZXJ5Rm5gLlxuICogQHBhcmFtIG9wdGlvbnMgLSBUaGUgaW5maW5pdGUgcXVlcnkgb3B0aW9ucyB0byB0YWcgd2l0aCB0aGUgdHlwZSBmcm9tIGBxdWVyeUZuYC5cbiAqIEByZXR1cm5zIFRoZSB0YWdnZWQgaW5maW5pdGUgcXVlcnkgb3B0aW9ucy5cbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluZmluaXRlUXVlcnlPcHRpb25zKG9wdGlvbnM6IHVua25vd24pIHtcbiAgcmV0dXJuIG9wdGlvbnNcbn1cbiJdfQ==
@@ -1,15 +0,0 @@
1
- import { InfiniteQueryObserver } from '@tanstack/query-core';
2
- import { createBaseQuery } from './create-base-query';
3
- import { assertInjector } from './util/assert-injector/assert-injector';
4
- /**
5
- * Injects an infinite query: a declarative dependency on an asynchronous source of data that is tied to a unique key.
6
- * Infinite queries can additively "load more" data onto an existing set of data or "infinite scroll"
7
- * @param optionsFn - A function that returns infinite query options.
8
- * @param injector - The Angular injector to use.
9
- * @returns The infinite query result.
10
- * @public
11
- */
12
- export function injectInfiniteQuery(optionsFn, injector) {
13
- return assertInjector(injectInfiniteQuery, injector, () => createBaseQuery(optionsFn, InfiniteQueryObserver));
14
- }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LWluZmluaXRlLXF1ZXJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luamVjdC1pbmZpbml0ZS1xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFDckQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdDQUF3QyxDQUFBO0FBcUd2RTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxTQUE4RCxFQUM5RCxRQUFtQjtJQUVuQixPQUFPLGNBQWMsQ0FBQyxtQkFBbUIsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLENBQ3hELGVBQWUsQ0FBQyxTQUFTLEVBQUUscUJBQTZDLENBQUMsQ0FDMUUsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmZpbml0ZVF1ZXJ5T2JzZXJ2ZXIgfSBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcbmltcG9ydCB7IGNyZWF0ZUJhc2VRdWVyeSB9IGZyb20gJy4vY3JlYXRlLWJhc2UtcXVlcnknXG5pbXBvcnQgeyBhc3NlcnRJbmplY3RvciB9IGZyb20gJy4vdXRpbC9hc3NlcnQtaW5qZWN0b3IvYXNzZXJ0LWluamVjdG9yJ1xuaW1wb3J0IHR5cGUgeyBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgdHlwZSB7XG4gIERlZmF1bHRFcnJvcixcbiAgSW5maW5pdGVEYXRhLFxuICBRdWVyeUNsaWVudCxcbiAgUXVlcnlLZXksXG4gIFF1ZXJ5T2JzZXJ2ZXIsXG59IGZyb20gJ0B0YW5zdGFjay9xdWVyeS1jb3JlJ1xuaW1wb3J0IHR5cGUge1xuICBDcmVhdGVJbmZpbml0ZVF1ZXJ5T3B0aW9ucyxcbiAgQ3JlYXRlSW5maW5pdGVRdWVyeVJlc3VsdCxcbiAgRGVmaW5lZENyZWF0ZUluZmluaXRlUXVlcnlSZXN1bHQsXG59IGZyb20gJy4vdHlwZXMnXG5pbXBvcnQgdHlwZSB7XG4gIERlZmluZWRJbml0aWFsRGF0YUluZmluaXRlT3B0aW9ucyxcbiAgVW5kZWZpbmVkSW5pdGlhbERhdGFJbmZpbml0ZU9wdGlvbnMsXG59IGZyb20gJy4vaW5maW5pdGUtcXVlcnktb3B0aW9ucydcblxuLyoqXG4gKiBJbmplY3RzIGFuIGluZmluaXRlIHF1ZXJ5OiBhIGRlY2xhcmF0aXZlIGRlcGVuZGVuY3kgb24gYW4gYXN5bmNocm9ub3VzIHNvdXJjZSBvZiBkYXRhIHRoYXQgaXMgdGllZCB0byBhIHVuaXF1ZSBrZXkuXG4gKiBJbmZpbml0ZSBxdWVyaWVzIGNhbiBhZGRpdGl2ZWx5IFwibG9hZCBtb3JlXCIgZGF0YSBvbnRvIGFuIGV4aXN0aW5nIHNldCBvZiBkYXRhIG9yIFwiaW5maW5pdGUgc2Nyb2xsXCJcbiAqIEBwYXJhbSBvcHRpb25zRm4gLSBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBpbmZpbml0ZSBxdWVyeSBvcHRpb25zLlxuICogQHBhcmFtIGluamVjdG9yIC0gVGhlIEFuZ3VsYXIgaW5qZWN0b3IgdG8gdXNlLlxuICogQHJldHVybnMgVGhlIGluZmluaXRlIHF1ZXJ5IHJlc3VsdC5cbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEluZmluaXRlUXVlcnk8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yID0gRGVmYXVsdEVycm9yLFxuICBURGF0YSA9IEluZmluaXRlRGF0YTxUUXVlcnlGbkRhdGE+LFxuICBUUXVlcnlLZXkgZXh0ZW5kcyBRdWVyeUtleSA9IFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtID0gdW5rbm93bixcbj4oXG4gIG9wdGlvbnNGbjogKFxuICAgIGNsaWVudDogUXVlcnlDbGllbnQsXG4gICkgPT4gRGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zPFxuICAgIFRRdWVyeUZuRGF0YSxcbiAgICBURXJyb3IsXG4gICAgVERhdGEsXG4gICAgVFF1ZXJ5S2V5LFxuICAgIFRQYWdlUGFyYW1cbiAgPixcbiAgaW5qZWN0b3I/OiBJbmplY3Rvcixcbik6IERlZmluZWRDcmVhdGVJbmZpbml0ZVF1ZXJ5UmVzdWx0PFREYXRhLCBURXJyb3I+XG5cbi8qKlxuICogSW5qZWN0cyBhbiBpbmZpbml0ZSBxdWVyeTogYSBkZWNsYXJhdGl2ZSBkZXBlbmRlbmN5IG9uIGFuIGFzeW5jaHJvbm91cyBzb3VyY2Ugb2YgZGF0YSB0aGF0IGlzIHRpZWQgdG8gYSB1bmlxdWUga2V5LlxuICogSW5maW5pdGUgcXVlcmllcyBjYW4gYWRkaXRpdmVseSBcImxvYWQgbW9yZVwiIGRhdGEgb250byBhbiBleGlzdGluZyBzZXQgb2YgZGF0YSBvciBcImluZmluaXRlIHNjcm9sbFwiXG4gKiBAcGFyYW0gb3B0aW9uc0ZuIC0gQSBmdW5jdGlvbiB0aGF0IHJldHVybnMgaW5maW5pdGUgcXVlcnkgb3B0aW9ucy5cbiAqIEBwYXJhbSBpbmplY3RvciAtIFRoZSBBbmd1bGFyIGluamVjdG9yIHRvIHVzZS5cbiAqIEByZXR1cm5zIFRoZSBpbmZpbml0ZSBxdWVyeSByZXN1bHQuXG4gKiBAcHVibGljXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RJbmZpbml0ZVF1ZXJ5PFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvciA9IERlZmF1bHRFcnJvcixcbiAgVERhdGEgPSBJbmZpbml0ZURhdGE8VFF1ZXJ5Rm5EYXRhPixcbiAgVFF1ZXJ5S2V5IGV4dGVuZHMgUXVlcnlLZXkgPSBRdWVyeUtleSxcbiAgVFBhZ2VQYXJhbSA9IHVua25vd24sXG4+KFxuICBvcHRpb25zRm46IChcbiAgICBjbGllbnQ6IFF1ZXJ5Q2xpZW50LFxuICApID0+IFVuZGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zPFxuICAgIFRRdWVyeUZuRGF0YSxcbiAgICBURXJyb3IsXG4gICAgVERhdGEsXG4gICAgVFF1ZXJ5S2V5LFxuICAgIFRQYWdlUGFyYW1cbiAgPixcbiAgaW5qZWN0b3I/OiBJbmplY3Rvcixcbik6IENyZWF0ZUluZmluaXRlUXVlcnlSZXN1bHQ8VERhdGEsIFRFcnJvcj5cblxuLyoqXG4gKiBJbmplY3RzIGFuIGluZmluaXRlIHF1ZXJ5OiBhIGRlY2xhcmF0aXZlIGRlcGVuZGVuY3kgb24gYW4gYXN5bmNocm9ub3VzIHNvdXJjZSBvZiBkYXRhIHRoYXQgaXMgdGllZCB0byBhIHVuaXF1ZSBrZXkuXG4gKiBJbmZpbml0ZSBxdWVyaWVzIGNhbiBhZGRpdGl2ZWx5IFwibG9hZCBtb3JlXCIgZGF0YSBvbnRvIGFuIGV4aXN0aW5nIHNldCBvZiBkYXRhIG9yIFwiaW5maW5pdGUgc2Nyb2xsXCJcbiAqIEBwYXJhbSBvcHRpb25zRm4gLSBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBpbmZpbml0ZSBxdWVyeSBvcHRpb25zLlxuICogQHBhcmFtIGluamVjdG9yIC0gVGhlIEFuZ3VsYXIgaW5qZWN0b3IgdG8gdXNlLlxuICogQHJldHVybnMgVGhlIGluZmluaXRlIHF1ZXJ5IHJlc3VsdC5cbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEluZmluaXRlUXVlcnk8XG4gIFRRdWVyeUZuRGF0YSxcbiAgVEVycm9yID0gRGVmYXVsdEVycm9yLFxuICBURGF0YSA9IEluZmluaXRlRGF0YTxUUXVlcnlGbkRhdGE+LFxuICBUUXVlcnlLZXkgZXh0ZW5kcyBRdWVyeUtleSA9IFF1ZXJ5S2V5LFxuICBUUGFnZVBhcmFtID0gdW5rbm93bixcbj4oXG4gIG9wdGlvbnNGbjogKFxuICAgIGNsaWVudDogUXVlcnlDbGllbnQsXG4gICkgPT4gQ3JlYXRlSW5maW5pdGVRdWVyeU9wdGlvbnM8XG4gICAgVFF1ZXJ5Rm5EYXRhLFxuICAgIFRFcnJvcixcbiAgICBURGF0YSxcbiAgICBUUXVlcnlGbkRhdGEsXG4gICAgVFF1ZXJ5S2V5LFxuICAgIFRQYWdlUGFyYW1cbiAgPixcbiAgaW5qZWN0b3I/OiBJbmplY3Rvcixcbik6IENyZWF0ZUluZmluaXRlUXVlcnlSZXN1bHQ8VERhdGEsIFRFcnJvcj5cblxuLyoqXG4gKiBJbmplY3RzIGFuIGluZmluaXRlIHF1ZXJ5OiBhIGRlY2xhcmF0aXZlIGRlcGVuZGVuY3kgb24gYW4gYXN5bmNocm9ub3VzIHNvdXJjZSBvZiBkYXRhIHRoYXQgaXMgdGllZCB0byBhIHVuaXF1ZSBrZXkuXG4gKiBJbmZpbml0ZSBxdWVyaWVzIGNhbiBhZGRpdGl2ZWx5IFwibG9hZCBtb3JlXCIgZGF0YSBvbnRvIGFuIGV4aXN0aW5nIHNldCBvZiBkYXRhIG9yIFwiaW5maW5pdGUgc2Nyb2xsXCJcbiAqIEBwYXJhbSBvcHRpb25zRm4gLSBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBpbmZpbml0ZSBxdWVyeSBvcHRpb25zLlxuICogQHBhcmFtIGluamVjdG9yIC0gVGhlIEFuZ3VsYXIgaW5qZWN0b3IgdG8gdXNlLlxuICogQHJldHVybnMgVGhlIGluZmluaXRlIHF1ZXJ5IHJlc3VsdC5cbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEluZmluaXRlUXVlcnkoXG4gIG9wdGlvbnNGbjogKGNsaWVudDogUXVlcnlDbGllbnQpID0+IENyZWF0ZUluZmluaXRlUXVlcnlPcHRpb25zLFxuICBpbmplY3Rvcj86IEluamVjdG9yLFxuKSB7XG4gIHJldHVybiBhc3NlcnRJbmplY3RvcihpbmplY3RJbmZpbml0ZVF1ZXJ5LCBpbmplY3RvciwgKCkgPT5cbiAgICBjcmVhdGVCYXNlUXVlcnkob3B0aW9uc0ZuLCBJbmZpbml0ZVF1ZXJ5T2JzZXJ2ZXIgYXMgdHlwZW9mIFF1ZXJ5T2JzZXJ2ZXIpLFxuICApXG59XG4iXX0=
@@ -1,38 +0,0 @@
1
- import { DestroyRef, NgZone, inject, signal } from '@angular/core';
2
- import { notifyManager } from '@tanstack/query-core';
3
- import { assertInjector } from './util/assert-injector/assert-injector';
4
- import { injectQueryClient } from './inject-query-client';
5
- /**
6
- * Injects a signal that tracks the number of queries that your application is loading or
7
- * fetching in the background.
8
- *
9
- * Can be used for app-wide loading indicators
10
- * @param filters - The filters to apply to the query.
11
- * @param injector - The Angular injector to use.
12
- * @returns signal with number of loading or fetching queries.
13
- * @public
14
- */
15
- export function injectIsFetching(filters, injector) {
16
- return assertInjector(injectIsFetching, injector, () => {
17
- const queryClient = injectQueryClient();
18
- const destroyRef = inject(DestroyRef);
19
- const ngZone = inject(NgZone);
20
- const cache = queryClient.getQueryCache();
21
- // isFetching is the prev value initialized on mount *
22
- let isFetching = queryClient.isFetching(filters);
23
- const result = signal(isFetching);
24
- const unsubscribe = cache.subscribe(notifyManager.batchCalls(() => {
25
- const newIsFetching = queryClient.isFetching(filters);
26
- if (isFetching !== newIsFetching) {
27
- // * and update with each change
28
- isFetching = newIsFetching;
29
- ngZone.run(() => {
30
- result.set(isFetching);
31
- });
32
- }
33
- }));
34
- destroyRef.onDestroy(unsubscribe);
35
- return result;
36
- });
37
- }
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LWlzLWZldGNoaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luamVjdC1pcy1mZXRjaGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDdkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUE7QUFJekQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxVQUFVLGdCQUFnQixDQUM5QixPQUFzQixFQUN0QixRQUFtQjtJQUVuQixPQUFPLGNBQWMsQ0FBQyxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFO1FBQ3JELE1BQU0sV0FBVyxHQUFHLGlCQUFpQixFQUFFLENBQUE7UUFDdkMsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQ3JDLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQTtRQUU3QixNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsYUFBYSxFQUFFLENBQUE7UUFDekMsc0RBQXNEO1FBQ3RELElBQUksVUFBVSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUE7UUFFaEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBRWpDLE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQ2pDLGFBQWEsQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQzVCLE1BQU0sYUFBYSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUE7WUFDckQsSUFBSSxVQUFVLEtBQUssYUFBYSxFQUFFLENBQUM7Z0JBQ2pDLGdDQUFnQztnQkFDaEMsVUFBVSxHQUFHLGFBQWEsQ0FBQTtnQkFDMUIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUU7b0JBQ2QsTUFBTSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQTtnQkFDeEIsQ0FBQyxDQUFDLENBQUE7WUFDSixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQ0gsQ0FBQTtRQUVELFVBQVUsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUE7UUFFakMsT0FBTyxNQUFNLENBQUE7SUFDZixDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXN0cm95UmVmLCBOZ1pvbmUsIGluamVjdCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IG5vdGlmeU1hbmFnZXIgfSBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcbmltcG9ydCB7IGFzc2VydEluamVjdG9yIH0gZnJvbSAnLi91dGlsL2Fzc2VydC1pbmplY3Rvci9hc3NlcnQtaW5qZWN0b3InXG5pbXBvcnQgeyBpbmplY3RRdWVyeUNsaWVudCB9IGZyb20gJy4vaW5qZWN0LXF1ZXJ5LWNsaWVudCdcbmltcG9ydCB0eXBlIHsgUXVlcnlGaWx0ZXJzIH0gZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5pbXBvcnQgdHlwZSB7IEluamVjdG9yLCBTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG4vKipcbiAqIEluamVjdHMgYSBzaWduYWwgdGhhdCB0cmFja3MgdGhlIG51bWJlciBvZiBxdWVyaWVzIHRoYXQgeW91ciBhcHBsaWNhdGlvbiBpcyBsb2FkaW5nIG9yXG4gKiBmZXRjaGluZyBpbiB0aGUgYmFja2dyb3VuZC5cbiAqXG4gKiBDYW4gYmUgdXNlZCBmb3IgYXBwLXdpZGUgbG9hZGluZyBpbmRpY2F0b3JzXG4gKiBAcGFyYW0gZmlsdGVycyAtIFRoZSBmaWx0ZXJzIHRvIGFwcGx5IHRvIHRoZSBxdWVyeS5cbiAqIEBwYXJhbSBpbmplY3RvciAtIFRoZSBBbmd1bGFyIGluamVjdG9yIHRvIHVzZS5cbiAqIEByZXR1cm5zIHNpZ25hbCB3aXRoIG51bWJlciBvZiBsb2FkaW5nIG9yIGZldGNoaW5nIHF1ZXJpZXMuXG4gKiBAcHVibGljXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RJc0ZldGNoaW5nKFxuICBmaWx0ZXJzPzogUXVlcnlGaWx0ZXJzLFxuICBpbmplY3Rvcj86IEluamVjdG9yLFxuKTogU2lnbmFsPG51bWJlcj4ge1xuICByZXR1cm4gYXNzZXJ0SW5qZWN0b3IoaW5qZWN0SXNGZXRjaGluZywgaW5qZWN0b3IsICgpID0+IHtcbiAgICBjb25zdCBxdWVyeUNsaWVudCA9IGluamVjdFF1ZXJ5Q2xpZW50KClcbiAgICBjb25zdCBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpXG4gICAgY29uc3Qgbmdab25lID0gaW5qZWN0KE5nWm9uZSlcblxuICAgIGNvbnN0IGNhY2hlID0gcXVlcnlDbGllbnQuZ2V0UXVlcnlDYWNoZSgpXG4gICAgLy8gaXNGZXRjaGluZyBpcyB0aGUgcHJldiB2YWx1ZSBpbml0aWFsaXplZCBvbiBtb3VudCAqXG4gICAgbGV0IGlzRmV0Y2hpbmcgPSBxdWVyeUNsaWVudC5pc0ZldGNoaW5nKGZpbHRlcnMpXG5cbiAgICBjb25zdCByZXN1bHQgPSBzaWduYWwoaXNGZXRjaGluZylcblxuICAgIGNvbnN0IHVuc3Vic2NyaWJlID0gY2FjaGUuc3Vic2NyaWJlKFxuICAgICAgbm90aWZ5TWFuYWdlci5iYXRjaENhbGxzKCgpID0+IHtcbiAgICAgICAgY29uc3QgbmV3SXNGZXRjaGluZyA9IHF1ZXJ5Q2xpZW50LmlzRmV0Y2hpbmcoZmlsdGVycylcbiAgICAgICAgaWYgKGlzRmV0Y2hpbmcgIT09IG5ld0lzRmV0Y2hpbmcpIHtcbiAgICAgICAgICAvLyAqIGFuZCB1cGRhdGUgd2l0aCBlYWNoIGNoYW5nZVxuICAgICAgICAgIGlzRmV0Y2hpbmcgPSBuZXdJc0ZldGNoaW5nXG4gICAgICAgICAgbmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgICByZXN1bHQuc2V0KGlzRmV0Y2hpbmcpXG4gICAgICAgICAgfSlcbiAgICAgICAgfVxuICAgICAgfSksXG4gICAgKVxuXG4gICAgZGVzdHJveVJlZi5vbkRlc3Ryb3kodW5zdWJzY3JpYmUpXG5cbiAgICByZXR1cm4gcmVzdWx0XG4gIH0pXG59XG4iXX0=
@@ -1,37 +0,0 @@
1
- import { DestroyRef, NgZone, inject, signal } from '@angular/core';
2
- import { notifyManager } from '@tanstack/query-core';
3
- import { assertInjector } from './util/assert-injector/assert-injector';
4
- import { injectQueryClient } from './inject-query-client';
5
- /**
6
- * Injects a signal that tracks the number of mutations that your application is fetching.
7
- *
8
- * Can be used for app-wide loading indicators
9
- * @param filters - The filters to apply to the query.
10
- * @param injector - The Angular injector to use.
11
- * @returns signal with number of fetching mutations.
12
- * @public
13
- */
14
- export function injectIsMutating(filters, injector) {
15
- return assertInjector(injectIsMutating, injector, () => {
16
- const queryClient = injectQueryClient();
17
- const destroyRef = inject(DestroyRef);
18
- const ngZone = inject(NgZone);
19
- const cache = queryClient.getMutationCache();
20
- // isMutating is the prev value initialized on mount *
21
- let isMutating = queryClient.isMutating(filters);
22
- const result = signal(isMutating);
23
- const unsubscribe = cache.subscribe(notifyManager.batchCalls(() => {
24
- const newIsMutating = queryClient.isMutating(filters);
25
- if (isMutating !== newIsMutating) {
26
- // * and update with each change
27
- isMutating = newIsMutating;
28
- ngZone.run(() => {
29
- result.set(isMutating);
30
- });
31
- }
32
- }));
33
- destroyRef.onDestroy(unsubscribe);
34
- return result;
35
- });
36
- }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LWlzLW11dGF0aW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luamVjdC1pcy1tdXRhdGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDdkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUE7QUFJekQ7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQzlCLE9BQXlCLEVBQ3pCLFFBQW1CO0lBRW5CLE9BQU8sY0FBYyxDQUFDLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUU7UUFDckQsTUFBTSxXQUFXLEdBQUcsaUJBQWlCLEVBQUUsQ0FBQTtRQUN2QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUE7UUFDckMsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBRTdCLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFBO1FBQzVDLHNEQUFzRDtRQUN0RCxJQUFJLFVBQVUsR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBRWhELE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUVqQyxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUNqQyxhQUFhLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUM1QixNQUFNLGFBQWEsR0FBRyxXQUFXLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1lBQ3JELElBQUksVUFBVSxLQUFLLGFBQWEsRUFBRSxDQUFDO2dCQUNqQyxnQ0FBZ0M7Z0JBQ2hDLFVBQVUsR0FBRyxhQUFhLENBQUE7Z0JBQzFCLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFO29CQUNkLE1BQU0sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUE7Z0JBQ3hCLENBQUMsQ0FBQyxDQUFBO1lBQ0osQ0FBQztRQUNILENBQUMsQ0FBQyxDQUNILENBQUE7UUFFRCxVQUFVLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFBO1FBRWpDLE9BQU8sTUFBTSxDQUFBO0lBQ2YsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgTmdab25lLCBpbmplY3QsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBub3RpZnlNYW5hZ2VyIH0gZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5pbXBvcnQgeyBhc3NlcnRJbmplY3RvciB9IGZyb20gJy4vdXRpbC9hc3NlcnQtaW5qZWN0b3IvYXNzZXJ0LWluamVjdG9yJ1xuaW1wb3J0IHsgaW5qZWN0UXVlcnlDbGllbnQgfSBmcm9tICcuL2luamVjdC1xdWVyeS1jbGllbnQnXG5pbXBvcnQgdHlwZSB7IE11dGF0aW9uRmlsdGVycyB9IGZyb20gJ0B0YW5zdGFjay9xdWVyeS1jb3JlJ1xuaW1wb3J0IHR5cGUgeyBJbmplY3RvciwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuLyoqXG4gKiBJbmplY3RzIGEgc2lnbmFsIHRoYXQgdHJhY2tzIHRoZSBudW1iZXIgb2YgbXV0YXRpb25zIHRoYXQgeW91ciBhcHBsaWNhdGlvbiBpcyBmZXRjaGluZy5cbiAqXG4gKiBDYW4gYmUgdXNlZCBmb3IgYXBwLXdpZGUgbG9hZGluZyBpbmRpY2F0b3JzXG4gKiBAcGFyYW0gZmlsdGVycyAtIFRoZSBmaWx0ZXJzIHRvIGFwcGx5IHRvIHRoZSBxdWVyeS5cbiAqIEBwYXJhbSBpbmplY3RvciAtIFRoZSBBbmd1bGFyIGluamVjdG9yIHRvIHVzZS5cbiAqIEByZXR1cm5zIHNpZ25hbCB3aXRoIG51bWJlciBvZiBmZXRjaGluZyBtdXRhdGlvbnMuXG4gKiBAcHVibGljXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RJc011dGF0aW5nKFxuICBmaWx0ZXJzPzogTXV0YXRpb25GaWx0ZXJzLFxuICBpbmplY3Rvcj86IEluamVjdG9yLFxuKTogU2lnbmFsPG51bWJlcj4ge1xuICByZXR1cm4gYXNzZXJ0SW5qZWN0b3IoaW5qZWN0SXNNdXRhdGluZywgaW5qZWN0b3IsICgpID0+IHtcbiAgICBjb25zdCBxdWVyeUNsaWVudCA9IGluamVjdFF1ZXJ5Q2xpZW50KClcbiAgICBjb25zdCBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpXG4gICAgY29uc3Qgbmdab25lID0gaW5qZWN0KE5nWm9uZSlcblxuICAgIGNvbnN0IGNhY2hlID0gcXVlcnlDbGllbnQuZ2V0TXV0YXRpb25DYWNoZSgpXG4gICAgLy8gaXNNdXRhdGluZyBpcyB0aGUgcHJldiB2YWx1ZSBpbml0aWFsaXplZCBvbiBtb3VudCAqXG4gICAgbGV0IGlzTXV0YXRpbmcgPSBxdWVyeUNsaWVudC5pc011dGF0aW5nKGZpbHRlcnMpXG5cbiAgICBjb25zdCByZXN1bHQgPSBzaWduYWwoaXNNdXRhdGluZylcblxuICAgIGNvbnN0IHVuc3Vic2NyaWJlID0gY2FjaGUuc3Vic2NyaWJlKFxuICAgICAgbm90aWZ5TWFuYWdlci5iYXRjaENhbGxzKCgpID0+IHtcbiAgICAgICAgY29uc3QgbmV3SXNNdXRhdGluZyA9IHF1ZXJ5Q2xpZW50LmlzTXV0YXRpbmcoZmlsdGVycylcbiAgICAgICAgaWYgKGlzTXV0YXRpbmcgIT09IG5ld0lzTXV0YXRpbmcpIHtcbiAgICAgICAgICAvLyAqIGFuZCB1cGRhdGUgd2l0aCBlYWNoIGNoYW5nZVxuICAgICAgICAgIGlzTXV0YXRpbmcgPSBuZXdJc011dGF0aW5nXG4gICAgICAgICAgbmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgICByZXN1bHQuc2V0KGlzTXV0YXRpbmcpXG4gICAgICAgICAgfSlcbiAgICAgICAgfVxuICAgICAgfSksXG4gICAgKVxuXG4gICAgZGVzdHJveVJlZi5vbkRlc3Ryb3kodW5zdWJzY3JpYmUpXG5cbiAgICByZXR1cm4gcmVzdWx0XG4gIH0pXG59XG4iXX0=