本文整理匯總了TypeScript中apollo-utilities.isEqual函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript isEqual函數的具體用法?TypeScript isEqual怎麽用?TypeScript isEqual使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了isEqual函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: isDifferentFromLastResult
// Compares newResult to the snapshot we took of this.lastResult when it was
// first received.
public isDifferentFromLastResult(newResult: ApolloQueryResult<TData>) {
const { lastResultSnapshot: snapshot } = this;
return !(
snapshot &&
newResult &&
snapshot.networkStatus === newResult.networkStatus &&
snapshot.stale === newResult.stale &&
isEqual(snapshot.data, newResult.data)
);
}
示例2: refetch
public refetch(variables?: any): Promise<ApolloQueryResult<T>> {
const { fetchPolicy } = this.options;
// early return if trying to read from cache during refetch
if (fetchPolicy === 'cache-only') {
return Promise.reject(
new Error(
'cache-only fetchPolicy option should not be used together with query refetch.',
),
);
}
if (!isEqual(this.variables, variables)) {
// update observable variables
this.variables = {
...this.variables,
...variables,
};
}
if (!isEqual(this.options.variables, this.variables)) {
// Update the existing options with new variables
this.options.variables = {
...this.options.variables,
...this.variables,
};
}
// Override fetchPolicy for this call only
// only network-only and no-cache are safe to use
const isNetworkFetchPolicy =
fetchPolicy === 'network-only' || fetchPolicy === 'no-cache';
const combinedOptions: WatchQueryOptions = {
...this.options,
fetchPolicy: isNetworkFetchPolicy ? fetchPolicy : 'network-only',
};
return this.queryManager
.fetchQuery(this.queryId, combinedOptions, FetchType.refetch)
.then(result => maybeDeepFreeze(result));
}
示例3: setVariables
/**
* Update the variables of this observable query, and fetch the new results
* if they've changed. If you want to force new results, use `refetch`.
*
* Note: if the variables have not changed, the promise will return the old
* results immediately, and the `next` callback will *not* fire.
*
* Note: if the query is not active (there are no subscribers), the promise
* will return null immediately.
*
* @param variables: The new set of variables. If there are missing variables,
* the previous values of those variables will be used.
*
* @param tryFetch: Try and fetch new results even if the variables haven't
* changed (we may still just hit the store, but if there's nothing in there
* this will refetch)
*
* @param fetchResults: Option to ignore fetching results when updating variables
*
*/
public setVariables(
variables: any,
tryFetch: boolean = false,
fetchResults = true,
): Promise<ApolloQueryResult<T>> {
// since setVariables restarts the subscription, we reset the tornDown status
this.isTornDown = false;
const newVariables = {
...this.variables,
...variables,
};
if (isEqual(newVariables, this.variables) && !tryFetch) {
// If we have no observers, then we don't actually want to make a network
// request. As soon as someone observes the query, the request will kick
// off. For now, we just store any changes. (See #1077)
if (this.observers.length === 0 || !fetchResults) {
return new Promise(resolve => resolve());
}
return this.result();
} else {
this.lastVariables = this.variables;
this.variables = newVariables;
this.options.variables = newVariables;
// See comment above
if (this.observers.length === 0) {
return new Promise(resolve => resolve());
}
// Use the same options as before, but with new variables
return this.queryManager
.fetchQuery(this.queryId, {
...this.options,
variables: this.variables,
} as WatchQueryOptions)
.then(result => maybeDeepFreeze(result));
}
}
示例4: getQueryDefinition
/**
* Given a store and a query, return as much of the result as possible and
* identify if any data was missing from the store.
* @param {DocumentNode} query A parsed GraphQL query document
* @param {Store} store The Apollo Client store object
* @param {any} previousResult The previous result returned by this function for the same query
* @return {result: Object, complete: [boolean]}
*/
public diffQueryAgainstStore<T>({
store,
query,
variables,
previousResult,
returnPartialData = true,
rootId = 'ROOT_QUERY',
fragmentMatcherFunction,
config,
}: DiffQueryAgainstStoreOptions): Cache.DiffResult<T> {
// Throw the right validation error by trying to find a query in the document
const queryDefinition = getQueryDefinition(query);
variables = assign({}, getDefaultValues(queryDefinition), variables);
const context: ReadStoreContext = {
// Global settings
store,
dataIdFromObject: (config && config.dataIdFromObject) || null,
cacheRedirects: (config && config.cacheRedirects) || {},
};
const execResult = this.executeStoreQuery({
query,
rootValue: {
type: 'id',
id: rootId,
generated: true,
typename: 'Query',
},
contextValue: context,
variableValues: variables,
fragmentMatcher: fragmentMatcherFunction,
});
const hasMissingFields =
execResult.missing && execResult.missing.length > 0;
if (hasMissingFields && ! returnPartialData) {
execResult.missing.forEach(info => {
if (info.tolerable) return;
throw new InvariantError(
`Can't find field ${info.fieldName} on object ${JSON.stringify(
info.object,
null,
2,
)}.`,
);
});
}
if (previousResult) {
if (isEqual(previousResult, execResult.result)) {
execResult.result = previousResult;
}
}
return {
result: execResult.result,
complete: !hasMissingFields,
};
}
示例5: assertIdValue
const readStoreResolver: Resolver = (
fieldName: string,
idValue: IdValueWithPreviousResult,
args: any,
context: ReadStoreContext,
{ resultKey, directives }: ExecInfo,
) => {
assertIdValue(idValue);
const objId = idValue.id;
const obj = context.store.get(objId);
const storeKeyName = getStoreKeyName(fieldName, args, directives);
let fieldValue = (obj || {})[storeKeyName];
if (typeof fieldValue === 'undefined') {
if (
context.cacheResolvers &&
obj &&
(obj.__typename || objId === 'ROOT_QUERY')
) {
const typename = obj.__typename || 'Query';
// Look for the type in the custom resolver map
const type = context.cacheResolvers[typename];
if (type) {
// Look for the field in the custom resolver map
const resolver = type[fieldName];
if (resolver) {
fieldValue = resolver(obj, args);
}
}
}
}
if (typeof fieldValue === 'undefined') {
if (!context.returnPartialData) {
throw new Error(
`Can't find field ${storeKeyName} on object (${objId}) ${JSON.stringify(
obj,
null,
2,
)}.`,
);
}
context.hasMissingField = true;
return fieldValue;
}
// if this is an object scalar, it must be a json blob and we have to unescape it
if (isJsonValue(fieldValue)) {
// If the JSON blob is the same now as in the previous result, return the previous result to
// maintain referential equality.
//
// `isEqual` will first perform a referential equality check (with `===`) in case the JSON
// value has not changed in the store, and then a deep equality check if that fails in case a
// new JSON object was returned by the API but that object may still be the same.
if (
idValue.previousResult &&
isEqual(idValue.previousResult[resultKey], fieldValue.json)
) {
return idValue.previousResult[resultKey];
}
return fieldValue.json;
}
// If we had a previous result, try adding that previous result value for this field to our field
// value. This will create a new value without mutating the old one.
if (idValue.previousResult) {
fieldValue = addPreviousResultToIdValues(
fieldValue,
idValue.previousResult[resultKey],
);
}
return fieldValue;
};
示例6: assertIdValue
const readStoreResolver: Resolver = (
fieldName: string,
idValue: IdValueWithPreviousResult,
args: any,
context: ReadStoreContext,
{ resultKey, directives }: ExecInfo,
) => {
assertIdValue(idValue);
const objId = idValue.id;
const obj = context.store.get(objId);
let storeKeyName = fieldName;
if (args || directives) {
// We happen to know here that getStoreKeyName returns its first
// argument unmodified if there are no args or directives, so we can
// avoid calling the function at all in that case, as a small but
// important optimization to this frequently executed code.
storeKeyName = getStoreKeyName(storeKeyName, args, directives);
}
let fieldValue: StoreValue | string | void = void 0;
if (obj) {
fieldValue = obj[storeKeyName];
if (
typeof fieldValue === 'undefined' &&
context.cacheRedirects &&
(obj.__typename || objId === 'ROOT_QUERY')
) {
const typename = obj.__typename || 'Query';
// Look for the type in the custom resolver map
const type = context.cacheRedirects[typename];
if (type) {
// Look for the field in the custom resolver map
const resolver = type[fieldName];
if (resolver) {
fieldValue = resolver(obj, args, {
getCacheKey(storeObj: StoreObject) {
return toIdValue({
id: context.dataIdFromObject(storeObj),
typename: storeObj.__typename,
});
},
});
}
}
}
}
if (typeof fieldValue === 'undefined') {
if (!context.returnPartialData) {
throw new Error(
`Can't find field ${storeKeyName} on object (${objId}) ${JSON.stringify(
obj,
null,
2,
)}.`,
);
}
context.hasMissingField = true;
return fieldValue;
}
// if this is an object scalar, it must be a json blob and we have to unescape it
if (isJsonValue(fieldValue)) {
// If the JSON blob is the same now as in the previous result, return the previous result to
// maintain referential equality.
//
// `isEqual` will first perform a referential equality check (with `===`) in case the JSON
// value has not changed in the store, and then a deep equality check if that fails in case a
// new JSON object was returned by the API but that object may still be the same.
if (
idValue.previousResult &&
isEqual(idValue.previousResult[resultKey], fieldValue.json)
) {
return idValue.previousResult[resultKey];
}
return fieldValue.json;
}
// If we had a previous result, try adding that previous result value for this field to our field
// value. This will create a new value without mutating the old one.
if (idValue.previousResult) {
fieldValue = addPreviousResultToIdValues(
fieldValue,
idValue.previousResult[resultKey],
);
}
return fieldValue;
};