@tanstack/angular-query-experimental 5.21.7 → 5.22.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.
@@ -1,4 +1,4 @@
1
- import { DestroyRef, assertInInjectionContext, computed, effect, inject, signal, } from '@angular/core';
1
+ import { DestroyRef, assertInInjectionContext, computed, effect, inject, signal, untracked, } from '@angular/core';
2
2
  import { notifyManager } from '@tanstack/query-core';
3
3
  import { signalProxy } from './signal-proxy';
4
4
  /**
@@ -21,17 +21,20 @@ export function createBaseQuery(options, Observer, queryClient) {
21
21
  const observer = new Observer(queryClient, defaultedOptionsSignal());
22
22
  const resultSignal = signal(observer.getOptimisticResult(defaultedOptionsSignal()));
23
23
  effect(() => {
24
- // Do not notify on updates because of changes in the options because
25
- // these changes should already be reflected in the optimistic result.
26
24
  const defaultedOptions = defaultedOptionsSignal();
27
25
  observer.setOptions(defaultedOptions, {
26
+ // Do not notify on updates because of changes in the options because
27
+ // these changes should already be reflected in the optimistic result.
28
28
  listeners: false,
29
29
  });
30
- resultSignal.set(observer.getOptimisticResult(defaultedOptions));
31
- }, { allowSignalWrites: true });
30
+ untracked(() =>
31
+ // Set the signal in effect because it's both 'computed' from options()
32
+ // and needs to be set imperatively in the query observer listener.
33
+ resultSignal.set(observer.getOptimisticResult(defaultedOptions)));
34
+ });
32
35
  // observer.trackResult is not used as this optimization is not needed for Angular
33
36
  const unsubscribe = observer.subscribe(notifyManager.batchCalls((val) => resultSignal.set(val)));
34
37
  destroyRef.onDestroy(unsubscribe);
35
38
  return signalProxy(resultSignal);
36
39
  }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJhc2UtcXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY3JlYXRlLWJhc2UtcXVlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFVBQVUsRUFDVix3QkFBd0IsRUFDeEIsUUFBUSxFQUNSLE1BQU0sRUFDTixNQUFNLEVBQ04sTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFBO0FBQ3RCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFJNUM7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZUFBZSxDQU83QixPQVFDLEVBQ0QsUUFBOEIsRUFDOUIsV0FBd0I7SUFFeEIsd0JBQXdCLENBQUMsZUFBZSxDQUFDLENBQUE7SUFDekMsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFBO0lBRXJDOzs7OztPQUtHO0lBQ0gsTUFBTSxzQkFBc0IsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1FBQzNDLE1BQU0sZ0JBQWdCLEdBQUcsV0FBVyxDQUFDLG1CQUFtQixDQUN0RCxPQUFPLENBQUMsV0FBVyxDQUFDLENBQ3JCLENBQUE7UUFDRCxnQkFBZ0IsQ0FBQyxrQkFBa0IsR0FBRyxZQUFZLENBQUE7UUFDbEQsT0FBTyxnQkFBZ0IsQ0FBQTtJQUN6QixDQUFDLENBQUMsQ0FBQTtJQUVGLE1BQU0sUUFBUSxHQUFHLElBQUksUUFBUSxDQU0zQixXQUFXLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQyxDQUFBO0lBRXhDLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FDekIsUUFBUSxDQUFDLG1CQUFtQixDQUFDLHNCQUFzQixFQUFFLENBQUMsQ0FDdkQsQ0FBQTtJQUVELE1BQU0sQ0FDSixHQUFHLEVBQUU7UUFDSCxxRUFBcUU7UUFDckUsc0VBQXNFO1FBQ3RFLE1BQU0sZ0JBQWdCLEdBQUcsc0JBQXNCLEVBQUUsQ0FBQTtRQUNqRCxRQUFRLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFO1lBQ3BDLFNBQVMsRUFBRSxLQUFLO1NBQ2pCLENBQUMsQ0FBQTtRQUNGLFlBQVksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQTtJQUNsRSxDQUFDLEVBQ0QsRUFBRSxpQkFBaUIsRUFBRSxJQUFJLEVBQUUsQ0FDNUIsQ0FBQTtJQUVELGtGQUFrRjtJQUNsRixNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsU0FBUyxDQUNwQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQ3pELENBQUE7SUFDRCxVQUFVLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBRWpDLE9BQU8sV0FBVyxDQUFDLFlBQVksQ0FBeUMsQ0FBQTtBQUMxRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0LFxuICBjb21wdXRlZCxcbiAgZWZmZWN0LFxuICBpbmplY3QsXG4gIHNpZ25hbCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IG5vdGlmeU1hbmFnZXIgfSBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcbmltcG9ydCB7IHNpZ25hbFByb3h5IH0gZnJvbSAnLi9zaWduYWwtcHJveHknXG5pbXBvcnQgdHlwZSB7IFF1ZXJ5Q2xpZW50LCBRdWVyeUtleSwgUXVlcnlPYnNlcnZlciB9IGZyb20gJ0B0YW5zdGFjay9xdWVyeS1jb3JlJ1xuaW1wb3J0IHR5cGUgeyBDcmVhdGVCYXNlUXVlcnlPcHRpb25zLCBDcmVhdGVCYXNlUXVlcnlSZXN1bHQgfSBmcm9tICcuL3R5cGVzJ1xuXG4vKipcbiAqIEJhc2UgaW1wbGVtZW50YXRpb24gZm9yIGBpbmplY3RRdWVyeWAgYW5kIGBpbmplY3RJbmZpbml0ZVF1ZXJ5YC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUJhc2VRdWVyeTxcbiAgVFF1ZXJ5Rm5EYXRhLFxuICBURXJyb3IsXG4gIFREYXRhLFxuICBUUXVlcnlEYXRhLFxuICBUUXVlcnlLZXkgZXh0ZW5kcyBRdWVyeUtleSxcbj4oXG4gIG9wdGlvbnM6IChcbiAgICBjbGllbnQ6IFF1ZXJ5Q2xpZW50LFxuICApID0+IENyZWF0ZUJhc2VRdWVyeU9wdGlvbnM8XG4gICAgVFF1ZXJ5Rm5EYXRhLFxuICAgIFRFcnJvcixcbiAgICBURGF0YSxcbiAgICBUUXVlcnlEYXRhLFxuICAgIFRRdWVyeUtleVxuICA+LFxuICBPYnNlcnZlcjogdHlwZW9mIFF1ZXJ5T2JzZXJ2ZXIsXG4gIHF1ZXJ5Q2xpZW50OiBRdWVyeUNsaWVudCxcbik6IENyZWF0ZUJhc2VRdWVyeVJlc3VsdDxURGF0YSwgVEVycm9yPiB7XG4gIGFzc2VydEluSW5qZWN0aW9uQ29udGV4dChjcmVhdGVCYXNlUXVlcnkpXG4gIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZilcblxuICAvKipcbiAgICogU2lnbmFsIHRoYXQgaGFzIHRoZSBkZWZhdWx0IG9wdGlvbnMgZnJvbSBxdWVyeSBjbGllbnQgYXBwbGllZFxuICAgKiBjb21wdXRlZCgpIGlzIHVzZWQgc28gc2lnbmFscyBjYW4gYmUgaW5zZXJ0ZWQgaW50byB0aGUgb3B0aW9uc1xuICAgKiBtYWtpbmcgaXQgcmVhY3RpdmUuIFdyYXBwaW5nIG9wdGlvbnMgaW4gYSBmdW5jdGlvbiBlbnN1cmVzIGVtYmVkZGVkIGV4cHJlc3Npb25zXG4gICAqIGFyZSBwcmVzZXJ2ZWQgYW5kIGNhbiBrZWVwIGJlaW5nIGFwcGxpZWQgYWZ0ZXIgc2lnbmFsIGNoYW5nZXNcbiAgICovXG4gIGNvbnN0IGRlZmF1bHRlZE9wdGlvbnNTaWduYWwgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgZGVmYXVsdGVkT3B0aW9ucyA9IHF1ZXJ5Q2xpZW50LmRlZmF1bHRRdWVyeU9wdGlvbnMoXG4gICAgICBvcHRpb25zKHF1ZXJ5Q2xpZW50KSxcbiAgICApXG4gICAgZGVmYXVsdGVkT3B0aW9ucy5fb3B0aW1pc3RpY1Jlc3VsdHMgPSAnb3B0aW1pc3RpYydcbiAgICByZXR1cm4gZGVmYXVsdGVkT3B0aW9uc1xuICB9KVxuXG4gIGNvbnN0IG9ic2VydmVyID0gbmV3IE9ic2VydmVyPFxuICAgIFRRdWVyeUZuRGF0YSxcbiAgICBURXJyb3IsXG4gICAgVERhdGEsXG4gICAgVFF1ZXJ5RGF0YSxcbiAgICBUUXVlcnlLZXlcbiAgPihxdWVyeUNsaWVudCwgZGVmYXVsdGVkT3B0aW9uc1NpZ25hbCgpKVxuXG4gIGNvbnN0IHJlc3VsdFNpZ25hbCA9IHNpZ25hbChcbiAgICBvYnNlcnZlci5nZXRPcHRpbWlzdGljUmVzdWx0KGRlZmF1bHRlZE9wdGlvbnNTaWduYWwoKSksXG4gIClcblxuICBlZmZlY3QoXG4gICAgKCkgPT4ge1xuICAgICAgLy8gRG8gbm90IG5vdGlmeSBvbiB1cGRhdGVzIGJlY2F1c2Ugb2YgY2hhbmdlcyBpbiB0aGUgb3B0aW9ucyBiZWNhdXNlXG4gICAgICAvLyB0aGVzZSBjaGFuZ2VzIHNob3VsZCBhbHJlYWR5IGJlIHJlZmxlY3RlZCBpbiB0aGUgb3B0aW1pc3RpYyByZXN1bHQuXG4gICAgICBjb25zdCBkZWZhdWx0ZWRPcHRpb25zID0gZGVmYXVsdGVkT3B0aW9uc1NpZ25hbCgpXG4gICAgICBvYnNlcnZlci5zZXRPcHRpb25zKGRlZmF1bHRlZE9wdGlvbnMsIHtcbiAgICAgICAgbGlzdGVuZXJzOiBmYWxzZSxcbiAgICAgIH0pXG4gICAgICByZXN1bHRTaWduYWwuc2V0KG9ic2VydmVyLmdldE9wdGltaXN0aWNSZXN1bHQoZGVmYXVsdGVkT3B0aW9ucykpXG4gICAgfSxcbiAgICB7IGFsbG93U2lnbmFsV3JpdGVzOiB0cnVlIH0sXG4gIClcblxuICAvLyBvYnNlcnZlci50cmFja1Jlc3VsdCBpcyBub3QgdXNlZCBhcyB0aGlzIG9wdGltaXphdGlvbiBpcyBub3QgbmVlZGVkIGZvciBBbmd1bGFyXG4gIGNvbnN0IHVuc3Vic2NyaWJlID0gb2JzZXJ2ZXIuc3Vic2NyaWJlKFxuICAgIG5vdGlmeU1hbmFnZXIuYmF0Y2hDYWxscygodmFsKSA9PiByZXN1bHRTaWduYWwuc2V0KHZhbCkpLFxuICApXG4gIGRlc3Ryb3lSZWYub25EZXN0cm95KHVuc3Vic2NyaWJlKVxuXG4gIHJldHVybiBzaWduYWxQcm94eShyZXN1bHRTaWduYWwpIGFzIENyZWF0ZUJhc2VRdWVyeVJlc3VsdDxURGF0YSwgVEVycm9yPlxufVxuIl19
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJhc2UtcXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY3JlYXRlLWJhc2UtcXVlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFVBQVUsRUFDVix3QkFBd0IsRUFDeEIsUUFBUSxFQUNSLE1BQU0sRUFDTixNQUFNLEVBQ04sTUFBTSxFQUNOLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQTtBQUN0QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUE7QUFDcEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBSTVDOztHQUVHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FPN0IsT0FRQyxFQUNELFFBQThCLEVBQzlCLFdBQXdCO0lBRXhCLHdCQUF3QixDQUFDLGVBQWUsQ0FBQyxDQUFBO0lBQ3pDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQTtJQUVyQzs7Ozs7T0FLRztJQUNILE1BQU0sc0JBQXNCLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtRQUMzQyxNQUFNLGdCQUFnQixHQUFHLFdBQVcsQ0FBQyxtQkFBbUIsQ0FDdEQsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUNyQixDQUFBO1FBQ0QsZ0JBQWdCLENBQUMsa0JBQWtCLEdBQUcsWUFBWSxDQUFBO1FBQ2xELE9BQU8sZ0JBQWdCLENBQUE7SUFDekIsQ0FBQyxDQUFDLENBQUE7SUFFRixNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsQ0FNM0IsV0FBVyxFQUFFLHNCQUFzQixFQUFFLENBQUMsQ0FBQTtJQUV4QyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQ3pCLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDLENBQ3ZELENBQUE7SUFFRCxNQUFNLENBQUMsR0FBRyxFQUFFO1FBQ1YsTUFBTSxnQkFBZ0IsR0FBRyxzQkFBc0IsRUFBRSxDQUFBO1FBQ2pELFFBQVEsQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLEVBQUU7WUFDcEMscUVBQXFFO1lBQ3JFLHNFQUFzRTtZQUN0RSxTQUFTLEVBQUUsS0FBSztTQUNqQixDQUFDLENBQUE7UUFDRixTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2IsdUVBQXVFO1FBQ3ZFLG1FQUFtRTtRQUNuRSxZQUFZLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQ2pFLENBQUE7SUFDSCxDQUFDLENBQUMsQ0FBQTtJQUVGLGtGQUFrRjtJQUNsRixNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsU0FBUyxDQUNwQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQ3pELENBQUE7SUFDRCxVQUFVLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBRWpDLE9BQU8sV0FBVyxDQUFDLFlBQVksQ0FBeUMsQ0FBQTtBQUMxRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGVzdHJveVJlZixcbiAgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0LFxuICBjb21wdXRlZCxcbiAgZWZmZWN0LFxuICBpbmplY3QsXG4gIHNpZ25hbCxcbiAgdW50cmFja2VkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgbm90aWZ5TWFuYWdlciB9IGZyb20gJ0B0YW5zdGFjay9xdWVyeS1jb3JlJ1xuaW1wb3J0IHsgc2lnbmFsUHJveHkgfSBmcm9tICcuL3NpZ25hbC1wcm94eSdcbmltcG9ydCB0eXBlIHsgUXVlcnlDbGllbnQsIFF1ZXJ5S2V5LCBRdWVyeU9ic2VydmVyIH0gZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5pbXBvcnQgdHlwZSB7IENyZWF0ZUJhc2VRdWVyeU9wdGlvbnMsIENyZWF0ZUJhc2VRdWVyeVJlc3VsdCB9IGZyb20gJy4vdHlwZXMnXG5cbi8qKlxuICogQmFzZSBpbXBsZW1lbnRhdGlvbiBmb3IgYGluamVjdFF1ZXJ5YCBhbmQgYGluamVjdEluZmluaXRlUXVlcnlgLlxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQmFzZVF1ZXJ5PFxuICBUUXVlcnlGbkRhdGEsXG4gIFRFcnJvcixcbiAgVERhdGEsXG4gIFRRdWVyeURhdGEsXG4gIFRRdWVyeUtleSBleHRlbmRzIFF1ZXJ5S2V5LFxuPihcbiAgb3B0aW9uczogKFxuICAgIGNsaWVudDogUXVlcnlDbGllbnQsXG4gICkgPT4gQ3JlYXRlQmFzZVF1ZXJ5T3B0aW9uczxcbiAgICBUUXVlcnlGbkRhdGEsXG4gICAgVEVycm9yLFxuICAgIFREYXRhLFxuICAgIFRRdWVyeURhdGEsXG4gICAgVFF1ZXJ5S2V5XG4gID4sXG4gIE9ic2VydmVyOiB0eXBlb2YgUXVlcnlPYnNlcnZlcixcbiAgcXVlcnlDbGllbnQ6IFF1ZXJ5Q2xpZW50LFxuKTogQ3JlYXRlQmFzZVF1ZXJ5UmVzdWx0PFREYXRhLCBURXJyb3I+IHtcbiAgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0KGNyZWF0ZUJhc2VRdWVyeSlcbiAgY29uc3QgZGVzdHJveVJlZiA9IGluamVjdChEZXN0cm95UmVmKVxuXG4gIC8qKlxuICAgKiBTaWduYWwgdGhhdCBoYXMgdGhlIGRlZmF1bHQgb3B0aW9ucyBmcm9tIHF1ZXJ5IGNsaWVudCBhcHBsaWVkXG4gICAqIGNvbXB1dGVkKCkgaXMgdXNlZCBzbyBzaWduYWxzIGNhbiBiZSBpbnNlcnRlZCBpbnRvIHRoZSBvcHRpb25zXG4gICAqIG1ha2luZyBpdCByZWFjdGl2ZS4gV3JhcHBpbmcgb3B0aW9ucyBpbiBhIGZ1bmN0aW9uIGVuc3VyZXMgZW1iZWRkZWQgZXhwcmVzc2lvbnNcbiAgICogYXJlIHByZXNlcnZlZCBhbmQgY2FuIGtlZXAgYmVpbmcgYXBwbGllZCBhZnRlciBzaWduYWwgY2hhbmdlc1xuICAgKi9cbiAgY29uc3QgZGVmYXVsdGVkT3B0aW9uc1NpZ25hbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBkZWZhdWx0ZWRPcHRpb25zID0gcXVlcnlDbGllbnQuZGVmYXVsdFF1ZXJ5T3B0aW9ucyhcbiAgICAgIG9wdGlvbnMocXVlcnlDbGllbnQpLFxuICAgIClcbiAgICBkZWZhdWx0ZWRPcHRpb25zLl9vcHRpbWlzdGljUmVzdWx0cyA9ICdvcHRpbWlzdGljJ1xuICAgIHJldHVybiBkZWZhdWx0ZWRPcHRpb25zXG4gIH0pXG5cbiAgY29uc3Qgb2JzZXJ2ZXIgPSBuZXcgT2JzZXJ2ZXI8XG4gICAgVFF1ZXJ5Rm5EYXRhLFxuICAgIFRFcnJvcixcbiAgICBURGF0YSxcbiAgICBUUXVlcnlEYXRhLFxuICAgIFRRdWVyeUtleVxuICA+KHF1ZXJ5Q2xpZW50LCBkZWZhdWx0ZWRPcHRpb25zU2lnbmFsKCkpXG5cbiAgY29uc3QgcmVzdWx0U2lnbmFsID0gc2lnbmFsKFxuICAgIG9ic2VydmVyLmdldE9wdGltaXN0aWNSZXN1bHQoZGVmYXVsdGVkT3B0aW9uc1NpZ25hbCgpKSxcbiAgKVxuXG4gIGVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgZGVmYXVsdGVkT3B0aW9ucyA9IGRlZmF1bHRlZE9wdGlvbnNTaWduYWwoKVxuICAgIG9ic2VydmVyLnNldE9wdGlvbnMoZGVmYXVsdGVkT3B0aW9ucywge1xuICAgICAgLy8gRG8gbm90IG5vdGlmeSBvbiB1cGRhdGVzIGJlY2F1c2Ugb2YgY2hhbmdlcyBpbiB0aGUgb3B0aW9ucyBiZWNhdXNlXG4gICAgICAvLyB0aGVzZSBjaGFuZ2VzIHNob3VsZCBhbHJlYWR5IGJlIHJlZmxlY3RlZCBpbiB0aGUgb3B0aW1pc3RpYyByZXN1bHQuXG4gICAgICBsaXN0ZW5lcnM6IGZhbHNlLFxuICAgIH0pXG4gICAgdW50cmFja2VkKCgpID0+XG4gICAgICAvLyBTZXQgdGhlIHNpZ25hbCBpbiBlZmZlY3QgYmVjYXVzZSBpdCdzIGJvdGggJ2NvbXB1dGVkJyBmcm9tIG9wdGlvbnMoKVxuICAgICAgLy8gYW5kIG5lZWRzIHRvIGJlIHNldCBpbXBlcmF0aXZlbHkgaW4gdGhlIHF1ZXJ5IG9ic2VydmVyIGxpc3RlbmVyLlxuICAgICAgcmVzdWx0U2lnbmFsLnNldChvYnNlcnZlci5nZXRPcHRpbWlzdGljUmVzdWx0KGRlZmF1bHRlZE9wdGlvbnMpKSxcbiAgICApXG4gIH0pXG5cbiAgLy8gb2JzZXJ2ZXIudHJhY2tSZXN1bHQgaXMgbm90IHVzZWQgYXMgdGhpcyBvcHRpbWl6YXRpb24gaXMgbm90IG5lZWRlZCBmb3IgQW5ndWxhclxuICBjb25zdCB1bnN1YnNjcmliZSA9IG9ic2VydmVyLnN1YnNjcmliZShcbiAgICBub3RpZnlNYW5hZ2VyLmJhdGNoQ2FsbHMoKHZhbCkgPT4gcmVzdWx0U2lnbmFsLnNldCh2YWwpKSxcbiAgKVxuICBkZXN0cm95UmVmLm9uRGVzdHJveSh1bnN1YnNjcmliZSlcblxuICByZXR1cm4gc2lnbmFsUHJveHkocmVzdWx0U2lnbmFsKSBhcyBDcmVhdGVCYXNlUXVlcnlSZXN1bHQ8VERhdGEsIFRFcnJvcj5cbn1cbiJdfQ==
@@ -8,8 +8,9 @@ export * from './inject-infinite-query';
8
8
  export * from './inject-is-fetching';
9
9
  export * from './inject-is-mutating';
10
10
  export * from './inject-mutation';
11
+ export * from './inject-mutation-state';
11
12
  export * from './inject-queries';
12
13
  export * from './inject-query';
13
14
  export { injectQueryClient, provideQueryClient, QUERY_CLIENT, } from './inject-query-client';
14
15
  export { provideAngularQuery } from './providers';
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEJBQTBCO0FBRTFCLGlCQUFpQjtBQUNqQixjQUFjLHNCQUFzQixDQUFBO0FBRXBDLGNBQWMsU0FBUyxDQUFBO0FBTXZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUU5QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUUvRCxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLGtCQUFrQixFQUNsQixZQUFZLEdBQ2IsTUFBTSx1QkFBdUIsQ0FBQTtBQUM5QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxhQUFhLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuXG4vLyBSZS1leHBvcnQgY29yZVxuZXhwb3J0ICogZnJvbSAnQHRhbnN0YWNrL3F1ZXJ5LWNvcmUnXG5cbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnXG5cbmV4cG9ydCB0eXBlIHtcbiAgRGVmaW5lZEluaXRpYWxEYXRhT3B0aW9ucyxcbiAgVW5kZWZpbmVkSW5pdGlhbERhdGFPcHRpb25zLFxufSBmcm9tICcuL3F1ZXJ5LW9wdGlvbnMnXG5leHBvcnQgeyBxdWVyeU9wdGlvbnMgfSBmcm9tICcuL3F1ZXJ5LW9wdGlvbnMnXG5cbmV4cG9ydCB7IGluZmluaXRlUXVlcnlPcHRpb25zIH0gZnJvbSAnLi9pbmZpbml0ZS1xdWVyeS1vcHRpb25zJ1xuXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1pbmZpbml0ZS1xdWVyeSdcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LWlzLWZldGNoaW5nJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtaXMtbXV0YXRpbmcnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1tdXRhdGlvbidcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LXF1ZXJpZXMnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1xdWVyeSdcbmV4cG9ydCB7XG4gIGluamVjdFF1ZXJ5Q2xpZW50LFxuICBwcm92aWRlUXVlcnlDbGllbnQsXG4gIFFVRVJZX0NMSUVOVCxcbn0gZnJvbSAnLi9pbmplY3QtcXVlcnktY2xpZW50J1xuZXhwb3J0IHsgcHJvdmlkZUFuZ3VsYXJRdWVyeSB9IGZyb20gJy4vcHJvdmlkZXJzJ1xuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMEJBQTBCO0FBRTFCLGlCQUFpQjtBQUNqQixjQUFjLHNCQUFzQixDQUFBO0FBRXBDLGNBQWMsU0FBUyxDQUFBO0FBTXZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUU5QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUUvRCxjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGdCQUFnQixDQUFBO0FBQzlCLE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsa0JBQWtCLEVBQ2xCLFlBQVksR0FDYixNQUFNLHVCQUF1QixDQUFBO0FBQzlCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5cbi8vIFJlLWV4cG9ydCBjb3JlXG5leHBvcnQgKiBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcydcblxuZXhwb3J0IHR5cGUge1xuICBEZWZpbmVkSW5pdGlhbERhdGFPcHRpb25zLFxuICBVbmRlZmluZWRJbml0aWFsRGF0YU9wdGlvbnMsXG59IGZyb20gJy4vcXVlcnktb3B0aW9ucydcbmV4cG9ydCB7IHF1ZXJ5T3B0aW9ucyB9IGZyb20gJy4vcXVlcnktb3B0aW9ucydcblxuZXhwb3J0IHsgaW5maW5pdGVRdWVyeU9wdGlvbnMgfSBmcm9tICcuL2luZmluaXRlLXF1ZXJ5LW9wdGlvbnMnXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LWluZmluaXRlLXF1ZXJ5J1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtaXMtZmV0Y2hpbmcnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1pcy1tdXRhdGluZydcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0LW11dGF0aW9uJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtbXV0YXRpb24tc3RhdGUnXG5leHBvcnQgKiBmcm9tICcuL2luamVjdC1xdWVyaWVzJ1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3QtcXVlcnknXG5leHBvcnQge1xuICBpbmplY3RRdWVyeUNsaWVudCxcbiAgcHJvdmlkZVF1ZXJ5Q2xpZW50LFxuICBRVUVSWV9DTElFTlQsXG59IGZyb20gJy4vaW5qZWN0LXF1ZXJ5LWNsaWVudCdcbmV4cG9ydCB7IHByb3ZpZGVBbmd1bGFyUXVlcnkgfSBmcm9tICcuL3Byb3ZpZGVycydcbiJdfQ==
@@ -0,0 +1,36 @@
1
+ import { DestroyRef, effect, inject, signal, untracked } from '@angular/core';
2
+ import { notifyManager, replaceEqualDeep, } from '@tanstack/query-core';
3
+ import { assertInjector } from './util/assert-injector/assert-injector';
4
+ import { injectQueryClient } from './inject-query-client';
5
+ function getResult(mutationCache, options) {
6
+ return mutationCache
7
+ .findAll(options.filters)
8
+ .map((mutation) => (options.select
9
+ ? options.select(mutation)
10
+ : mutation.state));
11
+ }
12
+ export function injectMutationState(mutationStateOptionsFn = () => ({}), options) {
13
+ return assertInjector(injectMutationState, options?.injector, () => {
14
+ const destroyRef = inject(DestroyRef);
15
+ const queryClient = injectQueryClient();
16
+ const mutationCache = queryClient.getMutationCache();
17
+ const result = signal(getResult(mutationCache, mutationStateOptionsFn()));
18
+ effect(() => {
19
+ const mutationStateOptions = mutationStateOptionsFn();
20
+ untracked(() => {
21
+ // Setting the signal from an effect because it's both 'computed' from options()
22
+ // and needs to be set imperatively in the mutationCache listener.
23
+ result.set(getResult(mutationCache, mutationStateOptions));
24
+ });
25
+ });
26
+ const unsubscribe = mutationCache.subscribe(notifyManager.batchCalls(() => {
27
+ const nextResult = replaceEqualDeep(result(), getResult(mutationCache, mutationStateOptionsFn()));
28
+ if (result() !== nextResult) {
29
+ result.set(nextResult);
30
+ }
31
+ }));
32
+ destroyRef.onDestroy(unsubscribe);
33
+ return result;
34
+ });
35
+ }
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LW11dGF0aW9uLXN0YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2luamVjdC1tdXRhdGlvbi1zdGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUM3RSxPQUFPLEVBTUwsYUFBYSxFQUNiLGdCQUFnQixHQUNqQixNQUFNLHNCQUFzQixDQUFBO0FBQzdCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQTtBQUN2RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQVV6RCxTQUFTLFNBQVMsQ0FDaEIsYUFBNEIsRUFDNUIsT0FBc0M7SUFFdEMsT0FBTyxhQUFhO1NBQ2pCLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDO1NBQ3hCLEdBQUcsQ0FDRixDQUFDLFFBQVEsRUFBVyxFQUFFLENBQ3BCLENBQUMsT0FBTyxDQUFDLE1BQU07UUFDYixDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FDWixRQUE2RCxDQUM5RDtRQUNILENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFZLENBQ2pDLENBQUE7QUFDTCxDQUFDO0FBTUQsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyx5QkFBOEQsR0FBRyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFDeEUsT0FBb0M7SUFFcEMsT0FBTyxjQUFjLENBQUMsbUJBQW1CLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUU7UUFDakUsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQ3JDLE1BQU0sV0FBVyxHQUFHLGlCQUFpQixFQUFFLENBQUE7UUFFdkMsTUFBTSxhQUFhLEdBQUcsV0FBVyxDQUFDLGdCQUFnQixFQUFFLENBQUE7UUFFcEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUNuQixTQUFTLENBQUMsYUFBYSxFQUFFLHNCQUFzQixFQUFFLENBQUMsQ0FDbkQsQ0FBQTtRQUVELE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDVixNQUFNLG9CQUFvQixHQUFHLHNCQUFzQixFQUFFLENBQUE7WUFDckQsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDYixnRkFBZ0Y7Z0JBQ2hGLGtFQUFrRTtnQkFDbEUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLG9CQUFvQixDQUFDLENBQUMsQ0FBQTtZQUM1RCxDQUFDLENBQUMsQ0FBQTtRQUNKLENBQUMsQ0FBQyxDQUFBO1FBRUYsTUFBTSxXQUFXLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FDekMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDNUIsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQ2pDLE1BQU0sRUFBRSxFQUNSLFNBQVMsQ0FBQyxhQUFhLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQyxDQUNuRCxDQUFBO1lBQ0QsSUFBSSxNQUFNLEVBQUUsS0FBSyxVQUFVLEVBQUU7Z0JBQzNCLE1BQU0sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUE7YUFDdkI7UUFDSCxDQUFDLENBQUMsQ0FDSCxDQUFBO1FBRUQsVUFBVSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQTtRQUVqQyxPQUFPLE1BQU0sQ0FBQTtJQUNmLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIGVmZmVjdCwgaW5qZWN0LCBzaWduYWwsIHVudHJhY2tlZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQge1xuICB0eXBlIERlZmF1bHRFcnJvcixcbiAgdHlwZSBNdXRhdGlvbixcbiAgdHlwZSBNdXRhdGlvbkNhY2hlLFxuICB0eXBlIE11dGF0aW9uRmlsdGVycyxcbiAgdHlwZSBNdXRhdGlvblN0YXRlLFxuICBub3RpZnlNYW5hZ2VyLFxuICByZXBsYWNlRXF1YWxEZWVwLFxufSBmcm9tICdAdGFuc3RhY2svcXVlcnktY29yZSdcbmltcG9ydCB7IGFzc2VydEluamVjdG9yIH0gZnJvbSAnLi91dGlsL2Fzc2VydC1pbmplY3Rvci9hc3NlcnQtaW5qZWN0b3InXG5pbXBvcnQgeyBpbmplY3RRdWVyeUNsaWVudCB9IGZyb20gJy4vaW5qZWN0LXF1ZXJ5LWNsaWVudCdcbmltcG9ydCB0eXBlIHsgSW5qZWN0b3IsIFNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbnR5cGUgTXV0YXRpb25TdGF0ZU9wdGlvbnM8VFJlc3VsdCA9IE11dGF0aW9uU3RhdGU+ID0ge1xuICBmaWx0ZXJzPzogTXV0YXRpb25GaWx0ZXJzXG4gIHNlbGVjdD86IChcbiAgICBtdXRhdGlvbjogTXV0YXRpb248dW5rbm93biwgRGVmYXVsdEVycm9yLCB1bmtub3duLCB1bmtub3duPixcbiAgKSA9PiBUUmVzdWx0XG59XG5cbmZ1bmN0aW9uIGdldFJlc3VsdDxUUmVzdWx0ID0gTXV0YXRpb25TdGF0ZT4oXG4gIG11dGF0aW9uQ2FjaGU6IE11dGF0aW9uQ2FjaGUsXG4gIG9wdGlvbnM6IE11dGF0aW9uU3RhdGVPcHRpb25zPFRSZXN1bHQ+LFxuKTogQXJyYXk8VFJlc3VsdD4ge1xuICByZXR1cm4gbXV0YXRpb25DYWNoZVxuICAgIC5maW5kQWxsKG9wdGlvbnMuZmlsdGVycylcbiAgICAubWFwKFxuICAgICAgKG11dGF0aW9uKTogVFJlc3VsdCA9PlxuICAgICAgICAob3B0aW9ucy5zZWxlY3RcbiAgICAgICAgICA/IG9wdGlvbnMuc2VsZWN0KFxuICAgICAgICAgICAgICBtdXRhdGlvbiBhcyBNdXRhdGlvbjx1bmtub3duLCBEZWZhdWx0RXJyb3IsIHVua25vd24sIHVua25vd24+LFxuICAgICAgICAgICAgKVxuICAgICAgICAgIDogbXV0YXRpb24uc3RhdGUpIGFzIFRSZXN1bHQsXG4gICAgKVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEluamVjdE11dGF0aW9uU3RhdGVPcHRpb25zIHtcbiAgaW5qZWN0b3I/OiBJbmplY3RvclxufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0TXV0YXRpb25TdGF0ZTxUUmVzdWx0ID0gTXV0YXRpb25TdGF0ZT4oXG4gIG11dGF0aW9uU3RhdGVPcHRpb25zRm46ICgpID0+IE11dGF0aW9uU3RhdGVPcHRpb25zPFRSZXN1bHQ+ID0gKCkgPT4gKHt9KSxcbiAgb3B0aW9ucz86IEluamVjdE11dGF0aW9uU3RhdGVPcHRpb25zLFxuKTogU2lnbmFsPEFycmF5PFRSZXN1bHQ+PiB7XG4gIHJldHVybiBhc3NlcnRJbmplY3RvcihpbmplY3RNdXRhdGlvblN0YXRlLCBvcHRpb25zPy5pbmplY3RvciwgKCkgPT4ge1xuICAgIGNvbnN0IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZilcbiAgICBjb25zdCBxdWVyeUNsaWVudCA9IGluamVjdFF1ZXJ5Q2xpZW50KClcblxuICAgIGNvbnN0IG11dGF0aW9uQ2FjaGUgPSBxdWVyeUNsaWVudC5nZXRNdXRhdGlvbkNhY2hlKClcblxuICAgIGNvbnN0IHJlc3VsdCA9IHNpZ25hbDxBcnJheTxUUmVzdWx0Pj4oXG4gICAgICBnZXRSZXN1bHQobXV0YXRpb25DYWNoZSwgbXV0YXRpb25TdGF0ZU9wdGlvbnNGbigpKSxcbiAgICApXG5cbiAgICBlZmZlY3QoKCkgPT4ge1xuICAgICAgY29uc3QgbXV0YXRpb25TdGF0ZU9wdGlvbnMgPSBtdXRhdGlvblN0YXRlT3B0aW9uc0ZuKClcbiAgICAgIHVudHJhY2tlZCgoKSA9PiB7XG4gICAgICAgIC8vIFNldHRpbmcgdGhlIHNpZ25hbCBmcm9tIGFuIGVmZmVjdCBiZWNhdXNlIGl0J3MgYm90aCAnY29tcHV0ZWQnIGZyb20gb3B0aW9ucygpXG4gICAgICAgIC8vIGFuZCBuZWVkcyB0byBiZSBzZXQgaW1wZXJhdGl2ZWx5IGluIHRoZSBtdXRhdGlvbkNhY2hlIGxpc3RlbmVyLlxuICAgICAgICByZXN1bHQuc2V0KGdldFJlc3VsdChtdXRhdGlvbkNhY2hlLCBtdXRhdGlvblN0YXRlT3B0aW9ucykpXG4gICAgICB9KVxuICAgIH0pXG5cbiAgICBjb25zdCB1bnN1YnNjcmliZSA9IG11dGF0aW9uQ2FjaGUuc3Vic2NyaWJlKFxuICAgICAgbm90aWZ5TWFuYWdlci5iYXRjaENhbGxzKCgpID0+IHtcbiAgICAgICAgY29uc3QgbmV4dFJlc3VsdCA9IHJlcGxhY2VFcXVhbERlZXAoXG4gICAgICAgICAgcmVzdWx0KCksXG4gICAgICAgICAgZ2V0UmVzdWx0KG11dGF0aW9uQ2FjaGUsIG11dGF0aW9uU3RhdGVPcHRpb25zRm4oKSksXG4gICAgICAgIClcbiAgICAgICAgaWYgKHJlc3VsdCgpICE9PSBuZXh0UmVzdWx0KSB7XG4gICAgICAgICAgcmVzdWx0LnNldChuZXh0UmVzdWx0KVxuICAgICAgICB9XG4gICAgICB9KSxcbiAgICApXG5cbiAgICBkZXN0cm95UmVmLm9uRGVzdHJveSh1bnN1YnNjcmliZSlcblxuICAgIHJldHVybiByZXN1bHRcbiAgfSlcbn1cbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { notifyManager, InfiniteQueryObserver, MutationObserver, QueriesObserver, QueryObserver } from '@tanstack/query-core';
1
+ import { notifyManager, InfiniteQueryObserver, MutationObserver, replaceEqualDeep, QueriesObserver, QueryObserver } from '@tanstack/query-core';
2
2
  export * from '@tanstack/query-core';
3
3
  import { untracked, computed, assertInInjectionContext, DestroyRef, inject, signal, effect, Injector, runInInjectionContext, InjectionToken, ENVIRONMENT_INITIALIZER, makeEnvironmentProviders } from '@angular/core';
4
4
 
@@ -71,14 +71,17 @@ function createBaseQuery(options, Observer, queryClient) {
71
71
  const observer = new Observer(queryClient, defaultedOptionsSignal());
72
72
  const resultSignal = signal(observer.getOptimisticResult(defaultedOptionsSignal()));
73
73
  effect(() => {
74
- // Do not notify on updates because of changes in the options because
75
- // these changes should already be reflected in the optimistic result.
76
74
  const defaultedOptions = defaultedOptionsSignal();
77
75
  observer.setOptions(defaultedOptions, {
76
+ // Do not notify on updates because of changes in the options because
77
+ // these changes should already be reflected in the optimistic result.
78
78
  listeners: false,
79
79
  });
80
- resultSignal.set(observer.getOptimisticResult(defaultedOptions));
81
- }, { allowSignalWrites: true });
80
+ untracked(() =>
81
+ // Set the signal in effect because it's both 'computed' from options()
82
+ // and needs to be set imperatively in the query observer listener.
83
+ resultSignal.set(observer.getOptimisticResult(defaultedOptions)));
84
+ });
82
85
  // observer.trackResult is not used as this optimization is not needed for Angular
83
86
  const unsubscribe = observer.subscribe(notifyManager.batchCalls((val) => resultSignal.set(val)));
84
87
  destroyRef.onDestroy(unsubscribe);
@@ -239,6 +242,38 @@ function injectMutation(options, injector) {
239
242
  }
240
243
  function noop() { }
241
244
 
245
+ function getResult(mutationCache, options) {
246
+ return mutationCache
247
+ .findAll(options.filters)
248
+ .map((mutation) => (options.select
249
+ ? options.select(mutation)
250
+ : mutation.state));
251
+ }
252
+ function injectMutationState(mutationStateOptionsFn = () => ({}), options) {
253
+ return assertInjector(injectMutationState, options?.injector, () => {
254
+ const destroyRef = inject(DestroyRef);
255
+ const queryClient = injectQueryClient();
256
+ const mutationCache = queryClient.getMutationCache();
257
+ const result = signal(getResult(mutationCache, mutationStateOptionsFn()));
258
+ effect(() => {
259
+ const mutationStateOptions = mutationStateOptionsFn();
260
+ untracked(() => {
261
+ // Setting the signal from an effect because it's both 'computed' from options()
262
+ // and needs to be set imperatively in the mutationCache listener.
263
+ result.set(getResult(mutationCache, mutationStateOptions));
264
+ });
265
+ });
266
+ const unsubscribe = mutationCache.subscribe(notifyManager.batchCalls(() => {
267
+ const nextResult = replaceEqualDeep(result(), getResult(mutationCache, mutationStateOptionsFn()));
268
+ if (result() !== nextResult) {
269
+ result.set(nextResult);
270
+ }
271
+ }));
272
+ destroyRef.onDestroy(unsubscribe);
273
+ return result;
274
+ });
275
+ }
276
+
242
277
  function injectQueries({ queries, ...options }, injector) {
243
278
  return assertInjector(injectQueries, injector, () => {
244
279
  const queryClient = injectQueryClient();
@@ -294,5 +329,5 @@ function provideAngularQuery(queryClient) {
294
329
  * Generated bundle index. Do not edit.
295
330
  */
