apollo-angular
Version:
Use your GraphQL data in your Angular app, with the Apollo Client
182 lines • 20.3 kB
JavaScript
import { Injectable, Optional, Inject } from '@angular/core';
import { ApolloClient } from '@apollo/client/core';
import { from } from 'rxjs';
import { QueryRef } from './query-ref';
import { APOLLO_OPTIONS, APOLLO_NAMED_OPTIONS, APOLLO_FLAGS } from './tokens';
import { fromPromise, useMutationLoading, wrapWithZone, fixObservable, pickFlag } from './utils';
import * as i0 from "@angular/core";
export class ApolloBase {
constructor(ngZone, flags, _client) {
this.ngZone = ngZone;
this.flags = flags;
this._client = _client;
this.useInitialLoading = pickFlag(flags, 'useInitialLoading', false);
this.useMutationLoading = pickFlag(flags, 'useMutationLoading', false);
}
watchQuery(options) {
return new QueryRef(this.ensureClient().watchQuery({
...options,
}), this.ngZone, {
useInitialLoading: this.useInitialLoading,
...options,
});
}
query(options) {
return fromPromise(() => this.ensureClient().query({ ...options }));
}
mutate(options) {
return useMutationLoading(fromPromise(() => this.ensureClient().mutate({ ...options })), options.useMutationLoading ?? this.useMutationLoading);
}
subscribe(options, extra) {
const obs = from(fixObservable(this.ensureClient().subscribe({ ...options })));
return extra && extra.useZone !== true ? obs : wrapWithZone(obs, this.ngZone);
}
/**
* Get an instance of ApolloClient
* @deprecated use `apollo.client` instead
*/
getClient() {
return this.client;
}
/**
* Set a new instance of ApolloClient
* Remember to clean up the store before setting a new client.
* @deprecated use `apollo.client = client` instead
*
* @param client ApolloClient instance
*/
setClient(client) {
this.client = client;
}
/**
* Get an instance of ApolloClient
*/
get client() {
return this._client;
}
/**
* Set a new instance of ApolloClient
* Remember to clean up the store before setting a new client.
*
* @param client ApolloClient instance
*/
set client(client) {
if (this._client) {
throw new Error('Client has been already defined');
}
this._client = client;
}
ensureClient() {
this.checkInstance();
return this._client;
}
checkInstance() {
if (!this._client) {
throw new Error('Client has not been defined yet');
}
}
}
export class Apollo extends ApolloBase {
constructor(_ngZone, apolloOptions, apolloNamedOptions, flags) {
super(_ngZone, flags);
this._ngZone = _ngZone;
this.map = new Map();
if (apolloOptions) {
this.createDefault(apolloOptions);
}
if (apolloNamedOptions && typeof apolloNamedOptions === 'object') {
for (let name in apolloNamedOptions) {
if (apolloNamedOptions.hasOwnProperty(name)) {
const options = apolloNamedOptions[name];
this.create(options, name);
}
}
}
}
/**
* Create an instance of ApolloClient
* @param options Options required to create ApolloClient
* @param name client's name
*/
create(options, name) {
if (isDefault(name)) {
this.createDefault(options);
}
else {
this.createNamed(name, options);
}
}
/**
* Use a default ApolloClient
*/
default() {
return this;
}
/**
* Use a named ApolloClient
* @param name client's name
*/
use(name) {
if (isDefault(name)) {
return this.default();
}
return this.map.get(name);
}
/**
* Create a default ApolloClient, same as `apollo.create(options)`
* @param options ApolloClient's options
*/
createDefault(options) {
if (this.getClient()) {
throw new Error('Apollo has been already created.');
}
return this.setClient(new ApolloClient(options));
}
/**
* Create a named ApolloClient, same as `apollo.create(options, name)`
* @param name client's name
* @param options ApolloClient's options
*/
createNamed(name, options) {
if (this.map.has(name)) {
throw new Error(`Client ${name} has been already created`);
}
this.map.set(name, new ApolloBase(this._ngZone, this.flags, new ApolloClient(options)));
}
/**
* Remember to clean up the store before removing a client
* @param name client's name
*/
removeClient(name) {
if (isDefault(name)) {
this._client = undefined;
}
else {
this.map.delete(name);
}
}
}
Apollo.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: Apollo, deps: [{ token: i0.NgZone }, { token: APOLLO_OPTIONS, optional: true }, { token: APOLLO_NAMED_OPTIONS, optional: true }, { token: APOLLO_FLAGS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
Apollo.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: Apollo });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: Apollo, decorators: [{
type: Injectable
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [APOLLO_OPTIONS]
}] }, { type: undefined, decorators: [{
type: Inject,
args: [APOLLO_NAMED_OPTIONS]
}, {
type: Optional
}] }, { type: undefined, decorators: [{
type: Inject,
args: [APOLLO_FLAGS]
}, {
type: Optional
}] }]; } });
function isDefault(name) {
return !name || name === 'default';
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apollo.js","sourceRoot":"","sources":["../../src/apollo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAUrE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAc,IAAI,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAUvC,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;;AAEjG,MAAM,OAAO,UAAU;IAIrB,YAAsB,MAAc,EAAY,KAAa,EAAY,OAAmC;QAAtF,WAAM,GAAN,MAAM,CAAQ;QAAY,UAAK,GAAL,KAAK,CAAQ;QAAY,YAAO,GAAP,OAAO,CAA4B;QAC1G,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,KAAK,EAAE,mBAAmB,EAAE,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,kBAAkB,GAAG,QAAQ,CAAC,KAAK,EAAE,oBAAoB,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAEM,UAAU,CACf,OAA6C;QAE7C,OAAO,IAAI,QAAQ,CACjB,IAAI,CAAC,YAAY,EAAE,CAAC,UAAU,CAAoB;YAChD,GAAG,OAAO;SACX,CAAuC,EACxC,IAAI,CAAC,MAAM,EACX;YACE,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,GAAG,OAAO;SACX,CACF,CAAC;IACJ,CAAC;IAEM,KAAK,CAAqB,OAA2B;QAC1D,OAAO,WAAW,CAAuB,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,KAAK,CAAO,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC;IAClG,CAAC;IAEM,MAAM,CAAqB,OAA8B;QAC9D,OAAO,kBAAkB,CACvB,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,CAAO,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,EACnE,OAAO,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CACtD,CAAC;IACJ,CAAC;IAEM,SAAS,CACd,OAAkC,EAClC,KAAgC;QAEhC,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,SAAS,CAAO,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;QAErF,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAChF,CAAC;IAED;;;OAGG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;;;;;OAMG;IACI,SAAS,CAAC,MAAiC;QAChD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,IAAW,MAAM,CAAC,MAAiC;QACjD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;SACpD;QAED,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;SACpD;IACH,CAAC;CACF;AAGD,MAAM,OAAO,MAAO,SAAQ,UAAe;IAGzC,YACU,OAAe,EAGvB,aAAwC,EACE,kBAAiC,EACzC,KAAa;QAE/C,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAPd,YAAO,GAAP,OAAO,CAAQ;QAHjB,QAAG,GAAiC,IAAI,GAAG,EAA2B,CAAC;QAY7E,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;SACnC;QAED,IAAI,kBAAkB,IAAI,OAAO,kBAAkB,KAAK,QAAQ,EAAE;YAChE,KAAK,IAAI,IAAI,IAAI,kBAAkB,EAAE;gBACnC,IAAI,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;oBAC3C,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;oBACzC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;iBAC5B;aACF;SACF;IACH,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAc,OAAyC,EAAE,IAAa;QACjF,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,aAAa,CAAc,OAAO,CAAC,CAAC;SAC1C;aAAM;YACL,IAAI,CAAC,WAAW,CAAc,IAAI,EAAE,OAAO,CAAC,CAAC;SAC9C;IACH,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACI,GAAG,CAAC,IAAY;QACrB,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;YACnB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;SACvB;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,aAAa,CAAc,OAAyC;QACzE,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE;YACpB,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;SACrD;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,YAAY,CAAc,OAAO,CAAC,CAAC,CAAC;IAChE,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAc,IAAY,EAAE,OAAyC;QACrF,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACtB,MAAM,IAAI,KAAK,CAAC,UAAU,IAAI,2BAA2B,CAAC,CAAC;SAC5D;QACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,YAAY,CAAc,OAAO,CAAC,CAAC,CAAC,CAAC;IACvG,CAAC;IAED;;;OAGG;IACI,YAAY,CAAC,IAAa;QAC/B,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACvB;IACH,CAAC;;mGA5FU,MAAM,wCAMP,cAAc,6BAEd,oBAAoB,6BACpB,YAAY;uGATX,MAAM;2FAAN,MAAM;kBADlB,UAAU;;0BAMN,QAAQ;;0BACR,MAAM;2BAAC,cAAc;;0BAErB,MAAM;2BAAC,oBAAoB;;0BAAG,QAAQ;;0BACtC,MAAM;2BAAC,YAAY;;0BAAG,QAAQ;;AAsFnC,SAAS,SAAS,CAAC,IAAa;IAC9B,OAAO,CAAC,IAAI,IAAI,IAAI,KAAK,SAAS,CAAC;AACrC,CAAC","sourcesContent":["import { Injectable, Optional, Inject, NgZone } from '@angular/core';\nimport type {\n  QueryOptions,\n  ApolloQueryResult,\n  SubscriptionOptions,\n  ApolloClientOptions,\n  ObservableQuery,\n  FetchResult,\n  OperationVariables,\n} from '@apollo/client/core';\nimport { ApolloClient } from '@apollo/client/core';\nimport { Observable, from } from 'rxjs';\n\nimport { QueryRef } from './query-ref';\nimport type {\n  WatchQueryOptions,\n  ExtraSubscriptionOptions,\n  EmptyObject,\n  NamedOptions,\n  Flags,\n  MutationResult,\n  MutationOptions,\n} from './types';\nimport { APOLLO_OPTIONS, APOLLO_NAMED_OPTIONS, APOLLO_FLAGS } from './tokens';\nimport { fromPromise, useMutationLoading, wrapWithZone, fixObservable, pickFlag } from './utils';\n\nexport class ApolloBase<TCacheShape = any> {\n  private useInitialLoading: boolean;\n  private useMutationLoading: boolean;\n\n  constructor(protected ngZone: NgZone, protected flags?: Flags, protected _client?: ApolloClient<TCacheShape>) {\n    this.useInitialLoading = pickFlag(flags, 'useInitialLoading', false);\n    this.useMutationLoading = pickFlag(flags, 'useMutationLoading', false);\n  }\n\n  public watchQuery<TData, TVariables extends OperationVariables = EmptyObject>(\n    options: WatchQueryOptions<TVariables, TData>\n  ): QueryRef<TData, TVariables> {\n    return new QueryRef<TData, TVariables>(\n      this.ensureClient().watchQuery<TData, TVariables>({\n        ...options,\n      }) as ObservableQuery<TData, TVariables>,\n      this.ngZone,\n      {\n        useInitialLoading: this.useInitialLoading,\n        ...options,\n      }\n    );\n  }\n\n  public query<T, V = EmptyObject>(options: QueryOptions<V, T>): Observable<ApolloQueryResult<T>> {\n    return fromPromise<ApolloQueryResult<T>>(() => this.ensureClient().query<T, V>({ ...options }));\n  }\n\n  public mutate<T, V = EmptyObject>(options: MutationOptions<T, V>): Observable<MutationResult<T>> {\n    return useMutationLoading(\n      fromPromise(() => this.ensureClient().mutate<T, V>({ ...options })),\n      options.useMutationLoading ?? this.useMutationLoading\n    );\n  }\n\n  public subscribe<T, V = EmptyObject>(\n    options: SubscriptionOptions<V, T>,\n    extra?: ExtraSubscriptionOptions\n  ): Observable<FetchResult<T>> {\n    const obs = from(fixObservable(this.ensureClient().subscribe<T, V>({ ...options })));\n\n    return extra && extra.useZone !== true ? obs : wrapWithZone(obs, this.ngZone);\n  }\n\n  /**\n   * Get an instance of ApolloClient\n   * @deprecated use `apollo.client` instead\n   */\n  public getClient() {\n    return this.client;\n  }\n\n  /**\n   * Set a new instance of ApolloClient\n   * Remember to clean up the store before setting a new client.\n   * @deprecated use `apollo.client = client` instead\n   *\n   * @param client ApolloClient instance\n   */\n  public setClient(client: ApolloClient<TCacheShape>) {\n    this.client = client;\n  }\n\n  /**\n   * Get an instance of ApolloClient\n   */\n  public get client(): ApolloClient<TCacheShape> {\n    return this._client;\n  }\n\n  /**\n   * Set a new instance of ApolloClient\n   * Remember to clean up the store before setting a new client.\n   *\n   * @param client ApolloClient instance\n   */\n  public set client(client: ApolloClient<TCacheShape>) {\n    if (this._client) {\n      throw new Error('Client has been already defined');\n    }\n\n    this._client = client;\n  }\n\n  private ensureClient() {\n    this.checkInstance();\n\n    return this._client;\n  }\n\n  private checkInstance(): void {\n    if (!this._client) {\n      throw new Error('Client has not been defined yet');\n    }\n  }\n}\n\n@Injectable()\nexport class Apollo extends ApolloBase<any> {\n  private map: Map<string, ApolloBase<any>> = new Map<string, ApolloBase<any>>();\n\n  constructor(\n    private _ngZone: NgZone,\n    @Optional()\n    @Inject(APOLLO_OPTIONS)\n    apolloOptions?: ApolloClientOptions<any>,\n    @Inject(APOLLO_NAMED_OPTIONS) @Optional() apolloNamedOptions?: NamedOptions,\n    @Inject(APOLLO_FLAGS) @Optional() flags?: Flags\n  ) {\n    super(_ngZone, flags);\n\n    if (apolloOptions) {\n      this.createDefault(apolloOptions);\n    }\n\n    if (apolloNamedOptions && typeof apolloNamedOptions === 'object') {\n      for (let name in apolloNamedOptions) {\n        if (apolloNamedOptions.hasOwnProperty(name)) {\n          const options = apolloNamedOptions[name];\n          this.create(options, name);\n        }\n      }\n    }\n  }\n\n  /**\n   * Create an instance of ApolloClient\n   * @param options Options required to create ApolloClient\n   * @param name client's name\n   */\n  public create<TCacheShape>(options: ApolloClientOptions<TCacheShape>, name?: string): void {\n    if (isDefault(name)) {\n      this.createDefault<TCacheShape>(options);\n    } else {\n      this.createNamed<TCacheShape>(name, options);\n    }\n  }\n\n  /**\n   * Use a default ApolloClient\n   */\n  public default(): ApolloBase<any> {\n    return this;\n  }\n\n  /**\n   * Use a named ApolloClient\n   * @param name client's name\n   */\n  public use(name: string): ApolloBase<any> {\n    if (isDefault(name)) {\n      return this.default();\n    }\n    return this.map.get(name);\n  }\n\n  /**\n   * Create a default ApolloClient, same as `apollo.create(options)`\n   * @param options ApolloClient's options\n   */\n  public createDefault<TCacheShape>(options: ApolloClientOptions<TCacheShape>): void {\n    if (this.getClient()) {\n      throw new Error('Apollo has been already created.');\n    }\n\n    return this.setClient(new ApolloClient<TCacheShape>(options));\n  }\n\n  /**\n   * Create a named ApolloClient, same as `apollo.create(options, name)`\n   * @param name client's name\n   * @param options ApolloClient's options\n   */\n  public createNamed<TCacheShape>(name: string, options: ApolloClientOptions<TCacheShape>): void {\n    if (this.map.has(name)) {\n      throw new Error(`Client ${name} has been already created`);\n    }\n    this.map.set(name, new ApolloBase(this._ngZone, this.flags, new ApolloClient<TCacheShape>(options)));\n  }\n\n  /**\n   * Remember to clean up the store before removing a client\n   * @param name client's name\n   */\n  public removeClient(name?: string): void {\n    if (isDefault(name)) {\n      this._client = undefined;\n    } else {\n      this.map.delete(name);\n    }\n  }\n}\n\nfunction isDefault(name?: string): boolean {\n  return !name || name === 'default';\n}\n"]}