@tanstack/angular-query-experimental 5.59.17 → 5.60.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/README.md +6 -6
- package/build/README.md +6 -6
- package/build/esm2022/index.mjs +3 -3
- package/build/esm2022/inject-query-client.mjs +3 -2
- package/build/esm2022/providers.mjs +159 -9
- package/build/esm2022/util/is-dev-mode/is-dev-mode.mjs +3 -0
- package/build/fesm2022/tanstack-angular-query-experimental.mjs +161 -10
- package/build/fesm2022/tanstack-angular-query-experimental.mjs.map +1 -1
- package/build/rollup.d.ts +167 -14
- package/package.json +4 -2
package/README.md
CHANGED
|
@@ -29,7 +29,7 @@ Visit https://tanstack.com/query/latest/docs/framework/angular/overview
|
|
|
29
29
|
|
|
30
30
|
# Quick Start
|
|
31
31
|
|
|
32
|
-
> Angular Query requires Angular 16 or higher.
|
|
32
|
+
> The Angular adapter for TanStack Query requires Angular 16 or higher.
|
|
33
33
|
|
|
34
34
|
1. Install `angular-query`
|
|
35
35
|
|
|
@@ -55,14 +55,14 @@ or
|
|
|
55
55
|
$ bun add @tanstack/angular-query-experimental
|
|
56
56
|
```
|
|
57
57
|
|
|
58
|
-
2. Initialize **
|
|
58
|
+
2. Initialize **TanStack Query** by adding **provideTanStackQuery** to your application
|
|
59
59
|
|
|
60
60
|
```ts
|
|
61
|
-
import {
|
|
61
|
+
import { provideTanStackQuery } from '@tanstack/angular-query-experimental'
|
|
62
62
|
import { QueryClient } from '@tanstack/angular-query-experimental'
|
|
63
63
|
|
|
64
64
|
bootstrapApplication(AppComponent, {
|
|
65
|
-
providers: [
|
|
65
|
+
providers: [provideTanStackQuery(new QueryClient())],
|
|
66
66
|
})
|
|
67
67
|
```
|
|
68
68
|
|
|
@@ -71,14 +71,14 @@ or in a NgModule-based app
|
|
|
71
71
|
```ts
|
|
72
72
|
import { provideHttpClient } from '@angular/common/http'
|
|
73
73
|
import {
|
|
74
|
-
|
|
74
|
+
provideTanStackQuery,
|
|
75
75
|
QueryClient,
|
|
76
76
|
} from '@tanstack/angular-query-experimental'
|
|
77
77
|
|
|
78
78
|
@NgModule({
|
|
79
79
|
declarations: [AppComponent],
|
|
80
80
|
imports: [BrowserModule],
|
|
81
|
-
providers: [
|
|
81
|
+
providers: [provideTanStackQuery(new QueryClient())],
|
|
82
82
|
bootstrap: [AppComponent],
|
|
83
83
|
})
|
|
84
84
|
```
|
package/build/README.md
CHANGED
|
@@ -29,7 +29,7 @@ Visit https://tanstack.com/query/latest/docs/framework/angular/overview
|
|
|
29
29
|
|
|
30
30
|
# Quick Start
|
|
31
31
|
|
|
32
|
-
> Angular Query requires Angular 16 or higher.
|
|
32
|
+
> The Angular adapter for TanStack Query requires Angular 16 or higher.
|
|
33
33
|
|
|
34
34
|
1. Install `angular-query`
|
|
35
35
|
|
|
@@ -55,14 +55,14 @@ or
|
|
|
55
55
|
$ bun add @tanstack/angular-query-experimental
|
|
56
56
|
```
|
|
57
57
|
|
|
58
|
-
2. Initialize **
|
|
58
|
+
2. Initialize **TanStack Query** by adding **provideTanStackQuery** to your application
|
|
59
59
|
|
|
60
60
|
```ts
|
|
61
|
-
import {
|
|
61
|
+
import { provideTanStackQuery } from '@tanstack/angular-query-experimental'
|
|
62
62
|
import { QueryClient } from '@tanstack/angular-query-experimental'
|
|
63
63
|
|
|
64
64
|
bootstrapApplication(AppComponent, {
|
|
65
|
-
providers: [
|
|
65
|
+
providers: [provideTanStackQuery(new QueryClient())],
|
|
66
66
|
})
|
|
67
67
|
```
|
|
68
68
|
|
|
@@ -71,14 +71,14 @@ or in a NgModule-based app
|
|
|
71
71
|
```ts
|
|
72
72
|
import { provideHttpClient } from '@angular/common/http'
|
|
73
73
|
import {
|
|
74
|
-
|
|
74
|
+
provideTanStackQuery,
|
|
75
75
|
QueryClient,
|
|
76
76
|
} from '@tanstack/angular-query-experimental'
|
|
77
77
|
|
|
78
78
|
@NgModule({
|
|
79
79
|
declarations: [AppComponent],
|
|
80
80
|
imports: [BrowserModule],
|
|
81
|
-
providers: [
|
|
81
|
+
providers: [provideTanStackQuery(new QueryClient())],
|
|
82
82
|
bootstrap: [AppComponent],
|
|
83
83
|
})
|
|
84
84
|
```
|
package/build/esm2022/index.mjs
CHANGED
|
@@ -11,6 +11,6 @@ export * from './inject-mutation';
|
|
|
11
11
|
export * from './inject-mutation-state';
|
|
12
12
|
export * from './inject-queries';
|
|
13
13
|
export * from './inject-query';
|
|
14
|
-
export
|
|
15
|
-
export
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
export * from './inject-query-client';
|
|
15
|
+
export * from './providers';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEJBQTBCO0FBRTFCLGlCQUFpQjtBQUNqQixjQUFjLHNCQUFzQixDQUFBO0FBRXBDLGNBQWMsU0FBUyxDQUFBO0FBTXZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQU05QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUUvRCxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGdCQUFnQixDQUFBO0FBQzlCLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsY0FBYyxhQUFhLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuXG4vLyBSZS1leHBvcnQgY29yZVxuZXhwb3J0ICogZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5cbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnXG5cbmV4cG9ydCB0eXBlIHtcbiAgRGVmaW5lZEluaXRpYWxEYXRhT3B0aW9ucyxcbiAgVW5kZWZpbmVkSW5pdGlhbERhdGFPcHRpb25zLFxufSBmcm9tICcuL3F1ZXJ5LW9wdGlvbnMnXG5leHBvcnQgeyBxdWVyeU9wdGlvbnMgfSBmcm9tICcuL3F1ZXJ5LW9wdGlvbnMnXG5cbmV4cG9ydCB0eXBlIHtcbiAgRGVmaW5lZEluaXRpYWxEYXRhSW5maW5pdGVPcHRpb25zLFxuICBVbmRlZmluZWRJbml0aWFsRGF0YUluZmluaXRlT3B0aW9ucyxcbn0gZnJvbSAnLi9pbmZpbml0ZS1xdWVyeS1vcHRpb25zJ1xuZXhwb3J0IHsgaW5maW5pdGVRdWVyeU9wdGlvbnMgfSBmcm9tICcuL2luZmluaXRlLXF1ZXJ5LW9wdGlvbnMnXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LWluZmluaXRlLXF1ZXJ5J1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtaXMtZmV0Y2hpbmcnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1pcy1tdXRhdGluZydcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LW11dGF0aW9uJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtbXV0YXRpb24tc3RhdGUnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1xdWVyaWVzJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtcXVlcnknXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1xdWVyeS1jbGllbnQnXG5leHBvcnQgKiBmcm9tICcuL3Byb3ZpZGVycydcbiJdfQ==
|
|
@@ -12,11 +12,12 @@ const tokens = createNoopInjectionToken('QueryClientToken');
|
|
|
12
12
|
*/
|
|
13
13
|
export const injectQueryClient = tokens[0];
|
|
14
14
|
/**
|
|
15
|
-
* Usually {@link
|
|
15
|
+
* Usually {@link provideTanStackQuery} is used once to set up TanStack Query and the
|
|
16
16
|
* {@link https://tanstack.com/query/latest/docs/reference/QueryClient|QueryClient}
|
|
17
17
|
* for the entire application. You can use `provideQueryClient` to provide a
|
|
18
18
|
* different `QueryClient` instance for a part of the application.
|
|
19
19
|
* @public
|
|
20
20
|
*/
|
|
21
21
|
export const provideQueryClient = tokens[1];
|
|
22
|
-
|
|
22
|
+
export const QUERY_CLIENT = tokens[2];
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LXF1ZXJ5LWNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbmplY3QtcXVlcnktY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFBO0FBRy9GLE1BQU0sTUFBTSxHQUFHLHdCQUF3QixDQUFjLGtCQUFrQixDQUFDLENBQUE7QUFFeEU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBRTFDOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQTtBQUUzQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlTm9vcEluamVjdGlvblRva2VuIH0gZnJvbSAnLi91dGlsL2NyZWF0ZS1pbmplY3Rpb24tdG9rZW4vY3JlYXRlLWluamVjdGlvbi10b2tlbidcbmltcG9ydCB0eXBlIHsgUXVlcnlDbGllbnQgfSBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcblxuY29uc3QgdG9rZW5zID0gY3JlYXRlTm9vcEluamVjdGlvblRva2VuPFF1ZXJ5Q2xpZW50PignUXVlcnlDbGllbnRUb2tlbicpXG5cbi8qKlxuICogSW5qZWN0cyB0aGUgYFF1ZXJ5Q2xpZW50YCBpbnN0YW5jZSBpbnRvIHRoZSBjb21wb25lbnQgb3Igc2VydmljZS5cbiAqXG4gKiAqKkV4YW1wbGUqKlxuICogYGBgdHNcbiAqIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gaW5qZWN0UXVlcnlDbGllbnQoKTtcbiAqIGBgYFxuICogQHJldHVybnMgVGhlIGBRdWVyeUNsaWVudGAgaW5zdGFuY2UuXG4gKiBAcHVibGljXG4gKi9cbmV4cG9ydCBjb25zdCBpbmplY3RRdWVyeUNsaWVudCA9IHRva2Vuc1swXVxuXG4vKipcbiAqIFVzdWFsbHkge0BsaW5rIHByb3ZpZGVUYW5TdGFja1F1ZXJ5fSBpcyB1c2VkIG9uY2UgdG8gc2V0IHVwIFRhblN0YWNrIFF1ZXJ5IGFuZCB0aGVcbiAqIHtAbGluayBodHRwczovL3RhbnN0YWNrLmNvbS9xdWVyeS9sYXRlc3QvZG9jcy9yZWZlcmVuY2UvUXVlcnlDbGllbnR8UXVlcnlDbGllbnR9XG4gKiBmb3IgdGhlIGVudGlyZSBhcHBsaWNhdGlvbi4gWW91IGNhbiB1c2UgYHByb3ZpZGVRdWVyeUNsaWVudGAgdG8gcHJvdmlkZSBhXG4gKiBkaWZmZXJlbnQgYFF1ZXJ5Q2xpZW50YCBpbnN0YW5jZSBmb3IgYSBwYXJ0IG9mIHRoZSBhcHBsaWNhdGlvbi5cbiAqIEBwdWJsaWNcbiAqL1xuZXhwb3J0IGNvbnN0IHByb3ZpZGVRdWVyeUNsaWVudCA9IHRva2Vuc1sxXVxuXG5leHBvcnQgY29uc3QgUVVFUllfQ0xJRU5UID0gdG9rZW5zWzJdXG4iXX0=
|
|
@@ -1,20 +1,23 @@
|
|
|
1
|
-
import { DestroyRef, ENVIRONMENT_INITIALIZER, inject, makeEnvironmentProviders, } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { DestroyRef, ENVIRONMENT_INITIALIZER, Injector, PLATFORM_ID, computed, effect, inject, makeEnvironmentProviders, runInInjectionContext, } from '@angular/core';
|
|
2
|
+
import { onlineManager } from '@tanstack/query-core';
|
|
3
|
+
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
|
4
|
+
import { injectQueryClient, provideQueryClient } from './inject-query-client';
|
|
5
|
+
import { isDevMode } from './util/is-dev-mode/is-dev-mode';
|
|
3
6
|
/**
|
|
4
7
|
* Sets up providers necessary to enable TanStack Query functionality for Angular applications.
|
|
5
8
|
*
|
|
6
|
-
* Allows to configure a `QueryClient
|
|
9
|
+
* Allows to configure a `QueryClient` and optional features such as developer tools.
|
|
7
10
|
*
|
|
8
11
|
* **Example - standalone**
|
|
9
12
|
*
|
|
10
13
|
* ```ts
|
|
11
14
|
* import {
|
|
12
|
-
*
|
|
15
|
+
* provideTanStackQuery,
|
|
13
16
|
* QueryClient,
|
|
14
17
|
* } from '@tanstack/angular-query-experimental'
|
|
15
18
|
*
|
|
16
19
|
* bootstrapApplication(AppComponent, {
|
|
17
|
-
* providers: [
|
|
20
|
+
* providers: [provideTanStackQuery(new QueryClient())],
|
|
18
21
|
* })
|
|
19
22
|
* ```
|
|
20
23
|
*
|
|
@@ -22,24 +25,44 @@ import { provideQueryClient } from './inject-query-client';
|
|
|
22
25
|
*
|
|
23
26
|
* ```ts
|
|
24
27
|
* import {
|
|
25
|
-
*
|
|
28
|
+
* provideTanStackQuery,
|
|
26
29
|
* QueryClient,
|
|
27
30
|
* } from '@tanstack/angular-query-experimental'
|
|
28
31
|
*
|
|
29
32
|
* @NgModule({
|
|
30
33
|
* declarations: [AppComponent],
|
|
31
34
|
* imports: [BrowserModule],
|
|
32
|
-
* providers: [
|
|
35
|
+
* providers: [provideTanStackQuery(new QueryClient())],
|
|
33
36
|
* bootstrap: [AppComponent],
|
|
34
37
|
* })
|
|
35
38
|
* export class AppModule {}
|
|
36
39
|
* ```
|
|
40
|
+
*
|
|
41
|
+
* You can also enable optional developer tools by adding `withDevtools`. By
|
|
42
|
+
* default the tools will then be loaded when your app is in development mode.
|
|
43
|
+
* ```ts
|
|
44
|
+
* import {
|
|
45
|
+
* provideTanStackQuery,
|
|
46
|
+
* withDevtools
|
|
47
|
+
* QueryClient,
|
|
48
|
+
* } from '@tanstack/angular-query-experimental'
|
|
49
|
+
*
|
|
50
|
+
* bootstrapApplication(AppComponent,
|
|
51
|
+
* {
|
|
52
|
+
* providers: [
|
|
53
|
+
* provideTanStackQuery(new QueryClient(), withDevtools())
|
|
54
|
+
* ]
|
|
55
|
+
* }
|
|
56
|
+
* )
|
|
57
|
+
* ```
|
|
37
58
|
* @param queryClient - A `QueryClient` instance.
|
|
59
|
+
* @param features - Optional features to configure additional Query functionality.
|
|
38
60
|
* @returns A set of providers to set up TanStack Query.
|
|
39
61
|
* @public
|
|
40
62
|
* @see https://tanstack.com/query/v5/docs/framework/angular/quick-start
|
|
63
|
+
* @see withDevtools
|
|
41
64
|
*/
|
|
42
|
-
export function
|
|
65
|
+
export function provideTanStackQuery(queryClient, ...features) {
|
|
43
66
|
return makeEnvironmentProviders([
|
|
44
67
|
provideQueryClient(queryClient),
|
|
45
68
|
{
|
|
@@ -51,6 +74,133 @@ export function provideAngularQuery(queryClient) {
|
|
|
51
74
|
inject(DestroyRef).onDestroy(() => queryClient.unmount());
|
|
52
75
|
},
|
|
53
76
|
},
|
|
77
|
+
features.map((feature) => feature.ɵproviders),
|
|
54
78
|
]);
|
|
55
79
|
}
|
|
56
|
-
|
|
80
|
+
/**
|
|
81
|
+
* Sets up providers necessary to enable TanStack Query functionality for Angular applications.
|
|
82
|
+
*
|
|
83
|
+
* Allows to configure a `QueryClient`.
|
|
84
|
+
* @param queryClient - A `QueryClient` instance.
|
|
85
|
+
* @returns A set of providers to set up TanStack Query.
|
|
86
|
+
* @public
|
|
87
|
+
* @see https://tanstack.com/query/v5/docs/framework/angular/quick-start
|
|
88
|
+
* @deprecated Use `provideTanStackQuery` instead.
|
|
89
|
+
*/
|
|
90
|
+
export function provideAngularQuery(queryClient) {
|
|
91
|
+
return provideTanStackQuery(queryClient);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Helper function to create an object that represents a Query feature.
|
|
95
|
+
* @param kind -
|
|
96
|
+
* @param providers -
|
|
97
|
+
* @returns A Query feature.
|
|
98
|
+
*/
|
|
99
|
+
function queryFeature(kind, providers) {
|
|
100
|
+
return { ɵkind: kind, ɵproviders: providers };
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Enables developer tools.
|
|
104
|
+
*
|
|
105
|
+
* **Example**
|
|
106
|
+
*
|
|
107
|
+
* ```ts
|
|
108
|
+
* export const appConfig: ApplicationConfig = {
|
|
109
|
+
* providers: [
|
|
110
|
+
* provideTanStackQuery(new QueryClient(), withDevtools())
|
|
111
|
+
* ]
|
|
112
|
+
* }
|
|
113
|
+
* ```
|
|
114
|
+
* By default the devtools will be loaded when Angular runs in development mode and rendered in `<body>`.
|
|
115
|
+
*
|
|
116
|
+
* If you need more control over when devtools are loaded, you can use the `loadDevtools` option. This is particularly useful if you want to load devtools based on environment configurations. For instance, you might have a test environment running in production mode but still require devtools to be available.
|
|
117
|
+
*
|
|
118
|
+
* If you need more control over where devtools are rendered, consider `injectDevtoolsPanel`. This allows rendering devtools inside your own devtools for example.
|
|
119
|
+
* @param optionsFn - A function that returns `DevtoolsOptions`.
|
|
120
|
+
* @returns A set of providers for use with `provideTanStackQuery`.
|
|
121
|
+
* @public
|
|
122
|
+
* @see {@link provideTanStackQuery}
|
|
123
|
+
* @see {@link DevtoolsOptions}
|
|
124
|
+
*/
|
|
125
|
+
export function withDevtools(optionsFn) {
|
|
126
|
+
let providers = [];
|
|
127
|
+
if (!isDevMode() && !optionsFn) {
|
|
128
|
+
providers = [];
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
providers = [
|
|
132
|
+
{
|
|
133
|
+
provide: ENVIRONMENT_INITIALIZER,
|
|
134
|
+
multi: true,
|
|
135
|
+
useFactory: () => {
|
|
136
|
+
if (!isPlatformBrowser(inject(PLATFORM_ID)))
|
|
137
|
+
return () => { };
|
|
138
|
+
const injector = inject(Injector);
|
|
139
|
+
const options = computed(() => runInInjectionContext(injector, () => optionsFn?.() ?? {}));
|
|
140
|
+
let devtools = null;
|
|
141
|
+
let el = null;
|
|
142
|
+
const shouldLoadToolsSignal = computed(() => {
|
|
143
|
+
const { loadDevtools } = options();
|
|
144
|
+
return typeof loadDevtools === 'boolean'
|
|
145
|
+
? loadDevtools
|
|
146
|
+
: isDevMode();
|
|
147
|
+
});
|
|
148
|
+
const doc = inject(DOCUMENT);
|
|
149
|
+
const destroyRef = inject(DestroyRef);
|
|
150
|
+
const getResolvedQueryClient = () => {
|
|
151
|
+
const injectedClient = injectQueryClient({
|
|
152
|
+
optional: true,
|
|
153
|
+
injector,
|
|
154
|
+
});
|
|
155
|
+
const client = options().client ?? injectedClient;
|
|
156
|
+
if (!client) {
|
|
157
|
+
throw new Error('No QueryClient found');
|
|
158
|
+
}
|
|
159
|
+
return client;
|
|
160
|
+
};
|
|
161
|
+
const destroyDevtools = () => {
|
|
162
|
+
devtools?.unmount();
|
|
163
|
+
el?.remove();
|
|
164
|
+
devtools = null;
|
|
165
|
+
};
|
|
166
|
+
return () => effect(() => {
|
|
167
|
+
const shouldLoadTools = shouldLoadToolsSignal();
|
|
168
|
+
const { client, position, errorTypes, buttonPosition, initialIsOpen, } = options();
|
|
169
|
+
if (devtools && !shouldLoadTools) {
|
|
170
|
+
destroyDevtools();
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
else if (devtools && shouldLoadTools) {
|
|
174
|
+
client && devtools.setClient(client);
|
|
175
|
+
position && devtools.setPosition(position);
|
|
176
|
+
errorTypes && devtools.setErrorTypes(errorTypes);
|
|
177
|
+
buttonPosition && devtools.setButtonPosition(buttonPosition);
|
|
178
|
+
initialIsOpen && devtools.setInitialIsOpen(initialIsOpen);
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
else if (!shouldLoadTools) {
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
el = doc.body.appendChild(document.createElement('div'));
|
|
185
|
+
el.classList.add('tsqd-parent-container');
|
|
186
|
+
import('@tanstack/query-devtools').then((queryDevtools) => runInInjectionContext(injector, () => {
|
|
187
|
+
devtools = new queryDevtools.TanstackQueryDevtools({
|
|
188
|
+
...options(),
|
|
189
|
+
client: getResolvedQueryClient(),
|
|
190
|
+
queryFlavor: 'Angular Query',
|
|
191
|
+
version: '5',
|
|
192
|
+
onlineManager,
|
|
193
|
+
});
|
|
194
|
+
el && devtools.mount(el);
|
|
195
|
+
// Unmount the devtools on application destroy
|
|
196
|
+
destroyRef.onDestroy(destroyDevtools);
|
|
197
|
+
}));
|
|
198
|
+
});
|
|
199
|
+
},
|
|
200
|
+
},
|
|
201
|
+
];
|
|
202
|
+
}
|
|
203
|
+
return queryFeature('DeveloperTools', providers);
|
|
204
|
+
}
|
|
205
|
+
export const queryFeatures = ['DeveloperTools'];
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"providers.js","sourceRoot":"","sources":["../../src/providers.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  DestroyRef,\n  ENVIRONMENT_INITIALIZER,\n  Injector,\n  PLATFORM_ID,\n  computed,\n  effect,\n  inject,\n  makeEnvironmentProviders,\n  runInInjectionContext,\n} from '@angular/core'\nimport { onlineManager } from '@tanstack/query-core'\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common'\nimport { injectQueryClient, provideQueryClient } from './inject-query-client'\nimport { isDevMode } from './util/is-dev-mode/is-dev-mode'\nimport type { QueryClient } from '@tanstack/query-core'\nimport type { EnvironmentProviders, Provider } from '@angular/core'\nimport type {\n  DevtoolsButtonPosition,\n  DevtoolsErrorType,\n  DevtoolsPosition,\n  TanstackQueryDevtools,\n} from '@tanstack/query-devtools'\n\n/**\n * Sets up providers necessary to enable TanStack Query functionality for Angular applications.\n *\n * Allows to configure a `QueryClient` and optional features such as developer tools.\n *\n * **Example - standalone**\n *\n * ```ts\n * import {\n *   provideTanStackQuery,\n *   QueryClient,\n * } from '@tanstack/angular-query-experimental'\n *\n * bootstrapApplication(AppComponent, {\n *   providers: [provideTanStackQuery(new QueryClient())],\n * })\n * ```\n *\n * **Example - NgModule-based**\n *\n * ```ts\n * import {\n *   provideTanStackQuery,\n *   QueryClient,\n * } from '@tanstack/angular-query-experimental'\n *\n * @NgModule({\n *   declarations: [AppComponent],\n *   imports: [BrowserModule],\n *   providers: [provideTanStackQuery(new QueryClient())],\n *   bootstrap: [AppComponent],\n * })\n * export class AppModule {}\n * ```\n *\n * You can also enable optional developer tools by adding `withDevtools`. By\n * default the tools will then be loaded when your app is in development mode.\n * ```ts\n * import {\n *   provideTanStackQuery,\n *   withDevtools\n *   QueryClient,\n * } from '@tanstack/angular-query-experimental'\n *\n * bootstrapApplication(AppComponent,\n *   {\n *     providers: [\n *       provideTanStackQuery(new QueryClient(), withDevtools())\n *     ]\n *   }\n * )\n * ```\n * @param queryClient - A `QueryClient` instance.\n * @param features - Optional features to configure additional Query functionality.\n * @returns A set of providers to set up TanStack Query.\n * @public\n * @see https://tanstack.com/query/v5/docs/framework/angular/quick-start\n * @see withDevtools\n */\nexport function provideTanStackQuery(\n  queryClient: QueryClient,\n  ...features: Array<QueryFeatures>\n): EnvironmentProviders {\n  return makeEnvironmentProviders([\n    provideQueryClient(queryClient),\n    {\n      provide: ENVIRONMENT_INITIALIZER,\n      multi: true,\n      useValue: () => {\n        queryClient.mount()\n        // Unmount the query client on application destroy\n        inject(DestroyRef).onDestroy(() => queryClient.unmount())\n      },\n    },\n    features.map((feature) => feature.ɵproviders),\n  ])\n}\n\n/**\n * Sets up providers necessary to enable TanStack Query functionality for Angular applications.\n *\n * Allows to configure a `QueryClient`.\n * @param queryClient - A `QueryClient` instance.\n * @returns A set of providers to set up TanStack Query.\n * @public\n * @see https://tanstack.com/query/v5/docs/framework/angular/quick-start\n * @deprecated Use `provideTanStackQuery` instead.\n */\nexport function provideAngularQuery(\n  queryClient: QueryClient,\n): EnvironmentProviders {\n  return provideTanStackQuery(queryClient)\n}\n\n/**\n * Helper type to represent a Query feature.\n */\nexport interface QueryFeature<TFeatureKind extends QueryFeatureKind> {\n  ɵkind: TFeatureKind\n  ɵproviders: Array<Provider>\n}\n\n/**\n * Helper function to create an object that represents a Query feature.\n * @param kind -\n * @param providers -\n * @returns A Query feature.\n */\nfunction queryFeature<TFeatureKind extends QueryFeatureKind>(\n  kind: TFeatureKind,\n  providers: Array<Provider>,\n): QueryFeature<TFeatureKind> {\n  return { ɵkind: kind, ɵproviders: providers }\n}\n\n/**\n * A type alias that represents a feature which enables developer tools.\n * The type is used to describe the return value of the `withDevtools` function.\n * @public\n * @see {@link withDevtools}\n */\nexport type DeveloperToolsFeature = QueryFeature<'DeveloperTools'>\n\n/**\n * Options for configuring the TanStack Query devtools.\n * @public\n */\nexport interface DevtoolsOptions {\n  /**\n   * Set this true if you want the devtools to default to being open\n   */\n  initialIsOpen?: boolean\n  /**\n   * The position of the TanStack logo to open and close the devtools panel.\n   * `top-left` | `top-right` | `bottom-left` | `bottom-right` | `relative`\n   * Defaults to `bottom-right`.\n   */\n  buttonPosition?: DevtoolsButtonPosition\n  /**\n   * The position of the TanStack Query devtools panel.\n   * `top` | `bottom` | `left` | `right`\n   * Defaults to `bottom`.\n   */\n  position?: DevtoolsPosition\n  /**\n   * Custom instance of QueryClient\n   */\n  client?: QueryClient\n  /**\n   * Use this so you can define custom errors that can be shown in the devtools.\n   */\n  errorTypes?: Array<DevtoolsErrorType>\n  /**\n   * Use this to pass a nonce to the style tag that is added to the document head. This is useful if you are using a Content Security Policy (CSP) nonce to allow inline styles.\n   */\n  styleNonce?: string\n  /**\n   * Use this so you can attach the devtool's styles to a specific element in the DOM.\n   */\n  shadowDOMTarget?: ShadowRoot\n\n  /**\n   * Whether the developer tools should load.\n   * - `auto`- (Default) Lazily loads devtools when in development mode. Skips loading in production mode.\n   * - `true`- Always load the devtools, regardless of the environment.\n   * - `false`- Never load the devtools, regardless of the environment.\n   *\n   * You can use `true` and `false` to override loading developer tools from an environment file.\n   * For example, a test environment might run in production mode but you may want to load developer tools.\n   *\n   * Additionally, you can use a signal in the callback to dynamically load the devtools based on a condition. For example,\n   * a signal created from a RxJS observable that listens for a keyboard shortcut.\n   *\n   * **Example**\n   * ```ts\n   *    withDevtools(() => ({\n   *      initialIsOpen: true,\n   *      loadDevtools: inject(ExampleService).loadDevtools()\n   *    }))\n   *  ```\n   */\n  loadDevtools?: 'auto' | boolean\n}\n\n/**\n * Enables developer tools.\n *\n * **Example**\n *\n * ```ts\n * export const appConfig: ApplicationConfig = {\n *   providers: [\n *     provideTanStackQuery(new QueryClient(), withDevtools())\n *   ]\n * }\n * ```\n * By default the devtools will be loaded when Angular runs in development mode and rendered in `<body>`.\n *\n * If you need more control over when devtools are loaded, you can use the `loadDevtools` option. This is particularly useful if you want to load devtools based on environment configurations. For instance, you might have a test environment running in production mode but still require devtools to be available.\n *\n * If you need more control over where devtools are rendered, consider `injectDevtoolsPanel`. This allows rendering devtools inside your own devtools for example.\n * @param optionsFn - A function that returns `DevtoolsOptions`.\n * @returns A set of providers for use with `provideTanStackQuery`.\n * @public\n * @see {@link provideTanStackQuery}\n * @see {@link DevtoolsOptions}\n */\nexport function withDevtools(\n  optionsFn?: () => DevtoolsOptions,\n): DeveloperToolsFeature {\n  let providers: Array<Provider> = []\n  if (!isDevMode() && !optionsFn) {\n    providers = []\n  } else {\n    providers = [\n      {\n        provide: ENVIRONMENT_INITIALIZER,\n        multi: true,\n        useFactory: () => {\n          if (!isPlatformBrowser(inject(PLATFORM_ID))) return () => {}\n          const injector = inject(Injector)\n          const options = computed(() =>\n            runInInjectionContext(injector, () => optionsFn?.() ?? {}),\n          )\n\n          let devtools: TanstackQueryDevtools | null = null\n          let el: HTMLElement | null = null\n\n          const shouldLoadToolsSignal = computed(() => {\n            const { loadDevtools } = options()\n            return typeof loadDevtools === 'boolean'\n              ? loadDevtools\n              : isDevMode()\n          })\n\n          const doc = inject(DOCUMENT)\n          const destroyRef = inject(DestroyRef)\n\n          const getResolvedQueryClient = () => {\n            const injectedClient = injectQueryClient({\n              optional: true,\n              injector,\n            })\n            const client = options().client ?? injectedClient\n            if (!client) {\n              throw new Error('No QueryClient found')\n            }\n            return client\n          }\n\n          const destroyDevtools = () => {\n            devtools?.unmount()\n            el?.remove()\n            devtools = null\n          }\n\n          return () =>\n            effect(() => {\n              const shouldLoadTools = shouldLoadToolsSignal()\n              const {\n                client,\n                position,\n                errorTypes,\n                buttonPosition,\n                initialIsOpen,\n              } = options()\n\n              if (devtools && !shouldLoadTools) {\n                destroyDevtools()\n                return\n              } else if (devtools && shouldLoadTools) {\n                client && devtools.setClient(client)\n                position && devtools.setPosition(position)\n                errorTypes && devtools.setErrorTypes(errorTypes)\n                buttonPosition && devtools.setButtonPosition(buttonPosition)\n                initialIsOpen && devtools.setInitialIsOpen(initialIsOpen)\n                return\n              } else if (!shouldLoadTools) {\n                return\n              }\n\n              el = doc.body.appendChild(document.createElement('div'))\n              el.classList.add('tsqd-parent-container')\n\n              import('@tanstack/query-devtools').then((queryDevtools) =>\n                runInInjectionContext(injector, () => {\n                  devtools = new queryDevtools.TanstackQueryDevtools({\n                    ...options(),\n                    client: getResolvedQueryClient(),\n                    queryFlavor: 'Angular Query',\n                    version: '5',\n                    onlineManager,\n                  })\n\n                  el && devtools.mount(el)\n\n                  // Unmount the devtools on application destroy\n                  destroyRef.onDestroy(destroyDevtools)\n                }),\n              )\n            })\n        },\n      },\n    ]\n  }\n  return queryFeature('DeveloperTools', providers)\n}\n\n/**\n * A type alias that represents all Query features available for use with `provideTanStackQuery`.\n * Features can be enabled by adding special functions to the `provideTanStackQuery` call.\n * See documentation for each symbol to find corresponding function name. See also `provideTanStackQuery`\n * documentation on how to use those functions.\n * @public\n * @see {@link provideTanStackQuery}\n */\nexport type QueryFeatures = DeveloperToolsFeature // Union type of features but just one now\n\nexport const queryFeatures = ['DeveloperTools'] as const\n\nexport type QueryFeatureKind = (typeof queryFeatures)[number]\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// Re-export for mocking in tests
|
|
2
|
+
export { isDevMode } from '@angular/core';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZGV2LW1vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbC9pcy1kZXYtbW9kZS9pcy1kZXYtbW9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxpQ0FBaUM7QUFFakMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlLWV4cG9ydCBmb3IgbW9ja2luZyBpbiB0ZXN0c1xuXG5leHBvcnQgeyBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuIl19
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { notifyManager, InfiniteQueryObserver, MutationObserver, replaceEqualDeep, QueriesObserver, QueryObserver } from '@tanstack/query-core';
|
|
1
|
+
import { notifyManager, InfiniteQueryObserver, MutationObserver, replaceEqualDeep, QueriesObserver, QueryObserver, onlineManager } from '@tanstack/query-core';
|
|
2
2
|
export * from '@tanstack/query-core';
|
|
3
|
-
import { untracked, computed, assertInInjectionContext, inject, Injector, runInInjectionContext, InjectionToken, NgZone, DestroyRef, signal, effect, makeEnvironmentProviders, ENVIRONMENT_INITIALIZER } from '@angular/core';
|
|
3
|
+
import { untracked, computed, assertInInjectionContext, inject, Injector, runInInjectionContext, InjectionToken, NgZone, DestroyRef, signal, effect, makeEnvironmentProviders, ENVIRONMENT_INITIALIZER, isDevMode, PLATFORM_ID } from '@angular/core';
|
|
4
|
+
import { isPlatformBrowser, DOCUMENT } from '@angular/common';
|
|
4
5
|
|
|
5
6
|
/* istanbul ignore file */
|
|
6
7
|
|
|
@@ -210,13 +211,14 @@ const tokens = createNoopInjectionToken('QueryClientToken');
|
|
|
210
211
|
*/
|
|
211
212
|
const injectQueryClient = tokens[0];
|
|
212
213
|
/**
|
|
213
|
-
* Usually {@link
|
|
214
|
+
* Usually {@link provideTanStackQuery} is used once to set up TanStack Query and the
|
|
214
215
|
* {@link https://tanstack.com/query/latest/docs/reference/QueryClient|QueryClient}
|
|
215
216
|
* for the entire application. You can use `provideQueryClient` to provide a
|
|
216
217
|
* different `QueryClient` instance for a part of the application.
|
|
217
218
|
* @public
|
|
218
219
|
*/
|
|
219
220
|
const provideQueryClient = tokens[1];
|
|
221
|
+
const QUERY_CLIENT = tokens[2];
|
|
220
222
|
|
|
221
223
|
/**
|
|
222
224
|
* Base implementation for `injectQuery` and `injectInfiniteQuery`.
|
|
@@ -522,21 +524,23 @@ function injectQuery(optionsFn, injector) {
|
|
|
522
524
|
return assertInjector(injectQuery, injector, () => createBaseQuery(optionsFn, QueryObserver));
|
|
523
525
|
}
|
|
524
526
|
|
|
527
|
+
// Re-export for mocking in tests
|
|
528
|
+
|
|
525
529
|
/**
|
|
526
530
|
* Sets up providers necessary to enable TanStack Query functionality for Angular applications.
|
|
527
531
|
*
|
|
528
|
-
* Allows to configure a `QueryClient
|
|
532
|
+
* Allows to configure a `QueryClient` and optional features such as developer tools.
|
|
529
533
|
*
|
|
530
534
|
* **Example - standalone**
|
|
531
535
|
*
|
|
532
536
|
* ```ts
|
|
533
537
|
* import {
|
|
534
|
-
*
|
|
538
|
+
* provideTanStackQuery,
|
|
535
539
|
* QueryClient,
|
|
536
540
|
* } from '@tanstack/angular-query-experimental'
|
|
537
541
|
*
|
|
538
542
|
* bootstrapApplication(AppComponent, {
|
|
539
|
-
* providers: [
|
|
543
|
+
* providers: [provideTanStackQuery(new QueryClient())],
|
|
540
544
|
* })
|
|
541
545
|
* ```
|
|
542
546
|
*
|
|
@@ -544,24 +548,44 @@ function injectQuery(optionsFn, injector) {
|
|
|
544
548
|
*
|
|
545
549
|
* ```ts
|
|
546
550
|
* import {
|
|
547
|
-
*
|
|
551
|
+
* provideTanStackQuery,
|
|
548
552
|
* QueryClient,
|
|
549
553
|
* } from '@tanstack/angular-query-experimental'
|
|
550
554
|
*
|
|
551
555
|
* @NgModule({
|
|
552
556
|
* declarations: [AppComponent],
|
|
553
557
|
* imports: [BrowserModule],
|
|
554
|
-
* providers: [
|
|
558
|
+
* providers: [provideTanStackQuery(new QueryClient())],
|
|
555
559
|
* bootstrap: [AppComponent],
|
|
556
560
|
* })
|
|
557
561
|
* export class AppModule {}
|
|
558
562
|
* ```
|
|
563
|
+
*
|
|
564
|
+
* You can also enable optional developer tools by adding `withDevtools`. By
|
|
565
|
+
* default the tools will then be loaded when your app is in development mode.
|
|
566
|
+
* ```ts
|
|
567
|
+
* import {
|
|
568
|
+
* provideTanStackQuery,
|
|
569
|
+
* withDevtools
|
|
570
|
+
* QueryClient,
|
|
571
|
+
* } from '@tanstack/angular-query-experimental'
|
|
572
|
+
*
|
|
573
|
+
* bootstrapApplication(AppComponent,
|
|
574
|
+
* {
|
|
575
|
+
* providers: [
|
|
576
|
+
* provideTanStackQuery(new QueryClient(), withDevtools())
|
|
577
|
+
* ]
|
|
578
|
+
* }
|
|
579
|
+
* )
|
|
580
|
+
* ```
|
|
559
581
|
* @param queryClient - A `QueryClient` instance.
|
|
582
|
+
* @param features - Optional features to configure additional Query functionality.
|
|
560
583
|
* @returns A set of providers to set up TanStack Query.
|
|
561
584
|
* @public
|
|
562
585
|
* @see https://tanstack.com/query/v5/docs/framework/angular/quick-start
|
|
586
|
+
* @see withDevtools
|
|
563
587
|
*/
|
|
564
|
-
function
|
|
588
|
+
function provideTanStackQuery(queryClient, ...features) {
|
|
565
589
|
return makeEnvironmentProviders([
|
|
566
590
|
provideQueryClient(queryClient),
|
|
567
591
|
{
|
|
@@ -573,8 +597,135 @@ function provideAngularQuery(queryClient) {
|
|
|
573
597
|
inject(DestroyRef).onDestroy(() => queryClient.unmount());
|
|
574
598
|
},
|
|
575
599
|
},
|
|
600
|
+
features.map((feature) => feature.ɵproviders),
|
|
576
601
|
]);
|
|
577
602
|
}
|
|
603
|
+
/**
|
|
604
|
+
* Sets up providers necessary to enable TanStack Query functionality for Angular applications.
|
|
605
|
+
*
|
|
606
|
+
* Allows to configure a `QueryClient`.
|
|
607
|
+
* @param queryClient - A `QueryClient` instance.
|
|
608
|
+
* @returns A set of providers to set up TanStack Query.
|
|
609
|
+
* @public
|
|
610
|
+
* @see https://tanstack.com/query/v5/docs/framework/angular/quick-start
|
|
611
|
+
* @deprecated Use `provideTanStackQuery` instead.
|
|
612
|
+
*/
|
|
613
|
+
function provideAngularQuery(queryClient) {
|
|
614
|
+
return provideTanStackQuery(queryClient);
|
|
615
|
+
}
|
|
616
|
+
/**
|
|
617
|
+
* Helper function to create an object that represents a Query feature.
|
|
618
|
+
* @param kind -
|
|
619
|
+
* @param providers -
|
|
620
|
+
* @returns A Query feature.
|
|
621
|
+
*/
|
|
622
|
+
function queryFeature(kind, providers) {
|
|
623
|
+
return { ɵkind: kind, ɵproviders: providers };
|
|
624
|
+
}
|
|
625
|
+
/**
|
|
626
|
+
* Enables developer tools.
|
|
627
|
+
*
|
|
628
|
+
* **Example**
|
|
629
|
+
*
|
|
630
|
+
* ```ts
|
|
631
|
+
* export const appConfig: ApplicationConfig = {
|
|
632
|
+
* providers: [
|
|
633
|
+
* provideTanStackQuery(new QueryClient(), withDevtools())
|
|
634
|
+
* ]
|
|
635
|
+
* }
|
|
636
|
+
* ```
|
|
637
|
+
* By default the devtools will be loaded when Angular runs in development mode and rendered in `<body>`.
|
|
638
|
+
*
|
|
639
|
+
* If you need more control over when devtools are loaded, you can use the `loadDevtools` option. This is particularly useful if you want to load devtools based on environment configurations. For instance, you might have a test environment running in production mode but still require devtools to be available.
|
|
640
|
+
*
|
|
641
|
+
* If you need more control over where devtools are rendered, consider `injectDevtoolsPanel`. This allows rendering devtools inside your own devtools for example.
|
|
642
|
+
* @param optionsFn - A function that returns `DevtoolsOptions`.
|
|
643
|
+
* @returns A set of providers for use with `provideTanStackQuery`.
|
|
644
|
+
* @public
|
|
645
|
+
* @see {@link provideTanStackQuery}
|
|
646
|
+
* @see {@link DevtoolsOptions}
|
|
647
|
+
*/
|
|
648
|
+
function withDevtools(optionsFn) {
|
|
649
|
+
let providers = [];
|
|
650
|
+
if (!isDevMode() && !optionsFn) {
|
|
651
|
+
providers = [];
|
|
652
|
+
}
|
|
653
|
+
else {
|
|
654
|
+
providers = [
|
|
655
|
+
{
|
|
656
|
+
provide: ENVIRONMENT_INITIALIZER,
|
|
657
|
+
multi: true,
|
|
658
|
+
useFactory: () => {
|
|
659
|
+
if (!isPlatformBrowser(inject(PLATFORM_ID)))
|
|
660
|
+
return () => { };
|
|
661
|
+
const injector = inject(Injector);
|
|
662
|
+
const options = computed(() => runInInjectionContext(injector, () => optionsFn?.() ?? {}));
|
|
663
|
+
let devtools = null;
|
|
664
|
+
let el = null;
|
|
665
|
+
const shouldLoadToolsSignal = computed(() => {
|
|
666
|
+
const { loadDevtools } = options();
|
|
667
|
+
return typeof loadDevtools === 'boolean'
|
|
668
|
+
? loadDevtools
|
|
669
|
+
: isDevMode();
|
|
670
|
+
});
|
|
671
|
+
const doc = inject(DOCUMENT);
|
|
672
|
+
const destroyRef = inject(DestroyRef);
|
|
673
|
+
const getResolvedQueryClient = () => {
|
|
674
|
+
const injectedClient = injectQueryClient({
|
|
675
|
+
optional: true,
|
|
676
|
+
injector,
|
|
677
|
+
});
|
|
678
|
+
const client = options().client ?? injectedClient;
|
|
679
|
+
if (!client) {
|
|
680
|
+
throw new Error('No QueryClient found');
|
|
681
|
+
}
|
|
682
|
+
return client;
|
|
683
|
+
};
|
|
684
|
+
const destroyDevtools = () => {
|
|
685
|
+
devtools?.unmount();
|
|
686
|
+
el?.remove();
|
|
687
|
+
devtools = null;
|
|
688
|
+
};
|
|
689
|
+
return () => effect(() => {
|
|
690
|
+
const shouldLoadTools = shouldLoadToolsSignal();
|
|
691
|
+
const { client, position, errorTypes, buttonPosition, initialIsOpen, } = options();
|
|
692
|
+
if (devtools && !shouldLoadTools) {
|
|
693
|
+
destroyDevtools();
|
|
694
|
+
return;
|
|
695
|
+
}
|
|
696
|
+
else if (devtools && shouldLoadTools) {
|
|
697
|
+
client && devtools.setClient(client);
|
|
698
|
+
position && devtools.setPosition(position);
|
|
699
|
+
errorTypes && devtools.setErrorTypes(errorTypes);
|
|
700
|
+
buttonPosition && devtools.setButtonPosition(buttonPosition);
|
|
701
|
+
initialIsOpen && devtools.setInitialIsOpen(initialIsOpen);
|
|
702
|
+
return;
|
|
703
|
+
}
|
|
704
|
+
else if (!shouldLoadTools) {
|
|
705
|
+
return;
|
|
706
|
+
}
|
|
707
|
+
el = doc.body.appendChild(document.createElement('div'));
|
|
708
|
+
el.classList.add('tsqd-parent-container');
|
|
709
|
+
import('@tanstack/query-devtools').then((queryDevtools) => runInInjectionContext(injector, () => {
|
|
710
|
+
devtools = new queryDevtools.TanstackQueryDevtools({
|
|
711
|
+
...options(),
|
|
712
|
+
client: getResolvedQueryClient(),
|
|
713
|
+
queryFlavor: 'Angular Query',
|
|
714
|
+
version: '5',
|
|
715
|
+
onlineManager,
|
|
716
|
+
});
|
|
717
|
+
el && devtools.mount(el);
|
|
718
|
+
// Unmount the devtools on application destroy
|
|
719
|
+
destroyRef.onDestroy(destroyDevtools);
|
|
720
|
+
}));
|
|
721
|
+
});
|
|
722
|
+
},
|
|
723
|
+
},
|
|
724
|
+
];
|
|
725
|
+
}
|
|
726
|
+
return queryFeature('DeveloperTools', providers);
|
|
727
|
+
}
|
|
728
|
+
const queryFeatures = ['DeveloperTools'];
|
|
578
729
|
|
|
579
730
|
/* istanbul ignore file */
|
|
580
731
|
// Re-export core
|
|
@@ -583,5 +734,5 @@ function provideAngularQuery(queryClient) {
|
|
|
583
734
|
* Generated bundle index. Do not edit.
|
|
584
735
|
*/
|
|
585
736
|
|
|
586
|
-
export { infiniteQueryOptions, injectInfiniteQuery, injectIsFetching, injectIsMutating, injectMutation, injectMutationState, injectQueries, injectQuery, injectQueryClient, provideAngularQuery, provideQueryClient, queryOptions };
|
|
737
|
+
export { QUERY_CLIENT, infiniteQueryOptions, injectInfiniteQuery, injectIsFetching, injectIsMutating, injectMutation, injectMutationState, injectQueries, injectQuery, injectQueryClient, provideAngularQuery, provideQueryClient, provideTanStackQuery, queryFeatures, queryOptions, withDevtools };
|
|
587
738
|
//# sourceMappingURL=tanstack-angular-query-experimental.mjs.map
|