當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript apollo-cache.ApolloCache類代碼示例

本文整理匯總了TypeScript中apollo-cache.ApolloCache的典型用法代碼示例。如果您正苦於以下問題:TypeScript ApolloCache類的具體用法?TypeScript ApolloCache怎麽用?TypeScript ApolloCache使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了ApolloCache類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: tryFunctionOrLogError

          .forEach(queryId => {
            const { query, updater } = mutation.updateQueries[queryId];
            // Read the current query result from the store.
            const { result: currentQueryResult, complete } = this.cache.diff({
              query: query.document,
              variables: query.variables,
              returnPartialData: true,
              optimistic: false,
            });

            if (!complete) {
              return;
            }

            // Run our reducer using the current query result and the mutation result.
            const nextQueryResult = tryFunctionOrLogError(() =>
              updater(currentQueryResult, {
                mutationResult: mutation.result,
                queryName: getOperationName(query.document) || undefined,
                queryVariables: query.variables,
              }),
            );

            // Write the modified result back into the store if we got a new result.
            if (nextQueryResult) {
              cacheWrites.push({
                result: nextQueryResult,
                dataId: 'ROOT_QUERY',
                query: query.document,
                variables: query.variables,
              });
            }
          });
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:33,代碼來源:store.ts

示例2: markMutationComplete

 public markMutationComplete({
   mutationId,
   optimisticResponse,
 }: {
   mutationId: string;
   optimisticResponse?: any;
 }) {
   if (!optimisticResponse) return;
   this.cache.removeOptimistic(mutationId);
 }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:10,代碼來源:store.ts

示例3: buildRootValueFromCache

 // Query the cache and return matching data.
 private buildRootValueFromCache(
   document: DocumentNode,
   variables?: Record<string, any>,
 ) {
   return this.cache.diff({
     query: buildQueryFromSelectionSet(document),
     variables,
     optimistic: false,
   }).result;
 }
開發者ID:apollostack,項目名稱:apollo-client,代碼行數:11,代碼來源:LocalState.ts

示例4: markUpdateQueryResult

 public markUpdateQueryResult(
   document: DocumentNode,
   variables: any,
   newResult: any,
 ) {
   this.cache.write({
     result: newResult,
     dataId: 'ROOT_QUERY',
     variables,
     query: document,
   });
 }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:12,代碼來源:store.ts

示例5: markSubscriptionResult

 public markSubscriptionResult(
   result: ExecutionResult,
   document: DocumentNode,
   variables: any,
 ) {
   // the subscription interface should handle not sending us results we no longer subscribe to.
   // XXX I don't think we ever send in an object with errors, but we might in the future...
   if (!graphQLResultHasError(result)) {
     this.cache.write({
       result: result.data,
       dataId: 'ROOT_SUBSCRIPTION',
       query: document,
       variables: variables,
     });
   }
 }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:16,代碼來源:store.ts

示例6: markQueryResult

 public markQueryResult(
   result: ExecutionResult,
   document: DocumentNode,
   variables: any,
   fetchMoreForQueryId: string | undefined,
   ignoreErrors: boolean = false,
 ) {
   let writeWithErrors = !graphQLResultHasError(result);
   if (ignoreErrors && graphQLResultHasError(result) && result.data) {
     writeWithErrors = true;
   }
   if (!fetchMoreForQueryId && writeWithErrors) {
     this.cache.write({
       result: result.data,
       dataId: 'ROOT_QUERY',
       query: document,
       variables: variables,
     });
   }
 }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:20,代碼來源:store.ts

示例7: markMutationInit

  public markMutationInit(mutation: {
    mutationId: string;
    document: DocumentNode;
    variables: any;
    updateQueries: { [queryId: string]: QueryWithUpdater };
    update: ((proxy: DataProxy, mutationResult: Object) => void) | undefined;
    optimisticResponse: Object | Function | undefined;
  }) {
    if (mutation.optimisticResponse) {
      let optimistic: Object;
      if (typeof mutation.optimisticResponse === 'function') {
        optimistic = mutation.optimisticResponse(mutation.variables);
      } else {
        optimistic = mutation.optimisticResponse;
      }

      const changeFn = () => {
        this.markMutationResult({
          mutationId: mutation.mutationId,
          result: { data: optimistic },
          document: mutation.document,
          variables: mutation.variables,
          updateQueries: mutation.updateQueries,
          update: mutation.update,
        });
      };

      this.cache.recordOptimisticTransaction(c => {
        const orig = this.cache;
        this.cache = c;

        try {
          changeFn();
        } finally {
          this.cache = orig;
        }
      }, mutation.mutationId);
    }
  }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:39,代碼來源:store.ts

示例8: reset

 public reset(): Promise<void> {
   return this.cache.reset();
 }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:3,代碼來源:store.ts

示例9: markMutationResult

  public markMutationResult(mutation: {
    mutationId: string;
    result: ExecutionResult;
    document: DocumentNode;
    variables: any;
    updateQueries: { [queryId: string]: QueryWithUpdater };
    update: ((proxy: DataProxy, mutationResult: Object) => void) | undefined;
  }) {
    // Incorporate the result from this mutation into the store
    if (!graphQLResultHasError(mutation.result)) {
      const cacheWrites: Cache.WriteOptions[] = [];
      cacheWrites.push({
        result: mutation.result.data,
        dataId: 'ROOT_MUTATION',
        query: mutation.document,
        variables: mutation.variables,
      });

      if (mutation.updateQueries) {
        Object.keys(mutation.updateQueries)
          .filter(id => mutation.updateQueries[id])
          .forEach(queryId => {
            const { query, updater } = mutation.updateQueries[queryId];
            // Read the current query result from the store.
            const { result: currentQueryResult, complete } = this.cache.diff({
              query: query.document,
              variables: query.variables,
              returnPartialData: true,
              optimistic: false,
            });

            if (!complete) {
              return;
            }

            // Run our reducer using the current query result and the mutation result.
            const nextQueryResult = tryFunctionOrLogError(() =>
              updater(currentQueryResult, {
                mutationResult: mutation.result,
                queryName: getOperationName(query.document) || undefined,
                queryVariables: query.variables,
              }),
            );

            // Write the modified result back into the store if we got a new result.
            if (nextQueryResult) {
              cacheWrites.push({
                result: nextQueryResult,
                dataId: 'ROOT_QUERY',
                query: query.document,
                variables: query.variables,
              });
            }
          });
      }

      this.cache.performTransaction(c => {
        cacheWrites.forEach(write => c.write(write));
      });

      // If the mutation has some writes associated with it then we need to
      // apply those writes to the store by running this reducer again with a
      // write action.
      const update = mutation.update;
      if (update) {
        this.cache.performTransaction(c => {
          tryFunctionOrLogError(() => update(c, mutation.result));
        });
      }
    }
  }
開發者ID:NewSpring,項目名稱:apollo-client,代碼行數:71,代碼來源:store.ts


注:本文中的apollo-cache.ApolloCache類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。