296
331
 
297
- export { QUERY_CLIENT, infiniteQueryOptions, injectInfiniteQuery, injectIsFetching, injectIsMutating, injectMutation, injectQueries, injectQuery, injectQueryClient, provideAngularQuery, provideQueryClient, queryOptions };
332
+ export { QUERY_CLIENT, infiniteQueryOptions, injectInfiniteQuery, injectIsFetching, injectIsMutating, injectMutation, injectMutationState, injectQueries, injectQuery, injectQueryClient, provideAngularQuery, provideQueryClient, queryOptions };
298
333
  //# sourceMappingURL=tanstack-angular-query-experimental.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"tanstack-angular-query-experimental.mjs","sources":["../../src/types.ts","../../src/query-options.ts","../../src/infinite-query-options.ts","../../src/signal-proxy.ts","../../src/create-base-query.ts","../../src/util/assert-injector/assert-injector.ts","../../src/util/create-injection-token/create-injection-token.ts","../../src/inject-query-client.ts","../../src/inject-infinite-query.ts","../../src/inject-is-fetching.ts","../../src/inject-is-mutating.ts","../../src/inject-mutation.ts","../../src/inject-queries.ts","../../src/inject-query.ts","../../src/providers.ts","../../src/index.ts","../../src/tanstack-angular-query-experimental.ts"],"sourcesContent":["/* istanbul ignore file */\n\nimport type {\n DefaultError,\n DefinedInfiniteQueryObserverResult,\n DefinedQueryObserverResult,\n InfiniteQueryObserverOptions,\n InfiniteQueryObserverResult,\n MutateFunction,\n MutationObserverOptions,\n MutationObserverResult,\n QueryKey,\n QueryObserverOptions,\n QueryObserverResult,\n} from '@tanstack/query-core'\nimport type { MapToSignals } from './signal-proxy'\n\nexport interface CreateBaseQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> extends QueryObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n > {}\n\nexport interface CreateQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> extends Omit<\n CreateBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'suspense'\n > {}\n\ntype CreateStatusBasedQueryResult<\n TStatus extends QueryObserverResult['status'],\n TData = unknown,\n TError = DefaultError,\n> = Extract<QueryObserverResult<TData, TError>, { status: TStatus }>\n\nexport interface BaseQueryNarrowing<TData = unknown, TError = DefaultError> {\n isSuccess: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'success', TData, TError>\n >\n isError: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'error', TData, TError>\n >\n isPending: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'pending', TData, TError>\n >\n}\n\nexport interface CreateInfiniteQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> extends Omit<\n InfiniteQueryObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey,\n TPageParam\n >,\n 'suspense'\n > {}\n\nexport type CreateBaseQueryResult<\n TData = unknown,\n TError = DefaultError,\n TState = QueryObserverResult<TData, TError>,\n> = BaseQueryNarrowing<TData, TError> &\n MapToSignals<Omit<TState, keyof BaseQueryNarrowing>>\n\nexport type CreateQueryResult<\n TData = unknown,\n TError = DefaultError,\n> = CreateBaseQueryResult<TData, TError>\n\nexport type DefinedCreateQueryResult<\n TData = unknown,\n TError = DefaultError,\n TDefinedQueryObserver = DefinedQueryObserverResult<TData, TError>,\n> = MapToSignals<TDefinedQueryObserver>\n\nexport type CreateInfiniteQueryResult<\n TData = unknown,\n TError = DefaultError,\n> = MapToSignals<InfiniteQueryObserverResult<TData, TError>>\n\nexport type DefinedCreateInfiniteQueryResult<\n TData = unknown,\n TError = DefaultError,\n TDefinedInfiniteQueryObserver = DefinedInfiniteQueryObserverResult<\n TData,\n TError\n >,\n> = MapToSignals<TDefinedInfiniteQueryObserver>\n\nexport interface CreateMutationOptions<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> extends Omit<\n MutationObserverOptions<TData, TError, TVariables, TContext>,\n '_defaulted'\n > {}\n\nexport type CreateMutateFunction<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> = (\n ...args: Parameters<MutateFunction<TData, TError, TVariables, TContext>>\n) => void\n\nexport type CreateMutateAsyncFunction<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> = MutateFunction<TData, TError, TVariables, TContext>\n\nexport type CreateBaseMutationResult<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> = Override<\n MutationObserverResult<TData, TError, TVariables, TContext>,\n { mutate: CreateMutateFunction<TData, TError, TVariables, TContext> }\n> & {\n mutateAsync: CreateMutateAsyncFunction<TData, TError, TVariables, TContext>\n}\n\ntype CreateStatusBasedMutationResult<\n TStatus extends CreateBaseMutationResult['status'],\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> = Extract<\n CreateBaseMutationResult<TData, TError, TVariables, TContext>,\n { status: TStatus }\n>\n\nexport interface BaseMutationNarrowing<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> {\n isSuccess: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'success',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isError: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'error',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isPending: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'pending',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isIdle: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<'idle', TData, TError, TVariables, TContext>\n >\n}\n\nexport type CreateMutationResult<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n TState = CreateStatusBasedMutationResult<\n CreateBaseMutationResult['status'],\n TData,\n TError,\n TVariables,\n TContext\n >,\n> = BaseMutationNarrowing<TData, TError, TVariables, TContext> &\n MapToSignals<Omit<TState, keyof BaseMutationNarrowing>>\n\ntype Override<TTargetA, TTargetB> = {\n [AKey in keyof TTargetA]: AKey extends keyof TTargetB\n ? TTargetB[AKey]\n : TTargetA[AKey]\n}\n","import type { DataTag, DefaultError, QueryKey } from '@tanstack/query-core'\nimport type { CreateQueryOptions } from './types'\n\nexport type UndefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData?: undefined\n}\n\ntype NonUndefinedGuard<T> = T extends undefined ? never : T\n\nexport type DefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData:\n | NonUndefinedGuard<TQueryFnData>\n | (() => NonUndefinedGuard<TQueryFnData>)\n}\n\nexport function queryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n): UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey> & {\n queryKey: DataTag<TQueryKey, TQueryFnData>\n}\n\nexport function queryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n): DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey> & {\n queryKey: DataTag<TQueryKey, TQueryFnData>\n}\n\nexport function queryOptions(options: unknown) {\n return options\n}\n","import type { DataTag } from '@tanstack/query-core'\nimport type { InfiniteData } from '@tanstack/query-core'\nimport type { CreateInfiniteQueryOptions } from './types'\nimport type { DefaultError, QueryKey } from '@tanstack/query-core'\n\nexport type UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> = CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n> & {\n initialData?: undefined\n}\n\ntype NonUndefinedGuard<T> = T extends undefined ? never : T\n\nexport type DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> = CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n> & {\n initialData:\n | NonUndefinedGuard<InfiniteData<TQueryFnData, TPageParam>>\n | (() => NonUndefinedGuard<InfiniteData<TQueryFnData, TPageParam>>)\n}\n\nexport function infiniteQueryOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n): UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n> & {\n queryKey: DataTag<TQueryKey, InfiniteData<TQueryFnData>>\n}\n\nexport function infiniteQueryOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n): DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n> & {\n queryKey: DataTag<TQueryKey, InfiniteData<TQueryFnData>>\n}\n\nexport function infiniteQueryOptions(options: unknown) {\n return options\n}\n","import { computed, untracked } from '@angular/core'\nimport type { Signal } from '@angular/core'\n\nexport type MapToSignals<T> = {\n [K in keyof T]: T[K] extends Function ? T[K] : Signal<T[K]>\n}\n\n/**\n * Exposes fields of an object passed via an Angular `Signal` as `Computed` signals.\n *\n * Functions on the object are passed through as-is.\n *\n * @param inputSignal - `Signal` that must return an object.\n *\n */\nexport function signalProxy<TInput extends Record<string | symbol, any>>(\n inputSignal: Signal<TInput>,\n) {\n const internalState = {} as MapToSignals<TInput>\n\n return new Proxy<MapToSignals<TInput>>(internalState, {\n get(target, prop) {\n // first check if we have it in our internal state and return it\n const computedField = target[prop]\n if (computedField) return computedField\n\n // then, check if it's a function on the resultState and return it\n const targetField = untracked(inputSignal)[prop]\n if (typeof targetField === 'function') return targetField\n\n // finally, create a computed field, store it and return it\n // @ts-expect-error\n return (target[prop] = computed(() => inputSignal()[prop]))\n },\n has(_, prop) {\n return !!untracked(inputSignal)[prop]\n },\n ownKeys() {\n return Reflect.ownKeys(untracked(inputSignal))\n },\n getOwnPropertyDescriptor() {\n return {\n enumerable: true,\n configurable: true,\n }\n },\n })\n}\n","import {\n DestroyRef,\n assertInInjectionContext,\n computed,\n effect,\n inject,\n signal,\n} from '@angular/core'\nimport { notifyManager } from '@tanstack/query-core'\nimport { signalProxy } from './signal-proxy'\nimport type { QueryClient, QueryKey, QueryObserver } from '@tanstack/query-core'\nimport type { CreateBaseQueryOptions, CreateBaseQueryResult } from './types'\n\n/**\n * Base implementation for `injectQuery` and `injectInfiniteQuery`.\n */\nexport function createBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => CreateBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >,\n Observer: typeof QueryObserver,\n queryClient: QueryClient,\n): CreateBaseQueryResult<TData, TError> {\n assertInInjectionContext(createBaseQuery)\n const destroyRef = inject(DestroyRef)\n\n /**\n * Signal that has the default options from query client applied\n * computed() is used so signals can be inserted into the options\n * making it reactive. Wrapping options in a function ensures embedded expressions\n * are preserved and can keep being applied after signal changes\n */\n const defaultedOptionsSignal = computed(() => {\n const defaultedOptions = queryClient.defaultQueryOptions(\n options(queryClient),\n )\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n\n const observer = new Observer<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >(queryClient, defaultedOptionsSignal())\n\n const resultSignal = signal(\n observer.getOptimisticResult(defaultedOptionsSignal()),\n )\n\n effect(\n () => {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n const defaultedOptions = defaultedOptionsSignal()\n observer.setOptions(defaultedOptions, {\n listeners: false,\n })\n resultSignal.set(observer.getOptimisticResult(defaultedOptions))\n },\n { allowSignalWrites: true },\n )\n\n // observer.trackResult is not used as this optimization is not needed for Angular\n const unsubscribe = observer.subscribe(\n notifyManager.batchCalls((val) => resultSignal.set(val)),\n )\n destroyRef.onDestroy(unsubscribe)\n\n return signalProxy(resultSignal) as CreateBaseQueryResult<TData, TError>\n}\n","/* eslint-disable @cspell/spellchecker */\n/**\n * The code in this file is adapted from NG Extension Platform at https://ngxtension.netlify.app.\n *\n * Original Author: Chau Tran\n *\n * NG Extension Platform is an open-source project licensed under the MIT license.\n *\n * For more information about the original code, see\n * https://github.com/nartc/ngxtension-platform\n */\n/* eslint-enable */\n\nimport {\n Injector,\n assertInInjectionContext,\n inject,\n runInInjectionContext,\n} from '@angular/core'\n\n/**\n * `assertInjector` extends `assertInInjectionContext` with an optional `Injector`\n * After assertion, `assertInjector` runs the `runner` function with the guaranteed `Injector`\n * whether it is the default `Injector` within the current **Injection Context**\n * or the custom `Injector` that was passed in.\n *\n * @template {() => any} Runner - Runner is a function that can return anything\n * @param {Function} fn - the Function to pass in `assertInInjectionContext`\n * @param {Injector | undefined | null} injector - the optional \"custom\" Injector\n * @param {Runner} runner - the runner fn\n * @returns {ReturnType<Runner>} result - returns the result of the Runner\n *\n * @example\n * ```ts\n * function injectValue(injector?: Injector) {\n * return assertInjector(injectValue, injector, () => 'value');\n * }\n *\n * injectValue(); // string\n * ```\n */\nexport function assertInjector<TRunner extends () => any>(\n fn: Function,\n injector: Injector | undefined | null,\n runner: TRunner,\n): ReturnType<TRunner>\n/**\n * `assertInjector` extends `assertInInjectionContext` with an optional `Injector`\n * After assertion, `assertInjector` returns a guaranteed `Injector` whether it is the default `Injector`\n * within the current **Injection Context** or the custom `Injector` that was passed in.\n *\n * @param {Function} fn - the Function to pass in `assertInInjectionContext`\n * @param {Injector | undefined | null} injector - the optional \"custom\" Injector\n * @returns Injector\n *\n * @example\n * ```ts\n * function injectDestroy(injector?: Injector) {\n * injector = assertInjector(injectDestroy, injector);\n *\n * return runInInjectionContext(injector, () => {\n * // code\n * })\n * }\n * ```\n */\nexport function assertInjector(\n fn: Function,\n injector: Injector | undefined | null,\n): Injector\nexport function assertInjector(\n fn: Function,\n injector: Injector | undefined | null,\n runner?: () => any,\n) {\n !injector && assertInInjectionContext(fn)\n const assertedInjector = injector ?? inject(Injector)\n\n if (!runner) return assertedInjector\n return runInInjectionContext(assertedInjector, runner)\n}\n","/* eslint-disable @cspell/spellchecker */\n/**\n * The code in this file is adapted from NG Extension Platform at https://ngxtension.netlify.app.\n *\n * Original Author: Chau Tran\n *\n * NG Extension Platform is an open-source project licensed under the MIT license.\n *\n * For more information about the original code, see\n * https://github.com/nartc/ngxtension-platform\n */\n/* eslint-enable */\n\nimport {\n type EnvironmentProviders,\n type FactoryProvider,\n type Host,\n type InjectOptions,\n InjectionToken,\n type Injector,\n type Optional,\n type Provider,\n type Self,\n type SkipSelf,\n type Type,\n inject,\n runInInjectionContext,\n} from '@angular/core'\nimport { assertInjector } from '../assert-injector/assert-injector'\n\ntype CreateInjectionTokenDep<TTokenType> =\n | Type<TTokenType>\n // NOTE: we don't have an AbstractType\n | (abstract new (...args: Array<any>) => TTokenType)\n | InjectionToken<TTokenType>\n\ntype CreateInjectionTokenDeps<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> = {\n [Index in keyof TFactoryDeps]:\n | CreateInjectionTokenDep<TFactoryDeps[Index]>\n | [\n ...modifiers: Array<Optional | Self | SkipSelf | Host>,\n token: CreateInjectionTokenDep<TFactoryDeps[Index]>,\n ]\n} & { length: TFactoryDeps['length'] }\n\ntype CreateInjectionTokenOptions<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> =\n // this means TFunction has no parameters\n (TFactoryDeps[0] extends undefined\n ? { deps?: never }\n : { deps: CreateInjectionTokenDeps<TFactory, TFactoryDeps> }) & {\n isRoot?: boolean\n multi?: boolean\n token?: InjectionToken<ReturnType<TFactory>>\n extraProviders?: Provider | EnvironmentProviders\n }\n\ntype CreateProvideFnOptions<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> = Pick<\n CreateInjectionTokenOptions<TFactory, TFactoryDeps>,\n 'deps' | 'extraProviders' | 'multi'\n>\n\ntype InjectFn<TFactoryReturn> = {\n (): TFactoryReturn\n (\n injectOptions: InjectOptions & { optional?: false } & {\n injector?: Injector\n },\n ): TFactoryReturn\n (\n injectOptions: InjectOptions & { injector?: Injector },\n ): TFactoryReturn | null\n}\n\ntype ProvideFn<\n TNoop extends boolean,\n TFactoryReturn,\n TReturn = TFactoryReturn extends Array<infer Item> ? Item : TFactoryReturn,\n> = (TNoop extends true\n ? (value: TReturn | (() => TReturn)) => Provider\n : () => Provider) &\n (TReturn extends Function\n ? (value: TReturn | (() => TReturn), isFunctionValue: boolean) => Provider\n : (value: TReturn | (() => TReturn)) => Provider)\n\ntype CreateInjectionTokenReturn<\n TFactoryReturn,\n TNoop extends boolean = false,\n> = [\n InjectFn<TFactoryReturn>,\n ProvideFn<TNoop, TFactoryReturn>,\n InjectionToken<TFactoryReturn>,\n () => Provider,\n]\n\nfunction createInjectFn<TValue>(token: InjectionToken<TValue>) {\n return function (\n this: Function,\n {\n injector,\n ...injectOptions\n }: InjectOptions & { injector?: Injector } = {},\n ) {\n injector = assertInjector(this, injector)\n return runInInjectionContext(injector, () =>\n inject(token, injectOptions as InjectOptions),\n )\n }\n}\n\nfunction createProvideFn<\n TValue,\n TFactory extends (...args: Array<any>) => any = (\n ...args: Array<any>\n ) => TValue,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n>(\n token: InjectionToken<TValue>,\n factory: (...args: Array<any>) => TValue,\n opts: CreateProvideFnOptions<TFactory, TFactoryDeps> = {},\n) {\n const { deps = [], multi = false, extraProviders = [] } = opts\n return (value?: TValue | (() => TValue), isFunctionValue = false) => {\n let provider: Provider\n if (typeof value !== 'undefined') {\n // eslint-disable-next-line no-shadow\n const factory =\n typeof value === 'function'\n ? isFunctionValue\n ? () => value\n : value\n : () => value\n\n provider = {\n provide: token,\n useFactory: factory,\n multi,\n }\n } else {\n provider = {\n provide: token,\n useFactory: factory,\n deps: deps as FactoryProvider['deps'],\n multi,\n }\n }\n\n return [extraProviders, provider]\n }\n}\n\nexport function createNoopInjectionToken<\n TValue,\n TMulti extends boolean = false,\n TOptions = Pick<\n CreateInjectionTokenOptions<() => void, []>,\n 'extraProviders'\n > &\n (TMulti extends true ? { multi: true } : Record<string, never>),\n>(description: string, options?: TOptions) {\n type TReturn = TMulti extends true ? Array<TValue> : TValue\n\n const token =\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n (options as CreateInjectionTokenOptions<() => void, []>)?.token ||\n new InjectionToken<TReturn>(description)\n return [\n createInjectFn(token) as CreateInjectionTokenReturn<TReturn, true>[0],\n createProvideFn(\n token,\n () => null!,\n (options || {}) as CreateProvideFnOptions<() => void, []>,\n ) as CreateInjectionTokenReturn<TReturn, true>[1],\n token,\n () => {},\n ] as CreateInjectionTokenReturn<TReturn, true>\n}\n","import { createNoopInjectionToken } from './util/create-injection-token/create-injection-token'\nimport type { QueryClient } from '@tanstack/query-core'\n\nconst [injectQueryClient, provideQueryClient, QUERY_CLIENT] =\n createNoopInjectionToken<QueryClient>('QueryClientToken')\n\nexport { injectQueryClient, provideQueryClient, QUERY_CLIENT }\n","import { InfiniteQueryObserver } from '@tanstack/query-core'\nimport { createBaseQuery } from './create-base-query'\nimport { injectQueryClient } from './inject-query-client'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport type { Injector } from '@angular/core'\nimport type {\n DefaultError,\n InfiniteData,\n QueryClient,\n QueryKey,\n QueryObserver,\n} from '@tanstack/query-core'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n DefinedCreateInfiniteQueryResult,\n} from './types'\nimport type {\n DefinedInitialDataInfiniteOptions,\n UndefinedInitialDataInfiniteOptions,\n} from './infinite-query-options'\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): CreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): DefinedCreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): CreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery(\n options: (client: QueryClient) => CreateInfiniteQueryOptions,\n injector?: Injector,\n) {\n return assertInjector(injectInfiniteQuery, injector, () => {\n const queryClient = injectQueryClient()\n return createBaseQuery(\n options,\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n )\n })\n}\n","import { DestroyRef, inject, signal } from '@angular/core'\nimport { type QueryFilters, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\n\nexport function injectIsFetching(\n filters?: QueryFilters,\n injector?: Injector,\n): Signal<number> {\n return assertInjector(injectIsFetching, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const cache = queryClient.getQueryCache()\n // isFetching is the prev value initialized on mount *\n let isFetching = queryClient.isFetching(filters)\n\n const result = signal(isFetching)\n\n const unsubscribe = cache.subscribe(\n notifyManager.batchCalls(() => {\n const newIsFetching = queryClient.isFetching(filters)\n if (isFetching !== newIsFetching) {\n // * and update with each change\n isFetching = newIsFetching\n result.set(isFetching)\n }\n }),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { DestroyRef, inject, signal } from '@angular/core'\nimport { type MutationFilters, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\n\nexport function injectIsMutating(\n filters?: MutationFilters,\n injector?: Injector,\n): Signal<number> {\n return assertInjector(injectIsMutating, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const cache = queryClient.getMutationCache()\n // isMutating is the prev value initialized on mount *\n let isMutating = queryClient.isMutating(filters)\n\n const result = signal(isMutating)\n\n const unsubscribe = cache.subscribe(\n notifyManager.batchCalls(() => {\n const newIsMutating = queryClient.isMutating(filters)\n if (isMutating !== newIsMutating) {\n // * and update with each change\n isMutating = newIsMutating\n result.set(isMutating)\n }\n }),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { DestroyRef, computed, effect, inject, signal } from '@angular/core'\nimport { MutationObserver, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { signalProxy } from './signal-proxy'\nimport { injectQueryClient } from './inject-query-client'\nimport type { DefaultError, QueryClient } from '@tanstack/query-core'\nimport type { Injector } from '@angular/core'\n\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\n\nexport function injectMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: (\n client: QueryClient,\n ) => CreateMutationOptions<TData, TError, TVariables, TContext>,\n injector?: Injector,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n return assertInjector(injectMutation, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n queryClient,\n options(queryClient),\n )\n const mutate: CreateMutateFunction<TData, TError, TVariables, TContext> = (\n variables,\n mutateOptions,\n ) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n }\n\n effect(() => {\n observer.setOptions(options(queryClient))\n })\n\n const result = signal(observer.getCurrentResult())\n\n const unsubscribe = observer.subscribe(\n notifyManager.batchCalls((val) => result.set(val)),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n const resultSignal = computed(() => ({\n ...result(),\n mutate,\n mutateAsync: result().mutate,\n }))\n\n return signalProxy(resultSignal) as unknown as CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext\n >\n })\n}\n\nfunction noop() {}\n","import { QueriesObserver, notifyManager } from '@tanstack/query-core'\nimport { DestroyRef, computed, effect, inject, signal } from '@angular/core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\nimport type {\n DefaultError,\n QueriesObserverOptions,\n QueriesPlaceholderDataFunction,\n QueryFunction,\n QueryKey,\n QueryObserverOptions,\n QueryObserverResult,\n ThrowOnError,\n} from '@tanstack/query-core'\n\n// This defines the `CreateQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype QueryObserverOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n QueryObserverOptions<TQueryFnData, TError, TData, TQueryFnData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? QueryObserverOptionsForCreateQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TData,\n TQueryKey\n >\n : T extends {\n queryFn?: QueryFunction<\n infer TQueryFnData,\n infer TQueryKey\n >\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TQueryFnData,\n TQueryKey\n >\n : // Fallback\n QueryObserverOptionsForCreateQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? QueryObserverResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? QueryObserverResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? QueryObserverResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? QueryObserverResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? QueryObserverResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? QueryObserverResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverResult<\n TData,\n unknown extends TError ? DefaultError : TError\n >\n : T extends {\n queryFn?: QueryFunction<infer TQueryFnData, any>\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverResult<\n TQueryFnData,\n unknown extends TError ? DefaultError : TError\n >\n : // Fallback\n QueryObserverResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends Array<any>,\n TResult extends Array<any> = [],\n TDepth extends ReadonlyArray<number> = [],\n> = TDepth['length'] extends MAXIMUM_DEPTH\n ? Array<QueryObserverOptionsForCreateQueries>\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...TResult, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<\n [...Tail],\n [...TResult, GetOptions<Head>],\n [...TDepth, 1]\n >\n : Array<unknown> extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends Array<\n QueryObserverOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >\n >\n ? Array<\n QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TData,\n TQueryKey\n >\n >\n : // Fallback\n Array<QueryObserverOptionsForCreateQueries>\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends Array<any>,\n TResult extends Array<any> = [],\n TDepth extends ReadonlyArray<number> = [],\n> = TDepth['length'] extends MAXIMUM_DEPTH\n ? Array<QueryObserverResult>\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...TResult, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<\n [...Tail],\n [...TResult, GetResults<Head>],\n [...TDepth, 1]\n >\n : T extends Array<\n QueryObserverOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >\n >\n ? // Dynamic-size (homogenous) CreateQueryOptions array: map directly to array of results\n Array<\n QueryObserverResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >\n >\n : // Fallback\n Array<QueryObserverResult>\n\nexport function injectQueries<\n T extends Array<any>,\n TCombinedResult = QueriesResults<T>,\n>(\n {\n queries,\n ...options\n }: {\n queries: Signal<[...QueriesOptions<T>]>\n combine?: (result: QueriesResults<T>) => TCombinedResult\n },\n injector?: Injector,\n): Signal<TCombinedResult> {\n return assertInjector(injectQueries, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const defaultedQueries = computed(() => {\n return queries().map((opts) => {\n const defaultedOptions = queryClient.defaultQueryOptions(opts)\n // Make sure the results are already in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = 'optimistic'\n\n return defaultedOptions\n })\n })\n\n const observer = new QueriesObserver<TCombinedResult>(\n queryClient,\n defaultedQueries(),\n options as QueriesObserverOptions<TCombinedResult>,\n )\n\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n effect(() => {\n observer.setQueries(\n defaultedQueries(),\n options as QueriesObserverOptions<TCombinedResult>,\n { listeners: false },\n )\n })\n\n const [, getCombinedResult] = observer.getOptimisticResult(\n defaultedQueries(),\n (options as QueriesObserverOptions<TCombinedResult>).combine,\n )\n\n const result = signal(getCombinedResult() as any)\n\n const unsubscribe = observer.subscribe(notifyManager.batchCalls(result.set))\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { QueryObserver } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport { createBaseQuery } from './create-base-query'\nimport type { DefaultError, QueryClient, QueryKey } from '@tanstack/query-core'\nimport type { Injector } from '@angular/core'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n} from './types'\nimport type {\n DefinedInitialDataOptions,\n UndefinedInitialDataOptions,\n} from './query-options'\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): CreateQueryResult<TData, TError>\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): DefinedCreateQueryResult<TData, TError>\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): CreateQueryResult<TData, TError>\n\nexport function injectQuery(\n options: (client: QueryClient) => CreateQueryOptions,\n injector?: Injector,\n) {\n return assertInjector(injectQuery, injector, () => {\n const queryClient = injectQueryClient()\n return createBaseQuery(options, QueryObserver, queryClient)\n })\n}\n","import {\n DestroyRef,\n ENVIRONMENT_INITIALIZER,\n inject,\n makeEnvironmentProviders,\n} from '@angular/core'\nimport { provideQueryClient } from './inject-query-client'\nimport type { EnvironmentProviders } from '@angular/core'\nimport type { QueryClient } from '@tanstack/query-core'\n\nexport function provideAngularQuery(\n queryClient: QueryClient,\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 ])\n}\n","/* istanbul ignore file */\n\n// Re-export core\nexport * from '@tanstack/query-core'\n\nexport * from './types'\n\nexport type {\n DefinedInitialDataOptions,\n UndefinedInitialDataOptions,\n} from './query-options'\nexport { queryOptions } from './query-options'\n\nexport { infiniteQueryOptions } from './infinite-query-options'\n\nexport * from './inject-infinite-query'\nexport * from './inject-is-fetching'\nexport * from './inject-is-mutating'\nexport * from './inject-mutation'\nexport * from './inject-queries'\nexport * from './inject-query'\nexport {\n injectQueryClient,\n provideQueryClient,\n QUERY_CLIENT,\n} from './inject-query-client'\nexport { provideAngularQuery } from './providers'\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tanstack-angular-query-experimental.mjs","sources":["../../src/types.ts","../../src/query-options.ts","../../src/infinite-query-options.ts","../../src/signal-proxy.ts","../../src/create-base-query.ts","../../src/util/assert-injector/assert-injector.ts","../../src/util/create-injection-token/create-injection-token.ts","../../src/inject-query-client.ts","../../src/inject-infinite-query.ts","../../src/inject-is-fetching.ts","../../src/inject-is-mutating.ts","../../src/inject-mutation.ts","../../src/inject-mutation-state.ts","../../src/inject-queries.ts","../../src/inject-query.ts","../../src/providers.ts","../../src/index.ts","../../src/tanstack-angular-query-experimental.ts"],"sourcesContent":["/* istanbul ignore file */\n\nimport type {\n DefaultError,\n DefinedInfiniteQueryObserverResult,\n DefinedQueryObserverResult,\n InfiniteQueryObserverOptions,\n InfiniteQueryObserverResult,\n MutateFunction,\n MutationObserverOptions,\n MutationObserverResult,\n QueryKey,\n QueryObserverOptions,\n QueryObserverResult,\n} from '@tanstack/query-core'\nimport type { MapToSignals } from './signal-proxy'\n\nexport interface CreateBaseQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> extends QueryObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n > {}\n\nexport interface CreateQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> extends Omit<\n CreateBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey\n >,\n 'suspense'\n > {}\n\ntype CreateStatusBasedQueryResult<\n TStatus extends QueryObserverResult['status'],\n TData = unknown,\n TError = DefaultError,\n> = Extract<QueryObserverResult<TData, TError>, { status: TStatus }>\n\nexport interface BaseQueryNarrowing<TData = unknown, TError = DefaultError> {\n isSuccess: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'success', TData, TError>\n >\n isError: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'error', TData, TError>\n >\n isPending: (\n this: CreateBaseQueryResult<TData, TError>,\n ) => this is CreateBaseQueryResult<\n TData,\n TError,\n CreateStatusBasedQueryResult<'pending', TData, TError>\n >\n}\n\nexport interface CreateInfiniteQueryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> extends Omit<\n InfiniteQueryObserverOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey,\n TPageParam\n >,\n 'suspense'\n > {}\n\nexport type CreateBaseQueryResult<\n TData = unknown,\n TError = DefaultError,\n TState = QueryObserverResult<TData, TError>,\n> = BaseQueryNarrowing<TData, TError> &\n MapToSignals<Omit<TState, keyof BaseQueryNarrowing>>\n\nexport type CreateQueryResult<\n TData = unknown,\n TError = DefaultError,\n> = CreateBaseQueryResult<TData, TError>\n\nexport type DefinedCreateQueryResult<\n TData = unknown,\n TError = DefaultError,\n TDefinedQueryObserver = DefinedQueryObserverResult<TData, TError>,\n> = MapToSignals<TDefinedQueryObserver>\n\nexport type CreateInfiniteQueryResult<\n TData = unknown,\n TError = DefaultError,\n> = MapToSignals<InfiniteQueryObserverResult<TData, TError>>\n\nexport type DefinedCreateInfiniteQueryResult<\n TData = unknown,\n TError = DefaultError,\n TDefinedInfiniteQueryObserver = DefinedInfiniteQueryObserverResult<\n TData,\n TError\n >,\n> = MapToSignals<TDefinedInfiniteQueryObserver>\n\nexport interface CreateMutationOptions<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> extends Omit<\n MutationObserverOptions<TData, TError, TVariables, TContext>,\n '_defaulted'\n > {}\n\nexport type CreateMutateFunction<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> = (\n ...args: Parameters<MutateFunction<TData, TError, TVariables, TContext>>\n) => void\n\nexport type CreateMutateAsyncFunction<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n> = MutateFunction<TData, TError, TVariables, TContext>\n\nexport type CreateBaseMutationResult<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> = Override<\n MutationObserverResult<TData, TError, TVariables, TContext>,\n { mutate: CreateMutateFunction<TData, TError, TVariables, TContext> }\n> & {\n mutateAsync: CreateMutateAsyncFunction<TData, TError, TVariables, TContext>\n}\n\ntype CreateStatusBasedMutationResult<\n TStatus extends CreateBaseMutationResult['status'],\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> = Extract<\n CreateBaseMutationResult<TData, TError, TVariables, TContext>,\n { status: TStatus }\n>\n\nexport interface BaseMutationNarrowing<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n> {\n isSuccess: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'success',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isError: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'error',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isPending: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<\n 'pending',\n TData,\n TError,\n TVariables,\n TContext\n >\n >\n isIdle: (\n this: CreateMutationResult<TData, TError, TVariables, TContext>,\n ) => this is CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext,\n CreateStatusBasedMutationResult<'idle', TData, TError, TVariables, TContext>\n >\n}\n\nexport type CreateMutationResult<\n TData = unknown,\n TError = DefaultError,\n TVariables = unknown,\n TContext = unknown,\n TState = CreateStatusBasedMutationResult<\n CreateBaseMutationResult['status'],\n TData,\n TError,\n TVariables,\n TContext\n >,\n> = BaseMutationNarrowing<TData, TError, TVariables, TContext> &\n MapToSignals<Omit<TState, keyof BaseMutationNarrowing>>\n\ntype Override<TTargetA, TTargetB> = {\n [AKey in keyof TTargetA]: AKey extends keyof TTargetB\n ? TTargetB[AKey]\n : TTargetA[AKey]\n}\n","import type { DataTag, DefaultError, QueryKey } from '@tanstack/query-core'\nimport type { CreateQueryOptions } from './types'\n\nexport type UndefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData?: undefined\n}\n\ntype NonUndefinedGuard<T> = T extends undefined ? never : T\n\nexport type DefinedInitialDataOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey> & {\n initialData:\n | NonUndefinedGuard<TQueryFnData>\n | (() => NonUndefinedGuard<TQueryFnData>)\n}\n\nexport function queryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n): UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey> & {\n queryKey: DataTag<TQueryKey, TQueryFnData>\n}\n\nexport function queryOptions<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n): DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey> & {\n queryKey: DataTag<TQueryKey, TQueryFnData>\n}\n\nexport function queryOptions(options: unknown) {\n return options\n}\n","import type { DataTag } from '@tanstack/query-core'\nimport type { InfiniteData } from '@tanstack/query-core'\nimport type { CreateInfiniteQueryOptions } from './types'\nimport type { DefaultError, QueryKey } from '@tanstack/query-core'\n\nexport type UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> = CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n> & {\n initialData?: undefined\n}\n\ntype NonUndefinedGuard<T> = T extends undefined ? never : T\n\nexport type DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n> = CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n> & {\n initialData:\n | NonUndefinedGuard<InfiniteData<TQueryFnData, TPageParam>>\n | (() => NonUndefinedGuard<InfiniteData<TQueryFnData, TPageParam>>)\n}\n\nexport function infiniteQueryOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n): UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n> & {\n queryKey: DataTag<TQueryKey, InfiniteData<TQueryFnData>>\n}\n\nexport function infiniteQueryOptions<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n): DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n> & {\n queryKey: DataTag<TQueryKey, InfiniteData<TQueryFnData>>\n}\n\nexport function infiniteQueryOptions(options: unknown) {\n return options\n}\n","import { computed, untracked } from '@angular/core'\nimport type { Signal } from '@angular/core'\n\nexport type MapToSignals<T> = {\n [K in keyof T]: T[K] extends Function ? T[K] : Signal<T[K]>\n}\n\n/**\n * Exposes fields of an object passed via an Angular `Signal` as `Computed` signals.\n *\n * Functions on the object are passed through as-is.\n *\n * @param inputSignal - `Signal` that must return an object.\n *\n */\nexport function signalProxy<TInput extends Record<string | symbol, any>>(\n inputSignal: Signal<TInput>,\n) {\n const internalState = {} as MapToSignals<TInput>\n\n return new Proxy<MapToSignals<TInput>>(internalState, {\n get(target, prop) {\n // first check if we have it in our internal state and return it\n const computedField = target[prop]\n if (computedField) return computedField\n\n // then, check if it's a function on the resultState and return it\n const targetField = untracked(inputSignal)[prop]\n if (typeof targetField === 'function') return targetField\n\n // finally, create a computed field, store it and return it\n // @ts-expect-error\n return (target[prop] = computed(() => inputSignal()[prop]))\n },\n has(_, prop) {\n return !!untracked(inputSignal)[prop]\n },\n ownKeys() {\n return Reflect.ownKeys(untracked(inputSignal))\n },\n getOwnPropertyDescriptor() {\n return {\n enumerable: true,\n configurable: true,\n }\n },\n })\n}\n","import {\n DestroyRef,\n assertInInjectionContext,\n computed,\n effect,\n inject,\n signal,\n untracked,\n} from '@angular/core'\nimport { notifyManager } from '@tanstack/query-core'\nimport { signalProxy } from './signal-proxy'\nimport type { QueryClient, QueryKey, QueryObserver } from '@tanstack/query-core'\nimport type { CreateBaseQueryOptions, CreateBaseQueryResult } from './types'\n\n/**\n * Base implementation for `injectQuery` and `injectInfiniteQuery`.\n */\nexport function createBaseQuery<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey extends QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => CreateBaseQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >,\n Observer: typeof QueryObserver,\n queryClient: QueryClient,\n): CreateBaseQueryResult<TData, TError> {\n assertInInjectionContext(createBaseQuery)\n const destroyRef = inject(DestroyRef)\n\n /**\n * Signal that has the default options from query client applied\n * computed() is used so signals can be inserted into the options\n * making it reactive. Wrapping options in a function ensures embedded expressions\n * are preserved and can keep being applied after signal changes\n */\n const defaultedOptionsSignal = computed(() => {\n const defaultedOptions = queryClient.defaultQueryOptions(\n options(queryClient),\n )\n defaultedOptions._optimisticResults = 'optimistic'\n return defaultedOptions\n })\n\n const observer = new Observer<\n TQueryFnData,\n TError,\n TData,\n TQueryData,\n TQueryKey\n >(queryClient, defaultedOptionsSignal())\n\n const resultSignal = signal(\n observer.getOptimisticResult(defaultedOptionsSignal()),\n )\n\n effect(() => {\n const defaultedOptions = defaultedOptionsSignal()\n observer.setOptions(defaultedOptions, {\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n listeners: false,\n })\n untracked(() =>\n // Set the signal in effect because it's both 'computed' from options()\n // and needs to be set imperatively in the query observer listener.\n resultSignal.set(observer.getOptimisticResult(defaultedOptions)),\n )\n })\n\n // observer.trackResult is not used as this optimization is not needed for Angular\n const unsubscribe = observer.subscribe(\n notifyManager.batchCalls((val) => resultSignal.set(val)),\n )\n destroyRef.onDestroy(unsubscribe)\n\n return signalProxy(resultSignal) as CreateBaseQueryResult<TData, TError>\n}\n","/* eslint-disable @cspell/spellchecker */\n/**\n * The code in this file is adapted from NG Extension Platform at https://ngxtension.netlify.app.\n *\n * Original Author: Chau Tran\n *\n * NG Extension Platform is an open-source project licensed under the MIT license.\n *\n * For more information about the original code, see\n * https://github.com/nartc/ngxtension-platform\n */\n/* eslint-enable */\n\nimport {\n Injector,\n assertInInjectionContext,\n inject,\n runInInjectionContext,\n} from '@angular/core'\n\n/**\n * `assertInjector` extends `assertInInjectionContext` with an optional `Injector`\n * After assertion, `assertInjector` runs the `runner` function with the guaranteed `Injector`\n * whether it is the default `Injector` within the current **Injection Context**\n * or the custom `Injector` that was passed in.\n *\n * @template {() => any} Runner - Runner is a function that can return anything\n * @param {Function} fn - the Function to pass in `assertInInjectionContext`\n * @param {Injector | undefined | null} injector - the optional \"custom\" Injector\n * @param {Runner} runner - the runner fn\n * @returns {ReturnType<Runner>} result - returns the result of the Runner\n *\n * @example\n * ```ts\n * function injectValue(injector?: Injector) {\n * return assertInjector(injectValue, injector, () => 'value');\n * }\n *\n * injectValue(); // string\n * ```\n */\nexport function assertInjector<TRunner extends () => any>(\n fn: Function,\n injector: Injector | undefined | null,\n runner: TRunner,\n): ReturnType<TRunner>\n/**\n * `assertInjector` extends `assertInInjectionContext` with an optional `Injector`\n * After assertion, `assertInjector` returns a guaranteed `Injector` whether it is the default `Injector`\n * within the current **Injection Context** or the custom `Injector` that was passed in.\n *\n * @param {Function} fn - the Function to pass in `assertInInjectionContext`\n * @param {Injector | undefined | null} injector - the optional \"custom\" Injector\n * @returns Injector\n *\n * @example\n * ```ts\n * function injectDestroy(injector?: Injector) {\n * injector = assertInjector(injectDestroy, injector);\n *\n * return runInInjectionContext(injector, () => {\n * // code\n * })\n * }\n * ```\n */\nexport function assertInjector(\n fn: Function,\n injector: Injector | undefined | null,\n): Injector\nexport function assertInjector(\n fn: Function,\n injector: Injector | undefined | null,\n runner?: () => any,\n) {\n !injector && assertInInjectionContext(fn)\n const assertedInjector = injector ?? inject(Injector)\n\n if (!runner) return assertedInjector\n return runInInjectionContext(assertedInjector, runner)\n}\n","/* eslint-disable @cspell/spellchecker */\n/**\n * The code in this file is adapted from NG Extension Platform at https://ngxtension.netlify.app.\n *\n * Original Author: Chau Tran\n *\n * NG Extension Platform is an open-source project licensed under the MIT license.\n *\n * For more information about the original code, see\n * https://github.com/nartc/ngxtension-platform\n */\n/* eslint-enable */\n\nimport {\n type EnvironmentProviders,\n type FactoryProvider,\n type Host,\n type InjectOptions,\n InjectionToken,\n type Injector,\n type Optional,\n type Provider,\n type Self,\n type SkipSelf,\n type Type,\n inject,\n runInInjectionContext,\n} from '@angular/core'\nimport { assertInjector } from '../assert-injector/assert-injector'\n\ntype CreateInjectionTokenDep<TTokenType> =\n | Type<TTokenType>\n // NOTE: we don't have an AbstractType\n | (abstract new (...args: Array<any>) => TTokenType)\n | InjectionToken<TTokenType>\n\ntype CreateInjectionTokenDeps<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> = {\n [Index in keyof TFactoryDeps]:\n | CreateInjectionTokenDep<TFactoryDeps[Index]>\n | [\n ...modifiers: Array<Optional | Self | SkipSelf | Host>,\n token: CreateInjectionTokenDep<TFactoryDeps[Index]>,\n ]\n} & { length: TFactoryDeps['length'] }\n\ntype CreateInjectionTokenOptions<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> =\n // this means TFunction has no parameters\n (TFactoryDeps[0] extends undefined\n ? { deps?: never }\n : { deps: CreateInjectionTokenDeps<TFactory, TFactoryDeps> }) & {\n isRoot?: boolean\n multi?: boolean\n token?: InjectionToken<ReturnType<TFactory>>\n extraProviders?: Provider | EnvironmentProviders\n }\n\ntype CreateProvideFnOptions<\n TFactory extends (...args: Array<any>) => any,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n> = Pick<\n CreateInjectionTokenOptions<TFactory, TFactoryDeps>,\n 'deps' | 'extraProviders' | 'multi'\n>\n\ntype InjectFn<TFactoryReturn> = {\n (): TFactoryReturn\n (\n injectOptions: InjectOptions & { optional?: false } & {\n injector?: Injector\n },\n ): TFactoryReturn\n (\n injectOptions: InjectOptions & { injector?: Injector },\n ): TFactoryReturn | null\n}\n\ntype ProvideFn<\n TNoop extends boolean,\n TFactoryReturn,\n TReturn = TFactoryReturn extends Array<infer Item> ? Item : TFactoryReturn,\n> = (TNoop extends true\n ? (value: TReturn | (() => TReturn)) => Provider\n : () => Provider) &\n (TReturn extends Function\n ? (value: TReturn | (() => TReturn), isFunctionValue: boolean) => Provider\n : (value: TReturn | (() => TReturn)) => Provider)\n\ntype CreateInjectionTokenReturn<\n TFactoryReturn,\n TNoop extends boolean = false,\n> = [\n InjectFn<TFactoryReturn>,\n ProvideFn<TNoop, TFactoryReturn>,\n InjectionToken<TFactoryReturn>,\n () => Provider,\n]\n\nfunction createInjectFn<TValue>(token: InjectionToken<TValue>) {\n return function (\n this: Function,\n {\n injector,\n ...injectOptions\n }: InjectOptions & { injector?: Injector } = {},\n ) {\n injector = assertInjector(this, injector)\n return runInInjectionContext(injector, () =>\n inject(token, injectOptions as InjectOptions),\n )\n }\n}\n\nfunction createProvideFn<\n TValue,\n TFactory extends (...args: Array<any>) => any = (\n ...args: Array<any>\n ) => TValue,\n TFactoryDeps extends Parameters<TFactory> = Parameters<TFactory>,\n>(\n token: InjectionToken<TValue>,\n factory: (...args: Array<any>) => TValue,\n opts: CreateProvideFnOptions<TFactory, TFactoryDeps> = {},\n) {\n const { deps = [], multi = false, extraProviders = [] } = opts\n return (value?: TValue | (() => TValue), isFunctionValue = false) => {\n let provider: Provider\n if (typeof value !== 'undefined') {\n // eslint-disable-next-line no-shadow\n const factory =\n typeof value === 'function'\n ? isFunctionValue\n ? () => value\n : value\n : () => value\n\n provider = {\n provide: token,\n useFactory: factory,\n multi,\n }\n } else {\n provider = {\n provide: token,\n useFactory: factory,\n deps: deps as FactoryProvider['deps'],\n multi,\n }\n }\n\n return [extraProviders, provider]\n }\n}\n\nexport function createNoopInjectionToken<\n TValue,\n TMulti extends boolean = false,\n TOptions = Pick<\n CreateInjectionTokenOptions<() => void, []>,\n 'extraProviders'\n > &\n (TMulti extends true ? { multi: true } : Record<string, never>),\n>(description: string, options?: TOptions) {\n type TReturn = TMulti extends true ? Array<TValue> : TValue\n\n const token =\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n (options as CreateInjectionTokenOptions<() => void, []>)?.token ||\n new InjectionToken<TReturn>(description)\n return [\n createInjectFn(token) as CreateInjectionTokenReturn<TReturn, true>[0],\n createProvideFn(\n token,\n () => null!,\n (options || {}) as CreateProvideFnOptions<() => void, []>,\n ) as CreateInjectionTokenReturn<TReturn, true>[1],\n token,\n () => {},\n ] as CreateInjectionTokenReturn<TReturn, true>\n}\n","import { createNoopInjectionToken } from './util/create-injection-token/create-injection-token'\nimport type { QueryClient } from '@tanstack/query-core'\n\nconst [injectQueryClient, provideQueryClient, QUERY_CLIENT] =\n createNoopInjectionToken<QueryClient>('QueryClientToken')\n\nexport { injectQueryClient, provideQueryClient, QUERY_CLIENT }\n","import { InfiniteQueryObserver } from '@tanstack/query-core'\nimport { createBaseQuery } from './create-base-query'\nimport { injectQueryClient } from './inject-query-client'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport type { Injector } from '@angular/core'\nimport type {\n DefaultError,\n InfiniteData,\n QueryClient,\n QueryKey,\n QueryObserver,\n} from '@tanstack/query-core'\nimport type {\n CreateInfiniteQueryOptions,\n CreateInfiniteQueryResult,\n DefinedCreateInfiniteQueryResult,\n} from './types'\nimport type {\n DefinedInitialDataInfiniteOptions,\n UndefinedInitialDataInfiniteOptions,\n} from './infinite-query-options'\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => UndefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): CreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => DefinedInitialDataInfiniteOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): DefinedCreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery<\n TQueryFnData,\n TError = DefaultError,\n TData = InfiniteData<TQueryFnData>,\n TQueryKey extends QueryKey = QueryKey,\n TPageParam = unknown,\n>(\n options: (\n client: QueryClient,\n ) => CreateInfiniteQueryOptions<\n TQueryFnData,\n TError,\n TData,\n TQueryFnData,\n TQueryKey,\n TPageParam\n >,\n injector?: Injector,\n): CreateInfiniteQueryResult<TData, TError>\n\nexport function injectInfiniteQuery(\n options: (client: QueryClient) => CreateInfiniteQueryOptions,\n injector?: Injector,\n) {\n return assertInjector(injectInfiniteQuery, injector, () => {\n const queryClient = injectQueryClient()\n return createBaseQuery(\n options,\n InfiniteQueryObserver as typeof QueryObserver,\n queryClient,\n )\n })\n}\n","import { DestroyRef, inject, signal } from '@angular/core'\nimport { type QueryFilters, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\n\nexport function injectIsFetching(\n filters?: QueryFilters,\n injector?: Injector,\n): Signal<number> {\n return assertInjector(injectIsFetching, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const cache = queryClient.getQueryCache()\n // isFetching is the prev value initialized on mount *\n let isFetching = queryClient.isFetching(filters)\n\n const result = signal(isFetching)\n\n const unsubscribe = cache.subscribe(\n notifyManager.batchCalls(() => {\n const newIsFetching = queryClient.isFetching(filters)\n if (isFetching !== newIsFetching) {\n // * and update with each change\n isFetching = newIsFetching\n result.set(isFetching)\n }\n }),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { DestroyRef, inject, signal } from '@angular/core'\nimport { type MutationFilters, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\n\nexport function injectIsMutating(\n filters?: MutationFilters,\n injector?: Injector,\n): Signal<number> {\n return assertInjector(injectIsMutating, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const cache = queryClient.getMutationCache()\n // isMutating is the prev value initialized on mount *\n let isMutating = queryClient.isMutating(filters)\n\n const result = signal(isMutating)\n\n const unsubscribe = cache.subscribe(\n notifyManager.batchCalls(() => {\n const newIsMutating = queryClient.isMutating(filters)\n if (isMutating !== newIsMutating) {\n // * and update with each change\n isMutating = newIsMutating\n result.set(isMutating)\n }\n }),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { DestroyRef, computed, effect, inject, signal } from '@angular/core'\nimport { MutationObserver, notifyManager } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { signalProxy } from './signal-proxy'\nimport { injectQueryClient } from './inject-query-client'\nimport type { DefaultError, QueryClient } from '@tanstack/query-core'\nimport type { Injector } from '@angular/core'\n\nimport type {\n CreateMutateFunction,\n CreateMutationOptions,\n CreateMutationResult,\n} from './types'\n\nexport function injectMutation<\n TData = unknown,\n TError = DefaultError,\n TVariables = void,\n TContext = unknown,\n>(\n options: (\n client: QueryClient,\n ) => CreateMutationOptions<TData, TError, TVariables, TContext>,\n injector?: Injector,\n): CreateMutationResult<TData, TError, TVariables, TContext> {\n return assertInjector(injectMutation, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const observer = new MutationObserver<TData, TError, TVariables, TContext>(\n queryClient,\n options(queryClient),\n )\n const mutate: CreateMutateFunction<TData, TError, TVariables, TContext> = (\n variables,\n mutateOptions,\n ) => {\n observer.mutate(variables, mutateOptions).catch(noop)\n }\n\n effect(() => {\n observer.setOptions(options(queryClient))\n })\n\n const result = signal(observer.getCurrentResult())\n\n const unsubscribe = observer.subscribe(\n notifyManager.batchCalls((val) => result.set(val)),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n const resultSignal = computed(() => ({\n ...result(),\n mutate,\n mutateAsync: result().mutate,\n }))\n\n return signalProxy(resultSignal) as unknown as CreateMutationResult<\n TData,\n TError,\n TVariables,\n TContext\n >\n })\n}\n\nfunction noop() {}\n","import { DestroyRef, effect, inject, signal, untracked } from '@angular/core'\nimport {\n type DefaultError,\n type Mutation,\n type MutationCache,\n type MutationFilters,\n type MutationState,\n notifyManager,\n replaceEqualDeep,\n} from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\n\ntype MutationStateOptions<TResult = MutationState> = {\n filters?: MutationFilters\n select?: (\n mutation: Mutation<unknown, DefaultError, unknown, unknown>,\n ) => TResult\n}\n\nfunction getResult<TResult = MutationState>(\n mutationCache: MutationCache,\n options: MutationStateOptions<TResult>,\n): Array<TResult> {\n return mutationCache\n .findAll(options.filters)\n .map(\n (mutation): TResult =>\n (options.select\n ? options.select(\n mutation as Mutation<unknown, DefaultError, unknown, unknown>,\n )\n : mutation.state) as TResult,\n )\n}\n\nexport interface InjectMutationStateOptions {\n injector?: Injector\n}\n\nexport function injectMutationState<TResult = MutationState>(\n mutationStateOptionsFn: () => MutationStateOptions<TResult> = () => ({}),\n options?: InjectMutationStateOptions,\n): Signal<Array<TResult>> {\n return assertInjector(injectMutationState, options?.injector, () => {\n const destroyRef = inject(DestroyRef)\n const queryClient = injectQueryClient()\n\n const mutationCache = queryClient.getMutationCache()\n\n const result = signal<Array<TResult>>(\n getResult(mutationCache, mutationStateOptionsFn()),\n )\n\n effect(() => {\n const mutationStateOptions = mutationStateOptionsFn()\n untracked(() => {\n // Setting the signal from an effect because it's both 'computed' from options()\n // and needs to be set imperatively in the mutationCache listener.\n result.set(getResult(mutationCache, mutationStateOptions))\n })\n })\n\n const unsubscribe = mutationCache.subscribe(\n notifyManager.batchCalls(() => {\n const nextResult = replaceEqualDeep(\n result(),\n getResult(mutationCache, mutationStateOptionsFn()),\n )\n if (result() !== nextResult) {\n result.set(nextResult)\n }\n }),\n )\n\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { QueriesObserver, notifyManager } from '@tanstack/query-core'\nimport { DestroyRef, computed, effect, inject, signal } from '@angular/core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport type { Injector, Signal } from '@angular/core'\nimport type {\n DefaultError,\n QueriesObserverOptions,\n QueriesPlaceholderDataFunction,\n QueryFunction,\n QueryKey,\n QueryObserverOptions,\n QueryObserverResult,\n ThrowOnError,\n} from '@tanstack/query-core'\n\n// This defines the `CreateQueryOptions` that are accepted in `QueriesOptions` & `GetOptions`.\n// `placeholderData` function does not have a parameter\ntype QueryObserverOptionsForCreateQueries<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n> = Omit<\n QueryObserverOptions<TQueryFnData, TError, TData, TQueryFnData, TQueryKey>,\n 'placeholderData'\n> & {\n placeholderData?: TQueryFnData | QueriesPlaceholderDataFunction<TQueryFnData>\n}\n\n// Avoid TS depth-limit error in case of large array literal\ntype MAXIMUM_DEPTH = 20\n\ntype GetOptions<T> =\n // Part 1: responsible for applying explicit type parameter to function arguments, if object { queryFnData: TQueryFnData, error: TError, data: TData }\n T extends {\n queryFnData: infer TQueryFnData\n error?: infer TError\n data: infer TData\n }\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? QueryObserverOptionsForCreateQueries<unknown, TError, TData>\n : // Part 2: responsible for applying explicit type parameter to function arguments, if tuple [TQueryFnData, TError, TData]\n T extends [infer TQueryFnData, infer TError, infer TData]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError, TData>\n : T extends [infer TQueryFnData, infer TError]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? QueryObserverOptionsForCreateQueries<TQueryFnData>\n : // Part 3: responsible for inferring and enforcing type if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<infer TQueryFnData, infer TQueryKey>\n select: (data: any) => infer TData\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TData,\n TQueryKey\n >\n : T extends {\n queryFn?: QueryFunction<\n infer TQueryFnData,\n infer TQueryKey\n >\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TQueryFnData,\n TQueryKey\n >\n : // Fallback\n QueryObserverOptionsForCreateQueries\n\ntype GetResults<T> =\n // Part 1: responsible for mapping explicit type parameter to function result, if object\n T extends { queryFnData: any; error?: infer TError; data: infer TData }\n ? QueryObserverResult<TData, TError>\n : T extends { queryFnData: infer TQueryFnData; error?: infer TError }\n ? QueryObserverResult<TQueryFnData, TError>\n : T extends { data: infer TData; error?: infer TError }\n ? QueryObserverResult<TData, TError>\n : // Part 2: responsible for mapping explicit type parameter to function result, if tuple\n T extends [any, infer TError, infer TData]\n ? QueryObserverResult<TData, TError>\n : T extends [infer TQueryFnData, infer TError]\n ? QueryObserverResult<TQueryFnData, TError>\n : T extends [infer TQueryFnData]\n ? QueryObserverResult<TQueryFnData>\n : // Part 3: responsible for mapping inferred type to results, if no explicit parameter was provided\n T extends {\n queryFn?: QueryFunction<unknown, any>\n select: (data: any) => infer TData\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverResult<\n TData,\n unknown extends TError ? DefaultError : TError\n >\n : T extends {\n queryFn?: QueryFunction<infer TQueryFnData, any>\n throwOnError?: ThrowOnError<any, infer TError, any, any>\n }\n ? QueryObserverResult<\n TQueryFnData,\n unknown extends TError ? DefaultError : TError\n >\n : // Fallback\n QueryObserverResult\n\n/**\n * QueriesOptions reducer recursively unwraps function arguments to infer/enforce type param\n */\nexport type QueriesOptions<\n T extends Array<any>,\n TResult extends Array<any> = [],\n TDepth extends ReadonlyArray<number> = [],\n> = TDepth['length'] extends MAXIMUM_DEPTH\n ? Array<QueryObserverOptionsForCreateQueries>\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...TResult, GetOptions<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesOptions<\n [...Tail],\n [...TResult, GetOptions<Head>],\n [...TDepth, 1]\n >\n : Array<unknown> extends T\n ? T\n : // If T is *some* array but we couldn't assign unknown[] to it, then it must hold some known/homogenous type!\n // use this to infer the param types in the case of Array.map() argument\n T extends Array<\n QueryObserverOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n infer TQueryKey\n >\n >\n ? Array<\n QueryObserverOptionsForCreateQueries<\n TQueryFnData,\n TError,\n TData,\n TQueryKey\n >\n >\n : // Fallback\n Array<QueryObserverOptionsForCreateQueries>\n\n/**\n * QueriesResults reducer recursively maps type param to results\n */\nexport type QueriesResults<\n T extends Array<any>,\n TResult extends Array<any> = [],\n TDepth extends ReadonlyArray<number> = [],\n> = TDepth['length'] extends MAXIMUM_DEPTH\n ? Array<QueryObserverResult>\n : T extends []\n ? []\n : T extends [infer Head]\n ? [...TResult, GetResults<Head>]\n : T extends [infer Head, ...infer Tail]\n ? QueriesResults<\n [...Tail],\n [...TResult, GetResults<Head>],\n [...TDepth, 1]\n >\n : T extends Array<\n QueryObserverOptionsForCreateQueries<\n infer TQueryFnData,\n infer TError,\n infer TData,\n any\n >\n >\n ? // Dynamic-size (homogenous) CreateQueryOptions array: map directly to array of results\n Array<\n QueryObserverResult<\n unknown extends TData ? TQueryFnData : TData,\n unknown extends TError ? DefaultError : TError\n >\n >\n : // Fallback\n Array<QueryObserverResult>\n\nexport function injectQueries<\n T extends Array<any>,\n TCombinedResult = QueriesResults<T>,\n>(\n {\n queries,\n ...options\n }: {\n queries: Signal<[...QueriesOptions<T>]>\n combine?: (result: QueriesResults<T>) => TCombinedResult\n },\n injector?: Injector,\n): Signal<TCombinedResult> {\n return assertInjector(injectQueries, injector, () => {\n const queryClient = injectQueryClient()\n const destroyRef = inject(DestroyRef)\n\n const defaultedQueries = computed(() => {\n return queries().map((opts) => {\n const defaultedOptions = queryClient.defaultQueryOptions(opts)\n // Make sure the results are already in fetching state before subscribing or updating options\n defaultedOptions._optimisticResults = 'optimistic'\n\n return defaultedOptions\n })\n })\n\n const observer = new QueriesObserver<TCombinedResult>(\n queryClient,\n defaultedQueries(),\n options as QueriesObserverOptions<TCombinedResult>,\n )\n\n // Do not notify on updates because of changes in the options because\n // these changes should already be reflected in the optimistic result.\n effect(() => {\n observer.setQueries(\n defaultedQueries(),\n options as QueriesObserverOptions<TCombinedResult>,\n { listeners: false },\n )\n })\n\n const [, getCombinedResult] = observer.getOptimisticResult(\n defaultedQueries(),\n (options as QueriesObserverOptions<TCombinedResult>).combine,\n )\n\n const result = signal(getCombinedResult() as any)\n\n const unsubscribe = observer.subscribe(notifyManager.batchCalls(result.set))\n destroyRef.onDestroy(unsubscribe)\n\n return result\n })\n}\n","import { QueryObserver } from '@tanstack/query-core'\nimport { assertInjector } from './util/assert-injector/assert-injector'\nimport { injectQueryClient } from './inject-query-client'\nimport { createBaseQuery } from './create-base-query'\nimport type { DefaultError, QueryClient, QueryKey } from '@tanstack/query-core'\nimport type { Injector } from '@angular/core'\nimport type {\n CreateQueryOptions,\n CreateQueryResult,\n DefinedCreateQueryResult,\n} from './types'\nimport type {\n DefinedInitialDataOptions,\n UndefinedInitialDataOptions,\n} from './query-options'\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => UndefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): CreateQueryResult<TData, TError>\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => DefinedInitialDataOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): DefinedCreateQueryResult<TData, TError>\n\nexport function injectQuery<\n TQueryFnData = unknown,\n TError = DefaultError,\n TData = TQueryFnData,\n TQueryKey extends QueryKey = QueryKey,\n>(\n options: (\n client: QueryClient,\n ) => CreateQueryOptions<TQueryFnData, TError, TData, TQueryKey>,\n injector?: Injector,\n): CreateQueryResult<TData, TError>\n\nexport function injectQuery(\n options: (client: QueryClient) => CreateQueryOptions,\n injector?: Injector,\n) {\n return assertInjector(injectQuery, injector, () => {\n const queryClient = injectQueryClient()\n return createBaseQuery(options, QueryObserver, queryClient)\n })\n}\n","import {\n DestroyRef,\n ENVIRONMENT_INITIALIZER,\n inject,\n makeEnvironmentProviders,\n} from '@angular/core'\nimport { provideQueryClient } from './inject-query-client'\nimport type { EnvironmentProviders } from '@angular/core'\nimport type { QueryClient } from '@tanstack/query-core'\n\nexport function provideAngularQuery(\n queryClient: QueryClient,\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 ])\n}\n","/* istanbul ignore file */\n\n// Re-export core\nexport * from '@tanstack/query-core'\n\nexport * from './types'\n\nexport type {\n DefinedInitialDataOptions,\n UndefinedInitialDataOptions,\n} from './query-options'\nexport { queryOptions } from './query-options'\n\nexport { infiniteQueryOptions } from './infinite-query-options'\n\nexport * from './inject-infinite-query'\nexport * from './inject-is-fetching'\nexport * from './inject-is-mutating'\nexport * from './inject-mutation'\nexport * from './inject-mutation-state'\nexport * from './inject-queries'\nexport * from './inject-query'\nexport {\n injectQueryClient,\n provideQueryClient,\n QUERY_CLIENT,\n} from './inject-query-client'\nexport { provideAngularQuery } from './providers'\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/build/index.d.ts CHANGED
