1 | import { NetworkStatus } from '@apollo/client/core';
|
2 | import { Observable, from } from 'rxjs';
|
3 | import { wrapWithZone, fixObservable } from './utils';
|
4 | function useInitialLoading(obsQuery) {
|
5 | return function useInitialLoadingOperator(source) {
|
6 | return new Observable(function useInitialLoadingSubscription(subscriber) {
|
7 | const currentResult = obsQuery.getCurrentResult();
|
8 | const { loading, errors, error, partial, data } = currentResult;
|
9 | const { partialRefetch, fetchPolicy } = obsQuery.options;
|
10 | const hasError = errors || error;
|
11 | if (partialRefetch &&
|
12 | partial &&
|
13 | (!data || Object.keys(data).length === 0) &&
|
14 | fetchPolicy !== 'cache-only' &&
|
15 | !loading &&
|
16 | !hasError) {
|
17 | subscriber.next({
|
18 | ...currentResult,
|
19 | loading: true,
|
20 | networkStatus: NetworkStatus.loading,
|
21 | });
|
22 | }
|
23 | return source.subscribe(subscriber);
|
24 | });
|
25 | };
|
26 | }
|
27 | export class QueryRef {
|
28 | constructor(obsQuery, ngZone, options) {
|
29 | this.obsQuery = obsQuery;
|
30 | const wrapped = wrapWithZone(from(fixObservable(this.obsQuery)), ngZone);
|
31 | this.valueChanges = options.useInitialLoading
|
32 | ? wrapped.pipe(useInitialLoading(this.obsQuery))
|
33 | : wrapped;
|
34 | this.queryId = this.obsQuery.queryId;
|
35 | }
|
36 | // ObservableQuery's methods
|
37 | get options() {
|
38 | return this.obsQuery.options;
|
39 | }
|
40 | get variables() {
|
41 | return this.obsQuery.variables;
|
42 | }
|
43 | result() {
|
44 | return this.obsQuery.result();
|
45 | }
|
46 | getCurrentResult() {
|
47 | return this.obsQuery.getCurrentResult();
|
48 | }
|
49 | getLastResult() {
|
50 | return this.obsQuery.getLastResult();
|
51 | }
|
52 | getLastError() {
|
53 | return this.obsQuery.getLastError();
|
54 | }
|
55 | resetLastResults() {
|
56 | return this.obsQuery.resetLastResults();
|
57 | }
|
58 | refetch(variables) {
|
59 | return this.obsQuery.refetch(variables);
|
60 | }
|
61 | fetchMore(fetchMoreOptions) {
|
62 | return this.obsQuery.fetchMore(fetchMoreOptions);
|
63 | }
|
64 | subscribeToMore(options) {
|
65 | // XXX: there's a bug in apollo-client typings
|
66 | // it should not inherit types from ObservableQuery
|
67 | return this.obsQuery.subscribeToMore(options);
|
68 | }
|
69 | updateQuery(mapFn) {
|
70 | return this.obsQuery.updateQuery(mapFn);
|
71 | }
|
72 | stopPolling() {
|
73 | return this.obsQuery.stopPolling();
|
74 | }
|
75 | startPolling(pollInterval) {
|
76 | return this.obsQuery.startPolling(pollInterval);
|
77 | }
|
78 | setOptions(opts) {
|
79 | return this.obsQuery.setOptions(opts);
|
80 | }
|
81 | setVariables(variables) {
|
82 | return this.obsQuery.setVariables(variables);
|
83 | }
|
84 | }
|
85 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-ref.js","sourceRoot":"","sources":["../../src/query-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgZone} from '@angular/core';\nimport type {\n  ApolloQueryResult,\n  ObservableQuery,\n  ApolloError,\n  FetchMoreQueryOptions,\n  SubscribeToMoreOptions,\n  UpdateQueryOptions,\n  TypedDocumentNode,\n} from '@apollo/client/core';\nimport {NetworkStatus} from '@apollo/client/core';\nimport {Observable, from} from 'rxjs';\n\nimport {wrapWithZone, fixObservable} from './utils';\nimport {WatchQueryOptions, EmptyObject} from './types';\n\nfunction useInitialLoading<T, V>(obsQuery: ObservableQuery<T, V>) {\n  return function useInitialLoadingOperator<T>(\n    source: Observable<T>,\n  ): Observable<T> {\n    return new Observable(function useInitialLoadingSubscription(subscriber) {\n      const currentResult = obsQuery.getCurrentResult();\n      const {loading, errors, error, partial, data} = currentResult;\n      const {partialRefetch, fetchPolicy} = obsQuery.options;\n\n      const hasError = errors || error;\n\n      if (\n        partialRefetch &&\n        partial &&\n        (!data || Object.keys(data).length === 0) &&\n        fetchPolicy !== 'cache-only' &&\n        !loading &&\n        !hasError\n      ) {\n        subscriber.next({\n          ...currentResult,\n          loading: true,\n          networkStatus: NetworkStatus.loading,\n        } as any);\n      }\n\n      return source.subscribe(subscriber);\n    });\n  };\n}\n\nexport type QueryRefFromDocument<T extends TypedDocumentNode> =\n  T extends TypedDocumentNode<infer R, infer V> ? QueryRef<R, V> : never;\n\nexport class QueryRef<T, V = EmptyObject> {\n  public valueChanges: Observable<ApolloQueryResult<T>>;\n  public queryId: ObservableQuery<T, V>['queryId'];\n\n  constructor(\n    private obsQuery: ObservableQuery<T, V>,\n    ngZone: NgZone,\n    options: WatchQueryOptions<V, T>,\n  ) {\n    const wrapped = wrapWithZone(from(fixObservable(this.obsQuery)), ngZone);\n\n    this.valueChanges = options.useInitialLoading\n      ? wrapped.pipe(useInitialLoading(this.obsQuery))\n      : wrapped;\n    this.queryId = this.obsQuery.queryId;\n  }\n\n  // ObservableQuery's methods\n\n  public get options() {\n    return this.obsQuery.options;\n  }\n\n  public get variables() {\n    return this.obsQuery.variables;\n  }\n\n  public result(): Promise<ApolloQueryResult<T>> {\n    return this.obsQuery.result();\n  }\n\n  public getCurrentResult(): ApolloQueryResult<T> {\n    return this.obsQuery.getCurrentResult();\n  }\n\n  public getLastResult(): ApolloQueryResult<T> {\n    return this.obsQuery.getLastResult();\n  }\n\n  public getLastError(): ApolloError {\n    return this.obsQuery.getLastError();\n  }\n\n  public resetLastResults(): void {\n    return this.obsQuery.resetLastResults();\n  }\n\n  public refetch(variables?: V): Promise<ApolloQueryResult<T>> {\n    return this.obsQuery.refetch(variables);\n  }\n\n  public fetchMore<K = V>(\n    fetchMoreOptions: FetchMoreQueryOptions<K, T>,\n  ): Promise<ApolloQueryResult<T>> {\n    return this.obsQuery.fetchMore(fetchMoreOptions);\n  }\n\n  public subscribeToMore<MT = any, MV = EmptyObject>(\n    options: SubscribeToMoreOptions<T, MV, MT>,\n  ): () => void {\n    // XXX: there's a bug in apollo-client typings\n    // it should not inherit types from ObservableQuery\n    return this.obsQuery.subscribeToMore(options as any);\n  }\n  public updateQuery(\n    mapFn: (previousQueryResult: T, options: UpdateQueryOptions<V>) => T,\n  ): void {\n    return this.obsQuery.updateQuery(mapFn);\n  }\n\n  public stopPolling(): void {\n    return this.obsQuery.stopPolling();\n  }\n\n  public startPolling(pollInterval: number): void {\n    return this.obsQuery.startPolling(pollInterval);\n  }\n\n  public setOptions(opts: any) {\n    return this.obsQuery.setOptions(opts);\n  }\n\n  public setVariables(variables: V) {\n    return this.obsQuery.setVariables(variables);\n  }\n}\n"]} |
\ | No newline at end of file |