@@ -7,6 +7,7 @@ export * from './inject-infinite-query';
7
7
  export * from './inject-is-fetching';
8
8
  export * from './inject-is-mutating';
9
9
  export * from './inject-mutation';
10
+ export * from './inject-mutation-state';
10
11
  export * from './inject-queries';
11
12
  export * from './inject-query';
12
13
  export { injectQueryClient, provideQueryClient, QUERY_CLIENT, } from './inject-query-client';
@@ -0,0 +1,11 @@
1
+ import { type DefaultError, type Mutation, type MutationFilters, type MutationState } from '@tanstack/query-core';
2
+ import type { Injector, Signal } from '@angular/core';
3
+ type MutationStateOptions<TResult = MutationState> = {
4
+ filters?: MutationFilters;
5
+ select?: (mutation: Mutation<unknown, DefaultError, unknown, unknown>) => TResult;
6
+ };
7
+ export interface InjectMutationStateOptions {
8
+ injector?: Injector;
9
+ }
10
+ export declare function injectMutationState<TResult = MutationState>(mutationStateOptionsFn?: () => MutationStateOptions<TResult>, options?: InjectMutationStateOptions): Signal<Array<TResult>>;
11
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/angular-query-experimental",
3
- "version": "5.21.7",
3
+ "version": "5.22.0",
4
4
  "description": "Signals for managing, caching and syncing asynchronous and remote data in Angular",
5
5
  "author": "Arnoud de Vries",
6
6
  "license": "MIT",
@@ -0,0 +1,22 @@
1
+ import { describe, expectTypeOf } from 'vitest'
2
+ import { injectMutationState } from '../inject-mutation-state'
3
+ import type { MutationState, MutationStatus } from '@tanstack/query-core'
4
+
5
+ describe('injectMutationState', () => {
6
+ it('should default to QueryState', () => {
7
+ const result = injectMutationState(() => ({
8
+ filters: { status: 'pending' },
9
+ }))
10
+
11
+ expectTypeOf(result()).toEqualTypeOf<Array<MutationState>>()
12
+ })
13
+
14
+ it('should infer with select', () => {
15
+ const result = injectMutationState(() => ({
16
+ filters: { status: 'pending' },
17
+ select: (mutation) => mutation.state.status,
18
+ }))
19
+
20
+ expectTypeOf(result()).toEqualTypeOf<Array<MutationStatus>>()
21
+ })
22
+ })
@@ -0,0 +1,108 @@
1
+ import { signal } from '@angular/core'
2
+ import { QueryClient } from '@tanstack/query-core'
3
+ import { TestBed } from '@angular/core/testing'
4
+ import { describe, expect, test, vi } from 'vitest'
5
+ import { injectMutation } from '../inject-mutation'
6
+ import { injectMutationState } from '../inject-mutation-state'
7
+ import { provideAngularQuery } from '../providers'
8
+ import { successMutator } from './test-utils'
9
+
10
+ describe('injectMutationState', () => {
11
+ let queryClient: QueryClient
12
+
13
+ beforeEach(() => {
14
+ queryClient = new QueryClient()
15
+ vi.useFakeTimers()
16
+ TestBed.configureTestingModule({
17
+ providers: [provideAngularQuery(queryClient)],
18
+ })
19
+ })
20
+
21
+ afterEach(() => {
22
+ vi.useRealTimers()
23
+ })
24
+
25
+ describe('injectMutationState', () => {
26
+ test('should return variables after calling mutate', async () => {
27
+ const mutationKey = ['mutation']
28
+ const variables = 'foo123'
29
+
30
+ const mutation = TestBed.runInInjectionContext(() => {
31
+ return injectMutation(() => ({
32
+ mutationKey: mutationKey,
33
+ mutationFn: (params: string) => successMutator(params),
34
+ }))
35
+ })
36
+
37
+ mutation.mutate(variables)
38
+
39
+ const mutationState = TestBed.runInInjectionContext(() => {
40
+ return injectMutationState(() => ({
41
+ filters: { mutationKey, status: 'pending' },
42
+ select: (m) => m.state.variables,
43
+ }))
44
+ })
45
+
46
+ expect(mutationState()).toEqual([variables])
47
+ })
48
+
49
+ test('reactive options should update injectMutationState', async () => {
50
+ const mutationKey1 = ['mutation1']
51
+ const mutationKey2 = ['mutation2']
52
+ const variables1 = 'foo123'
53
+ const variables2 = 'bar234'
54
+
55
+ const [mutation1, mutation2] = TestBed.runInInjectionContext(() => {
56
+ return [
57
+ injectMutation(() => ({
58
+ mutationKey: mutationKey1,
59
+ mutationFn: (params: string) => successMutator(params),
60
+ })),
61
+ injectMutation(() => ({
62
+ mutationKey: mutationKey2,
63
+ mutationFn: (params: string) => successMutator(params),
64
+ })),
65
+ ]
66
+ })
67
+
68
+ mutation1.mutate(variables1)
69
+ mutation2.mutate(variables2)
70
+
71
+ const filterKey = signal(mutationKey1)
72
+
73
+ const mutationState = TestBed.runInInjectionContext(() => {
74
+ return injectMutationState(() => ({
75
+ filters: { mutationKey: filterKey(), status: 'pending' },
76
+ select: (m) => m.state.variables,
77
+ }))
78
+ })
79
+
80
+ expect(mutationState()).toEqual([variables1])
81
+
82
+ filterKey.set(mutationKey2)
83
+ TestBed.flushEffects()
84
+ expect(mutationState()).toEqual([variables2])
85
+ })
86
+
87
+ test('should return variables after calling mutate', async () => {
88
+ queryClient.clear()
89
+ const mutationKey = ['mutation']
90
+ const variables = 'bar234'
91
+
92
+ const mutation = TestBed.runInInjectionContext(() => {
93
+ return injectMutation(() => ({
94
+ mutationKey: mutationKey,
95
+ mutationFn: (params: string) => successMutator(params),
96
+ }))
97
+ })
98
+
99
+ mutation.mutate(variables)
100
+
101
+ const mutationState = TestBed.runInInjectionContext(() => {
102
+ return injectMutationState()
103
+ })
104
+
105
+ expect(mutationState()[0]?.variables).toEqual(variables)
106
+ })
107
+ })
108
+ })
@@ -123,7 +123,9 @@ describe('injectMutation', () => {
123
123
 
124
124
  test('reactive options should update mutation', async () => {
125
125
  const mutationCache = queryClient.getMutationCache()
126
- const mutationKey = signal(['foo'])
126
+ // Signal will be updated before the mutation is called
127
+ // this test confirms that the mutation uses the updated value
128
+ const mutationKey = signal(['1'])
127
129
  const mutation = TestBed.runInInjectionContext(() => {
128
130
  return injectMutation(() => ({
129
131
  mutationKey: mutationKey(),
@@ -131,19 +133,15 @@ describe('injectMutation', () => {
131
133
  }))
132
134
  })
133
135
 
134
- mutationKey.set(['bar'])
136
+ mutationKey.set(['2'])
135
137
 
136
138
  TestBed.flushEffects()
137
139
 
138
- await resolveMutations()
139
-
140
140
  mutation.mutate('xyz')
141
141
 
142
- await resolveMutations()
143
-
144
- const mutations = mutationCache.find({ mutationKey: ['bar'] })
142
+ const mutations = mutationCache.find({ mutationKey: ['2'] })
145
143
 
146
- expect(mutations?.options.mutationKey).toEqual(['bar'])
144
+ expect(mutations?.options.mutationKey).toEqual(['2'])
147
145
  })
148
146
 
149
147
  test('should reset state after invoking mutation.reset', async () => {
@@ -5,6 +5,7 @@ import {
5
5
  effect,
6
6
  inject,
7
7
  signal,
8
+ untracked,
8
9
  } from '@angular/core'
9
10
  import { notifyManager } from '@tanstack/query-core'
10
11
  import { signalProxy } from './signal-proxy'
@@ -62,18 +63,19 @@ export function createBaseQuery<
62
63
  observer.getOptimisticResult(defaultedOptionsSignal()),
63
64
  )
64
65
 
65
- effect(
66
- () => {
66
+ effect(() => {
67
+ const defaultedOptions = defaultedOptionsSignal()
68
+ observer.setOptions(defaultedOptions, {
67
69
  // Do not notify on updates because of changes in the options because
68
70
  // these changes should already be reflected in the optimistic result.
69
- const defaultedOptions = defaultedOptionsSignal()
70
- observer.setOptions(defaultedOptions, {
71
- listeners: false,
72
- })
73
- resultSignal.set(observer.getOptimisticResult(defaultedOptions))
74
- },
75
- { allowSignalWrites: true },
76
- )
71
+ listeners: false,
72
+ })
73
+ untracked(() =>
74
+ // Set the signal in effect because it's both 'computed' from options()
75
+ // and needs to be set imperatively in the query observer listener.
76
+ resultSignal.set(observer.getOptimisticResult(defaultedOptions)),
77
+ )
78
+ })
77
79
 
78
80
  // observer.trackResult is not used as this optimization is not needed for Angular
79
81
  const unsubscribe = observer.subscribe(
package/src/index.ts CHANGED
@@ -17,6 +17,7 @@ export * from './inject-infinite-query'
17
17
  export * from './inject-is-fetching'
18
18
  export * from './inject-is-mutating'
19
19
  export * from './inject-mutation'
20
+ export * from './inject-mutation-state'
20
21
  export * from './inject-queries'
21
22
  export * from './inject-query'
22
23
  export {
@@ -0,0 +1,81 @@
1
+ import { DestroyRef, effect, inject, signal, untracked } from '@angular/core'
2
+ import {
3
+ type DefaultError,
4
+ type Mutation,
5
+ type MutationCache,
6
+ type MutationFilters,
7
+ type MutationState,
8
+ notifyManager,
9
+ replaceEqualDeep,
10
+ } from '@tanstack/query-core'
11
+ import { assertInjector } from './util/assert-injector/assert-injector'
12
+ import { injectQueryClient } from './inject-query-client'
13
+ import type { Injector, Signal } from '@angular/core'
14
+
15
+ type MutationStateOptions<TResult = MutationState> = {
16
+ filters?: MutationFilters
17
+ select?: (
18
+ mutation: Mutation<unknown, DefaultError, unknown, unknown>,
19
+ ) => TResult
20
+ }
21
+
22
+ function getResult<TResult = MutationState>(
23
+ mutationCache: MutationCache,
24
+ options: MutationStateOptions<TResult>,
25
+ ): Array<TResult> {
26
+ return mutationCache
27
+ .findAll(options.filters)
28
+ .map(
29
+ (mutation): TResult =>
30
+ (options.select
31
+ ? options.select(
32
+ mutation as Mutation<unknown, DefaultError, unknown, unknown>,
33
+ )
34
+ : mutation.state) as TResult,
35
+ )
36
+ }
37
+
38
+ export interface InjectMutationStateOptions {
39
+ injector?: Injector
40
+ }
41
+
42
+ export function injectMutationState<TResult = MutationState>(
43
+ mutationStateOptionsFn: () => MutationStateOptions<TResult> = () => ({}),
44
+ options?: InjectMutationStateOptions,
45
+ ): Signal<Array<TResult>> {
46
+ return assertInjector(injectMutationState, options?.injector, () => {
47
+ const destroyRef = inject(DestroyRef)
48
+ const queryClient = injectQueryClient()
49
+
50
+ const mutationCache = queryClient.getMutationCache()
51
+
52
+ const result = signal<Array<TResult>>(
53
+ getResult(mutationCache, mutationStateOptionsFn()),
54
+ )
55
+
56
+ effect(() => {
57
+ const mutationStateOptions = mutationStateOptionsFn()
58
+ untracked(() => {
59
+ // Setting the signal from an effect because it's both 'computed' from options()
60
+ // and needs to be set imperatively in the mutationCache listener.
61
+ result.set(getResult(mutationCache, mutationStateOptions))
62
+ })
63
+ })
64
+
65
+ const unsubscribe = mutationCache.subscribe(
66
+ notifyManager.batchCalls(() => {
67
+ const nextResult = replaceEqualDeep(
68
+ result(),
69
+ getResult(mutationCache, mutationStateOptionsFn()),
70
+ )
71
+ if (result() !== nextResult) {
72
+ result.set(nextResult)
73
+ }
74
+ }),
75
+ )
76
+
77
+ destroyRef.onDestroy(unsubscribe)
78
+
79
+ return result
80
+ })
81
+ }