{"version":3,"sources":["../node_modules/graphql-tag/node_modules/tslib/tslib.es6.js","../../src/index.ts","../node_modules/graphql/language/printer.mjs","../../src/utilities/common/objects.ts","../node_modules/graphql/utilities/getOperationAST.mjs","../../src/core/index.ts","../node_modules/apollo-upload-client/node_modules/symbol-observable/es/index.js","../../src/utilities/common/environment.ts","../node_modules/apollo-upload-client/public/formDataAppendFile.js","../node_modules/apollo-upload-client/public/isExtractableFile.js","../../src/cache.ts","../../src/context.ts","../../src/helpers.ts","../../src/entry.ts","../../src/dep.ts","../../src/equality.ts","../../src/link/utils/fromError.ts","../../src/link/utils/toPromise.ts","../../src/link/utils/fromPromise.ts","../../src/link/utils/throwServerError.ts","../../src/link/utils/validateOperation.ts","../../src/link/utils/createOperation.ts","../../src/link/utils/transformOperation.ts","../../src/utilities/graphql/directives.ts","../../src/utilities/graphql/fragments.ts","../../src/utilities/graphql/storeUtils.ts","../../src/utilities/graphql/getFromAST.ts","../../src/utilities/common/filterInPlace.ts","../../src/utilities/graphql/transform.ts","../../src/utilities/common/mergeDeep.ts","../../src/utilities/observables/Observable.ts","../../src/utilities/common/cloneDeep.ts","../../src/utilities/common/maybeDeepFreeze.ts","../../src/utilities/observables/iteration.ts","../../src/utilities/observables/asyncMap.ts","../../src/utilities/observables/subclassing.ts","../../src/utilities/observables/Concast.ts","../../src/utilities/common/arrays.ts","../../src/utilities/common/errorHandling.ts","../../src/utilities/common/canUse.ts","../../src/utilities/common/compact.ts","../../src/react/hooks/useQuery.ts","../../src/react/hooks/useMutation.ts","../node_modules/apollo-upload-client/public/createUploadLink.js","../../src/link/core/split.ts","../../src/link/core/from.ts","../../src/react/context/ApolloProvider.tsx","../../src/react/hooks/useSubscription.ts","../../src/cache/core/cache.ts","../../src/cache/core/types/common.ts","../../src/cache/inmemory/entityStore.ts","../../src/cache/inmemory/readFromStore.ts","../../src/cache/inmemory/key-extractor.ts","../../src/cache/inmemory/policies.ts","../../src/utilities/common/stringifyForDisplay.ts","../../src/cache/inmemory/writeToStore.ts","../../src/cache/inmemory/inMemoryCache.ts","../node_modules/graphql/jsutils/isObjectLike.mjs","../node_modules/graphql/language/location.mjs","../node_modules/graphql/language/printLocation.mjs","../node_modules/graphql/error/GraphQLError.mjs","../node_modules/graphql/error/syntaxError.mjs","../node_modules/graphql/language/tokenKind.mjs","../node_modules/graphql/language/directiveLocation.mjs","../node_modules/graphql/language/lexer.mjs","../node_modules/graphql/language/parser.mjs","../../src/link/core/ApolloLink.ts","../../src/link/core/index.ts","../../src/cache/inmemory/object-canon.ts","../../src/errors/index.ts","../../src/utilities/globals/maybe.ts","../../src/cache/index.ts","../../src/cache/inmemory/reactiveVars.ts","../../src/invariant.ts","../../src/utilities/globals/DEV.ts","../../src/utilities/globals/fix-graphql.ts","../../src/utilities/globals/index.ts","../../src/react/parser/index.ts","../../src/react/hooks/useApolloClient.ts","../node_modules/apollo-upload-client/node_modules/graphql-tag/node_modules/tslib/tslib.es6.js","../../src/link/http/parseAndCheckHttpResponse.ts","../../src/link/http/serializeFetchParameter.ts","../../src/link/http/selectHttpOptionsAndBody.ts","../../src/link/http/checkFetcher.ts","../../src/link/http/createSignalIfSupported.ts","../../src/link/http/selectURI.ts","../../src/link/http/rewriteURIForGET.ts","../../src/link/http/createHttpLink.ts","../../src/link/http/HttpLink.ts","../../src/utilities/globals/global.ts","../node_modules/graphql/jsutils/nodejsCustomInspectSymbol.mjs","../../src/cache/inmemory/helpers.ts","../../src/core/Reobserver.ts","../../src/core/ObservableQuery.ts","../node_modules/graphql/jsutils/inspect.mjs","../node_modules/graphql/polyfills/symbols.mjs","../node_modules/graphql/language/blockString.mjs","../../src/react/context/ApolloContext.ts","../node_modules/graphql/language/kinds.mjs","../../src/core/LocalState.ts","../../src/core/QueryInfo.ts","../../src/core/QueryManager.ts","../../src/core/ApolloClient.ts","../../src/version.ts","../node_modules/@apollo/client/node_modules/ts-invariant/process/index.js","../node_modules/graphql/language/visitor.mjs","../node_modules/graphql/jsutils/devAssert.mjs","../node_modules/graphql/jsutils/instanceOf.mjs","../node_modules/graphql/language/source.mjs","../../src/link/core/empty.ts","../../src/link/core/concat.ts","../../src/link/core/execute.ts","../../src/cache/core/types/Cache.ts","../../src/core/networkStatus.ts","../../src/utilities/common/makeUniqueId.ts","../../src/link/ws/index.ts","../node_modules/apollo-upload-client/node_modules/ts-invariant/node_modules/tslib/tslib.es6.js","../node_modules/apollo-upload-client/node_modules/symbol-observable/es/ponyfill.js","../../src/link/error/index.ts","../node_modules/@apollo/client/node_modules/tslib/tslib.es6.js","../node_modules/graphql/jsutils/defineInspect.mjs","../node_modules/graphql/jsutils/invariant.mjs","../node_modules/graphql/language/ast.mjs"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","create","print","ast","visit","leave","printDocASTReducer","Name","node","value","Variable","name","Document","join","definitions","OperationDefinition","op","operation","varDefs","wrap","variableDefinitions","directives","selectionSet","VariableDefinition","_ref","variable","type","defaultValue","SelectionSet","_ref2","block","selections","Field","_ref3","alias","args","prefix","argsLine","indent","Argument","_ref4","FragmentSpread","_ref5","InlineFragment","_ref6","typeCondition","FragmentDefinition","_ref7","concat","IntValue","_ref8","FloatValue","_ref9","StringValue","_ref10","key","printBlockString","JSON","stringify","BooleanValue","_ref11","NullValue","EnumValue","_ref12","ListValue","_ref13","values","ObjectValue","_ref14","fields","ObjectField","_ref15","Directive","_ref16","NamedType","_ref17","ListType","_ref18","NonNullType","_ref19","SchemaDefinition","addDescription","_ref20","operationTypes","OperationTypeDefinition","_ref21","ScalarTypeDefinition","_ref22","ObjectTypeDefinition","_ref23","interfaces","FieldDefinition","_ref24","hasMultilineItems","InputValueDefinition","_ref25","InterfaceTypeDefinition","_ref26","UnionTypeDefinition","_ref27","types","EnumTypeDefinition","_ref28","EnumValueDefinition","_ref29","InputObjectTypeDefinition","_ref30","DirectiveDefinition","_ref31","repeatable","locations","SchemaExtension","_ref32","ScalarTypeExtension","_ref33","ObjectTypeExtension","_ref34","InterfaceTypeExtension","_ref35","UnionTypeExtension","_ref36","EnumTypeExtension","_ref37","InputObjectTypeExtension","_ref38","cb","description","maybeArray","_maybeArray$filter$jo","separator","undefined","filter","x","array","start","maybeString","end","str","replace","isMultiline","indexOf","some","isNonNullObject","obj","getOperationAST","documentAST","operationName","_i2","_documentAST$definiti2","_definition$name","definition","kind","Kind","OPERATION_DEFINITION","resetCaches","disableFragmentWarnings","enableExperimentalFragmentVariables","disableExperimentalFragmentVariables","root","self","window","global","module","ponyfill","exports","formData","fieldName","file","append","require","defaultDispose","max","dispose","map","Map","newest","oldest","has","get","getNode","older","newer","set","clean","size","delete","parentEntrySlot","maybeUnsubscribe","entryOrDep","unsubscribe","emptySetPool","assert","condition","optionalMessage","Error","valueGet","fn","parents","Set","childValues","dirtyChildren","dirty","recomputing","deps","Entry","count","peek","mightBeDirty","recompute","child","parent","getValue","add","reportDirtyChild","reportCleanChild","rememberParent","entry","forgetChildren","withValue","recomputeNewValue","subscribe","e","setDirty","maybeSubscribe","reportClean","setClean","reallyRecompute","reportDirty","forEach","forgetChild","dependOn","dep","pop","forgetDeps","clear","push","childValue","slice","a","b","len","valueIs","removeDirtyChild","dc","_value","options","depsByKey","depend","toString","fnToStr","Function","previousComparisons","equal","check","aTag","previouslyCompared","aKeys","definedKeys","bKeys","keyCount","k","message","aIterator","entries","isMap","info","next","done","aKey","aValue","aCode","full","suffix","fromIndex","endsWith","nativeCodeSuffix","keys","isDefinedKey","bSet","fromError","errorValue","observer","error","toPromise","observable","completed","Promise","resolve","reject","data","fromPromise","promise","then","complete","catch","bind","throwServerError","response","result","statusCode","status","createOperation","starting","context","defineProperty","enumerable","transformOperation","transformedOperation","variables","extensions","query","shouldInclude","directive","isInclusionDirective","directiveArguments","ifArgument","ifValue","getInclusionDirectives","every","evaledValue","hasDirectives","names","getDirectiveNames","hasClientExports","document","checkDocument","doc","operations","d","getOperationDefinition","getOperationName","getFragmentDefinitions","getQueryDefinition","queryDef","getMainDefinition","queryDoc","fragmentDefinition","getDefaultValues","defaultValues","defs","def","valueToObjectRepresentation","filterInPlace","test","target","elem","fragmentDef","modifiedDoc","selection","fakeObsSymbol","cloneDeep","cloneDeepHelper","val","seen","getPrototypeOf","iterateObserversSafely","observers","method","argument","observersWithMethod","obs","asyncMap","mapFn","catchFn","activeCallbackCount","promiseQueue","callback","makeCallback","examiner","delegate","arg","both","handler","caught","sub","isPromiseLike","sources","addObserver","removeObserver","addCount","handlers","latest","shift","cancel","reason","_","iterable","Array","from","deliverLastMessage","nextOrError","quietly","cleanup","called","once","isNonEmptyArray","isArray","graphQLResultHasError","errors","fixObservableSubclass","canUseWeakMap","WeakMap","navigator","product","compact","objects","mergeDeep","mergeDeepArray","merger","DeepMerger","merge","defaultReconciler","source","property","reconciler","isObject","pastCopies","sourceKey","targetValue","shallowCopyForMerge","isFrozen","__proto__","directiveName","useQuery","client","defaultWatchQueryOptions","defaultOptions","watchQuery","Query","partial","watchQueryOptions","createWatchQueryOptions","obsQuery","renderPromises","getSSRObservable","registerSSRObservable","ssr","skip","getCurrentResult","loading","addQueryPromise","getOptions","fetchData","setObsQuery","onError","onCompleted","setResult","ref","previousData","nextResult","current","setOptions","previousResult","subscription","onNext","last","resetLastResults","networkStatus","disableNetworkFetches","partialRefetch","fetchPolicy","refetch","ready","graphQLErrors","obsQueryFields","fetchMore","updateQuery","startPolling","stopPolling","subscribeToMore","otherOptions","useMutation","mutation","Mutation","mutationId","isMounted","execute","executeOptions","baseOptions","ignoreResults","clientOptions","mutate","reset","_extends","_require","ApolloLink","Observable","_require2","createSignalIfSupported","fallbackHttpConfig","parseAndCheckHttpResponse","rewriteURIForGET","selectHttpOptionsAndBody","selectURI","serializeFetchParameter","extractFiles","formDataAppendFile","isExtractableFile","_temp","_ref$uri","uri","fetchUri","useGETForQueries","_ref$isExtractableFil","customIsExtractableFile","CustomFormData","FormData","_ref$formDataAppendFi","customFormDataAppendFile","customFetch","fetch","fetchOptions","credentials","headers","linkConfig","http","includeExtensions","getContext","_context$clientAwaren","clientAwareness","version","contextConfig","_selectHttpOptionsAnd","body","_extractFiles","clone","files","form","paths","_rewriteURIForGET","newURI","parseError","controller","signal","addEventListener","abort","runtimeFetch","cleaningUp","setContext","split","ApolloProvider","children","ApolloContext","Provider","makeReference","id","__ref","String","isReference","Boolean","isDocumentNode","argObj","isIntValue","isFloatValue","Number","isBooleanValue","isStringValue","isObjectValue","isVariable","variableValue","isListValue","listValue","nestedArgArrayObj","isEnumValue","isNullValue","storeKeyNameFromField","field","directivesObj","getStoreKeyName","KNOWN_DIRECTIVES","filterKeys","sort","completeFieldName","stringifiedArgs","setStringify","previous","stringifyReplacer","_key","reduce","copy","argumentsObjectFromField","resultKeyNameFromField","getTypenameFromResult","fragmentMap","__typename","isField","typename","isInlineFragment","useSubscription","Subscription","setObservable","shouldResubscribe","fetchResult","onSubscriptionData","subscriptionData","onSubscriptionComplete","deepFreeze","workSet","__DEV__","freeze","TypeError","shallowFreeze","getOwnPropertyNames","maybeDeepFreeze","specifierInfoCache","lookupSpecifierInfo","spec","cacheKey","keyFieldsFnFromSpecifier","specifier","keyFieldsFn","object","extract","readField","keyObject","collectSpecifierPaths","schemaKeyPath","extracted","extractKeyPath","storeObject","extractKey","keyArgsFnFromSpecifier","keyArgsFn","collected","keyPath","firstKey","firstChar","charAt","variableName","varKeyPath","find","directiveArgs","extractor","getSpecifierPaths","path","toMerge","normalize","reducer","storeFieldName","undefId","makeUniqueId","_typeof","Symbol","iterator","constructor","getLocation","position","match","lineRegexp","line","column","exec","index","printLocation","location","printSourceLocation","sourceLocation","firstLineColumnOffset","locationOffset","whitespace","lineIndex","lineOffset","lineNum","columnOffset","columnNum","locationStr","lines","locationLine","subLineIndex","Math","floor","subLineColumnNum","subLines","printPrefixedLines","subLine","existingLines","padLen","_defineProperties","props","descriptor","configurable","writable","_possibleConstructorReturn","_assertThisInitialized","ReferenceError","_wrapNativeSuper","Class","_cache","Wrapper","_construct","_getPrototypeOf","_setPrototypeOf","Parent","_isNativeReflectConstruct","Reflect","construct","instance","sham","Proxy","Date","o","setPrototypeOf","GraphQLError","_Error","subClass","superClass","_inherits","Constructor","protoProps","staticProps","_super","Derived","hasNativeReflectConstruct","Super","NewTarget","_createSuper","nodes","positions","originalError","_locations2","_source2","_positions2","_extensions2","_this","_classCallCheck","_nodes$0$loc","_nodes","_source","loc","_locations","_positions","list","pos","_extensions","originalExtensions","defineProperties","stack","captureStackTrace","output","_error$nodes2","_i4","_error$locations2","printError","SYMBOL_TO_STRING_TAG","syntaxError","TokenKind","SOF","EOF","BANG","DOLLAR","AMP","PAREN_L","PAREN_R","SPREAD","COLON","EQUALS","AT","BRACKET_L","BRACKET_R","BRACE_L","PIPE","BRACE_R","NAME","INT","FLOAT","STRING","BLOCK_STRING","COMMENT","DirectiveLocation","QUERY","MUTATION","SUBSCRIPTION","FIELD","FRAGMENT_DEFINITION","FRAGMENT_SPREAD","INLINE_FRAGMENT","VARIABLE_DEFINITION","SCHEMA","SCALAR","OBJECT","FIELD_DEFINITION","ARGUMENT_DEFINITION","INTERFACE","UNION","ENUM","ENUM_VALUE","INPUT_OBJECT","INPUT_FIELD_DEFINITION","Lexer","startOfFileToken","Token","lastToken","token","lineStart","_proto","advance","lookahead","_token$next","readToken","printCharCode","code","isNaN","fromCharCode","toUpperCase","lexer","prev","bodyLength","charCodeAt","_line","_col","readComment","readBlockString","readString","readNumber","readName","unexpectedCharacterMessage","col","firstCode","isFloat","readDigits","isNameStart","c","chunkStart","charCode","char2hex","invalidSequence","rawValue","dedentBlockStringValue","parse","Parser","parseDocument","sourceObj","isSource","Source","_lexer","_options","parseName","expectToken","DOCUMENT","many","parseDefinition","parseOperationDefinition","parseFragmentDefinition","parseTypeSystemDefinition","parseTypeSystemExtension","peekDescription","unexpected","parseSelectionSet","parseOperationType","parseVariableDefinitions","parseDirectives","operationToken","optionalMany","parseVariableDefinition","parseVariable","parseTypeReference","expectOptionalToken","parseValueLiteral","VARIABLE","SELECTION_SET","parseSelection","parseFragment","parseField","nameOrAlias","parseArguments","isConst","item","parseConstArgument","parseArgument","ARGUMENT","hasTypeCondition","expectOptionalKeyword","parseFragmentName","parseNamedType","_this$_options","expectKeyword","experimentalFragmentVariables","parseList","parseObject","parseStringLiteral","BOOLEAN","NULL","LIST","any","_this2","parseObjectField","OBJECT_FIELD","parseDirective","DIRECTIVE","LIST_TYPE","NON_NULL_TYPE","NAMED_TYPE","keywordToken","parseSchemaDefinition","parseScalarTypeDefinition","parseObjectTypeDefinition","parseInterfaceTypeDefinition","parseUnionTypeDefinition","parseEnumTypeDefinition","parseInputObjectTypeDefinition","parseDirectiveDefinition","parseDescription","parseOperationTypeDefinition","SCHEMA_DEFINITION","OPERATION_TYPE_DEFINITION","SCALAR_TYPE_DEFINITION","parseImplementsInterfaces","parseFieldsDefinition","OBJECT_TYPE_DEFINITION","_this$_options2","allowLegacySDLImplementsInterfaces","delimitedMany","_this$_options3","allowLegacySDLEmptyFields","parseFieldDefinition","parseArgumentDefs","parseInputValueDef","INPUT_VALUE_DEFINITION","INTERFACE_TYPE_DEFINITION","parseUnionMemberTypes","UNION_TYPE_DEFINITION","parseEnumValuesDefinition","ENUM_TYPE_DEFINITION","parseEnumValueDefinition","ENUM_VALUE_DEFINITION","parseInputFieldsDefinition","INPUT_OBJECT_TYPE_DEFINITION","parseSchemaExtension","parseScalarTypeExtension","parseObjectTypeExtension","parseInterfaceTypeExtension","parseUnionTypeExtension","parseEnumTypeExtension","parseInputObjectTypeExtension","SCHEMA_EXTENSION","SCALAR_TYPE_EXTENSION","OBJECT_TYPE_EXTENSION","INTERFACE_TYPE_EXTENSION","UNION_TYPE_EXTENSION","ENUM_TYPE_EXTENSION","INPUT_OBJECT_TYPE_EXTENSION","parseDirectiveLocations","DIRECTIVE_DEFINITION","parseDirectiveLocation","startToken","_this$_options4","noLocation","Location","getTokenKindDesc","getTokenDesc","atToken","openKind","parseFn","closeKind","delimiterKind","isPunctuatorTokenKind","TYPENAME_FIELD","isEmpty","fragments","nullIfDocIsEmpty","getDirectiveMatcher","dir","removeDirectivesFromDocument","variablesInUse","variablesToRemove","fragmentSpreadsInUse","fragmentSpreadsToRemove","enter","getAllFragmentSpreadsFromSelectionSet","frag","v","config","argMatcher","aConfig","getArgumentMatcher","varDef","argConfig","removeArgumentsFromDocument","fs","removeFragmentSpreadFromDocument","addTypenameToDocument","lastIndexOf","added","connectionRemoveConfig","willRemove","removeConnectionDirectiveFromDocument","allFragments","buildQueryFromSelectionSet","removeClientSetsFromDocument","remove","passthrough","forward","of","toLink","isTerminating","link","request","empty","links","y","left","right","leftLink","rightLink","first","second","firstLink","nextLink","setOnError","stringifyCanon","stringifyCache","known","WeakSet","pool","passes","keysByJSON","admit","isKnown","pass","shallowCopy","original","lookupArray","sortedKeys","json","sorted","canonicalStringify","resetCanonicalStringify","canonical","ObjectCanon","maybe","thunk","isApolloError","err","networkError","errorMessage","extraInfo","graphQLError","generateErrorMessage","ApolloError","cacheSlot","cacheInfoMap","getCacheInfo","cache","vars","forgetCache","rv","recallCache","attachCache","makeVar","caches","listeners","newValue","broadcast","oldListeners","listener","attach","onNextChange","broadcastWatches","genericMessage","proto","framesToPop","InvariantError","invariant","verbosityLevels","verbosityLevel","wrapConsoleMethod","__","GLOBAL_KEY","DocumentType","cached","queries","mutations","subscriptions","OPERATION_FIELDS","validateOperation","getFragmentDefinition","clientOnly","useApolloClient","override","canUseWeakSet","canUseSymbol","for","text","bodyText","label","serialized","configs","fetcher","AbortController","fallbackURI","contextURI","chosenURI","queryParams","addQueryParam","encodeURIComponent","serializedVariables","serializedExtensions","fragment","preFragment","fragmentStart","substr","queryParamsPrefix","clientAwarenessHeaders","globalThis","argsFromFieldSpecifier","defaultDataIdFromObject","_id","nullKeyFieldsFn","simpleKeyArgsFn","_args","mergeTrueFn","existing","incoming","mergeObjects","mergeFalseFn","typePolicies","toBeAdded","supertypeMap","fuzzySubtypes","rootIdsByTypename","rootTypenamesById","usingPossibleTypes","dataIdFromObject","setRootTypename","possibleTypes","addPossibleTypes","addTypePolicies","identify","ROOT_QUERY","policy","getTypePolicy","keyFn","specifierOrId","queryType","mutationType","subscriptionType","updateTypePolicy","keyFields","setMerge","getFieldPolicy","read","keyArgs","which","rootId","old","supertype","getSupertypeSet","subtype","RegExp","supertypes","rest","inbox","splice","createIfMissing","fieldPolicies","supertypeSet","fragmentMatches","typenameSupertypeSet","needToCheckFuzzySubtypes","regExp","fuzzyString","hasKeyArgs","getStoreFieldName","fieldSpec","specifierOrString","objectOrReference","store","getFieldValue","readOptions","makeFieldFunctionOptions","getStorage","getMergeFunction","parentTypename","childTypename","runMergeFunction","storage","makeMergeObjectsFunction","policies","toReference","canRead","fieldNameOrOptions","eType","iType","computeKeyObject","trie","aliasMap","makeAliasMap","workQueue","responseKey","storeKey","aliases","subsets","strict","prevKey","keyObj","subset","responseName","console","setVerbosity","level","log","warn","nodejsCustomInspectSymbol","getFragmentDoc","recordOptimisticTransaction","transaction","optimisticId","performTransaction","transformDocument","gc","modify","transformForLink","readQuery","optimistic","returnPartialData","readFragment","fragmentName","writeQuery","write","dataId","writeFragment","shouldFetch","reobserve","newOptions","newNetworkStatus","updateOptions","updatePolling","concast","stop","pollingInfo","clearTimeout","timeout","pollInterval","interval","maybeFetch","nextFetchPolicy","poll","setTimeout","inspect","formatValue","seenValues","previouslySeenValues","customInspectFn","getCustomFn","customValue","min","remaining","items","formatArray","tag","getObjectTag","formatObject","formatObjectValue","asyncIterator","toStringTag","rawString","commonIndent","_commonIndent","isFirstLine","isEmptyLine","getBlockStringIndentation","startLine","isBlank","endLine","indentation","preferMultipleLines","isSingleLine","hasLeadingSpace","hasTrailingQuote","hasTrailingSlash","printAsMultipleLines","getFragmentQueryDocument","actualFragmentName","createFragmentMap","symTable","getFragmentFromSelection","contextKey","getApolloContext","displayName","definitionOperation","aliasedFieldName","mutationStoreValue","queryManager","safeGlobal","needToRemove","process","env","NODE_ENV","QueryDocumentKeys","BREAK","visitor","visitorKeys","inArray","edits","ancestors","newRoot","isLeaving","isEdited","_Object$keys2","editOffset","ii","editKey","editValue","_visitorKeys$node$kin","isNode","visitFn","getVisitFn","kindVisitor","kindSpecificVisitor","specificVisitor","specificKindVisitor","devAssert","instanceOf","Cache","NetworkStatus","isNetworkRequestInFlight","DELETE","delModifier","INVALIDATE","group","rootIds","refs","objOrRef","objOrIdOrRef","mergeIntoStore","toObject","lookup","dependOnExistence","merged","storeObjectReconciler","caching","__exists","fieldValue","evict","evicted","extraRootIds","getRootIdSet","__META","newData","retain","release","ids","snapshot","findChildRefIds","idsToRemove","makeCacheKey","keyMaker","makeDepKey","EntityStore","resultCaching","seed","storageTrie","sharedLayerGroup","addLayer","layerId","replay","removeLayer","Root","Layer","fromParent","existingObject","incomingObject","existingValue","incomingValue","supportsResultCaching","missingFromInvariant","executeSelectionSet","execSelectionSetImpl","varString","knownResults","executeSubSelectedArray","execSubSelectedArrayImpl","addTypename","diffQueryAgainstStore","execResult","hasMissingFields","missing","isFresh","objectsToMerge","finalResult","getMissing","handleMissing","resultName","wasClientOnly","childResult","reader","writeToStore","operationDefinition","processSelectionSet","mergeTree","written","sets","incomingFields","resultFieldKey","childTree","getChildMergeTree","processFieldValue","maybeRecycleChildMergeTree","applyMerges","getStorageArgs","eVal","iVal","aVal","emptyMergeTreePool","defaultConfig","watches","typenameDocumentCache","txCount","maybeBroadcastWatch","fromOptimisticTransaction","broadcastWatch","optimisticData","watchDep","storeWriter","storeReader","restore","diff","watch","immediate","forget","removeOptimistic","idToRemove","newOptimisticData","perform","layer","hasOwn","TypeOrFieldNameRegExp","fieldNameFromStoreName","selectionSetMatchesResult","storeValueIsStoreObject","makeProcessedFieldsMerger","prefixCounts","random","paramsOrClient","subscriptionClient","webSocketImpl","extendStatics","__extends","symbolObservablePonyfill","errorHandler","retriedSub","retriedResult","includeQuery","accept","defaultPrinter","printer","selectHttpOptionsAndBodyInternal","headersToLowerCase","toLowerCase","backupFetch","linkOptions","preferredFetch","includeUnusedVariables","requestOptions","contextHeaders","_controller","subclass","canUse","species","warnedAboutUpdateQuery","queryInfo","subObserver","_subscription","_observer","defaultSubscriptionObserverErrorCallback","tearDownQuery","isTornDown","queryId","generateQueryId","opDef","queryName","initialFetchPolicy","removeQuery","saveAsLastResult","lastResult","getLastResult","transform","hasForcedResolvers","getDiff","logMissingFieldErrors","updateLastResult","isDifferentFromLastResult","newResult","getLast","variablesMustMatch","getLastError","resetQueryStoreErrors","resetErrors","reobserveOptions","resetLastWrite","fetchMoreOptions","combinedOptions","qid","notifyOnNetworkStatusChange","observe","fetchQuery","fetchMoreResult","finally","stopQuery","startGraphQLSubscription","setVariables","broadcastQueries","setObservableQuery","fetchQueryObservable","ssrMode","assumeImmutableResults","useDisposableConcast","oldVariables","reportResult","reportError","lastError","errorResult","hasObservers","resolvers","fragmentMatcher","addResolvers","setFragmentMatcher","resolverGroup","setResolvers","getResolvers","runResolvers","remoteResult","onlyRunForcedResolvers","resolveDocument","localResult","getFragmentMatcher","clientQuery","serverQuery","prepareContext","getCacheKey","addExportedVariables","buildRootValueFromCache","shouldForceResolvers","forceResolvers","rootValue","mainDefinition","defaultOperationType","execContext","exportedVariables","resolveSelectionSet","resultsToMerge","resolveField","fieldResult","fragmentResult","all","aliasUsed","defaultResult","resultPromise","resolverType","resolverMap","resolveSubSelectedArray","destructiveMethodCounts","wrapDestructiveCacheMethod","methodName","cancelNotifyTimeout","lastRequestId","stopped","observableQuery","init","lastDiff","getDiffOptions","updateWatch","oq","updateLastDiff","canonizeResults","setDiff","oldDiff","notifyTimeout","oqListener","notify","shouldNotify","QueryInfo","watchOptions","watcher","lastWatch","lastWrite","shouldWrite","dmCount","markResult","cacheWriteBehavior","shouldWriteResult","errorPolicy","overwrite","diffOptions","markReady","markError","ignoreErrors","writeWithErrors","queryDeduplication","onBroadcast","localState","fetchCancelFns","transformCache","queryIdCounter","requestIdCounter","mutationIdCounter","inFlightLinkObservables","mutationStore","_info","stopQueryNoBroadcast","cancelPendingFetches","optimisticResponse","updateQueries","refetchQueries","awaitRefetchQueries","updateWithProxyFn","onQueryUpdated","keepRootFields","update","stopQueryInStore","queryNamesAndDocs","legacyQueryOptions","includedQueriesById","oldNetworkStatus","hasSuggestedDevtools","mergeOptions","defaults","resetStoreCallbacks","clearStoreCallbacks","ssrForceFetchDelay","connectToDevTools","__APOLLO_CLIENT__","typeDefs","clientAwarenessName","clientAwarenessVersion","resetStore","reFetchObservableQueries","top","__APOLLO_DEVTOOLS_GLOBAL_HOOK__","nav","ua","userAgent","url","devToolsHookCb","action","state","getQueryStore","dataWithOptimisticResults","__actionHookForDevTools","__requestRaw","payload","clearStore","discardWatches","onResetStore","onClearStore","includeStandby","results","getObservableQueries","include","serializedState","setLocalStateFragmentMatcher","setLink","newLink","__rest","getOwnPropertySymbols","propertyIsEnumerable","__awaiter","thisArg","_arguments","P","generator","fulfilled","step","rejected","__generator","f","g","sent","trys","ops","verb","__spreadArray","to","pack","ar","l","defineInspect","classObject","toJSON","endToken","maybeNode"],"mappings":"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","file":"static/js/apollo-lib.c20f687d.chunk.js","sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { __assign } from \"tslib\";\nimport { parse } from 'graphql';\nvar docCache = new Map();\nvar fragmentSourceMap = new Map();\nvar printFragmentWarnings = true;\nvar experimentalFragmentVariables = false;\nfunction normalize(string) {\n return string.replace(/[\\s,]+/g, ' ').trim();\n}\nfunction cacheKeyFromLoc(loc) {\n return normalize(loc.source.body.substring(loc.start, loc.end));\n}\nfunction processFragments(ast) {\n var seenKeys = new Set();\n var definitions = [];\n ast.definitions.forEach(function (fragmentDefinition) {\n if (fragmentDefinition.kind === 'FragmentDefinition') {\n var fragmentName = fragmentDefinition.name.value;\n var sourceKey = cacheKeyFromLoc(fragmentDefinition.loc);\n var sourceKeySet = fragmentSourceMap.get(fragmentName);\n if (sourceKeySet && !sourceKeySet.has(sourceKey)) {\n if (printFragmentWarnings) {\n console.warn(\"Warning: fragment with name \" + fragmentName + \" already exists.\\n\"\n + \"graphql-tag enforces all fragment names across your application to be unique; read more about\\n\"\n + \"this in the docs: http://dev.apollodata.com/core/fragments.html#unique-names\");\n }\n }\n else if (!sourceKeySet) {\n fragmentSourceMap.set(fragmentName, sourceKeySet = new Set);\n }\n sourceKeySet.add(sourceKey);\n if (!seenKeys.has(sourceKey)) {\n seenKeys.add(sourceKey);\n definitions.push(fragmentDefinition);\n }\n }\n else {\n definitions.push(fragmentDefinition);\n }\n });\n return __assign(__assign({}, ast), { definitions: definitions });\n}\nfunction stripLoc(doc) {\n var workSet = new Set(doc.definitions);\n workSet.forEach(function (node) {\n if (node.loc)\n delete node.loc;\n Object.keys(node).forEach(function (key) {\n var value = node[key];\n if (value && typeof value === 'object') {\n workSet.add(value);\n }\n });\n });\n var loc = doc.loc;\n if (loc) {\n delete loc.startToken;\n delete loc.endToken;\n }\n return doc;\n}\nfunction parseDocument(source) {\n var cacheKey = normalize(source);\n if (!docCache.has(cacheKey)) {\n var parsed = parse(source, {\n experimentalFragmentVariables: experimentalFragmentVariables\n });\n if (!parsed || parsed.kind !== 'Document') {\n throw new Error('Not a valid GraphQL document.');\n }\n docCache.set(cacheKey, stripLoc(processFragments(parsed)));\n }\n return docCache.get(cacheKey);\n}\nexport function gql(literals) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n if (typeof literals === 'string') {\n literals = [literals];\n }\n var result = literals[0];\n args.forEach(function (arg, i) {\n if (arg && arg.kind === 'Document') {\n result += arg.loc.source.body;\n }\n else {\n result += arg;\n }\n result += literals[i + 1];\n });\n return parseDocument(result);\n}\nexport function resetCaches() {\n docCache.clear();\n fragmentSourceMap.clear();\n}\nexport function disableFragmentWarnings() {\n printFragmentWarnings = false;\n}\nexport function enableExperimentalFragmentVariables() {\n experimentalFragmentVariables = true;\n}\nexport function disableExperimentalFragmentVariables() {\n experimentalFragmentVariables = false;\n}\nvar extras = {\n gql: gql,\n resetCaches: resetCaches,\n disableFragmentWarnings: disableFragmentWarnings,\n enableExperimentalFragmentVariables: enableExperimentalFragmentVariables,\n disableExperimentalFragmentVariables: disableExperimentalFragmentVariables\n};\n(function (gql_1) {\n gql_1.gql = extras.gql, gql_1.resetCaches = extras.resetCaches, gql_1.disableFragmentWarnings = extras.disableFragmentWarnings, gql_1.enableExperimentalFragmentVariables = extras.enableExperimentalFragmentVariables, gql_1.disableExperimentalFragmentVariables = extras.disableExperimentalFragmentVariables;\n})(gql || (gql = {}));\ngql[\"default\"] = gql;\nexport default gql;\n//# sourceMappingURL=index.js.map","import { visit } from \"./visitor.mjs\";\nimport { printBlockString } from \"./blockString.mjs\";\n/**\n * Converts an AST into a string, using one set of reasonable\n * formatting rules.\n */\n\nexport function print(ast) {\n return visit(ast, {\n leave: printDocASTReducer\n });\n}\nvar MAX_LINE_LENGTH = 80; // TODO: provide better type coverage in future\n\nvar printDocASTReducer = {\n Name: function Name(node) {\n return node.value;\n },\n Variable: function Variable(node) {\n return '$' + node.name;\n },\n // Document\n Document: function Document(node) {\n return join(node.definitions, '\\n\\n') + '\\n';\n },\n OperationDefinition: function OperationDefinition(node) {\n var op = node.operation;\n var name = node.name;\n var varDefs = wrap('(', join(node.variableDefinitions, ', '), ')');\n var directives = join(node.directives, ' ');\n var selectionSet = node.selectionSet; // Anonymous queries with no directives or variable definitions can use\n // the query short form.\n\n return !name && !directives && !varDefs && op === 'query' ? selectionSet : join([op, join([name, varDefs]), directives, selectionSet], ' ');\n },\n VariableDefinition: function VariableDefinition(_ref) {\n var variable = _ref.variable,\n type = _ref.type,\n defaultValue = _ref.defaultValue,\n directives = _ref.directives;\n return variable + ': ' + type + wrap(' = ', defaultValue) + wrap(' ', join(directives, ' '));\n },\n SelectionSet: function SelectionSet(_ref2) {\n var selections = _ref2.selections;\n return block(selections);\n },\n Field: function Field(_ref3) {\n var alias = _ref3.alias,\n name = _ref3.name,\n args = _ref3.arguments,\n directives = _ref3.directives,\n selectionSet = _ref3.selectionSet;\n var prefix = wrap('', alias, ': ') + name;\n var argsLine = prefix + wrap('(', join(args, ', '), ')');\n\n if (argsLine.length > MAX_LINE_LENGTH) {\n argsLine = prefix + wrap('(\\n', indent(join(args, '\\n')), '\\n)');\n }\n\n return join([argsLine, join(directives, ' '), selectionSet], ' ');\n },\n Argument: function Argument(_ref4) {\n var name = _ref4.name,\n value = _ref4.value;\n return name + ': ' + value;\n },\n // Fragments\n FragmentSpread: function FragmentSpread(_ref5) {\n var name = _ref5.name,\n directives = _ref5.directives;\n return '...' + name + wrap(' ', join(directives, ' '));\n },\n InlineFragment: function InlineFragment(_ref6) {\n var typeCondition = _ref6.typeCondition,\n directives = _ref6.directives,\n selectionSet = _ref6.selectionSet;\n return join(['...', wrap('on ', typeCondition), join(directives, ' '), selectionSet], ' ');\n },\n FragmentDefinition: function FragmentDefinition(_ref7) {\n var name = _ref7.name,\n typeCondition = _ref7.typeCondition,\n variableDefinitions = _ref7.variableDefinitions,\n directives = _ref7.directives,\n selectionSet = _ref7.selectionSet;\n return (// Note: fragment variable definitions are experimental and may be changed\n // or removed in the future.\n \"fragment \".concat(name).concat(wrap('(', join(variableDefinitions, ', '), ')'), \" \") + \"on \".concat(typeCondition, \" \").concat(wrap('', join(directives, ' '), ' ')) + selectionSet\n );\n },\n // Value\n IntValue: function IntValue(_ref8) {\n var value = _ref8.value;\n return value;\n },\n FloatValue: function FloatValue(_ref9) {\n var value = _ref9.value;\n return value;\n },\n StringValue: function StringValue(_ref10, key) {\n var value = _ref10.value,\n isBlockString = _ref10.block;\n return isBlockString ? printBlockString(value, key === 'description' ? '' : ' ') : JSON.stringify(value);\n },\n BooleanValue: function BooleanValue(_ref11) {\n var value = _ref11.value;\n return value ? 'true' : 'false';\n },\n NullValue: function NullValue() {\n return 'null';\n },\n EnumValue: function EnumValue(_ref12) {\n var value = _ref12.value;\n return value;\n },\n ListValue: function ListValue(_ref13) {\n var values = _ref13.values;\n return '[' + join(values, ', ') + ']';\n },\n ObjectValue: function ObjectValue(_ref14) {\n var fields = _ref14.fields;\n return '{' + join(fields, ', ') + '}';\n },\n ObjectField: function ObjectField(_ref15) {\n var name = _ref15.name,\n value = _ref15.value;\n return name + ': ' + value;\n },\n // Directive\n Directive: function Directive(_ref16) {\n var name = _ref16.name,\n args = _ref16.arguments;\n return '@' + name + wrap('(', join(args, ', '), ')');\n },\n // Type\n NamedType: function NamedType(_ref17) {\n var name = _ref17.name;\n return name;\n },\n ListType: function ListType(_ref18) {\n var type = _ref18.type;\n return '[' + type + ']';\n },\n NonNullType: function NonNullType(_ref19) {\n var type = _ref19.type;\n return type + '!';\n },\n // Type System Definitions\n SchemaDefinition: addDescription(function (_ref20) {\n var directives = _ref20.directives,\n operationTypes = _ref20.operationTypes;\n return join(['schema', join(directives, ' '), block(operationTypes)], ' ');\n }),\n OperationTypeDefinition: function OperationTypeDefinition(_ref21) {\n var operation = _ref21.operation,\n type = _ref21.type;\n return operation + ': ' + type;\n },\n ScalarTypeDefinition: addDescription(function (_ref22) {\n var name = _ref22.name,\n directives = _ref22.directives;\n return join(['scalar', name, join(directives, ' ')], ' ');\n }),\n ObjectTypeDefinition: addDescription(function (_ref23) {\n var name = _ref23.name,\n interfaces = _ref23.interfaces,\n directives = _ref23.directives,\n fields = _ref23.fields;\n return join(['type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n }),\n FieldDefinition: addDescription(function (_ref24) {\n var name = _ref24.name,\n args = _ref24.arguments,\n type = _ref24.type,\n directives = _ref24.directives;\n return name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + ': ' + type + wrap(' ', join(directives, ' '));\n }),\n InputValueDefinition: addDescription(function (_ref25) {\n var name = _ref25.name,\n type = _ref25.type,\n defaultValue = _ref25.defaultValue,\n directives = _ref25.directives;\n return join([name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')], ' ');\n }),\n InterfaceTypeDefinition: addDescription(function (_ref26) {\n var name = _ref26.name,\n interfaces = _ref26.interfaces,\n directives = _ref26.directives,\n fields = _ref26.fields;\n return join(['interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n }),\n UnionTypeDefinition: addDescription(function (_ref27) {\n var name = _ref27.name,\n directives = _ref27.directives,\n types = _ref27.types;\n return join(['union', name, join(directives, ' '), types && types.length !== 0 ? '= ' + join(types, ' | ') : ''], ' ');\n }),\n EnumTypeDefinition: addDescription(function (_ref28) {\n var name = _ref28.name,\n directives = _ref28.directives,\n values = _ref28.values;\n return join(['enum', name, join(directives, ' '), block(values)], ' ');\n }),\n EnumValueDefinition: addDescription(function (_ref29) {\n var name = _ref29.name,\n directives = _ref29.directives;\n return join([name, join(directives, ' ')], ' ');\n }),\n InputObjectTypeDefinition: addDescription(function (_ref30) {\n var name = _ref30.name,\n directives = _ref30.directives,\n fields = _ref30.fields;\n return join(['input', name, join(directives, ' '), block(fields)], ' ');\n }),\n DirectiveDefinition: addDescription(function (_ref31) {\n var name = _ref31.name,\n args = _ref31.arguments,\n repeatable = _ref31.repeatable,\n locations = _ref31.locations;\n return 'directive @' + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + (repeatable ? ' repeatable' : '') + ' on ' + join(locations, ' | ');\n }),\n SchemaExtension: function SchemaExtension(_ref32) {\n var directives = _ref32.directives,\n operationTypes = _ref32.operationTypes;\n return join(['extend schema', join(directives, ' '), block(operationTypes)], ' ');\n },\n ScalarTypeExtension: function ScalarTypeExtension(_ref33) {\n var name = _ref33.name,\n directives = _ref33.directives;\n return join(['extend scalar', name, join(directives, ' ')], ' ');\n },\n ObjectTypeExtension: function ObjectTypeExtension(_ref34) {\n var name = _ref34.name,\n interfaces = _ref34.interfaces,\n directives = _ref34.directives,\n fields = _ref34.fields;\n return join(['extend type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n },\n InterfaceTypeExtension: function InterfaceTypeExtension(_ref35) {\n var name = _ref35.name,\n interfaces = _ref35.interfaces,\n directives = _ref35.directives,\n fields = _ref35.fields;\n return join(['extend interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n },\n UnionTypeExtension: function UnionTypeExtension(_ref36) {\n var name = _ref36.name,\n directives = _ref36.directives,\n types = _ref36.types;\n return join(['extend union', name, join(directives, ' '), types && types.length !== 0 ? '= ' + join(types, ' | ') : ''], ' ');\n },\n EnumTypeExtension: function EnumTypeExtension(_ref37) {\n var name = _ref37.name,\n directives = _ref37.directives,\n values = _ref37.values;\n return join(['extend enum', name, join(directives, ' '), block(values)], ' ');\n },\n InputObjectTypeExtension: function InputObjectTypeExtension(_ref38) {\n var name = _ref38.name,\n directives = _ref38.directives,\n fields = _ref38.fields;\n return join(['extend input', name, join(directives, ' '), block(fields)], ' ');\n }\n};\n\nfunction addDescription(cb) {\n return function (node) {\n return join([node.description, cb(node)], '\\n');\n };\n}\n/**\n * Given maybeArray, print an empty string if it is null or empty, otherwise\n * print all items together separated by separator if provided\n */\n\n\nfunction join(maybeArray) {\n var _maybeArray$filter$jo;\n\n var separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n return (_maybeArray$filter$jo = maybeArray === null || maybeArray === void 0 ? void 0 : maybeArray.filter(function (x) {\n return x;\n }).join(separator)) !== null && _maybeArray$filter$jo !== void 0 ? _maybeArray$filter$jo : '';\n}\n/**\n * Given array, print each item on its own line, wrapped in an\n * indented \"{ }\" block.\n */\n\n\nfunction block(array) {\n return wrap('{\\n', indent(join(array, '\\n')), '\\n}');\n}\n/**\n * If maybeString is not null or empty, then wrap with start and end, otherwise print an empty string.\n */\n\n\nfunction wrap(start, maybeString) {\n var end = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';\n return maybeString != null && maybeString !== '' ? start + maybeString + end : '';\n}\n\nfunction indent(str) {\n return wrap(' ', str.replace(/\\n/g, '\\n '));\n}\n\nfunction isMultiline(str) {\n return str.indexOf('\\n') !== -1;\n}\n\nfunction hasMultilineItems(maybeArray) {\n return maybeArray != null && maybeArray.some(isMultiline);\n}\n","export function isNonNullObject(obj: any): obj is Record {\n return obj !== null && typeof obj === 'object';\n}\n","import { Kind } from \"../language/kinds.mjs\";\n/**\n * Returns an operation AST given a document AST and optionally an operation\n * name. If a name is not provided, an operation is only returned if only one is\n * provided in the document.\n */\n\nexport function getOperationAST(documentAST, operationName) {\n var operation = null;\n\n for (var _i2 = 0, _documentAST$definiti2 = documentAST.definitions; _i2 < _documentAST$definiti2.length; _i2++) {\n var definition = _documentAST$definiti2[_i2];\n\n if (definition.kind === Kind.OPERATION_DEFINITION) {\n var _definition$name;\n\n if (operationName == null) {\n // If no operation name was provided, only return an Operation if there\n // is one defined in the document. Upon encountering the second, return\n // null.\n if (operation) {\n return null;\n }\n\n operation = definition;\n } else if (((_definition$name = definition.name) === null || _definition$name === void 0 ? void 0 : _definition$name.value) === operationName) {\n return definition;\n }\n }\n }\n\n return operation;\n}\n","/* Core */\n\nexport {\n ApolloClient,\n ApolloClientOptions,\n DefaultOptions,\n mergeOptions,\n} from './ApolloClient';\nexport {\n ObservableQuery,\n FetchMoreOptions,\n UpdateQueryOptions,\n} from './ObservableQuery';\nexport {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n SubscriptionOptions,\n FetchPolicy,\n WatchQueryFetchPolicy,\n ErrorPolicy,\n FetchMoreQueryOptions,\n SubscribeToMoreOptions,\n MutationUpdaterFn,\n} from './watchQueryOptions';\nexport { NetworkStatus } from './networkStatus';\nexport * from './types';\nexport {\n Resolver,\n FragmentMatcher,\n} from './LocalState';\nexport { isApolloError, ApolloError } from '../errors';\n\n/* Cache */\n\nexport {\n // All the exports (types and values) from ../cache, minus cacheSlot,\n // which we want to keep semi-private.\n Cache,\n ApolloCache,\n Transaction,\n DataProxy,\n InMemoryCache,\n InMemoryCacheConfig,\n MissingFieldError,\n defaultDataIdFromObject,\n ReactiveVar,\n makeVar,\n TypePolicies,\n TypePolicy,\n FieldPolicy,\n FieldReadFunction,\n FieldMergeFunction,\n FieldFunctionOptions,\n PossibleTypesMap,\n} from '../cache';\n\nexport * from '../cache/inmemory/types';\n\n/* Link */\n\nexport * from '../link/core';\nexport * from '../link/http';\nexport {\n fromError,\n toPromise,\n fromPromise,\n ServerError,\n throwServerError,\n} from '../link/utils';\n\n/* Utilities */\n\nexport {\n Observable,\n Observer,\n ObservableSubscription,\n Reference,\n isReference,\n makeReference,\n StoreObject,\n} from '../utilities';\n\n/* Supporting */\n\n// The verbosity of invariant.{log,warn,error} can be controlled globally\n// (for anyone using the same ts-invariant package) by passing \"log\",\n// \"warn\", \"error\", or \"silent\" to setVerbosity (\"log\" is the default).\n// Note that all invariant.* logging is hidden in production.\nimport { setVerbosity } from \"ts-invariant\";\nexport { setVerbosity as setLogVerbosity }\nsetVerbosity(\"log\");\n\n// Note that importing `gql` by itself, then destructuring\n// additional properties separately before exporting, is intentional.\n// Due to the way the `graphql-tag` library is setup, certain bundlers\n// can't find the properties added to the exported `gql` function without\n// additional guidance (e.g. Rollup - see\n// https://rollupjs.org/guide/en/#error-name-is-not-exported-by-module).\n// Instead of having people that are using bundlers with `@apollo/client` add\n// extra bundler config to help `graphql-tag` exports be found (which would be\n// awkward since they aren't importing `graphql-tag` themselves), this\n// workaround of pulling the extra properties off the `gql` function,\n// then re-exporting them separately, helps keeps bundlers happy without any\n// additional config changes.\nimport gql from 'graphql-tag';\nexport const {\n resetCaches,\n disableFragmentWarnings,\n enableExperimentalFragmentVariables,\n disableExperimentalFragmentVariables\n} = gql;\nexport { gql };\n","/* global window */\nimport ponyfill from './ponyfill.js';\n\nvar root;\n\nif (typeof self !== 'undefined') {\n root = self;\n} else if (typeof window !== 'undefined') {\n root = window;\n} else if (typeof global !== 'undefined') {\n root = global;\n} else if (typeof module !== 'undefined') {\n root = module;\n} else {\n root = Function('return this')();\n}\n\nvar result = ponyfill(root);\nexport default result;\n","export function getEnv(): string | undefined {\n if (typeof process !== 'undefined' && process.env.NODE_ENV) {\n return process.env.NODE_ENV;\n }\n\n // default environment\n return 'development';\n}\n\nexport function isEnv(env: string): boolean {\n return getEnv() === env;\n}\n\nexport function isDevelopment(): boolean {\n return isEnv('development') === true;\n}\n\nexport function isTest(): boolean {\n return isEnv('test') === true;\n}\n","'use strict';\n\nmodule.exports = function formDataAppendFile(formData, fieldName, file) {\n formData.append(fieldName, file, file.name);\n};\n","'use strict';\n\nmodule.exports = require('extract-files/public/isExtractableFile');\n","interface Node {\n key: K;\n value: V;\n newer: Node | null;\n older: Node | null;\n}\n\nfunction defaultDispose() {}\n\nexport class Cache {\n private map = new Map>();\n private newest: Node | null = null;\n private oldest: Node | null = null;\n\n constructor(\n private max = Infinity,\n public dispose: (value: V, key: K) => void = defaultDispose,\n ) {}\n\n public has(key: K): boolean {\n return this.map.has(key);\n }\n\n public get(key: K): V | undefined {\n const node = this.getNode(key);\n return node && node.value;\n }\n\n private getNode(key: K): Node | undefined {\n const node = this.map.get(key);\n\n if (node && node !== this.newest) {\n const { older, newer } = node;\n\n if (newer) {\n newer.older = older;\n }\n\n if (older) {\n older.newer = newer;\n }\n\n node.older = this.newest;\n node.older!.newer = node;\n\n node.newer = null;\n this.newest = node;\n\n if (node === this.oldest) {\n this.oldest = newer;\n }\n }\n\n return node;\n }\n\n public set(key: K, value: V): V {\n let node = this.getNode(key);\n if (node) {\n return node.value = value;\n }\n\n node = {\n key,\n value,\n newer: null,\n older: this.newest\n };\n\n if (this.newest) {\n this.newest.newer = node;\n }\n\n this.newest = node;\n this.oldest = this.oldest || node;\n\n this.map.set(key, node);\n\n return node.value;\n }\n\n public clean() {\n while (this.oldest && this.map.size > this.max) {\n this.delete(this.oldest.key);\n }\n }\n\n public delete(key: K): boolean {\n const node = this.map.get(key);\n if (node) {\n if (node === this.newest) {\n this.newest = node.older;\n }\n\n if (node === this.oldest) {\n this.oldest = node.newer;\n }\n\n if (node.newer) {\n node.newer.older = node.older;\n }\n\n if (node.older) {\n node.older.newer = node.newer;\n }\n\n this.map.delete(key);\n this.dispose(node.value, key);\n\n return true;\n }\n\n return false;\n }\n}\n","import { AnyEntry } from \"./entry\";\nimport { Slot } from \"@wry/context\";\n\nexport const parentEntrySlot = new Slot();\n\nexport {\n bind as bindContext,\n noContext,\n setTimeout,\n asyncFromGen,\n} from \"@wry/context\";\n","export type Unsubscribable = {\n unsubscribe?: void | (() => any);\n}\n\nexport function maybeUnsubscribe(entryOrDep: Unsubscribable) {\n const { unsubscribe } = entryOrDep;\n if (typeof unsubscribe === \"function\") {\n entryOrDep.unsubscribe = void 0;\n unsubscribe();\n }\n}\n","import { parentEntrySlot } from \"./context\";\nimport { OptimisticWrapOptions } from \"./index\";\nimport { Dep } from \"./dep\";\nimport { maybeUnsubscribe, Unsubscribable } from \"./helpers\";\n\nconst emptySetPool: Set[] = [];\nconst POOL_TARGET_SIZE = 100;\n\n// Since this package might be used browsers, we should avoid using the\n// Node built-in assert module.\nfunction assert(condition: any, optionalMessage?: string) {\n if (! condition) {\n throw new Error(optionalMessage || \"assertion failure\");\n }\n}\n\n// Since exceptions are cached just like normal values, we need an efficient\n// way of representing unknown, ordinary, and exceptional values.\ntype Value =\n | [] // unknown\n | [T] // known value\n | [void, any]; // known exception\n\nfunction valueIs(a: Value, b: Value) {\n const len = a.length;\n return (\n // Unknown values are not equal to each other.\n len > 0 &&\n // Both values must be ordinary (or both exceptional) to be equal.\n len === b.length &&\n // The underlying value or exception must be the same.\n a[len - 1] === b[len - 1]\n );\n}\n\nfunction valueGet(value: Value): T {\n switch (value.length) {\n case 0: throw new Error(\"unknown value\");\n case 1: return value[0];\n case 2: throw value[1];\n }\n}\n\nfunction valueCopy(value: Value): Value {\n return value.slice(0) as Value;\n}\n\nexport type AnyEntry = Entry;\n\nexport class Entry {\n public static count = 0;\n\n public subscribe: OptimisticWrapOptions[\"subscribe\"];\n public unsubscribe: Unsubscribable[\"unsubscribe\"];\n\n public readonly parents = new Set();\n public readonly childValues = new Map>();\n\n // When this Entry has children that are dirty, this property becomes\n // a Set containing other Entry objects, borrowed from emptySetPool.\n // When the set becomes empty, it gets recycled back to emptySetPool.\n public dirtyChildren: Set | null = null;\n\n public dirty = true;\n public recomputing = false;\n public readonly value: Value = [];\n\n constructor(\n public readonly fn: (...args: TArgs) => TValue,\n ) {\n ++Entry.count;\n }\n\n public peek(): TValue | undefined {\n if (this.value.length === 1 && !mightBeDirty(this)) {\n return this.value[0];\n }\n }\n\n // This is the most important method of the Entry API, because it\n // determines whether the cached this.value can be returned immediately,\n // or must be recomputed. The overall performance of the caching system\n // depends on the truth of the following observations: (1) this.dirty is\n // usually false, (2) this.dirtyChildren is usually null/empty, and thus\n // (3) valueGet(this.value) is usually returned without recomputation.\n public recompute(args: TArgs): TValue {\n assert(! this.recomputing, \"already recomputing\");\n rememberParent(this);\n return mightBeDirty(this)\n ? reallyRecompute(this, args)\n : valueGet(this.value);\n }\n\n public setDirty() {\n if (this.dirty) return;\n this.dirty = true;\n this.value.length = 0;\n reportDirty(this);\n forgetChildren(this);\n // We can go ahead and unsubscribe here, since any further dirty\n // notifications we receive will be redundant, and unsubscribing may\n // free up some resources, e.g. file watchers.\n maybeUnsubscribe(this);\n }\n\n public dispose() {\n forgetChildren(this);\n maybeUnsubscribe(this);\n\n // Because this entry has been kicked out of the cache (in index.js),\n // we've lost the ability to find out if/when this entry becomes dirty,\n // whether that happens through a subscription, because of a direct call\n // to entry.setDirty(), or because one of its children becomes dirty.\n // Because of this loss of future information, we have to assume the\n // worst (that this entry might have become dirty very soon), so we must\n // immediately mark this entry's parents as dirty. Normally we could\n // just call entry.setDirty() rather than calling parent.setDirty() for\n // each parent, but that would leave this entry in parent.childValues\n // and parent.dirtyChildren, which would prevent the child from being\n // truly forgotten.\n this.parents.forEach(parent => {\n parent.setDirty();\n forgetChild(parent, this);\n });\n }\n\n private deps: Set> | null = null;\n\n public dependOn(dep: Dep) {\n dep.add(this);\n if (! this.deps) {\n this.deps = emptySetPool.pop() || new Set>();\n }\n this.deps.add(dep);\n }\n\n public forgetDeps() {\n if (this.deps) {\n this.deps.forEach(dep => dep.delete(this));\n this.deps.clear();\n emptySetPool.push(this.deps);\n this.deps = null;\n }\n }\n}\n\nfunction rememberParent(child: AnyEntry) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n child.parents.add(parent);\n\n if (! parent.childValues.has(child)) {\n parent.childValues.set(child, []);\n }\n\n if (mightBeDirty(child)) {\n reportDirtyChild(parent, child);\n } else {\n reportCleanChild(parent, child);\n }\n\n return parent;\n }\n}\n\nfunction reallyRecompute(entry: AnyEntry, args: any[]) {\n forgetChildren(entry);\n\n // Set entry as the parent entry while calling recomputeNewValue(entry).\n parentEntrySlot.withValue(entry, recomputeNewValue, [entry, args]);\n\n if (maybeSubscribe(entry, args)) {\n // If we successfully recomputed entry.value and did not fail to\n // (re)subscribe, then this Entry is no longer explicitly dirty.\n setClean(entry);\n }\n\n return valueGet(entry.value);\n}\n\nfunction recomputeNewValue(entry: AnyEntry, args: any[]) {\n entry.recomputing = true;\n // Set entry.value as unknown.\n entry.value.length = 0;\n try {\n // If entry.fn succeeds, entry.value will become a normal Value.\n entry.value[0] = entry.fn.apply(null, args);\n } catch (e) {\n // If entry.fn throws, entry.value will become exceptional.\n entry.value[1] = e;\n }\n // Either way, this line is always reached.\n entry.recomputing = false;\n}\n\nfunction mightBeDirty(entry: AnyEntry) {\n return entry.dirty || !!(entry.dirtyChildren && entry.dirtyChildren.size);\n}\n\nfunction setClean(entry: AnyEntry) {\n entry.dirty = false;\n\n if (mightBeDirty(entry)) {\n // This Entry may still have dirty children, in which case we can't\n // let our parents know we're clean just yet.\n return;\n }\n\n reportClean(entry);\n}\n\nfunction reportDirty(child: AnyEntry) {\n child.parents.forEach(parent => reportDirtyChild(parent, child));\n}\n\nfunction reportClean(child: AnyEntry) {\n child.parents.forEach(parent => reportCleanChild(parent, child));\n}\n\n// Let a parent Entry know that one of its children may be dirty.\nfunction reportDirtyChild(parent: AnyEntry, child: AnyEntry) {\n // Must have called rememberParent(child) before calling\n // reportDirtyChild(parent, child).\n assert(parent.childValues.has(child));\n assert(mightBeDirty(child));\n\n if (! parent.dirtyChildren) {\n parent.dirtyChildren = emptySetPool.pop() || new Set;\n\n } else if (parent.dirtyChildren.has(child)) {\n // If we already know this child is dirty, then we must have already\n // informed our own parents that we are dirty, so we can terminate\n // the recursion early.\n return;\n }\n\n parent.dirtyChildren.add(child);\n reportDirty(parent);\n}\n\n// Let a parent Entry know that one of its children is no longer dirty.\nfunction reportCleanChild(parent: AnyEntry, child: AnyEntry) {\n // Must have called rememberChild(child) before calling\n // reportCleanChild(parent, child).\n assert(parent.childValues.has(child));\n assert(! mightBeDirty(child));\n\n const childValue = parent.childValues.get(child)!;\n if (childValue.length === 0) {\n parent.childValues.set(child, valueCopy(child.value));\n } else if (! valueIs(childValue, child.value)) {\n parent.setDirty();\n }\n\n removeDirtyChild(parent, child);\n\n if (mightBeDirty(parent)) {\n return;\n }\n\n reportClean(parent);\n}\n\nfunction removeDirtyChild(parent: AnyEntry, child: AnyEntry) {\n const dc = parent.dirtyChildren;\n if (dc) {\n dc.delete(child);\n if (dc.size === 0) {\n if (emptySetPool.length < POOL_TARGET_SIZE) {\n emptySetPool.push(dc);\n }\n parent.dirtyChildren = null;\n }\n }\n}\n\n// Removes all children from this entry and returns an array of the\n// removed children.\nfunction forgetChildren(parent: AnyEntry) {\n if (parent.childValues.size > 0) {\n parent.childValues.forEach((_value, child) => {\n forgetChild(parent, child);\n });\n }\n\n // Remove this parent Entry from any sets to which it was added by the\n // addToSet method.\n parent.forgetDeps();\n\n // After we forget all our children, this.dirtyChildren must be empty\n // and therefore must have been reset to null.\n assert(parent.dirtyChildren === null);\n}\n\nfunction forgetChild(parent: AnyEntry, child: AnyEntry) {\n child.parents.delete(parent);\n parent.childValues.delete(child);\n removeDirtyChild(parent, child);\n}\n\nfunction maybeSubscribe(entry: AnyEntry, args: any[]) {\n if (typeof entry.subscribe === \"function\") {\n try {\n maybeUnsubscribe(entry); // Prevent double subscriptions.\n entry.unsubscribe = entry.subscribe.apply(null, args);\n } catch (e) {\n // If this Entry has a subscribe function and it threw an exception\n // (or an unsubscribe function it previously returned now throws),\n // return false to indicate that we were not able to subscribe (or\n // unsubscribe), and this Entry should remain dirty.\n entry.setDirty();\n return false;\n }\n }\n\n // Returning true indicates either that there was no entry.subscribe\n // function or that it succeeded.\n return true;\n}\n","import { AnyEntry } from \"./entry\";\nimport { OptimisticWrapOptions } from \"./index\";\nimport { parentEntrySlot } from \"./context\";\nimport { Unsubscribable, maybeUnsubscribe } from \"./helpers\";\n\nexport type OptimisticDependencyFunction =\n ((key: TKey) => void) & {\n dirty: (key: TKey) => void;\n };\n\nexport type Dep = Set & {\n subscribe: OptimisticWrapOptions<[TKey]>[\"subscribe\"];\n} & Unsubscribable;\n\nexport function dep(options?: {\n subscribe: Dep[\"subscribe\"];\n}) {\n const depsByKey = new Map>();\n const subscribe = options && options.subscribe;\n\n function depend(key: TKey) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n let dep = depsByKey.get(key);\n if (!dep) {\n depsByKey.set(key, dep = new Set as Dep);\n }\n parent.dependOn(dep);\n if (typeof subscribe === \"function\") {\n maybeUnsubscribe(dep);\n dep.unsubscribe = subscribe(key);\n }\n }\n }\n\n depend.dirty = function dirty(key: TKey) {\n const dep = depsByKey.get(key);\n if (dep) {\n dep.forEach(entry => entry.setDirty());\n depsByKey.delete(key);\n maybeUnsubscribe(dep);\n }\n };\n\n return depend as OptimisticDependencyFunction;\n}\n","const { toString, hasOwnProperty } = Object.prototype;\nconst fnToStr = Function.prototype.toString;\nconst previousComparisons = new Map>();\n\n/**\n * Performs a deep equality check on two JavaScript values, tolerating cycles.\n */\nexport function equal(a: any, b: any): boolean {\n try {\n return check(a, b);\n } finally {\n previousComparisons.clear();\n }\n}\n\n// Allow default imports as well.\nexport default equal;\n\nfunction check(a: any, b: any): boolean {\n // If the two values are strictly equal, our job is easy.\n if (a === b) {\n return true;\n }\n\n // Object.prototype.toString returns a representation of the runtime type of\n // the given value that is considerably more precise than typeof.\n const aTag = toString.call(a);\n const bTag = toString.call(b);\n\n // If the runtime types of a and b are different, they could maybe be equal\n // under some interpretation of equality, but for simplicity and performance\n // we just return false instead.\n if (aTag !== bTag) {\n return false;\n }\n\n switch (aTag) {\n case '[object Array]':\n // Arrays are a lot like other objects, but we can cheaply compare their\n // lengths as a short-cut before comparing their elements.\n if (a.length !== b.length) return false;\n // Fall through to object case...\n case '[object Object]': {\n if (previouslyCompared(a, b)) return true;\n\n const aKeys = definedKeys(a);\n const bKeys = definedKeys(b);\n\n // If `a` and `b` have a different number of enumerable keys, they\n // must be different.\n const keyCount = aKeys.length;\n if (keyCount !== bKeys.length) return false;\n\n // Now make sure they have the same keys.\n for (let k = 0; k < keyCount; ++k) {\n if (!hasOwnProperty.call(b, aKeys[k])) {\n return false;\n }\n }\n\n // Finally, check deep equality of all child properties.\n for (let k = 0; k < keyCount; ++k) {\n const key = aKeys[k];\n if (!check(a[key], b[key])) {\n return false;\n }\n }\n\n return true;\n }\n\n case '[object Error]':\n return a.name === b.name && a.message === b.message;\n\n case '[object Number]':\n // Handle NaN, which is !== itself.\n if (a !== a) return b !== b;\n // Fall through to shared +a === +b case...\n case '[object Boolean]':\n case '[object Date]':\n return +a === +b;\n\n case '[object RegExp]':\n case '[object String]':\n return a == `${b}`;\n\n case '[object Map]':\n case '[object Set]': {\n if (a.size !== b.size) return false;\n if (previouslyCompared(a, b)) return true;\n\n const aIterator = a.entries();\n const isMap = aTag === '[object Map]';\n\n while (true) {\n const info = aIterator.next();\n if (info.done) break;\n\n // If a instanceof Set, aValue === aKey.\n const [aKey, aValue] = info.value;\n\n // So this works the same way for both Set and Map.\n if (!b.has(aKey)) {\n return false;\n }\n\n // However, we care about deep equality of values only when dealing\n // with Map structures.\n if (isMap && !check(aValue, b.get(aKey))) {\n return false;\n }\n }\n\n return true;\n }\n\n case '[object AsyncFunction]':\n case '[object GeneratorFunction]':\n case '[object AsyncGeneratorFunction]':\n case '[object Function]': {\n const aCode = fnToStr.call(a);\n if (aCode !== fnToStr.call(b)) {\n return false;\n }\n\n // We consider non-native functions equal if they have the same code\n // (native functions require === because their code is censored).\n // Note that this behavior is not entirely sound, since !== function\n // objects with the same code can behave differently depending on\n // their closure scope. However, any function can behave differently\n // depending on the values of its input arguments (including this)\n // and its calling context (including its closure scope), even\n // though the function object is === to itself; and it is entirely\n // possible for functions that are not === to behave exactly the\n // same under all conceivable circumstances. Because none of these\n // factors are statically decidable in JavaScript, JS function\n // equality is not well-defined. This ambiguity allows us to\n // consider the best possible heuristic among various imperfect\n // options, and equating non-native functions that have the same\n // code has enormous practical benefits, such as when comparing\n // functions that are repeatedly passed as fresh function\n // expressions within objects that are otherwise deeply equal. Since\n // any function created from the same syntactic expression (in the\n // same code location) will always stringify to the same code\n // according to fnToStr.call, we can reasonably expect these\n // repeatedly passed function expressions to have the same code, and\n // thus behave \"the same\" (with all the caveats mentioned above),\n // even though the runtime function objects are !== to one another.\n return !endsWith(aCode, nativeCodeSuffix);\n }\n }\n\n // Otherwise the values are not equal.\n return false;\n}\n\nfunction definedKeys(obj: TObject) {\n // Remember that the second argument to Array.prototype.filter will be\n // used as `this` within the callback function.\n return Object.keys(obj).filter(isDefinedKey, obj);\n}\nfunction isDefinedKey(\n this: TObject,\n key: keyof TObject,\n) {\n return this[key] !== void 0;\n}\n\nconst nativeCodeSuffix = \"{ [native code] }\";\n\nfunction endsWith(full: string, suffix: string) {\n const fromIndex = full.length - suffix.length;\n return fromIndex >= 0 &&\n full.indexOf(suffix, fromIndex) === fromIndex;\n}\n\nfunction previouslyCompared(a: object, b: object): boolean {\n // Though cyclic references can make an object graph appear infinite from the\n // perspective of a depth-first traversal, the graph still contains a finite\n // number of distinct object references. We use the previousComparisons cache\n // to avoid comparing the same pair of object references more than once, which\n // guarantees termination (even if we end up comparing every object in one\n // graph to every object in the other graph, which is extremely unlikely),\n // while still allowing weird isomorphic structures (like rings with different\n // lengths) a chance to pass the equality test.\n let bSet = previousComparisons.get(a);\n if (bSet) {\n // Return true here because we can be sure false will be returned somewhere\n // else if the objects are not equivalent.\n if (bSet.has(b)) return true;\n } else {\n previousComparisons.set(a, bSet = new Set);\n }\n bSet.add(b);\n return false;\n}\n","import { Observable } from '../../utilities';\n\nexport function fromError(errorValue: any): Observable {\n return new Observable(observer => {\n observer.error(errorValue);\n });\n}\n","import { invariant } from 'ts-invariant';\n\nimport { Observable } from '../../utilities';\n\nexport function toPromise(observable: Observable): Promise {\n let completed = false;\n return new Promise((resolve, reject) => {\n observable.subscribe({\n next: data => {\n if (completed) {\n invariant.warn(\n `Promise Wrapper does not support multiple results from Observable`,\n );\n } else {\n completed = true;\n resolve(data);\n }\n },\n error: reject,\n });\n });\n}\n","import { Observable } from '../../utilities';\n\nexport function fromPromise(promise: Promise): Observable {\n return new Observable(observer => {\n promise\n .then((value: T) => {\n observer.next(value);\n observer.complete();\n })\n .catch(observer.error.bind(observer));\n });\n}\n","export type ServerError = Error & {\n response: Response;\n result: Record;\n statusCode: number;\n};\n\nexport const throwServerError = (\n response: Response,\n result: any,\n message: string\n) => {\n const error = new Error(message) as ServerError;\n error.name = 'ServerError';\n error.response = response;\n error.statusCode = response.status;\n error.result = result;\n throw error;\n};\n","import { InvariantError } from '../../utilities/globals'\nimport { GraphQLRequest } from '../core';\n\nexport function validateOperation(operation: GraphQLRequest): GraphQLRequest {\n const OPERATION_FIELDS = [\n 'query',\n 'operationName',\n 'variables',\n 'extensions',\n 'context',\n ];\n for (let key of Object.keys(operation)) {\n if (OPERATION_FIELDS.indexOf(key) < 0) {\n throw new InvariantError(`illegal argument: ${key}`);\n }\n }\n\n return operation;\n}\n","import { GraphQLRequest, Operation } from '../core';\n\nexport function createOperation(\n starting: any,\n operation: GraphQLRequest,\n): Operation {\n let context = { ...starting };\n const setContext = (next: any) => {\n if (typeof next === 'function') {\n context = { ...context, ...next(context) };\n } else {\n context = { ...context, ...next };\n }\n };\n const getContext = () => ({ ...context });\n\n Object.defineProperty(operation, 'setContext', {\n enumerable: false,\n value: setContext,\n });\n\n Object.defineProperty(operation, 'getContext', {\n enumerable: false,\n value: getContext,\n });\n\n return operation as Operation;\n}\n","import { GraphQLRequest, Operation } from '../core';\nimport { getOperationName } from '../../utilities';\n\nexport function transformOperation(operation: GraphQLRequest): GraphQLRequest {\n const transformedOperation: GraphQLRequest = {\n variables: operation.variables || {},\n extensions: operation.extensions || {},\n operationName: operation.operationName,\n query: operation.query,\n };\n\n // Best guess at an operation name\n if (!transformedOperation.operationName) {\n transformedOperation.operationName =\n typeof transformedOperation.query !== 'string'\n ? getOperationName(transformedOperation.query) || undefined\n : '';\n }\n\n return transformedOperation as Operation;\n}\n","import { invariant } from '../globals';\n\n// Provides the methods that allow QueryManager to handle the `skip` and\n// `include` directives within GraphQL.\nimport {\n SelectionNode,\n VariableNode,\n BooleanValueNode,\n DirectiveNode,\n DocumentNode,\n ArgumentNode,\n ValueNode,\n ASTNode,\n visit,\n} from 'graphql';\n\nexport type DirectiveInfo = {\n [fieldName: string]: { [argName: string]: any };\n};\n\nexport function shouldInclude(\n { directives }: SelectionNode,\n variables?: Record,\n): boolean {\n if (!directives || !directives.length) {\n return true;\n }\n return getInclusionDirectives(\n directives\n ).every(({ directive, ifArgument }) => {\n let evaledValue: boolean = false;\n if (ifArgument.value.kind === 'Variable') {\n evaledValue = variables && variables[(ifArgument.value as VariableNode).name.value];\n invariant(\n evaledValue !== void 0,\n `Invalid variable referenced in @${directive.name.value} directive.`,\n );\n } else {\n evaledValue = (ifArgument.value as BooleanValueNode).value;\n }\n return directive.name.value === 'skip' ? !evaledValue : evaledValue;\n });\n}\n\nexport function getDirectiveNames(root: ASTNode) {\n const names: string[] = [];\n\n visit(root, {\n Directive(node: DirectiveNode) {\n names.push(node.name.value);\n },\n });\n\n return names;\n}\n\nexport function hasDirectives(names: string[], root: ASTNode) {\n return getDirectiveNames(root).some(\n (name: string) => names.indexOf(name) > -1,\n );\n}\n\nexport function hasClientExports(document: DocumentNode) {\n return (\n document &&\n hasDirectives(['client'], document) &&\n hasDirectives(['export'], document)\n );\n}\n\nexport type InclusionDirectives = Array<{\n directive: DirectiveNode;\n ifArgument: ArgumentNode;\n}>;\n\nfunction isInclusionDirective({ name: { value } }: DirectiveNode): boolean {\n return value === 'skip' || value === 'include';\n}\n\nexport function getInclusionDirectives(\n directives: ReadonlyArray,\n): InclusionDirectives {\n const result: InclusionDirectives = [];\n\n if (directives && directives.length) {\n directives.forEach(directive => {\n if (!isInclusionDirective(directive)) return;\n\n const directiveArguments = directive.arguments;\n const directiveName = directive.name.value;\n\n invariant(\n directiveArguments && directiveArguments.length === 1,\n `Incorrect number of arguments for the @${directiveName} directive.`,\n );\n\n const ifArgument = directiveArguments![0];\n invariant(\n ifArgument.name && ifArgument.name.value === 'if',\n `Invalid argument for the @${directiveName} directive.`,\n );\n\n const ifValue: ValueNode = ifArgument.value;\n\n // means it has to be a variable value if this is a valid @skip or @include directive\n invariant(\n ifValue &&\n (ifValue.kind === 'Variable' || ifValue.kind === 'BooleanValue'),\n `Argument for the @${directiveName} directive must be a variable or a boolean value.`,\n );\n\n result.push({ directive, ifArgument });\n });\n }\n\n return result;\n}\n\n","import { invariant, InvariantError } from '../globals';\n\nimport {\n DocumentNode,\n FragmentDefinitionNode,\n InlineFragmentNode,\n SelectionNode,\n} from 'graphql';\n\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype Kind = any;\ntype OperationTypeNode = any;\n/**\n * Returns a query document which adds a single query operation that only\n * spreads the target fragment inside of it.\n *\n * So for example a document of:\n *\n * ```graphql\n * fragment foo on Foo { a b c }\n * ```\n *\n * Turns into:\n *\n * ```graphql\n * { ...foo }\n *\n * fragment foo on Foo { a b c }\n * ```\n *\n * The target fragment will either be the only fragment in the document, or a\n * fragment specified by the provided `fragmentName`. If there is more than one\n * fragment, but a `fragmentName` was not defined then an error will be thrown.\n */\nexport function getFragmentQueryDocument(\n document: DocumentNode,\n fragmentName?: string,\n): DocumentNode {\n let actualFragmentName = fragmentName;\n\n // Build an array of all our fragment definitions that will be used for\n // validations. We also do some validations on the other definitions in the\n // document while building this list.\n const fragments: Array = [];\n document.definitions.forEach(definition => {\n // Throw an error if we encounter an operation definition because we will\n // define our own operation definition later on.\n if (definition.kind === 'OperationDefinition') {\n throw new InvariantError(\n `Found a ${definition.operation} operation${\n definition.name ? ` named '${definition.name.value}'` : ''\n }. ` +\n 'No operations are allowed when using a fragment as a query. Only fragments are allowed.',\n );\n }\n // Add our definition to the fragments array if it is a fragment\n // definition.\n if (definition.kind === 'FragmentDefinition') {\n fragments.push(definition);\n }\n });\n\n // If the user did not give us a fragment name then let us try to get a\n // name from a single fragment in the definition.\n if (typeof actualFragmentName === 'undefined') {\n invariant(\n fragments.length === 1,\n `Found ${\n fragments.length\n } fragments. \\`fragmentName\\` must be provided when there is not exactly 1 fragment.`,\n );\n actualFragmentName = fragments[0].name.value;\n }\n\n // Generate a query document with an operation that simply spreads the\n // fragment inside of it.\n const query: DocumentNode = {\n ...document,\n definitions: [\n {\n kind: 'OperationDefinition' as Kind,\n // OperationTypeNode is an enum\n operation: 'query' as OperationTypeNode,\n selectionSet: {\n kind: 'SelectionSet' as Kind,\n selections: [\n {\n kind: 'FragmentSpread' as Kind,\n name: {\n kind: 'Name' as Kind,\n value: actualFragmentName,\n },\n },\n ],\n },\n },\n ...document.definitions,\n ],\n };\n\n return query;\n}\n\n/**\n * This is an interface that describes a map from fragment names to fragment definitions.\n */\nexport interface FragmentMap {\n [fragmentName: string]: FragmentDefinitionNode;\n}\n\n// Utility function that takes a list of fragment definitions and makes a hash out of them\n// that maps the name of the fragment to the fragment definition.\nexport function createFragmentMap(\n fragments: FragmentDefinitionNode[] = [],\n): FragmentMap {\n const symTable: FragmentMap = {};\n fragments.forEach(fragment => {\n symTable[fragment.name.value] = fragment;\n });\n return symTable;\n}\n\nexport function getFragmentFromSelection(\n selection: SelectionNode,\n fragmentMap?: FragmentMap,\n): InlineFragmentNode | FragmentDefinitionNode | null {\n switch (selection.kind) {\n case 'InlineFragment':\n return selection;\n case 'FragmentSpread': {\n const fragment = fragmentMap && fragmentMap[selection.name.value];\n invariant(fragment, `No fragment named ${selection.name.value}.`);\n return fragment!;\n }\n default:\n return null;\n }\n}\n","import { InvariantError } from '../globals';\n\nimport {\n DirectiveNode,\n FieldNode,\n IntValueNode,\n FloatValueNode,\n StringValueNode,\n BooleanValueNode,\n ObjectValueNode,\n ListValueNode,\n EnumValueNode,\n NullValueNode,\n VariableNode,\n InlineFragmentNode,\n ValueNode,\n SelectionNode,\n NameNode,\n SelectionSetNode,\n DocumentNode,\n} from 'graphql';\n\nimport { isNonNullObject } from '../common/objects';\nimport { FragmentMap, getFragmentFromSelection } from './fragments';\n\nexport interface Reference {\n readonly __ref: string;\n}\n\nexport function makeReference(id: string): Reference {\n return { __ref: String(id) };\n}\n\nexport function isReference(obj: any): obj is Reference {\n return Boolean(obj && typeof obj === 'object' && typeof obj.__ref === 'string');\n}\n\nexport type StoreValue =\n | number\n | string\n | string[]\n | Reference\n | Reference[]\n | null\n | undefined\n | void\n | Object;\n\nexport interface StoreObject {\n __typename?: string;\n [storeFieldName: string]: StoreValue;\n}\n\nexport function isDocumentNode(value: any): value is DocumentNode {\n return (\n isNonNullObject(value) &&\n (value as DocumentNode).kind === \"Document\" &&\n Array.isArray((value as DocumentNode).definitions)\n );\n}\n\nfunction isStringValue(value: ValueNode): value is StringValueNode {\n return value.kind === 'StringValue';\n}\n\nfunction isBooleanValue(value: ValueNode): value is BooleanValueNode {\n return value.kind === 'BooleanValue';\n}\n\nfunction isIntValue(value: ValueNode): value is IntValueNode {\n return value.kind === 'IntValue';\n}\n\nfunction isFloatValue(value: ValueNode): value is FloatValueNode {\n return value.kind === 'FloatValue';\n}\n\nfunction isVariable(value: ValueNode): value is VariableNode {\n return value.kind === 'Variable';\n}\n\nfunction isObjectValue(value: ValueNode): value is ObjectValueNode {\n return value.kind === 'ObjectValue';\n}\n\nfunction isListValue(value: ValueNode): value is ListValueNode {\n return value.kind === 'ListValue';\n}\n\nfunction isEnumValue(value: ValueNode): value is EnumValueNode {\n return value.kind === 'EnumValue';\n}\n\nfunction isNullValue(value: ValueNode): value is NullValueNode {\n return value.kind === 'NullValue';\n}\n\nexport function valueToObjectRepresentation(\n argObj: any,\n name: NameNode,\n value: ValueNode,\n variables?: Object,\n) {\n if (isIntValue(value) || isFloatValue(value)) {\n argObj[name.value] = Number(value.value);\n } else if (isBooleanValue(value) || isStringValue(value)) {\n argObj[name.value] = value.value;\n } else if (isObjectValue(value)) {\n const nestedArgObj = {};\n value.fields.map(obj =>\n valueToObjectRepresentation(nestedArgObj, obj.name, obj.value, variables),\n );\n argObj[name.value] = nestedArgObj;\n } else if (isVariable(value)) {\n const variableValue = (variables || ({} as any))[value.name.value];\n argObj[name.value] = variableValue;\n } else if (isListValue(value)) {\n argObj[name.value] = value.values.map(listValue => {\n const nestedArgArrayObj = {};\n valueToObjectRepresentation(\n nestedArgArrayObj,\n name,\n listValue,\n variables,\n );\n return (nestedArgArrayObj as any)[name.value];\n });\n } else if (isEnumValue(value)) {\n argObj[name.value] = (value as EnumValueNode).value;\n } else if (isNullValue(value)) {\n argObj[name.value] = null;\n } else {\n throw new InvariantError(\n `The inline argument \"${name.value}\" of kind \"${(value as any).kind}\"` +\n 'is not supported. Use variables instead of inline arguments to ' +\n 'overcome this limitation.',\n );\n }\n}\n\nexport function storeKeyNameFromField(\n field: FieldNode,\n variables?: Object,\n): string {\n let directivesObj: any = null;\n if (field.directives) {\n directivesObj = {};\n field.directives.forEach(directive => {\n directivesObj[directive.name.value] = {};\n\n if (directive.arguments) {\n directive.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(\n directivesObj[directive.name.value],\n name,\n value,\n variables,\n ),\n );\n }\n });\n }\n\n let argObj: any = null;\n if (field.arguments && field.arguments.length) {\n argObj = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables),\n );\n }\n\n return getStoreKeyName(field.name.value, argObj, directivesObj);\n}\n\nexport type Directives = {\n [directiveName: string]: {\n [argName: string]: any;\n };\n};\n\nconst KNOWN_DIRECTIVES: string[] = [\n 'connection',\n 'include',\n 'skip',\n 'client',\n 'rest',\n 'export',\n];\n\nexport const getStoreKeyName = Object.assign(function (\n fieldName: string,\n args?: Record | null,\n directives?: Directives,\n): string {\n if (\n args &&\n directives &&\n directives['connection'] &&\n directives['connection']['key']\n ) {\n if (\n directives['connection']['filter'] &&\n (directives['connection']['filter'] as string[]).length > 0\n ) {\n const filterKeys = directives['connection']['filter']\n ? (directives['connection']['filter'] as string[])\n : [];\n filterKeys.sort();\n\n const filteredArgs = {} as { [key: string]: any };\n filterKeys.forEach(key => {\n filteredArgs[key] = args[key];\n });\n\n return `${directives['connection']['key']}(${stringify(\n filteredArgs,\n )})`;\n } else {\n return directives['connection']['key'];\n }\n }\n\n let completeFieldName: string = fieldName;\n\n if (args) {\n // We can't use `JSON.stringify` here since it's non-deterministic,\n // and can lead to different store key names being created even though\n // the `args` object used during creation has the same properties/values.\n const stringifiedArgs: string = stringify(args);\n completeFieldName += `(${stringifiedArgs})`;\n }\n\n if (directives) {\n Object.keys(directives).forEach(key => {\n if (KNOWN_DIRECTIVES.indexOf(key) !== -1) return;\n if (directives[key] && Object.keys(directives[key]).length) {\n completeFieldName += `@${key}(${stringify(directives[key])})`;\n } else {\n completeFieldName += `@${key}`;\n }\n });\n }\n\n return completeFieldName;\n}, {\n setStringify(s: typeof stringify) {\n const previous = stringify;\n stringify = s;\n return previous;\n },\n});\n\n// Default stable JSON.stringify implementation. Can be updated/replaced with\n// something better by calling getStoreKeyName.setStringify.\nlet stringify = function defaultStringify(value: any): string {\n return JSON.stringify(value, stringifyReplacer);\n};\n\nfunction stringifyReplacer(_key: string, value: any): any {\n if (isNonNullObject(value) && !Array.isArray(value)) {\n value = Object.keys(value).sort().reduce((copy, key) => {\n copy[key] = value[key];\n return copy;\n }, {} as Record);\n }\n return value;\n}\n\nexport function argumentsObjectFromField(\n field: FieldNode | DirectiveNode,\n variables?: Record,\n): Object | null {\n if (field.arguments && field.arguments.length) {\n const argObj: Object = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables),\n );\n return argObj;\n }\n return null;\n}\n\nexport function resultKeyNameFromField(field: FieldNode): string {\n return field.alias ? field.alias.value : field.name.value;\n}\n\nexport function getTypenameFromResult(\n result: Record,\n selectionSet: SelectionSetNode,\n fragmentMap?: FragmentMap,\n): string | undefined {\n if (typeof result.__typename === 'string') {\n return result.__typename;\n }\n\n for (const selection of selectionSet.selections) {\n if (isField(selection)) {\n if (selection.name.value === '__typename') {\n return result[resultKeyNameFromField(selection)];\n }\n } else {\n const typename = getTypenameFromResult(\n result,\n getFragmentFromSelection(selection, fragmentMap)!.selectionSet,\n fragmentMap,\n );\n if (typeof typename === 'string') {\n return typename;\n }\n }\n }\n}\n\nexport function isField(selection: SelectionNode): selection is FieldNode {\n return selection.kind === 'Field';\n}\n\nexport function isInlineFragment(\n selection: SelectionNode,\n): selection is InlineFragmentNode {\n return selection.kind === 'InlineFragment';\n}\n\nexport type VariableValue = (node: VariableNode) => any;\n","import { invariant, InvariantError } from '../globals';\n\nimport {\n DocumentNode,\n OperationDefinitionNode,\n FragmentDefinitionNode,\n ValueNode,\n} from 'graphql';\n\nimport { valueToObjectRepresentation } from './storeUtils';\n\n// Checks the document for errors and throws an exception if there is an error.\nexport function checkDocument(doc: DocumentNode) {\n invariant(\n doc && doc.kind === 'Document',\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`,\n );\n\n const operations = doc.definitions\n .filter(d => d.kind !== 'FragmentDefinition')\n .map(definition => {\n if (definition.kind !== 'OperationDefinition') {\n throw new InvariantError(\n `Schema type definitions not allowed in queries. Found: \"${\n definition.kind\n }\"`,\n );\n }\n return definition;\n });\n\n invariant(\n operations.length <= 1,\n `Ambiguous GraphQL document: contains ${operations.length} operations`,\n );\n\n return doc;\n}\n\nexport function getOperationDefinition(\n doc: DocumentNode,\n): OperationDefinitionNode | undefined {\n checkDocument(doc);\n return doc.definitions.filter(\n definition => definition.kind === 'OperationDefinition',\n )[0] as OperationDefinitionNode;\n}\n\nexport function getOperationName(doc: DocumentNode): string | null {\n return (\n doc.definitions\n .filter(\n definition =>\n definition.kind === 'OperationDefinition' && definition.name,\n )\n .map((x: OperationDefinitionNode) => x!.name!.value)[0] || null\n );\n}\n\n// Returns the FragmentDefinitions from a particular document as an array\nexport function getFragmentDefinitions(\n doc: DocumentNode,\n): FragmentDefinitionNode[] {\n return doc.definitions.filter(\n definition => definition.kind === 'FragmentDefinition',\n ) as FragmentDefinitionNode[];\n}\n\nexport function getQueryDefinition(doc: DocumentNode): OperationDefinitionNode {\n const queryDef = getOperationDefinition(doc) as OperationDefinitionNode;\n\n invariant(\n queryDef && queryDef.operation === 'query',\n 'Must contain a query definition.',\n );\n\n return queryDef;\n}\n\nexport function getFragmentDefinition(\n doc: DocumentNode,\n): FragmentDefinitionNode {\n invariant(\n doc.kind === 'Document',\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`,\n );\n\n invariant(\n doc.definitions.length <= 1,\n 'Fragment must have exactly one definition.',\n );\n\n const fragmentDef = doc.definitions[0] as FragmentDefinitionNode;\n\n invariant(\n fragmentDef.kind === 'FragmentDefinition',\n 'Must be a fragment definition.',\n );\n\n return fragmentDef as FragmentDefinitionNode;\n}\n\n/**\n * Returns the first operation definition found in this document.\n * If no operation definition is found, the first fragment definition will be returned.\n * If no definitions are found, an error will be thrown.\n */\nexport function getMainDefinition(\n queryDoc: DocumentNode,\n): OperationDefinitionNode | FragmentDefinitionNode {\n checkDocument(queryDoc);\n\n let fragmentDefinition;\n\n for (let definition of queryDoc.definitions) {\n if (definition.kind === 'OperationDefinition') {\n const operation = (definition as OperationDefinitionNode).operation;\n if (\n operation === 'query' ||\n operation === 'mutation' ||\n operation === 'subscription'\n ) {\n return definition as OperationDefinitionNode;\n }\n }\n if (definition.kind === 'FragmentDefinition' && !fragmentDefinition) {\n // we do this because we want to allow multiple fragment definitions\n // to precede an operation definition.\n fragmentDefinition = definition as FragmentDefinitionNode;\n }\n }\n\n if (fragmentDefinition) {\n return fragmentDefinition;\n }\n\n throw new InvariantError(\n 'Expected a parsed GraphQL query with a query, mutation, subscription, or a fragment.',\n );\n}\n\nexport function getDefaultValues(\n definition: OperationDefinitionNode | undefined,\n): Record {\n const defaultValues = Object.create(null);\n const defs = definition && definition.variableDefinitions;\n if (defs && defs.length) {\n defs.forEach(def => {\n if (def.defaultValue) {\n valueToObjectRepresentation(\n defaultValues,\n def.variable.name,\n def.defaultValue as ValueNode,\n );\n }\n });\n }\n return defaultValues;\n}\n","export function filterInPlace(\n array: T[],\n test: (elem: T) => boolean,\n context?: any,\n): T[] {\n let target = 0;\n array.forEach(function (elem, i) {\n if (test.call(this, elem, i, array)) {\n array[target++] = elem;\n }\n }, context);\n array.length = target;\n return array;\n}\n","import { invariant } from '../globals';\n\nimport {\n DocumentNode,\n SelectionNode,\n SelectionSetNode,\n OperationDefinitionNode,\n FieldNode,\n DirectiveNode,\n FragmentDefinitionNode,\n ArgumentNode,\n FragmentSpreadNode,\n VariableDefinitionNode,\n VariableNode,\n visit,\n} from 'graphql';\n\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype Kind = any;\n\nimport {\n checkDocument,\n getOperationDefinition,\n getFragmentDefinition,\n getFragmentDefinitions,\n getMainDefinition,\n} from './getFromAST';\nimport { filterInPlace } from '../common/filterInPlace';\nimport { isField, isInlineFragment } from './storeUtils';\nimport {\n createFragmentMap,\n FragmentMap,\n} from './fragments';\n\nexport type RemoveNodeConfig = {\n name?: string;\n test?: (node: N) => boolean;\n remove?: boolean;\n};\n\nexport type GetNodeConfig = {\n name?: string;\n test?: (node: N) => boolean;\n};\n\nexport type RemoveDirectiveConfig = RemoveNodeConfig;\nexport type GetDirectiveConfig = GetNodeConfig;\nexport type RemoveArgumentsConfig = RemoveNodeConfig;\nexport type GetFragmentSpreadConfig = GetNodeConfig;\nexport type RemoveFragmentSpreadConfig = RemoveNodeConfig;\nexport type RemoveFragmentDefinitionConfig = RemoveNodeConfig<\n FragmentDefinitionNode\n>;\nexport type RemoveVariableDefinitionConfig = RemoveNodeConfig<\n VariableDefinitionNode\n>;\n\nconst TYPENAME_FIELD: FieldNode = {\n kind: 'Field' as Kind,\n name: {\n kind: 'Name' as Kind,\n value: '__typename',\n },\n};\n\nfunction isEmpty(\n op: OperationDefinitionNode | FragmentDefinitionNode,\n fragments: FragmentMap,\n): boolean {\n return op.selectionSet.selections.every(\n selection =>\n selection.kind === 'FragmentSpread' &&\n isEmpty(fragments[selection.name.value], fragments),\n );\n}\n\nfunction nullIfDocIsEmpty(doc: DocumentNode) {\n return isEmpty(\n getOperationDefinition(doc) || getFragmentDefinition(doc),\n createFragmentMap(getFragmentDefinitions(doc)),\n )\n ? null\n : doc;\n}\n\nfunction getDirectiveMatcher(\n directives: (RemoveDirectiveConfig | GetDirectiveConfig)[],\n) {\n return function directiveMatcher(directive: DirectiveNode) {\n return directives.some(\n dir =>\n (dir.name && dir.name === directive.name.value) ||\n (dir.test && dir.test(directive)),\n );\n };\n}\n\nexport function removeDirectivesFromDocument(\n directives: RemoveDirectiveConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n const variablesInUse: Record = Object.create(null);\n let variablesToRemove: RemoveArgumentsConfig[] = [];\n\n const fragmentSpreadsInUse: Record = Object.create(null);\n let fragmentSpreadsToRemove: RemoveFragmentSpreadConfig[] = [];\n\n let modifiedDoc = nullIfDocIsEmpty(\n visit(doc, {\n Variable: {\n enter(node, _key, parent) {\n // Store each variable that's referenced as part of an argument\n // (excluding operation definition variables), so we know which\n // variables are being used. If we later want to remove a variable\n // we'll first check to see if it's being used, before continuing with\n // the removal.\n if (\n (parent as VariableDefinitionNode).kind !== 'VariableDefinition'\n ) {\n variablesInUse[node.name.value] = true;\n }\n },\n },\n\n Field: {\n enter(node) {\n if (directives && node.directives) {\n // If `remove` is set to true for a directive, and a directive match\n // is found for a field, remove the field as well.\n const shouldRemoveField = directives.some(\n directive => directive.remove,\n );\n\n if (\n shouldRemoveField &&\n node.directives &&\n node.directives.some(getDirectiveMatcher(directives))\n ) {\n if (node.arguments) {\n // Store field argument variables so they can be removed\n // from the operation definition.\n node.arguments.forEach(arg => {\n if (arg.value.kind === 'Variable') {\n variablesToRemove.push({\n name: (arg.value as VariableNode).name.value,\n });\n }\n });\n }\n\n if (node.selectionSet) {\n // Store fragment spread names so they can be removed from the\n // document.\n getAllFragmentSpreadsFromSelectionSet(node.selectionSet).forEach(\n frag => {\n fragmentSpreadsToRemove.push({\n name: frag.name.value,\n });\n },\n );\n }\n\n // Remove the field.\n return null;\n }\n }\n },\n },\n\n FragmentSpread: {\n enter(node) {\n // Keep track of referenced fragment spreads. This is used to\n // determine if top level fragment definitions should be removed.\n fragmentSpreadsInUse[node.name.value] = true;\n },\n },\n\n Directive: {\n enter(node) {\n // If a matching directive is found, remove it.\n if (getDirectiveMatcher(directives)(node)) {\n return null;\n }\n },\n },\n }),\n );\n\n // If we've removed fields with arguments, make sure the associated\n // variables are also removed from the rest of the document, as long as they\n // aren't being used elsewhere.\n if (\n modifiedDoc &&\n filterInPlace(variablesToRemove, v => !!v.name && !variablesInUse[v.name]).length\n ) {\n modifiedDoc = removeArgumentsFromDocument(variablesToRemove, modifiedDoc);\n }\n\n // If we've removed selection sets with fragment spreads, make sure the\n // associated fragment definitions are also removed from the rest of the\n // document, as long as they aren't being used elsewhere.\n if (\n modifiedDoc &&\n filterInPlace(fragmentSpreadsToRemove, fs => !!fs.name && !fragmentSpreadsInUse[fs.name])\n .length\n ) {\n modifiedDoc = removeFragmentSpreadFromDocument(\n fragmentSpreadsToRemove,\n modifiedDoc,\n );\n }\n\n return modifiedDoc;\n}\n\nexport const addTypenameToDocument = Object.assign(function (\n doc: DocumentNode\n): DocumentNode {\n return visit(checkDocument(doc), {\n SelectionSet: {\n enter(node, _key, parent) {\n // Don't add __typename to OperationDefinitions.\n if (\n parent &&\n (parent as OperationDefinitionNode).kind === 'OperationDefinition'\n ) {\n return;\n }\n\n // No changes if no selections.\n const { selections } = node;\n if (!selections) {\n return;\n }\n\n // If selections already have a __typename, or are part of an\n // introspection query, do nothing.\n const skip = selections.some(selection => {\n return (\n isField(selection) &&\n (selection.name.value === '__typename' ||\n selection.name.value.lastIndexOf('__', 0) === 0)\n );\n });\n if (skip) {\n return;\n }\n\n // If this SelectionSet is @export-ed as an input variable, it should\n // not have a __typename field (see issue #4691).\n const field = parent as FieldNode;\n if (\n isField(field) &&\n field.directives &&\n field.directives.some(d => d.name.value === 'export')\n ) {\n return;\n }\n\n // Create and return a new SelectionSet with a __typename Field.\n return {\n ...node,\n selections: [...selections, TYPENAME_FIELD],\n };\n },\n },\n });\n}, {\n added(field: FieldNode): boolean {\n return field === TYPENAME_FIELD;\n },\n});\n\nconst connectionRemoveConfig = {\n test: (directive: DirectiveNode) => {\n const willRemove = directive.name.value === 'connection';\n if (willRemove) {\n if (\n !directive.arguments ||\n !directive.arguments.some(arg => arg.name.value === 'key')\n ) {\n invariant.warn(\n 'Removing an @connection directive even though it does not have a key. ' +\n 'You may want to use the key parameter to specify a store key.',\n );\n }\n }\n\n return willRemove;\n },\n};\n\nexport function removeConnectionDirectiveFromDocument(doc: DocumentNode) {\n return removeDirectivesFromDocument(\n [connectionRemoveConfig],\n checkDocument(doc),\n );\n}\n\nfunction hasDirectivesInSelectionSet(\n directives: GetDirectiveConfig[],\n selectionSet: SelectionSetNode | undefined,\n nestedCheck = true,\n): boolean {\n return (\n !!selectionSet &&\n selectionSet.selections &&\n selectionSet.selections.some(selection =>\n hasDirectivesInSelection(directives, selection, nestedCheck),\n )\n );\n}\n\nfunction hasDirectivesInSelection(\n directives: GetDirectiveConfig[],\n selection: SelectionNode,\n nestedCheck = true,\n): boolean {\n if (!isField(selection)) {\n return true;\n }\n\n if (!selection.directives) {\n return false;\n }\n\n return (\n selection.directives.some(getDirectiveMatcher(directives)) ||\n (nestedCheck &&\n hasDirectivesInSelectionSet(\n directives,\n selection.selectionSet,\n nestedCheck,\n ))\n );\n}\n\nfunction getArgumentMatcher(config: RemoveArgumentsConfig[]) {\n return function argumentMatcher(argument: ArgumentNode) {\n return config.some(\n (aConfig: RemoveArgumentsConfig) =>\n argument.value &&\n argument.value.kind === 'Variable' &&\n argument.value.name &&\n (aConfig.name === argument.value.name.value ||\n (aConfig.test && aConfig.test(argument))),\n );\n };\n}\n\nexport function removeArgumentsFromDocument(\n config: RemoveArgumentsConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n const argMatcher = getArgumentMatcher(config);\n\n return nullIfDocIsEmpty(\n visit(doc, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n // Remove matching top level variables definitions.\n variableDefinitions: node.variableDefinitions ? node.variableDefinitions.filter(\n varDef =>\n !config.some(arg => arg.name === varDef.variable.name.value),\n ) : [],\n };\n },\n },\n\n Field: {\n enter(node) {\n // If `remove` is set to true for an argument, and an argument match\n // is found for a field, remove the field as well.\n const shouldRemoveField = config.some(argConfig => argConfig.remove);\n\n if (shouldRemoveField) {\n let argMatchCount = 0;\n if (node.arguments) {\n node.arguments.forEach(arg => {\n if (argMatcher(arg)) {\n argMatchCount += 1;\n }\n });\n }\n\n if (argMatchCount === 1) {\n return null;\n }\n }\n },\n },\n\n Argument: {\n enter(node) {\n // Remove all matching arguments.\n if (argMatcher(node)) {\n return null;\n }\n },\n },\n }),\n );\n}\n\nexport function removeFragmentSpreadFromDocument(\n config: RemoveFragmentSpreadConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n function enter(\n node: FragmentSpreadNode | FragmentDefinitionNode,\n ): null | void {\n if (config.some(def => def.name === node.name.value)) {\n return null;\n }\n }\n\n return nullIfDocIsEmpty(\n visit(doc, {\n FragmentSpread: { enter },\n FragmentDefinition: { enter },\n }),\n );\n}\n\nfunction getAllFragmentSpreadsFromSelectionSet(\n selectionSet: SelectionSetNode,\n): FragmentSpreadNode[] {\n const allFragments: FragmentSpreadNode[] = [];\n\n selectionSet.selections.forEach(selection => {\n if (\n (isField(selection) || isInlineFragment(selection)) &&\n selection.selectionSet\n ) {\n getAllFragmentSpreadsFromSelectionSet(selection.selectionSet).forEach(\n frag => allFragments.push(frag),\n );\n } else if (selection.kind === 'FragmentSpread') {\n allFragments.push(selection);\n }\n });\n\n return allFragments;\n}\n\n// If the incoming document is a query, return it as is. Otherwise, build a\n// new document containing a query operation based on the selection set\n// of the previous main operation.\nexport function buildQueryFromSelectionSet(\n document: DocumentNode,\n): DocumentNode {\n const definition = getMainDefinition(document);\n const definitionOperation = (definition).operation;\n\n if (definitionOperation === 'query') {\n // Already a query, so return the existing document.\n return document;\n }\n\n // Build a new query using the selection set of the main operation.\n const modifiedDoc = visit(document, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n operation: 'query',\n };\n },\n },\n });\n return modifiedDoc;\n}\n\n// Remove fields / selection sets that include an @client directive.\nexport function removeClientSetsFromDocument(\n document: DocumentNode,\n): DocumentNode | null {\n checkDocument(document);\n\n let modifiedDoc = removeDirectivesFromDocument(\n [\n {\n test: (directive: DirectiveNode) => directive.name.value === 'client',\n remove: true,\n },\n ],\n document,\n );\n\n // After a fragment definition has had its @client related document\n // sets removed, if the only field it has left is a __typename field,\n // remove the entire fragment operation to prevent it from being fired\n // on the server.\n if (modifiedDoc) {\n modifiedDoc = visit(modifiedDoc, {\n FragmentDefinition: {\n enter(node) {\n if (node.selectionSet) {\n const isTypenameOnly = node.selectionSet.selections.every(\n selection =>\n isField(selection) && selection.name.value === '__typename',\n );\n if (isTypenameOnly) {\n return null;\n }\n }\n },\n },\n });\n }\n\n return modifiedDoc;\n}\n","import { isNonNullObject } from \"./objects\";\n\nconst { hasOwnProperty } = Object.prototype;\n\n// These mergeDeep and mergeDeepArray utilities merge any number of objects\n// together, sharing as much memory as possible with the source objects, while\n// remaining careful to avoid modifying any source objects.\n\n// Logically, the return type of mergeDeep should be the intersection of\n// all the argument types. The binary call signature is by far the most\n// common, but we support 0- through 5-ary as well. After that, the\n// resulting type is just the inferred array element type. Note to nerds:\n// there is a more clever way of doing this that converts the tuple type\n// first to a union type (easy enough: T[number]) and then converts the\n// union to an intersection type using distributive conditional type\n// inference, but that approach has several fatal flaws (boolean becomes\n// true & false, and the inferred type ends up as unknown in many cases),\n// in addition to being nearly impossible to explain/understand.\nexport type TupleToIntersection =\n T extends [infer A] ? A :\n T extends [infer A, infer B] ? A & B :\n T extends [infer A, infer B, infer C] ? A & B & C :\n T extends [infer A, infer B, infer C, infer D] ? A & B & C & D :\n T extends [infer A, infer B, infer C, infer D, infer E] ? A & B & C & D & E :\n T extends (infer U)[] ? U : any;\n\nexport function mergeDeep(\n ...sources: T\n): TupleToIntersection {\n return mergeDeepArray(sources);\n}\n\n// In almost any situation where you could succeed in getting the\n// TypeScript compiler to infer a tuple type for the sources array, you\n// could just use mergeDeep instead of mergeDeepArray, so instead of\n// trying to convert T[] to an intersection type we just infer the array\n// element type, which works perfectly when the sources array has a\n// consistent element type.\nexport function mergeDeepArray(sources: T[]): T {\n let target = sources[0] || ({} as T);\n const count = sources.length;\n if (count > 1) {\n const merger = new DeepMerger();\n for (let i = 1; i < count; ++i) {\n target = merger.merge(target, sources[i]);\n }\n }\n return target;\n}\n\nexport type ReconcilerFunction = (\n this: DeepMerger,\n target: Record,\n source: Record,\n property: string | number,\n ...context: TContextArgs\n) => any;\n\nconst defaultReconciler: ReconcilerFunction =\n function (target, source, property) {\n return this.merge(target[property], source[property]);\n };\n\nexport class DeepMerger {\n constructor(\n private reconciler: ReconcilerFunction = defaultReconciler,\n ) {}\n\n public merge(target: any, source: any, ...context: TContextArgs): any {\n if (isNonNullObject(source) && isNonNullObject(target)) {\n Object.keys(source).forEach(sourceKey => {\n if (hasOwnProperty.call(target, sourceKey)) {\n const targetValue = target[sourceKey];\n if (source[sourceKey] !== targetValue) {\n const result = this.reconciler(target, source, sourceKey, ...context);\n // A well-implemented reconciler may return targetValue to indicate\n // the merge changed nothing about the structure of the target.\n if (result !== targetValue) {\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = result;\n }\n }\n } else {\n // If there is no collision, the target can safely share memory with\n // the source, and the recursion can terminate here.\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = source[sourceKey];\n }\n });\n\n return target;\n }\n\n // If source (or target) is not an object, let source replace target.\n return source;\n }\n\n public isObject = isNonNullObject;\n\n private pastCopies = new Set();\n\n public shallowCopyForMerge(value: T): T {\n if (isNonNullObject(value)) {\n if (this.pastCopies.has(value)) {\n // In order to reuse a past copy, it must be mutable, but copied objects\n // can sometimes be frozen while this DeepMerger is still active.\n if (!Object.isFrozen(value)) return value;\n this.pastCopies.delete(value);\n }\n if (Array.isArray(value)) {\n value = (value as any).slice(0);\n } else {\n value = {\n __proto__: Object.getPrototypeOf(value),\n ...value,\n };\n }\n this.pastCopies.add(value);\n }\n return value;\n }\n}\n","import Observable from 'zen-observable';\n\n// This simplified polyfill attempts to follow the ECMAScript Observable\n// proposal (https://github.com/zenparsing/es-observable)\nimport 'symbol-observable';\n\nexport type ObservableSubscription = ZenObservable.Subscription;\nexport type Observer = ZenObservable.Observer;\nexport type Subscriber = ZenObservable.Subscriber;\n\n// The zen-observable package defines Observable.prototype[Symbol.observable]\n// when Symbol is supported, but RxJS interop depends on also setting this fake\n// '@@observable' string as a polyfill for Symbol.observable.\nconst { prototype } = Observable;\nconst fakeObsSymbol = '@@observable' as keyof typeof prototype;\nif (!prototype[fakeObsSymbol]) {\n prototype[fakeObsSymbol] = function () { return this; };\n}\n\nexport { Observable };\n","const { toString } = Object.prototype;\n\n/**\n * Deeply clones a value to create a new instance.\n */\nexport function cloneDeep(value: T): T {\n return cloneDeepHelper(value);\n}\n\nfunction cloneDeepHelper(val: T, seen?: Map): T {\n switch (toString.call(val)) {\n case \"[object Array]\": {\n seen = seen || new Map;\n if (seen.has(val)) return seen.get(val);\n const copy: T & any[] = (val as any).slice(0);\n seen.set(val, copy);\n copy.forEach(function (child, i) {\n copy[i] = cloneDeepHelper(child, seen);\n });\n return copy;\n }\n\n case \"[object Object]\": {\n seen = seen || new Map;\n if (seen.has(val)) return seen.get(val);\n // High fidelity polyfills of Object.create and Object.getPrototypeOf are\n // possible in all JS environments, so we will assume they exist/work.\n const copy = Object.create(Object.getPrototypeOf(val));\n seen.set(val, copy);\n Object.keys(val).forEach(key => {\n copy[key] = cloneDeepHelper((val as any)[key], seen);\n });\n return copy;\n }\n\n default:\n return val;\n }\n}\n","import '../globals'; // For __DEV__\nimport { isNonNullObject } from './objects';\n\nfunction deepFreeze(value: any) {\n const workSet = new Set([value]);\n workSet.forEach(obj => {\n if (isNonNullObject(obj) && shallowFreeze(obj) === obj) {\n Object.getOwnPropertyNames(obj).forEach(name => {\n if (isNonNullObject(obj[name])) workSet.add(obj[name]);\n });\n }\n });\n return value;\n}\n\nfunction shallowFreeze(obj: T): T | null {\n if (__DEV__ && !Object.isFrozen(obj)) {\n try {\n Object.freeze(obj);\n } catch (e) {\n // Some types like Uint8Array and Node.js's Buffer cannot be frozen, but\n // they all throw a TypeError when you try, so we re-throw any exceptions\n // that are not TypeErrors, since that would be unexpected.\n if (e instanceof TypeError) return null;\n throw e;\n }\n }\n return obj;\n}\n\nexport function maybeDeepFreeze(obj: T): T {\n if (__DEV__) {\n deepFreeze(obj);\n }\n return obj;\n}\n","import { Observer } from \"./Observable\";\n\nexport function iterateObserversSafely(\n observers: Set>,\n method: keyof Observer,\n argument?: A,\n) {\n // In case observers is modified during iteration, we need to commit to the\n // original elements, which also provides an opportunity to filter them down\n // to just the observers with the given method.\n const observersWithMethod: Observer[] = [];\n observers.forEach(obs => obs[method] && observersWithMethod.push(obs));\n observersWithMethod.forEach(obs => (obs as any)[method](argument));\n}\n","import { Observable, Observer } from \"./Observable\";\n\n// Like Observable.prototype.map, except that the mapping function can\n// optionally return a Promise (or be async).\nexport function asyncMap(\n observable: Observable,\n mapFn: (value: V) => R | PromiseLike,\n catchFn?: (error: any) => R | PromiseLike,\n): Observable {\n return new Observable(observer => {\n const { next, error, complete } = observer;\n let activeCallbackCount = 0;\n let completed = false;\n let promiseQueue = {\n // Normally we would initialize promiseQueue to Promise.resolve(), but\n // in this case, for backwards compatibility, we need to be careful to\n // invoke the first callback synchronously.\n then(callback: () => any) {\n return new Promise(resolve => resolve(callback()));\n },\n } as Promise;\n\n function makeCallback(\n examiner: typeof mapFn | typeof catchFn,\n delegate: typeof next | typeof error,\n ): (arg: any) => void {\n if (examiner) {\n return arg => {\n ++activeCallbackCount;\n const both = () => examiner(arg);\n promiseQueue = promiseQueue.then(both, both).then(\n result => {\n --activeCallbackCount;\n next && next.call(observer, result);\n if (completed) {\n handler.complete!();\n }\n },\n error => {\n --activeCallbackCount;\n throw error;\n },\n ).catch(caught => {\n error && error.call(observer, caught);\n });\n };\n } else {\n return arg => delegate && delegate.call(observer, arg);\n }\n }\n\n const handler: Observer = {\n next: makeCallback(mapFn, next),\n error: makeCallback(catchFn, error),\n complete() {\n completed = true;\n if (!activeCallbackCount) {\n complete && complete.call(observer);\n }\n },\n };\n\n const sub = observable.subscribe(handler);\n return () => sub.unsubscribe();\n });\n}\n","import { Observable } from \"./Observable\";\nimport { canUseSymbol } from \"../common/canUse\";\n\n// Generic implementations of Observable.prototype methods like map and\n// filter need to know how to create a new Observable from an Observable\n// subclass (like Concast or ObservableQuery). Those methods assume\n// (perhaps unwisely?) that they can call the subtype's constructor with a\n// Subscriber function, even though the subclass constructor might expect\n// different parameters. Defining this static Symbol.species property on\n// the subclass is a hint to generic Observable code to use the default\n// constructor instead of trying to do `new Subclass(observer => ...)`.\nexport function fixObservableSubclass<\n S extends new (...args: any[]) => Observable,\n>(subclass: S): S {\n function set(key: symbol | string) {\n // Object.defineProperty is necessary because the Symbol.species\n // property is a getter by default in modern JS environments, so we\n // can't assign to it with a normal assignment expression.\n Object.defineProperty(subclass, key, { value: Observable });\n }\n if (canUseSymbol && Symbol.species) {\n set(Symbol.species);\n }\n // The \"@@species\" string is used as a fake Symbol.species value in some\n // polyfill systems (including the SymbolSpecies variable used by\n // zen-observable), so we should set it as well, to be safe.\n set(\"@@species\");\n return subclass;\n}\n","import { Observable, Observer, ObservableSubscription, Subscriber } from \"./Observable\";\nimport { iterateObserversSafely } from \"./iteration\";\nimport { fixObservableSubclass } from \"./subclassing\";\n\ntype MaybeAsync = T | PromiseLike;\n\nfunction isPromiseLike(value: MaybeAsync): value is PromiseLike {\n return value && typeof (value as any).then === \"function\";\n}\n\n// Any individual Source can be an Observable or a promise for one.\ntype Source = MaybeAsync>;\n\nexport type ConcastSourcesIterable = Iterable>;\n\n// A Concast observable concatenates the given sources into a single\n// non-overlapping sequence of Ts, automatically unwrapping any promises,\n// and broadcasts the T elements of that sequence to any number of\n// subscribers, all without creating a bunch of intermediary Observable\n// wrapper objects.\n//\n// Even though any number of observers can subscribe to the Concast, each\n// source observable is guaranteed to receive at most one subscribe call,\n// and the results are multicast to all observers.\n//\n// In addition to broadcasting every next/error message to this.observers,\n// the Concast stores the most recent message using this.latest, so any\n// new observers can immediately receive the latest message, even if it\n// was originally delivered in the past. This behavior means we can assume\n// every active observer in this.observers has received the same most\n// recent message.\n//\n// With the exception of this.latest replay, a Concast is a \"hot\"\n// observable in the sense that it does not replay past results from the\n// beginning of time for each new observer.\n//\n// Could we have used some existing RxJS class instead? Concast is\n// similar to a BehaviorSubject, because it is multicast and redelivers\n// the latest next/error message to new subscribers. Unlike Subject,\n// Concast does not expose an Observer interface (this.handlers is\n// intentionally private), since Concast gets its inputs from the\n// concatenated sources. If we ever switch to RxJS, there may be some\n// value in reusing their code, but for now we use zen-observable, which\n// does not contain any Subject implementations.\nexport class Concast extends Observable {\n // Active observers receiving broadcast messages. Thanks to this.latest,\n // we can assume all observers in this Set have received the same most\n // recent message, though possibly at different times in the past.\n private observers = new Set>();\n\n // This property starts off undefined to indicate the initial\n // subscription has not yet begun, then points to each source\n // subscription in turn, and finally becomes null after the sources have\n // been exhausted. After that, it stays null.\n private sub?: ObservableSubscription | null;\n\n // Not only can the individual elements of the iterable be promises, but\n // also the iterable itself can be wrapped in a promise.\n constructor(sources: MaybeAsync> | Subscriber) {\n super(observer => {\n this.addObserver(observer);\n return () => this.removeObserver(observer);\n });\n\n // Suppress rejection warnings for this.promise, since it's perfectly\n // acceptable to pay no attention to this.promise if you're consuming\n // the results through the normal observable API.\n this.promise.catch(_ => {});\n\n // If someone accidentally tries to create a Concast using a subscriber\n // function, recover by creating an Observable from that subscriber and\n // using it as the source.\n if (typeof sources === \"function\") {\n sources = [new Observable(sources)];\n }\n\n if (isPromiseLike(sources)) {\n sources.then(\n iterable => this.start(iterable),\n this.handlers.error,\n );\n } else {\n this.start(sources);\n }\n }\n\n // A consumable array of source observables, incrementally consumed\n // each time this.handlers.complete is called.\n private sources: Source[];\n\n private start(sources: ConcastSourcesIterable) {\n if (this.sub !== void 0) return;\n\n // In practice, sources is most often simply an Array of observables.\n // TODO Consider using sources[Symbol.iterator]() to take advantage\n // of the laziness of non-Array iterables.\n this.sources = Array.from(sources);\n\n // Calling this.handlers.complete() kicks off consumption of the first\n // source observable. It's tempting to do this step lazily in\n // addObserver, but this.promise can be accessed without calling\n // addObserver, so consumption needs to begin eagerly.\n this.handlers.complete();\n }\n\n private deliverLastMessage(observer: Observer) {\n if (this.latest) {\n const nextOrError = this.latest[0];\n const method = observer[nextOrError];\n if (method) {\n method.call(observer, this.latest[1]);\n }\n // If the subscription is already closed, and the last message was\n // a 'next' message, simulate delivery of the final 'complete'\n // message again.\n if (this.sub === null &&\n nextOrError === \"next\" &&\n observer.complete) {\n observer.complete();\n }\n }\n }\n\n // Note: cleanup observers do not count towards this total.\n private addCount = 0;\n\n public addObserver(observer: Observer) {\n if (!this.observers.has(observer)) {\n // Immediately deliver the most recent message, so we can always\n // be sure all observers have the latest information.\n this.deliverLastMessage(observer);\n this.observers.add(observer);\n ++this.addCount;\n }\n }\n\n public removeObserver(\n observer: Observer,\n quietly?: boolean,\n ) {\n if (this.observers.delete(observer) &&\n --this.addCount < 1 &&\n !quietly) {\n // In case there are still any cleanup observers in this.observers,\n // and no error or completion has been broadcast yet, make sure\n // those observers receive an error that terminates them.\n this.handlers.error(new Error(\"Observable cancelled prematurely\"));\n }\n }\n\n // Any Concast object can be trivially converted to a Promise, without\n // having to create a new wrapper Observable. This promise provides an\n // easy way to observe the final state of the Concast.\n private resolve: (result?: T | PromiseLike) => void;\n private reject: (reason: any) => void;\n public readonly promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n\n // Name and argument of the most recently invoked observer method, used\n // to deliver latest results immediately to new observers.\n private latest?: [\"next\" | \"error\", any];\n\n // Bound handler functions that can be reused for every internal\n // subscription.\n private handlers = {\n next: (result: T) => {\n if (this.sub !== null) {\n this.latest = [\"next\", result];\n iterateObserversSafely(this.observers, \"next\", result);\n }\n },\n\n error: (error: any) => {\n const { sub } = this;\n if (sub !== null) {\n // Delay unsubscribing from the underlying subscription slightly,\n // so that immediately subscribing another observer can keep the\n // subscription active.\n if (sub) setTimeout(() => sub.unsubscribe());\n this.sub = null;\n this.latest = [\"error\", error];\n this.reject(error);\n iterateObserversSafely(this.observers, \"error\", error);\n }\n },\n\n complete: () => {\n if (this.sub !== null) {\n const value = this.sources.shift();\n if (!value) {\n this.sub = null;\n if (this.latest &&\n this.latest[0] === \"next\") {\n this.resolve(this.latest[1]);\n } else {\n this.resolve();\n }\n // We do not store this.latest = [\"complete\"], because doing so\n // discards useful information about the previous next (or\n // error) message. Instead, if new observers subscribe after\n // this Concast has completed, they will receive the final\n // 'next' message (unless there was an error) immediately\n // followed by a 'complete' message (see addObserver).\n iterateObserversSafely(this.observers, \"complete\");\n } else if (isPromiseLike(value)) {\n value.then(obs => this.sub = obs.subscribe(this.handlers));\n } else {\n this.sub = value.subscribe(this.handlers);\n }\n }\n },\n };\n\n public cleanup(callback: () => any) {\n let called = false;\n const once = () => {\n if (!called) {\n called = true;\n // Removing a cleanup observer should not unsubscribe from the\n // underlying Observable, so the only removeObserver behavior we\n // need here is to delete observer from this.observers.\n this.observers.delete(observer);\n callback();\n }\n }\n const observer = {\n next: once,\n error: once,\n complete: once,\n };\n const count = this.addCount;\n this.addObserver(observer);\n // Normally addObserver increments this.addCount, but we can \"hide\"\n // cleanup observers by restoring this.addCount to its previous value\n // after adding any cleanup observer.\n this.addCount = count;\n }\n\n // A public way to abort observation and broadcast.\n public cancel = (reason: any) => {\n this.reject(reason);\n this.sources = [];\n this.handlers.complete();\n }\n}\n\n// Necessary because the Concast constructor has a different signature\n// than the Observable constructor.\nfixObservableSubclass(Concast);\n","export function isNonEmptyArray(value?: ArrayLike): value is Array {\n return Array.isArray(value) && value.length > 0;\n}\n","import { ExecutionResult } from 'graphql';\n\nexport function graphQLResultHasError(result: ExecutionResult): boolean {\n return (result.errors && result.errors.length > 0) || false;\n}\n","export const canUseWeakMap = typeof WeakMap === 'function' && !(\n typeof navigator === 'object' &&\n navigator.product === 'ReactNative'\n);\n\nexport const canUseWeakSet = typeof WeakSet === 'function';\n\nexport const canUseSymbol =\n typeof Symbol === 'function' &&\n typeof Symbol.for === 'function';\n","import { TupleToIntersection } from './mergeDeep';\n\n/**\n * Merges the provided objects shallowly and removes\n * all properties with an `undefined` value\n */\nexport function compact(\n ...objects: TArgs\n): TupleToIntersection {\n const result = Object.create(null);\n\n objects.forEach(obj => {\n if (!obj) return;\n Object.keys(obj).forEach(key => {\n const value = (obj as any)[key];\n if (value !== void 0) {\n result[key] = value;\n }\n });\n });\n\n return result;\n}\n","import { useContext, useEffect, useMemo, useRef, useState } from 'react';\nimport { equal } from '@wry/equality';\nimport { OperationVariables, mergeOptions } from '../../core';\nimport { getApolloContext } from '../context';\nimport { ApolloError } from '../../errors';\nimport {\n ApolloQueryResult,\n NetworkStatus,\n ObservableQuery,\n DocumentNode,\n TypedDocumentNode,\n WatchQueryOptions,\n} from '../../core';\nimport {\n QueryHookOptions,\n QueryResult,\n} from '../types/types';\n\nimport { DocumentType, verifyDocumentType } from '../parser';\nimport { useApolloClient } from './useApolloClient';\n\nexport function useQuery<\n TData = any,\n TVariables = OperationVariables,\n>(\n query: DocumentNode | TypedDocumentNode,\n options?: QueryHookOptions,\n): QueryResult {\n const context = useContext(getApolloContext());\n const client = useApolloClient(options?.client);\n const defaultWatchQueryOptions = client.defaultOptions.watchQuery;\n verifyDocumentType(query, DocumentType.Query);\n const [obsQuery, setObsQuery] = useState(() => {\n const watchQueryOptions = createWatchQueryOptions(query, options, defaultWatchQueryOptions);\n // See if there is an existing observable that was used to fetch the same\n // data and if so, use it instead since it will contain the proper queryId\n // to fetch the result set. This is used during SSR.\n let obsQuery: ObservableQuery | null = null;\n if (context.renderPromises) {\n obsQuery = context.renderPromises.getSSRObservable(watchQueryOptions);\n }\n\n if (!obsQuery) {\n // Is it safe (StrictMode/memory-wise) to call client.watchQuery here?\n obsQuery = client.watchQuery(watchQueryOptions);\n if (context.renderPromises) {\n context.renderPromises.registerSSRObservable(\n obsQuery,\n watchQueryOptions,\n );\n }\n }\n\n if (\n context.renderPromises &&\n options?.ssr !== false &&\n !options?.skip &&\n obsQuery.getCurrentResult().loading\n ) {\n // TODO: This is a legacy API which could probably be cleaned up\n context.renderPromises.addQueryPromise(\n {\n // The only options which seem to actually be used by the\n // RenderPromises class are query and variables.\n getOptions: () => createWatchQueryOptions(query, options, defaultWatchQueryOptions),\n fetchData: () => new Promise((resolve) => {\n const sub = obsQuery!.subscribe({\n next(result) {\n if (!result.loading) {\n resolve()\n sub.unsubscribe();\n }\n },\n error() {\n resolve();\n sub.unsubscribe();\n },\n complete() {\n resolve();\n },\n });\n }),\n },\n // This callback never seemed to do anything\n () => null,\n );\n }\n\n return obsQuery;\n });\n\n let [result, setResult] = useState(() => {\n const result = obsQuery.getCurrentResult();\n if (!result.loading && options) {\n if (result.error) {\n options.onError?.(result.error);\n } else if (result.data) {\n options.onCompleted?.(result.data);\n }\n }\n\n return result;\n });\n\n const ref = useRef({\n client,\n query,\n options,\n result,\n previousData: void 0 as TData | undefined,\n watchQueryOptions: createWatchQueryOptions(query, options, defaultWatchQueryOptions),\n });\n\n // An effect to recreate the obsQuery whenever the client or query changes.\n // This effect is also responsible for checking and updating the obsQuery\n // options whenever they change.\n useEffect(() => {\n const watchQueryOptions = createWatchQueryOptions(query, options, defaultWatchQueryOptions);\n let nextResult: ApolloQueryResult | undefined;\n if (ref.current.client !== client || !equal(ref.current.query, query)) {\n const obsQuery = client.watchQuery(watchQueryOptions);\n setObsQuery(obsQuery);\n nextResult = obsQuery.getCurrentResult();\n } else if (!equal(ref.current.watchQueryOptions, watchQueryOptions)) {\n obsQuery.setOptions(watchQueryOptions).catch(() => {});\n nextResult = obsQuery.getCurrentResult();\n ref.current.watchQueryOptions = watchQueryOptions;\n }\n\n if (nextResult) {\n const previousResult = ref.current.result;\n if (previousResult.data) {\n ref.current.previousData = previousResult.data;\n }\n\n setResult(ref.current.result = nextResult);\n if (!nextResult.loading && options) {\n if (nextResult.error) {\n options.onError?.(nextResult.error);\n } else if (nextResult.data) {\n options.onCompleted?.(nextResult.data);\n }\n }\n }\n\n Object.assign(ref.current, { client, query });\n }, [obsQuery, client, query, options]);\n\n // An effect to subscribe to the current observable query\n useEffect(() => {\n if (context.renderPromises) {\n return;\n }\n\n let subscription = obsQuery.subscribe(onNext, onError);\n // We use `getCurrentResult()` instead of the callback argument because\n // the values differ slightly. Specifically, loading results will have\n // an empty object for data instead of `undefined` for some reason.\n function onNext() {\n const previousResult = ref.current.result;\n const result = obsQuery.getCurrentResult();\n // Make sure we're not attempting to re-render similar results\n if (\n previousResult &&\n previousResult.loading === result.loading &&\n previousResult.networkStatus === result.networkStatus &&\n equal(previousResult.data, result.data)\n ) {\n return;\n }\n\n if (previousResult.data) {\n ref.current.previousData = previousResult.data;\n }\n\n setResult(ref.current.result = result);\n if (!result.loading) {\n ref.current.options?.onCompleted?.(result.data);\n }\n }\n\n function onError(error: Error) {\n const last = obsQuery[\"last\"];\n subscription.unsubscribe();\n // Unfortunately, if `lastError` is set in the current\n // `observableQuery` when the subscription is re-created,\n // the subscription will immediately receive the error, which will\n // cause it to terminate again. To avoid this, we first clear\n // the last error/result from the `observableQuery` before re-starting\n // the subscription, and restore it afterwards (so the subscription\n // has a chance to stay open).\n try {\n obsQuery.resetLastResults();\n subscription = obsQuery.subscribe(onNext, onError);\n } finally {\n obsQuery[\"last\"] = last;\n }\n\n if (!error.hasOwnProperty('graphQLErrors')) {\n // The error is not a GraphQL error\n throw error;\n }\n\n const previousResult = ref.current.result;\n if (\n (previousResult && previousResult.loading) ||\n !equal(error, previousResult.error)\n ) {\n setResult(ref.current.result = {\n data: previousResult.data,\n error: error as ApolloError,\n loading: false,\n networkStatus: NetworkStatus.error,\n });\n ref.current.options?.onError?.(error as ApolloError);\n }\n }\n\n return () => subscription.unsubscribe();\n }, [obsQuery, context.renderPromises, client.disableNetworkFetches]);\n\n let partial: boolean | undefined;\n ({ partial, ...result } = result);\n\n {\n // BAD BOY CODE BLOCK WHERE WE PUT SIDE-EFFECTS IN THE RENDER FUNCTION\n //\n // TODO: This code should be removed when the partialRefetch option is\n // removed. I was unable to get this hook to behave reasonably in certain\n // edge cases when this block was put in an effect.\n if (\n partial &&\n options?.partialRefetch &&\n !result.loading &&\n (!result.data || Object.keys(result.data).length === 0) &&\n obsQuery.options.fetchPolicy !== 'cache-only'\n ) {\n result = {\n ...result,\n loading: true,\n networkStatus: NetworkStatus.refetch,\n };\n\n obsQuery.refetch();\n }\n\n // TODO: This is a hack to make sure useLazyQuery executions update the\n // obsevable query options for ssr.\n if (\n context.renderPromises &&\n options?.ssr !== false &&\n !options?.skip &&\n result.loading\n ) {\n obsQuery.setOptions(createWatchQueryOptions(query, options, defaultWatchQueryOptions)).catch(() => {});\n }\n\n // We assign options during rendering as a guard to make sure that\n // callbacks like onCompleted and onError are not stale.\n Object.assign(ref.current, { options });\n }\n\n if (\n (context.renderPromises || client.disableNetworkFetches) &&\n options?.ssr === false\n ) {\n // If SSR has been explicitly disabled, and this function has been called\n // on the server side, return the default loading state.\n result = ref.current.result = {\n loading: true,\n data: void 0 as unknown as TData,\n error: void 0,\n networkStatus: NetworkStatus.loading,\n };\n } else if (options?.skip || options?.fetchPolicy === 'standby') {\n // When skipping a query (ie. we're not querying for data but still want to\n // render children), make sure the `data` is cleared out and `loading` is\n // set to `false` (since we aren't loading anything).\n //\n // NOTE: We no longer think this is the correct behavior. Skipping should\n // not automatically set `data` to `undefined`, but instead leave the\n // previous data in place. In other words, skipping should not mandate that\n // previously received data is all of a sudden removed. Unfortunately,\n // changing this is breaking, so we'll have to wait until Apollo Client 4.0\n // to address this.\n result = {\n loading: false,\n data: void 0 as unknown as TData,\n error: void 0,\n networkStatus: NetworkStatus.ready,\n };\n }\n\n if (result.errors && result.errors.length) {\n // Until a set naming convention for networkError and graphQLErrors is\n // decided upon, we map errors (graphQLErrors) to the error options.\n // TODO: Is it possible for both result.error and result.errors to be\n // defined here?\n result = {\n ...result,\n error: result.error || new ApolloError({ graphQLErrors: result.errors }),\n };\n }\n\n const obsQueryFields = useMemo(() => ({\n refetch: obsQuery.refetch.bind(obsQuery),\n fetchMore: obsQuery.fetchMore.bind(obsQuery),\n updateQuery: obsQuery.updateQuery.bind(obsQuery),\n startPolling: obsQuery.startPolling.bind(obsQuery),\n stopPolling: obsQuery.stopPolling.bind(obsQuery),\n subscribeToMore: obsQuery.subscribeToMore.bind(obsQuery),\n }), [obsQuery]);\n\n return {\n ...obsQueryFields,\n variables: createWatchQueryOptions(query, options, defaultWatchQueryOptions).variables,\n client,\n called: true,\n previousData: ref.current.previousData,\n ...result,\n };\n}\n\n/**\n * A function to massage options before passing them the ObservableQuery.\n */\nfunction createWatchQueryOptions(\n query: DocumentNode | TypedDocumentNode,\n options: QueryHookOptions = {},\n defaultOptions?: Partial>\n): WatchQueryOptions {\n // TODO: For some reason, we pass context, which is the React Apollo Context,\n // into observable queries, and test for that.\n // removing hook specific options\n const {\n skip,\n ssr,\n onCompleted,\n onError,\n displayName,\n ...otherOptions\n } = options;\n\n let watchQueryOptions = { query, ...otherOptions };\n if (defaultOptions) {\n watchQueryOptions = mergeOptions(defaultOptions, watchQueryOptions);\n }\n\n if (skip) {\n watchQueryOptions.fetchPolicy = 'standby';\n } else if (\n watchQueryOptions.context?.renderPromises &&\n (\n watchQueryOptions.fetchPolicy === 'network-only' ||\n watchQueryOptions.fetchPolicy === 'cache-and-network'\n )\n ) {\n // this behavior was added to react-apollo without explanation in this PR\n // https://github.com/apollographql/react-apollo/pull/1579\n watchQueryOptions.fetchPolicy = 'cache-first';\n } else if (!watchQueryOptions.fetchPolicy) {\n // cache-first is the default policy, but we explicitly assign it here so\n // the cache policies computed based on options can be cleared\n watchQueryOptions.fetchPolicy = 'cache-first';\n }\n\n if (!watchQueryOptions.variables) {\n watchQueryOptions.variables = {} as TVariables;\n }\n\n return watchQueryOptions;\n}\n","import { useCallback, useEffect, useRef, useState } from 'react';\nimport { DocumentNode } from 'graphql';\nimport { TypedDocumentNode } from '@graphql-typed-document-node/core';\nimport {\n MutationFunctionOptions,\n MutationHookOptions,\n MutationResult,\n MutationTuple,\n} from '../types/types';\n\nimport {\n ApolloCache,\n DefaultContext,\n mergeOptions,\n OperationVariables,\n} from '../../core';\nimport { equal } from '@wry/equality';\nimport { DocumentType, verifyDocumentType } from '../parser';\nimport { ApolloError } from '../../errors';\nimport { useApolloClient } from './useApolloClient';\n\nexport function useMutation<\n TData = any,\n TVariables = OperationVariables,\n TContext = DefaultContext,\n TCache extends ApolloCache = ApolloCache,\n>(\n mutation: DocumentNode | TypedDocumentNode,\n options?: MutationHookOptions,\n): MutationTuple {\n const client = useApolloClient(options?.client);\n verifyDocumentType(mutation, DocumentType.Mutation);\n const [result, setResult] = useState>({\n called: false,\n loading: false,\n client,\n });\n\n const ref = useRef({\n result,\n mutationId: 0,\n isMounted: true,\n client,\n mutation,\n options,\n });\n\n // TODO: Trying to assign these in a useEffect or useLayoutEffect breaks\n // higher-order components.\n {\n Object.assign(ref.current, { client, options, mutation });\n }\n\n const execute = useCallback((\n executeOptions: MutationFunctionOptions<\n TData,\n TVariables,\n TContext,\n TCache\n > = {}\n ) => {\n const {client, options, mutation} = ref.current;\n const baseOptions = { ...options, mutation };\n if (!ref.current.result.loading && !baseOptions.ignoreResults) {\n setResult(ref.current.result = {\n loading: true,\n error: void 0,\n data: void 0,\n called: true,\n client,\n });\n }\n\n const mutationId = ++ref.current.mutationId;\n const clientOptions = mergeOptions(\n baseOptions,\n executeOptions as any,\n );\n\n return client.mutate(clientOptions).then((response) => {\n const { data, errors } = response;\n const error =\n errors && errors.length > 0\n ? new ApolloError({ graphQLErrors: errors })\n : void 0;\n\n if (\n mutationId === ref.current.mutationId &&\n !clientOptions.ignoreResults\n ) {\n const result = {\n called: true,\n loading: false,\n data,\n error,\n client,\n };\n\n if (ref.current.isMounted && !equal(ref.current.result, result)) {\n setResult(ref.current.result = result);\n }\n }\n\n baseOptions.onCompleted?.(response.data!);\n executeOptions.onCompleted?.(response.data!);\n return response;\n }).catch((error) => {\n if (\n mutationId === ref.current.mutationId &&\n ref.current.isMounted\n ) {\n const result = {\n loading: false,\n error,\n data: void 0,\n called: true,\n client,\n };\n\n if (!equal(ref.current.result, result)) {\n setResult(ref.current.result = result);\n }\n }\n\n if (baseOptions.onError || clientOptions.onError) {\n baseOptions.onError?.(error);\n executeOptions.onError?.(error);\n // TODO(brian): why are we returning this here???\n return { data: void 0, errors: error };\n }\n\n throw error;\n });\n }, []);\n\n const reset = useCallback(() => {\n setResult({ called: false, loading: false, client });\n }, []);\n\n useEffect(() => () => {\n ref.current.isMounted = false;\n }, []);\n\n return [execute, { reset, ...result }];\n}\n","'use strict';\n\nvar _extends = require('@babel/runtime/helpers/extends');\n\nvar _require = require('@apollo/client/core'),\n ApolloLink = _require.ApolloLink,\n Observable = _require.Observable;\n\nvar _require2 = require('@apollo/client/link/http'),\n createSignalIfSupported = _require2.createSignalIfSupported,\n fallbackHttpConfig = _require2.fallbackHttpConfig,\n parseAndCheckHttpResponse = _require2.parseAndCheckHttpResponse,\n rewriteURIForGET = _require2.rewriteURIForGET,\n selectHttpOptionsAndBody = _require2.selectHttpOptionsAndBody,\n selectURI = _require2.selectURI,\n serializeFetchParameter = _require2.serializeFetchParameter;\n\nvar extractFiles = require('extract-files/public/extractFiles');\n\nvar formDataAppendFile = require('./formDataAppendFile');\n\nvar isExtractableFile = require('./isExtractableFile');\n\nmodule.exports = function createUploadLink(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$uri = _ref.uri,\n fetchUri = _ref$uri === void 0 ? '/graphql' : _ref$uri,\n useGETForQueries = _ref.useGETForQueries,\n _ref$isExtractableFil = _ref.isExtractableFile,\n customIsExtractableFile =\n _ref$isExtractableFil === void 0\n ? isExtractableFile\n : _ref$isExtractableFil,\n CustomFormData = _ref.FormData,\n _ref$formDataAppendFi = _ref.formDataAppendFile,\n customFormDataAppendFile =\n _ref$formDataAppendFi === void 0\n ? formDataAppendFile\n : _ref$formDataAppendFi,\n customFetch = _ref.fetch,\n fetchOptions = _ref.fetchOptions,\n credentials = _ref.credentials,\n headers = _ref.headers,\n includeExtensions = _ref.includeExtensions;\n\n var linkConfig = {\n http: {\n includeExtensions: includeExtensions,\n },\n options: fetchOptions,\n credentials: credentials,\n headers: headers,\n };\n return new ApolloLink(function (operation) {\n var context = operation.getContext();\n var _context$clientAwaren = context.clientAwareness;\n _context$clientAwaren =\n _context$clientAwaren === void 0 ? {} : _context$clientAwaren;\n var name = _context$clientAwaren.name,\n version = _context$clientAwaren.version,\n headers = context.headers;\n var contextConfig = {\n http: context.http,\n options: context.fetchOptions,\n credentials: context.credentials,\n headers: _extends(\n {},\n name && {\n 'apollographql-client-name': name,\n },\n version && {\n 'apollographql-client-version': version,\n },\n headers\n ),\n };\n\n var _selectHttpOptionsAnd = selectHttpOptionsAndBody(\n operation,\n fallbackHttpConfig,\n linkConfig,\n contextConfig\n ),\n options = _selectHttpOptionsAnd.options,\n body = _selectHttpOptionsAnd.body;\n\n var _extractFiles = extractFiles(body, '', customIsExtractableFile),\n clone = _extractFiles.clone,\n files = _extractFiles.files;\n\n var uri = selectURI(operation, fetchUri);\n\n if (files.size) {\n delete options.headers['content-type'];\n var RuntimeFormData = CustomFormData || FormData;\n var form = new RuntimeFormData();\n form.append('operations', serializeFetchParameter(clone, 'Payload'));\n var map = {};\n var i = 0;\n files.forEach(function (paths) {\n map[++i] = paths;\n });\n form.append('map', JSON.stringify(map));\n i = 0;\n files.forEach(function (paths, file) {\n customFormDataAppendFile(form, ++i, file);\n });\n options.body = form;\n } else {\n if (\n useGETForQueries &&\n !operation.query.definitions.some(function (definition) {\n return (\n definition.kind === 'OperationDefinition' &&\n definition.operation === 'mutation'\n );\n })\n )\n options.method = 'GET';\n\n if (options.method === 'GET') {\n var _rewriteURIForGET = rewriteURIForGET(uri, body),\n newURI = _rewriteURIForGET.newURI,\n parseError = _rewriteURIForGET.parseError;\n\n if (parseError)\n return new Observable(function (observer) {\n observer.error(parseError);\n });\n uri = newURI;\n } else options.body = serializeFetchParameter(clone, 'Payload');\n }\n\n var _createSignalIfSuppor = createSignalIfSupported(),\n controller = _createSignalIfSuppor.controller;\n\n if (controller) {\n if (options.signal)\n options.signal.addEventListener('abort', function () {\n controller.abort();\n });\n options.signal = controller.signal;\n }\n\n var runtimeFetch = customFetch || fetch;\n return new Observable(function (observer) {\n var cleaningUp;\n runtimeFetch(uri, options)\n .then(function (response) {\n operation.setContext({\n response: response,\n });\n return response;\n })\n .then(parseAndCheckHttpResponse(operation))\n .then(function (result) {\n observer.next(result);\n observer.complete();\n })\n .catch(function (error) {\n if (!cleaningUp) {\n if (error.result && error.result.errors && error.result.data)\n observer.next(error.result);\n observer.error(error);\n }\n });\n return function () {\n cleaningUp = true;\n if (controller) controller.abort();\n };\n });\n });\n};\n","import { ApolloLink } from './ApolloLink';\n\nexport const split = ApolloLink.split;\n","import { ApolloLink } from './ApolloLink';\n\nexport const from = ApolloLink.from;\n","import { invariant } from '../../utilities/globals';\n\nimport * as React from 'react';\n\nimport { ApolloClient } from '../../core';\nimport { getApolloContext } from './ApolloContext';\n\nexport interface ApolloProviderProps {\n client: ApolloClient;\n children: React.ReactNode | React.ReactNode[] | null;\n}\n\nexport const ApolloProvider: React.FC> = ({\n client,\n children\n}) => {\n const ApolloContext = getApolloContext();\n return (\n \n {(context: any = {}) => {\n if (client && context.client !== client) {\n context = Object.assign({}, context, { client });\n }\n\n invariant(\n context.client,\n 'ApolloProvider was not passed a client instance. Make ' +\n 'sure you pass in your client via the \"client\" prop.'\n );\n\n return (\n \n {children}\n \n );\n }}\n \n );\n};\n","import '../../utilities/globals';\nimport { useState, useRef, useEffect } from 'react';\nimport { DocumentNode } from 'graphql';\nimport { TypedDocumentNode } from '@graphql-typed-document-node/core';\nimport { equal } from '@wry/equality';\n\nimport { DocumentType, verifyDocumentType } from '../parser';\nimport {\n SubscriptionHookOptions,\n SubscriptionResult\n} from '../types/types';\nimport { OperationVariables } from '../../core';\nimport { useApolloClient } from './useApolloClient';\n\nexport function useSubscription(\n subscription: DocumentNode | TypedDocumentNode,\n options?: SubscriptionHookOptions,\n) {\n const client = useApolloClient(options?.client);\n verifyDocumentType(subscription, DocumentType.Subscription);\n const [result, setResult] = useState>({\n loading: !options?.skip,\n error: void 0,\n data: void 0,\n variables: options?.variables,\n });\n\n const [observable, setObservable] = useState(() => {\n if (options?.skip) {\n return null;\n }\n\n return client.subscribe({\n query: subscription,\n variables: options?.variables,\n fetchPolicy: options?.fetchPolicy,\n context: options?.context,\n });\n });\n\n const ref = useRef({ client, subscription, options });\n useEffect(() => {\n let shouldResubscribe = options?.shouldResubscribe;\n if (typeof shouldResubscribe === 'function') {\n shouldResubscribe = !!shouldResubscribe(options!);\n }\n\n if (options?.skip) {\n if (!options?.skip !== !ref.current.options?.skip) {\n setResult({\n loading: false,\n data: void 0,\n error: void 0,\n variables: options?.variables,\n });\n setObservable(null);\n }\n } else if (\n shouldResubscribe !== false && (\n client !== ref.current.client ||\n subscription !== ref.current.subscription ||\n options?.fetchPolicy !== ref.current.options?.fetchPolicy ||\n !options?.skip !== !ref.current.options?.skip ||\n !equal(options?.variables, ref.current.options?.variables)\n )\n ) {\n setResult({\n loading: true,\n data: void 0,\n error: void 0,\n variables: options?.variables,\n });\n setObservable(client.subscribe({\n query: subscription,\n variables: options?.variables,\n fetchPolicy: options?.fetchPolicy,\n context: options?.context,\n }));\n }\n\n Object.assign(ref.current, { client, subscription, options });\n }, [client, subscription, options]);\n\n useEffect(() => {\n if (!observable) {\n return;\n }\n\n const subscription = observable.subscribe({\n next(fetchResult) {\n const result = {\n loading: false,\n // TODO: fetchResult.data can be null but SubscriptionResult.data\n // expects TData | undefined only\n data: fetchResult.data!,\n error: void 0,\n variables: options?.variables,\n };\n setResult(result);\n\n ref.current.options?.onSubscriptionData?.({\n client,\n subscriptionData: result\n });\n },\n error(error) {\n setResult({\n loading: false,\n data: void 0,\n error,\n variables: options?.variables,\n });\n },\n complete() {\n ref.current.options?.onSubscriptionComplete?.();\n },\n });\n\n return () => {\n subscription.unsubscribe();\n };\n }, [observable]);\n\n return result;\n}\n","import { DocumentNode } from 'graphql';\nimport { wrap } from 'optimism';\n\nimport {\n StoreObject,\n Reference,\n getFragmentQueryDocument,\n} from '../../utilities';\nimport { DataProxy } from './types/DataProxy';\nimport { Cache } from './types/Cache';\n\nexport type Transaction = (c: ApolloCache) => void;\n\nexport abstract class ApolloCache implements DataProxy {\n // required to implement\n // core API\n public abstract read(\n query: Cache.ReadOptions,\n ): T | null;\n public abstract write(\n write: Cache.WriteOptions,\n ): Reference | undefined;\n public abstract diff(query: Cache.DiffOptions): Cache.DiffResult;\n public abstract watch(watch: Cache.WatchOptions): () => void;\n public abstract reset(): Promise;\n\n // Remove whole objects from the cache by passing just options.id, or\n // specific fields by passing options.field and/or options.args. If no\n // options.args are provided, all fields matching options.field (even\n // those with arguments) will be removed. Returns true iff any data was\n // removed from the cache.\n public abstract evict(options: Cache.EvictOptions): boolean;\n\n // intializer / offline / ssr API\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public abstract restore(\n serializedState: TSerialized,\n ): ApolloCache;\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public abstract extract(optimistic?: boolean): TSerialized;\n\n // Optimistic API\n\n public abstract removeOptimistic(id: string): void;\n\n // Transactional API\n\n public abstract performTransaction(\n transaction: Transaction,\n // Although subclasses may implement recordOptimisticTransaction\n // however they choose, the default implementation simply calls\n // performTransaction with a string as the second argument, allowing\n // performTransaction to handle both optimistic and non-optimistic\n // (broadcast-batching) transactions. Passing null for optimisticId is\n // also allowed, and indicates that performTransaction should apply\n // the transaction non-optimistically (ignoring optimistic data).\n optimisticId?: string | null,\n ): void;\n\n public recordOptimisticTransaction(\n transaction: Transaction,\n optimisticId: string,\n ) {\n this.performTransaction(transaction, optimisticId);\n }\n\n // Optional API\n\n public transformDocument(document: DocumentNode): DocumentNode {\n return document;\n }\n\n public identify(object: StoreObject | Reference): string | undefined {\n return;\n }\n\n public gc(): string[] {\n return [];\n }\n\n public modify(options: Cache.ModifyOptions): boolean {\n return false;\n }\n\n // Experimental API\n\n public transformForLink(document: DocumentNode): DocumentNode {\n return document;\n }\n\n // DataProxy API\n /**\n *\n * @param options\n * @param optimistic\n */\n public readQuery(\n options: Cache.ReadQueryOptions,\n optimistic = !!options.optimistic,\n ): QueryType | null {\n return this.read({\n rootId: options.id || 'ROOT_QUERY',\n query: options.query,\n variables: options.variables,\n returnPartialData: options.returnPartialData,\n optimistic,\n });\n }\n\n // Make sure we compute the same (===) fragment query document every\n // time we receive the same fragment in readFragment.\n private getFragmentDoc = wrap(getFragmentQueryDocument);\n\n public readFragment(\n options: Cache.ReadFragmentOptions,\n optimistic = !!options.optimistic,\n ): FragmentType | null {\n return this.read({\n query: this.getFragmentDoc(options.fragment, options.fragmentName),\n variables: options.variables,\n rootId: options.id,\n returnPartialData: options.returnPartialData,\n optimistic,\n });\n }\n\n public writeQuery(\n options: Cache.WriteQueryOptions,\n ): Reference | undefined {\n return this.write({\n dataId: options.id || 'ROOT_QUERY',\n result: options.data,\n query: options.query,\n variables: options.variables,\n broadcast: options.broadcast,\n });\n }\n\n public writeFragment(\n options: Cache.WriteFragmentOptions,\n ): Reference | undefined {\n return this.write({\n dataId: options.id,\n result: options.data,\n variables: options.variables,\n query: this.getFragmentDoc(options.fragment, options.fragmentName),\n broadcast: options.broadcast,\n });\n }\n}\n","import { FieldNode } from 'graphql';\n\nimport {\n Reference,\n StoreObject,\n StoreValue,\n isReference,\n} from '../../../utilities';\n\nimport { StorageType } from '../../inmemory/policies';\n\n// The Readonly type only really works for object types, since it marks\n// all of the object's properties as readonly, but there are many cases when\n// a generic type parameter like TExisting might be a string or some other\n// primitive type, in which case we need to avoid wrapping it with Readonly.\n// SafeReadonly collapses to just string, which makes string\n// assignable to SafeReadonly, whereas string is not assignable to\n// Readonly, somewhat surprisingly.\nexport type SafeReadonly = T extends object ? Readonly : T;\n\nexport class MissingFieldError {\n constructor(\n public readonly message: string,\n public readonly path: (string | number)[],\n public readonly query: import('graphql').DocumentNode,\n public readonly clientOnly: boolean,\n public readonly variables?: Record,\n ) {}\n}\n\nexport interface FieldSpecifier {\n typename?: string;\n fieldName: string;\n field?: FieldNode;\n args?: Record;\n variables?: Record;\n}\n\nexport interface ReadFieldOptions extends FieldSpecifier {\n from?: StoreObject | Reference;\n}\n\nexport interface ReadFieldFunction {\n (options: ReadFieldOptions): SafeReadonly | undefined;\n (\n fieldName: string,\n from?: StoreObject | Reference,\n ): SafeReadonly | undefined;\n}\n\nexport type ToReferenceFunction = (\n objOrIdOrRef: StoreObject | string | Reference,\n mergeIntoStore?: boolean,\n) => Reference | undefined;\n\nexport type CanReadFunction = (value: StoreValue) => boolean;\n\nexport type Modifier = (value: T, details: {\n DELETE: any;\n INVALIDATE: any;\n fieldName: string;\n storeFieldName: string;\n readField: ReadFieldFunction;\n canRead: CanReadFunction;\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n storage: StorageType;\n}) => T;\n\nexport type Modifiers = {\n [fieldName: string]: Modifier;\n};\n","import { dep, OptimisticDependencyFunction, KeyTrie } from 'optimism';\nimport { equal } from '@wry/equality';\n\nimport {\n isReference,\n StoreValue,\n StoreObject,\n Reference,\n makeReference,\n DeepMerger,\n maybeDeepFreeze,\n canUseWeakMap,\n} from '../../utilities';\nimport { NormalizedCache, NormalizedCacheObject } from './types';\nimport { hasOwn, fieldNameFromStoreName } from './helpers';\nimport { Policies, StorageType } from './policies';\nimport { Cache } from '../core/types/Cache';\nimport {\n SafeReadonly,\n Modifier,\n Modifiers,\n ReadFieldOptions,\n ToReferenceFunction,\n CanReadFunction,\n} from '../core/types/common';\n\nconst DELETE: any = Object.create(null);\nconst delModifier: Modifier = () => DELETE;\nconst INVALIDATE: any = Object.create(null);\n\nexport abstract class EntityStore implements NormalizedCache {\n protected data: NormalizedCacheObject = Object.create(null);\n\n constructor(\n public readonly policies: Policies,\n public readonly group: CacheGroup,\n ) {}\n\n public abstract addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer;\n\n public abstract removeLayer(layerId: string): EntityStore;\n\n // Although the EntityStore class is abstract, it contains concrete\n // implementations of the various NormalizedCache interface methods that\n // are inherited by the Root and Layer subclasses.\n\n public toObject(): NormalizedCacheObject {\n return { ...this.data };\n }\n\n public has(dataId: string): boolean {\n return this.lookup(dataId, true) !== void 0;\n }\n\n public get(dataId: string, fieldName: string): StoreValue {\n this.group.depend(dataId, fieldName);\n if (hasOwn.call(this.data, dataId)) {\n const storeObject = this.data[dataId];\n if (storeObject && hasOwn.call(storeObject, fieldName)) {\n return storeObject[fieldName];\n }\n }\n if (fieldName === \"__typename\" &&\n hasOwn.call(this.policies.rootTypenamesById, dataId)) {\n return this.policies.rootTypenamesById[dataId];\n }\n if (this instanceof Layer) {\n return this.parent.get(dataId, fieldName);\n }\n }\n\n protected lookup(dataId: string, dependOnExistence?: boolean): StoreObject | undefined {\n // The has method (above) calls lookup with dependOnExistence = true, so\n // that it can later be invalidated when we add or remove a StoreObject for\n // this dataId. Any consumer who cares about the contents of the StoreObject\n // should not rely on this dependency, since the contents could change\n // without the object being added or removed.\n if (dependOnExistence) this.group.depend(dataId, \"__exists\");\n\n if (hasOwn.call(this.data, dataId)) {\n return this.data[dataId];\n }\n\n if (this instanceof Layer) {\n return this.parent.lookup(dataId, dependOnExistence);\n }\n\n if (this.policies.rootTypenamesById[dataId]) {\n return Object.create(null);\n }\n }\n\n public merge(dataId: string, incoming: StoreObject): void {\n const existing = this.lookup(dataId);\n const merged: StoreObject =\n new DeepMerger(storeObjectReconciler).merge(existing, incoming);\n // Even if merged === existing, existing may have come from a lower\n // layer, so we always need to set this.data[dataId] on this level.\n this.data[dataId] = merged;\n if (merged !== existing) {\n delete this.refs[dataId];\n if (this.group.caching) {\n const fieldsToDirty: Record = Object.create(null);\n\n // If we added a new StoreObject where there was previously none, dirty\n // anything that depended on the existence of this dataId, such as the\n // EntityStore#has method.\n if (!existing) fieldsToDirty.__exists = 1;\n\n // Now invalidate dependents who called getFieldValue for any fields\n // that are changing as a result of this merge.\n Object.keys(incoming).forEach(storeFieldName => {\n if (!existing || existing[storeFieldName] !== merged[storeFieldName]) {\n // Always dirty the full storeFieldName, which may include\n // serialized arguments following the fieldName prefix.\n fieldsToDirty[storeFieldName] = 1;\n\n // Also dirty fieldNameFromStoreName(storeFieldName) if it's\n // different from storeFieldName and this field does not have\n // keyArgs configured, because that means the cache can't make\n // any assumptions about how field values with the same field\n // name but different arguments might be interrelated, so it\n // must err on the side of invalidating all field values that\n // share the same short fieldName, regardless of arguments.\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName &&\n !this.policies.hasKeyArgs(merged.__typename, fieldName)) {\n fieldsToDirty[fieldName] = 1;\n }\n\n // If merged[storeFieldName] has become undefined, and this is the\n // Root layer, actually delete the property from the merged object,\n // which is guaranteed to have been created fresh in this method.\n if (merged[storeFieldName] === void 0 && !(this instanceof Layer)) {\n delete merged[storeFieldName];\n }\n }\n });\n\n Object.keys(fieldsToDirty).forEach(\n fieldName => this.group.dirty(dataId, fieldName));\n }\n }\n }\n\n public modify(\n dataId: string,\n fields: Modifier | Modifiers,\n ): boolean {\n const storeObject = this.lookup(dataId);\n\n if (storeObject) {\n const changedFields: Record = Object.create(null);\n let needToMerge = false;\n let allDeleted = true;\n\n const sharedDetails = {\n DELETE,\n INVALIDATE,\n isReference,\n toReference: this.toReference,\n canRead: this.canRead,\n readField: (\n fieldNameOrOptions: string | ReadFieldOptions,\n from?: StoreObject | Reference,\n ) => this.policies.readField(\n typeof fieldNameOrOptions === \"string\" ? {\n fieldName: fieldNameOrOptions,\n from: from || makeReference(dataId),\n } : fieldNameOrOptions,\n { store: this },\n ),\n };\n\n Object.keys(storeObject).forEach(storeFieldName => {\n const fieldName = fieldNameFromStoreName(storeFieldName);\n let fieldValue = storeObject[storeFieldName];\n if (fieldValue === void 0) return;\n const modify: Modifier = typeof fields === \"function\"\n ? fields\n : fields[storeFieldName] || fields[fieldName];\n if (modify) {\n let newValue = modify === delModifier ? DELETE :\n modify(maybeDeepFreeze(fieldValue), {\n ...sharedDetails,\n fieldName,\n storeFieldName,\n storage: this.getStorage(dataId, storeFieldName),\n });\n if (newValue === INVALIDATE) {\n this.group.dirty(dataId, storeFieldName);\n } else {\n if (newValue === DELETE) newValue = void 0;\n if (newValue !== fieldValue) {\n changedFields[storeFieldName] = newValue;\n needToMerge = true;\n fieldValue = newValue;\n }\n }\n }\n if (fieldValue !== void 0) {\n allDeleted = false;\n }\n });\n\n if (needToMerge) {\n this.merge(dataId, changedFields);\n\n if (allDeleted) {\n if (this instanceof Layer) {\n this.data[dataId] = void 0;\n } else {\n delete this.data[dataId];\n }\n this.group.dirty(dataId, \"__exists\");\n }\n\n return true;\n }\n }\n\n return false;\n }\n\n // If called with only one argument, removes the entire entity\n // identified by dataId. If called with a fieldName as well, removes all\n // fields of that entity whose names match fieldName according to the\n // fieldNameFromStoreName helper function. If called with a fieldName\n // and variables, removes all fields of that entity whose names match fieldName\n // and whose arguments when cached exactly match the variables passed.\n public delete(\n dataId: string,\n fieldName?: string,\n args?: Record,\n ) {\n const storeObject = this.lookup(dataId);\n if (storeObject) {\n const typename = this.getFieldValue(storeObject, \"__typename\");\n const storeFieldName = fieldName && args\n ? this.policies.getStoreFieldName({ typename, fieldName, args })\n : fieldName;\n return this.modify(dataId, storeFieldName ? {\n [storeFieldName]: delModifier,\n } : delModifier);\n }\n return false;\n }\n\n public evict(options: Cache.EvictOptions): boolean {\n let evicted = false;\n if (options.id) {\n if (hasOwn.call(this.data, options.id)) {\n evicted = this.delete(options.id, options.fieldName, options.args);\n }\n if (this instanceof Layer) {\n evicted = this.parent.evict(options) || evicted;\n }\n // Always invalidate the field to trigger rereading of watched\n // queries, even if no cache data was modified by the eviction,\n // because queries may depend on computed fields with custom read\n // functions, whose values are not stored in the EntityStore.\n if (options.fieldName || evicted) {\n this.group.dirty(options.id, options.fieldName || \"__exists\");\n }\n }\n return evicted;\n }\n\n public clear(): void {\n this.replace(null);\n }\n\n public extract(): NormalizedCacheObject {\n const obj = this.toObject();\n const extraRootIds: string[] = [];\n this.getRootIdSet().forEach(id => {\n if (!hasOwn.call(this.policies.rootTypenamesById, id)) {\n extraRootIds.push(id);\n }\n });\n if (extraRootIds.length) {\n obj.__META = { extraRootIds: extraRootIds.sort() };\n }\n return obj;\n }\n\n public replace(newData: NormalizedCacheObject | null): void {\n Object.keys(this.data).forEach(dataId => {\n if (!(newData && hasOwn.call(newData, dataId))) {\n this.delete(dataId);\n }\n });\n if (newData) {\n const { __META, ...rest } = newData;\n Object.keys(rest).forEach(dataId => {\n this.merge(dataId, rest[dataId] as StoreObject);\n });\n if (__META) {\n __META.extraRootIds.forEach(this.retain, this);\n }\n }\n }\n\n public abstract getStorage(\n idOrObj: string | StoreObject,\n ...storeFieldNames: (string | number)[]\n ): StorageType;\n\n // Maps root entity IDs to the number of times they have been retained, minus\n // the number of times they have been released. Retained entities keep other\n // entities they reference (even indirectly) from being garbage collected.\n private rootIds: {\n [rootId: string]: number;\n } = Object.create(null);\n\n public retain(rootId: string): number {\n return this.rootIds[rootId] = (this.rootIds[rootId] || 0) + 1;\n }\n\n public release(rootId: string): number {\n if (this.rootIds[rootId] > 0) {\n const count = --this.rootIds[rootId];\n if (!count) delete this.rootIds[rootId];\n return count;\n }\n return 0;\n }\n\n // Return a Set of all the ID strings that have been retained by\n // this layer/root *and* any layers/roots beneath it.\n public getRootIdSet(ids = new Set()) {\n Object.keys(this.rootIds).forEach(ids.add, ids);\n if (this instanceof Layer) {\n this.parent.getRootIdSet(ids);\n } else {\n // Official singleton IDs like ROOT_QUERY and ROOT_MUTATION are\n // always considered roots for garbage collection, regardless of\n // their retainment counts in this.rootIds.\n Object.keys(this.policies.rootTypenamesById).forEach(ids.add, ids);\n }\n return ids;\n }\n\n // The goal of garbage collection is to remove IDs from the Root layer of the\n // store that are no longer reachable starting from any IDs that have been\n // explicitly retained (see retain and release, above). Returns an array of\n // dataId strings that were removed from the store.\n public gc() {\n const ids = this.getRootIdSet();\n const snapshot = this.toObject();\n ids.forEach(id => {\n if (hasOwn.call(snapshot, id)) {\n // Because we are iterating over an ECMAScript Set, the IDs we add here\n // will be visited in later iterations of the forEach loop only if they\n // were not previously contained by the Set.\n Object.keys(this.findChildRefIds(id)).forEach(ids.add, ids);\n // By removing IDs from the snapshot object here, we protect them from\n // getting removed from the root store layer below.\n delete snapshot[id];\n }\n });\n const idsToRemove = Object.keys(snapshot);\n if (idsToRemove.length) {\n let root: EntityStore = this;\n while (root instanceof Layer) root = root.parent;\n idsToRemove.forEach(id => root.delete(id));\n }\n return idsToRemove;\n }\n\n // Lazily tracks { __ref: } strings contained by this.data[dataId].\n private refs: {\n [dataId: string]: Record;\n } = Object.create(null);\n\n public findChildRefIds(dataId: string): Record {\n if (!hasOwn.call(this.refs, dataId)) {\n const found = this.refs[dataId] = Object.create(null);\n const workSet = new Set([this.data[dataId]]);\n // Within the store, only arrays and objects can contain child entity\n // references, so we can prune the traversal using this predicate:\n const canTraverse = (obj: any) => obj !== null && typeof obj === 'object';\n workSet.forEach(obj => {\n if (isReference(obj)) {\n found[obj.__ref] = true;\n } else if (canTraverse(obj)) {\n Object.values(obj!)\n // No need to add primitive values to the workSet, since they cannot\n // contain reference objects.\n .filter(canTraverse)\n .forEach(workSet.add, workSet);\n }\n });\n }\n return this.refs[dataId];\n }\n\n // Used to compute cache keys specific to this.group.\n public makeCacheKey(...args: any[]) {\n return this.group.keyMaker.lookupArray(args);\n }\n\n // Bound function that can be passed around to provide easy access to fields\n // of Reference objects as well as ordinary objects.\n public getFieldValue = (\n objectOrReference: StoreObject | Reference | undefined,\n storeFieldName: string,\n ) => maybeDeepFreeze(\n isReference(objectOrReference)\n ? this.get(objectOrReference.__ref, storeFieldName)\n : objectOrReference && objectOrReference[storeFieldName]\n ) as SafeReadonly;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n public canRead: CanReadFunction = objOrRef => {\n return isReference(objOrRef)\n ? this.has(objOrRef.__ref)\n : typeof objOrRef === \"object\";\n };\n\n // Bound function that converts an id or an object with a __typename and\n // primary key fields to a Reference object. If called with a Reference object,\n // that same Reference object is returned. Pass true for mergeIntoStore to persist\n // an object into the store.\n public toReference: ToReferenceFunction = (\n objOrIdOrRef,\n mergeIntoStore,\n ) => {\n if (typeof objOrIdOrRef === \"string\") {\n return makeReference(objOrIdOrRef);\n }\n\n if (isReference(objOrIdOrRef)) {\n return objOrIdOrRef;\n }\n\n const [id] = this.policies.identify(objOrIdOrRef);\n\n if (id) {\n const ref = makeReference(id);\n if (mergeIntoStore) {\n this.merge(id, objOrIdOrRef);\n }\n return ref;\n }\n };\n}\n\nexport type FieldValueGetter = EntityStore[\"getFieldValue\"];\n\n// A single CacheGroup represents a set of one or more EntityStore objects,\n// typically the Root store in a CacheGroup by itself, and all active Layer\n// stores in a group together. A single EntityStore object belongs to only\n// one CacheGroup, store.group. The CacheGroup is responsible for tracking\n// dependencies, so store.group is helpful for generating unique keys for\n// cached results that need to be invalidated when/if those dependencies\n// change. If we used the EntityStore objects themselves as cache keys (that\n// is, store rather than store.group), the cache would become unnecessarily\n// fragmented by all the different Layer objects. Instead, the CacheGroup\n// approach allows all optimistic Layer objects in the same linked list to\n// belong to one CacheGroup, with the non-optimistic Root object belonging\n// to another CacheGroup, allowing resultCaching dependencies to be tracked\n// separately for optimistic and non-optimistic entity data.\nclass CacheGroup {\n private d: OptimisticDependencyFunction | null = null;\n\n constructor(public readonly caching: boolean) {\n this.d = caching ? dep() : null;\n }\n\n public depend(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d(makeDepKey(dataId, storeFieldName));\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName) {\n // Fields with arguments that contribute extra identifying\n // information to the fieldName (thus forming the storeFieldName)\n // depend not only on the full storeFieldName but also on the\n // short fieldName, so the field can be invalidated using either\n // level of specificity.\n this.d(makeDepKey(dataId, fieldName));\n }\n }\n }\n\n public dirty(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d.dirty(makeDepKey(dataId, storeFieldName));\n }\n }\n\n // Used by the EntityStore#makeCacheKey method to compute cache keys\n // specific to this CacheGroup.\n public readonly keyMaker = new KeyTrie(canUseWeakMap);\n}\n\nfunction makeDepKey(dataId: string, storeFieldName: string) {\n // Since field names cannot have '#' characters in them, this method\n // of joining the field name and the ID should be unambiguous, and much\n // cheaper than JSON.stringify([dataId, fieldName]).\n return storeFieldName + '#' + dataId;\n}\n\nexport namespace EntityStore {\n // Refer to this class as EntityStore.Root outside this namespace.\n export class Root extends EntityStore {\n // Although each Root instance gets its own unique CacheGroup object,\n // any Layer instances created by calling addLayer need to share a\n // single distinct CacheGroup object. Since this shared object must\n // outlast the Layer instances themselves, it needs to be created and\n // owned by the Root instance.\n private sharedLayerGroup: CacheGroup;\n\n constructor({\n policies,\n resultCaching = true,\n seed,\n }: {\n policies: Policies;\n resultCaching?: boolean;\n seed?: NormalizedCacheObject;\n }) {\n super(policies, new CacheGroup(resultCaching));\n this.sharedLayerGroup = new CacheGroup(resultCaching);\n if (seed) this.replace(seed);\n }\n\n public addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer {\n // The replay function will be called in the Layer constructor.\n return new Layer(layerId, this, replay, this.sharedLayerGroup);\n }\n\n public removeLayer(): Root {\n // Never remove the root layer.\n return this;\n }\n\n public readonly storageTrie = new KeyTrie(canUseWeakMap);\n public getStorage(): StorageType {\n return this.storageTrie.lookupArray(arguments);\n }\n }\n}\n\n// Not exported, since all Layer instances are created by the addLayer method\n// of the EntityStore.Root class.\nclass Layer extends EntityStore {\n constructor(\n public readonly id: string,\n public readonly parent: EntityStore,\n public readonly replay: (layer: EntityStore) => any,\n public readonly group: CacheGroup,\n ) {\n super(parent.policies, group);\n replay(this);\n }\n\n public addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer {\n return new Layer(layerId, this, replay, this.group);\n }\n\n public removeLayer(layerId: string): EntityStore {\n // Remove all instances of the given id, not just the first one.\n const parent = this.parent.removeLayer(layerId);\n\n if (layerId === this.id) {\n // Dirty every ID we're removing.\n if (this.group.caching) {\n Object.keys(this.data).forEach(dataId => {\n // If this.data[dataId] contains nothing different from what\n // lies beneath, we can avoid dirtying this dataId and all of\n // its fields, and simply discard this Layer. The only reason we\n // call this.delete here is to dirty the removed fields.\n if (this.data[dataId] !== (parent as Layer).lookup(dataId)) {\n this.delete(dataId);\n }\n });\n }\n return parent;\n }\n\n // No changes are necessary if the parent chain remains identical.\n if (parent === this.parent) return this;\n\n // Recreate this layer on top of the new parent.\n return parent.addLayer(this.id, this.replay);\n }\n\n public toObject(): NormalizedCacheObject {\n return {\n ...this.parent.toObject(),\n ...this.data,\n };\n }\n\n public findChildRefIds(dataId: string): Record {\n const fromParent = this.parent.findChildRefIds(dataId);\n return hasOwn.call(this.data, dataId) ? {\n ...fromParent,\n ...super.findChildRefIds(dataId),\n } : fromParent;\n }\n\n public getStorage(): StorageType {\n let p: EntityStore = this.parent;\n while ((p as Layer).parent) p = (p as Layer).parent;\n return p.getStorage.apply(p, arguments);\n }\n}\n\nfunction storeObjectReconciler(\n existingObject: StoreObject,\n incomingObject: StoreObject,\n property: string,\n): StoreValue {\n const existingValue = existingObject[property];\n const incomingValue = incomingObject[property];\n // Wherever there is a key collision, prefer the incoming value, unless\n // it is deeply equal to the existing value. It's worth checking deep\n // equality here (even though blindly returning incoming would be\n // logically correct) because preserving the referential identity of\n // existing data can prevent needless rereading and rerendering.\n return equal(existingValue, incomingValue) ? existingValue : incomingValue;\n}\n\nexport function supportsResultCaching(store: any): store is EntityStore {\n // When result caching is disabled, store.depend will be null.\n return !!(store instanceof EntityStore && store.group.caching);\n}\n","import {\n DocumentNode,\n FieldNode,\n SelectionSetNode,\n} from 'graphql';\nimport { wrap, OptimisticWrapperFunction } from 'optimism';\nimport { invariant, InvariantError } from 'ts-invariant';\n\nimport {\n isField,\n resultKeyNameFromField,\n Reference,\n isReference,\n makeReference,\n StoreObject,\n createFragmentMap,\n FragmentMap,\n shouldInclude,\n addTypenameToDocument,\n getDefaultValues,\n getFragmentDefinitions,\n getMainDefinition,\n getQueryDefinition,\n maybeDeepFreeze,\n mergeDeepArray,\n getFragmentFromSelection,\n} from '../../utilities';\nimport { Cache } from '../core/types/Cache';\nimport {\n DiffQueryAgainstStoreOptions,\n NormalizedCache,\n ReadMergeModifyContext,\n} from './types';\nimport { supportsResultCaching } from './entityStore';\nimport { getTypenameFromStoreObject } from './helpers';\nimport { Policies } from './policies';\nimport { InMemoryCache } from './inMemoryCache';\nimport { MissingFieldError } from '../core/types/common';\n\nexport type VariableMap = { [name: string]: any };\n\ninterface ReadContext extends ReadMergeModifyContext {\n query: DocumentNode;\n policies: Policies;\n fragmentMap: FragmentMap;\n path: (string | number)[];\n clientOnly: boolean;\n};\n\nexport type ExecResult = {\n result: R;\n missing?: MissingFieldError[];\n};\n\nfunction missingFromInvariant(\n err: InvariantError,\n context: ReadContext,\n) {\n return new MissingFieldError(\n err.message,\n context.path.slice(),\n context.query,\n context.clientOnly,\n context.variables,\n );\n}\n\ntype ExecSelectionSetOptions = {\n selectionSet: SelectionSetNode;\n objectOrReference: StoreObject | Reference;\n context: ReadContext;\n};\n\ntype ExecSubSelectedArrayOptions = {\n field: FieldNode;\n array: any[];\n context: ReadContext;\n};\n\nexport interface StoreReaderConfig {\n cache: InMemoryCache,\n addTypename?: boolean;\n}\n\nexport class StoreReader {\n constructor(private config: StoreReaderConfig) {\n this.config = { addTypename: true, ...config };\n }\n\n /**\n * Given a store and a query, return as much of the result as possible and\n * identify if any data was missing from the store.\n * @param {DocumentNode} query A parsed GraphQL query document\n * @param {Store} store The Apollo Client store object\n * @return {result: Object, complete: [boolean]}\n */\n public diffQueryAgainstStore({\n store,\n query,\n rootId = 'ROOT_QUERY',\n variables,\n returnPartialData = true,\n }: DiffQueryAgainstStoreOptions): Cache.DiffResult {\n const policies = this.config.cache.policies;\n\n variables = {\n ...getDefaultValues(getQueryDefinition(query)),\n ...variables,\n };\n\n const execResult = this.executeSelectionSet({\n selectionSet: getMainDefinition(query).selectionSet,\n objectOrReference: makeReference(rootId),\n context: {\n store,\n query,\n policies,\n variables,\n varString: JSON.stringify(variables),\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n path: [],\n clientOnly: false,\n },\n });\n\n const hasMissingFields =\n execResult.missing && execResult.missing.length > 0;\n if (hasMissingFields && !returnPartialData) {\n throw execResult.missing![0];\n }\n\n return {\n result: execResult.result,\n missing: execResult.missing,\n complete: !hasMissingFields,\n };\n }\n\n public isFresh(\n result: Record,\n parent: StoreObject | Reference,\n selectionSet: SelectionSetNode,\n context: ReadMergeModifyContext,\n ): boolean {\n if (supportsResultCaching(context.store) &&\n this.knownResults.get(result) === selectionSet) {\n const latest = this.executeSelectionSet.peek(selectionSet, parent, context);\n if (latest && result === latest.result) {\n return true;\n }\n }\n return false;\n }\n\n // Cached version of execSelectionSetImpl.\n private executeSelectionSet: OptimisticWrapperFunction<\n [ExecSelectionSetOptions], // Actual arguments tuple type.\n ExecResult, // Actual return type.\n // Arguments type after keyArgs translation.\n [SelectionSetNode, StoreObject | Reference, ReadMergeModifyContext]\n > = wrap(options => this.execSelectionSetImpl(options), {\n keyArgs(options) {\n return [\n options.selectionSet,\n options.objectOrReference,\n options.context,\n ];\n },\n // Note that the parameters of makeCacheKey are determined by the\n // array returned by keyArgs.\n makeCacheKey(selectionSet, parent, context) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(\n selectionSet,\n isReference(parent) ? parent.__ref : parent,\n context.varString,\n );\n }\n }\n });\n\n // Uncached version of executeSelectionSet.\n private execSelectionSetImpl({\n selectionSet,\n objectOrReference,\n context,\n }: ExecSelectionSetOptions): ExecResult {\n if (isReference(objectOrReference) &&\n !context.policies.rootTypenamesById[objectOrReference.__ref] &&\n !context.store.has(objectOrReference.__ref)) {\n return {\n result: {},\n missing: [missingFromInvariant(\n new InvariantError(\n `Dangling reference to missing ${objectOrReference.__ref} object`\n ),\n context,\n )],\n };\n }\n\n const { variables, policies, store } = context;\n const objectsToMerge: { [key: string]: any }[] = [];\n const finalResult: ExecResult = { result: null };\n const typename = store.getFieldValue(objectOrReference, \"__typename\");\n\n if (this.config.addTypename &&\n typeof typename === \"string\" &&\n !policies.rootIdsByTypename[typename]) {\n // Ensure we always include a default value for the __typename\n // field, if we have one, and this.config.addTypename is true. Note\n // that this field can be overridden by other merged objects.\n objectsToMerge.push({ __typename: typename });\n }\n\n function getMissing() {\n return finalResult.missing || (finalResult.missing = []);\n }\n\n function handleMissing(result: ExecResult): T {\n if (result.missing) getMissing().push(...result.missing);\n return result.result;\n }\n\n const workSet = new Set(selectionSet.selections);\n\n workSet.forEach(selection => {\n // Omit fields with directives @skip(if: ) or\n // @include(if: ).\n if (!shouldInclude(selection, variables)) return;\n\n if (isField(selection)) {\n let fieldValue = policies.readField({\n fieldName: selection.name.value,\n field: selection,\n variables: context.variables,\n from: objectOrReference,\n }, context);\n\n const resultName = resultKeyNameFromField(selection);\n context.path.push(resultName);\n\n // If this field has an @client directive, then the field and\n // everything beneath it is client-only, meaning it will never be\n // sent to the server.\n const wasClientOnly = context.clientOnly;\n // Once we enter a client-only subtree of the query, we can avoid\n // repeatedly checking selection.directives.\n context.clientOnly = wasClientOnly || !!(\n // We don't use the hasDirectives helper here, because it looks\n // for directives anywhere inside the AST node, whereas we only\n // care about directives directly attached to this field.\n selection.directives &&\n selection.directives.some(d => d.name.value === \"client\")\n );\n\n if (fieldValue === void 0) {\n if (!addTypenameToDocument.added(selection)) {\n getMissing().push(\n missingFromInvariant(\n new InvariantError(`Can't find field '${\n selection.name.value\n }' on ${\n isReference(objectOrReference)\n ? objectOrReference.__ref + \" object\"\n : \"object \" + JSON.stringify(objectOrReference, null, 2)\n }`),\n context,\n ),\n );\n }\n\n } else if (Array.isArray(fieldValue)) {\n fieldValue = handleMissing(this.executeSubSelectedArray({\n field: selection,\n array: fieldValue,\n context,\n }));\n\n } else if (!selection.selectionSet) {\n // If the field does not have a selection set, then we handle it\n // as a scalar value. However, that value should not contain any\n // Reference objects, and should be frozen in development, if it\n // happens to be an object that is mutable.\n if (process.env.NODE_ENV !== 'production') {\n assertSelectionSetForIdValue(\n context.store,\n selection,\n fieldValue,\n );\n maybeDeepFreeze(fieldValue);\n }\n\n } else if (fieldValue != null) {\n // In this case, because we know the field has a selection set,\n // it must be trying to query a GraphQLObjectType, which is why\n // fieldValue must be != null.\n fieldValue = handleMissing(this.executeSelectionSet({\n selectionSet: selection.selectionSet,\n objectOrReference: fieldValue as StoreObject | Reference,\n context,\n }));\n }\n\n if (fieldValue !== void 0) {\n objectsToMerge.push({ [resultName]: fieldValue });\n }\n\n context.clientOnly = wasClientOnly;\n\n invariant(context.path.pop() === resultName);\n\n } else {\n const fragment = getFragmentFromSelection(\n selection,\n context.fragmentMap,\n );\n\n if (fragment && policies.fragmentMatches(fragment, typename)) {\n fragment.selectionSet.selections.forEach(workSet.add, workSet);\n }\n }\n });\n\n // Perform a single merge at the end so that we can avoid making more\n // defensive shallow copies than necessary.\n finalResult.result = mergeDeepArray(objectsToMerge);\n\n if (process.env.NODE_ENV !== 'production') {\n Object.freeze(finalResult.result);\n }\n\n // Store this result with its selection set so that we can quickly\n // recognize it again in the StoreReader#isFresh method.\n this.knownResults.set(finalResult.result, selectionSet);\n\n return finalResult;\n }\n\n private knownResults = new WeakMap, SelectionSetNode>();\n\n // Cached version of execSubSelectedArrayImpl.\n private executeSubSelectedArray = wrap((options: ExecSubSelectedArrayOptions) => {\n return this.execSubSelectedArrayImpl(options);\n }, {\n makeCacheKey({ field, array, context }) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(\n field,\n array,\n context.varString,\n );\n }\n }\n });\n\n // Uncached version of executeSubSelectedArray.\n private execSubSelectedArrayImpl({\n field,\n array,\n context,\n }: ExecSubSelectedArrayOptions): ExecResult {\n let missing: MissingFieldError[] | undefined;\n\n function handleMissing(childResult: ExecResult, i: number): T {\n if (childResult.missing) {\n missing = missing || [];\n missing.push(...childResult.missing);\n }\n\n invariant(context.path.pop() === i);\n\n return childResult.result;\n }\n\n if (field.selectionSet) {\n array = array.filter(context.store.canRead);\n }\n\n array = array.map((item, i) => {\n // null value in array\n if (item === null) {\n return null;\n }\n\n context.path.push(i);\n\n // This is a nested array, recurse\n if (Array.isArray(item)) {\n return handleMissing(this.executeSubSelectedArray({\n field,\n array: item,\n context,\n }), i);\n }\n\n // This is an object, run the selection set on it\n if (field.selectionSet) {\n return handleMissing(this.executeSelectionSet({\n selectionSet: field.selectionSet,\n objectOrReference: item,\n context,\n }), i);\n }\n\n if (process.env.NODE_ENV !== 'production') {\n assertSelectionSetForIdValue(context.store, field, item);\n }\n\n invariant(context.path.pop() === i);\n\n return item;\n });\n\n if (process.env.NODE_ENV !== 'production') {\n Object.freeze(array);\n }\n\n return { result: array, missing };\n }\n}\n\nfunction assertSelectionSetForIdValue(\n store: NormalizedCache,\n field: FieldNode,\n fieldValue: any,\n) {\n if (!field.selectionSet) {\n const workSet = new Set([fieldValue]);\n workSet.forEach(value => {\n if (value && typeof value === \"object\") {\n invariant(\n !isReference(value),\n `Missing selection set for object of type ${\n getTypenameFromStoreObject(store, value)\n } returned for query field ${field.name.value}`,\n );\n Object.values(value).forEach(workSet.add, workSet);\n }\n });\n }\n}\n","import { invariant } from \"../../utilities/globals\";\n\nimport {\n argumentsObjectFromField,\n DeepMerger,\n isNonEmptyArray,\n isNonNullObject,\n} from \"../../utilities\";\n\nimport { hasOwn, isArray } from \"./helpers\";\nimport {\n KeySpecifier,\n KeyFieldsFunction,\n KeyArgsFunction,\n} from \"./policies\";\n\n// Mapping from JSON-encoded KeySpecifier strings to associated information.\nconst specifierInfoCache: Record = Object.create(null);\n\nfunction lookupSpecifierInfo(spec: KeySpecifier) {\n // It's safe to encode KeySpecifier arrays with JSON.stringify, since they're\n // just arrays of strings or nested KeySpecifier arrays, and the order of the\n // array elements is important (and suitably preserved by JSON.stringify).\n const cacheKey = JSON.stringify(spec);\n return specifierInfoCache[cacheKey] ||\n (specifierInfoCache[cacheKey] = Object.create(null));\n}\n\nexport function keyFieldsFnFromSpecifier(\n specifier: KeySpecifier,\n): KeyFieldsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return info.keyFieldsFn || (info.keyFieldsFn = (\n object,\n context,\n ) => {\n const extract: typeof extractKey =\n (from, key) => context.readField(key, from);\n\n const keyObject = context.keyObject = collectSpecifierPaths(\n specifier,\n schemaKeyPath => {\n let extracted = extractKeyPath(\n context.storeObject,\n schemaKeyPath,\n // Using context.readField to extract paths from context.storeObject\n // allows the extraction to see through Reference objects and respect\n // custom read functions.\n extract,\n );\n\n if (\n extracted === void 0 &&\n object !== context.storeObject &&\n hasOwn.call(object, schemaKeyPath[0])\n ) {\n // If context.storeObject fails to provide a value for the requested\n // path, fall back to the raw result object, if it has a top-level key\n // matching the first key in the path (schemaKeyPath[0]). This allows\n // key fields included in the written data to be saved in the cache\n // even if they are not selected explicitly in context.selectionSet.\n // Not being mentioned by context.selectionSet is convenient here,\n // since it means these extra fields cannot be affected by field\n // aliasing, which is why we can use extractKey instead of\n // context.readField for this extraction.\n extracted = extractKeyPath(object, schemaKeyPath, extractKey);\n }\n\n invariant(\n extracted !== void 0,\n `Missing field '${schemaKeyPath.join('.')}' while extracting keyFields from ${\n JSON.stringify(object)\n }`,\n );\n\n return extracted;\n },\n );\n\n return `${context.typename}:${JSON.stringify(keyObject)}`;\n });\n}\n\n// The keyArgs extraction process is roughly analogous to keyFields extraction,\n// but there are no aliases involved, missing fields are tolerated (by merely\n// omitting them from the key), and drawing from field.directives or variables\n// is allowed (in addition to drawing from the field's arguments object).\n// Concretely, these differences mean passing a different key path extractor\n// function to collectSpecifierPaths, reusing the shared extractKeyPath helper\n// wherever possible.\nexport function keyArgsFnFromSpecifier(specifier: KeySpecifier): KeyArgsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return info.keyArgsFn || (info.keyArgsFn = (args, {\n field,\n variables,\n fieldName,\n }) => {\n const collected = collectSpecifierPaths(specifier, keyPath => {\n const firstKey = keyPath[0];\n const firstChar = firstKey.charAt(0);\n\n if (firstChar === \"@\") {\n if (field && isNonEmptyArray(field.directives)) {\n const directiveName = firstKey.slice(1);\n // If the directive appears multiple times, only the first\n // occurrence's arguments will be used. TODO Allow repetition?\n // TODO Cache this work somehow, a la aliasMap?\n const d = field.directives.find(d => d.name.value === directiveName);\n // Fortunately argumentsObjectFromField works for DirectiveNode!\n const directiveArgs = d && argumentsObjectFromField(d, variables);\n // For directives without arguments (d defined, but directiveArgs ===\n // null), the presence or absence of the directive still counts as\n // part of the field key, so we return null in those cases. If no\n // directive with this name was found for this field (d undefined and\n // thus directiveArgs undefined), we return undefined, which causes\n // this value to be omitted from the key object returned by\n // collectSpecifierPaths.\n return directiveArgs && extractKeyPath(\n directiveArgs,\n // If keyPath.length === 1, this code calls extractKeyPath with an\n // empty path, which works because it uses directiveArgs as the\n // extracted value.\n keyPath.slice(1),\n );\n }\n // If the key started with @ but there was no corresponding directive,\n // we want to omit this value from the key object, not fall through to\n // treating @whatever as a normal argument name.\n return;\n }\n\n if (firstChar === \"$\") {\n const variableName = firstKey.slice(1);\n if (variables && hasOwn.call(variables, variableName)) {\n const varKeyPath = keyPath.slice(0);\n varKeyPath[0] = variableName;\n return extractKeyPath(variables, varKeyPath);\n }\n // If the key started with $ but there was no corresponding variable, we\n // want to omit this value from the key object, not fall through to\n // treating $whatever as a normal argument name.\n return;\n }\n\n if (args) {\n return extractKeyPath(args, keyPath);\n }\n });\n\n const suffix = JSON.stringify(collected);\n\n // If no arguments were passed to this field, and it didn't have any other\n // field key contributions from directives or variables, hide the empty\n // :{} suffix from the field key. However, a field passed no arguments can\n // still end up with a non-empty :{...} suffix if its key configuration\n // refers to directives or variables.\n if (args || suffix !== \"{}\") {\n fieldName += \":\" + suffix;\n }\n\n return fieldName;\n });\n}\n\nexport function collectSpecifierPaths(\n specifier: KeySpecifier,\n extractor: (path: string[]) => any,\n): Record {\n // For each path specified by specifier, invoke the extractor, and repeatedly\n // merge the results together, with appropriate ancestor context.\n const merger = new DeepMerger;\n return getSpecifierPaths(specifier).reduce((collected, path) => {\n let toMerge = extractor(path);\n if (toMerge !== void 0) {\n // This path is not expected to contain array indexes, so the toMerge\n // reconstruction will not contain arrays. TODO Fix this?\n for (let i = path.length - 1; i >= 0; --i) {\n toMerge = { [path[i]]: toMerge };\n }\n collected = merger.merge(collected, toMerge);\n }\n return collected;\n }, Object.create(null));\n}\n\nexport function getSpecifierPaths(spec: KeySpecifier): string[][] {\n const info = lookupSpecifierInfo(spec);\n\n if (!info.paths) {\n const paths: string[][] = info.paths = [];\n const currentPath: string[] = [];\n\n spec.forEach((s, i) => {\n if (isArray(s)) {\n getSpecifierPaths(s).forEach(p => paths.push(currentPath.concat(p)));\n currentPath.length = 0;\n } else {\n currentPath.push(s);\n if (!isArray(spec[i + 1])) {\n paths.push(currentPath.slice(0));\n currentPath.length = 0;\n }\n }\n });\n }\n\n return info.paths!;\n}\n\nfunction extractKey<\n TObj extends Record,\n TKey extends string,\n>(object: TObj, key: TKey): TObj[TKey] | undefined {\n return object[key];\n}\n\nexport function extractKeyPath(\n object: Record,\n path: string[],\n extract?: typeof extractKey,\n): any {\n // For each key in path, extract the corresponding child property from obj,\n // flattening arrays if encountered (uncommon for keyFields and keyArgs, but\n // possible). The final result of path.reduce is normalized so unexpected leaf\n // objects have their keys safely sorted. That final result is difficult to\n // type as anything other than any. You're welcome to try to improve the\n // return type, but keep in mind extractKeyPath is not a public function\n // (exported only for testing), so the effort may not be worthwhile unless the\n // limited set of actual callers (see above) pass arguments that TypeScript\n // can statically type. If we know only that path is some array of strings\n // (and not, say, a specific tuple of statically known strings), any (or\n // possibly unknown) is the honest answer.\n extract = extract || extractKey;\n return normalize(path.reduce(function reducer(obj, key): any {\n return isArray(obj)\n ? obj.map(child => reducer(child, key))\n : obj && extract!(obj, key);\n }, object));\n}\n\nfunction normalize(value: T): T {\n // Usually the extracted value will be a scalar value, since most primary\n // key fields are scalar, but just in case we get an object or an array, we\n // need to do some normalization of the order of (nested) keys.\n if (isNonNullObject(value)) {\n if (isArray(value)) {\n return value.map(normalize) as any;\n }\n return collectSpecifierPaths(\n Object.keys(value).sort(),\n path => extractKeyPath(value, path),\n ) as T;\n }\n return value;\n}\n","import {\n InlineFragmentNode,\n FragmentDefinitionNode,\n SelectionSetNode,\n FieldNode,\n} from 'graphql';\n\nimport { KeyTrie } from 'optimism';\nimport { invariant, InvariantError } from 'ts-invariant';\n\nimport {\n FragmentMap,\n getFragmentFromSelection,\n isField,\n getTypenameFromResult,\n storeKeyNameFromField,\n StoreValue,\n StoreObject,\n argumentsObjectFromField,\n Reference,\n isReference,\n getStoreKeyName,\n canUseWeakMap,\n compact,\n} from '../../utilities';\nimport { IdGetter, ReadMergeModifyContext, MergeInfo } from \"./types\";\nimport {\n hasOwn,\n fieldNameFromStoreName,\n storeValueIsStoreObject,\n selectionSetMatchesResult,\n TypeOrFieldNameRegExp,\n} from './helpers';\nimport { cacheSlot } from './reactiveVars';\nimport { InMemoryCache } from './inMemoryCache';\nimport {\n SafeReadonly,\n FieldSpecifier,\n ToReferenceFunction,\n ReadFieldFunction,\n ReadFieldOptions,\n CanReadFunction,\n} from '../core/types/common';\nimport { FieldValueGetter } from './entityStore';\n\nexport type TypePolicies = {\n [__typename: string]: TypePolicy;\n}\n\n// TypeScript 3.7 will allow recursive type aliases, so this should work:\n// type KeySpecifier = (string | KeySpecifier)[]\ntype KeySpecifier = (string | any[])[];\n\ntype KeyFieldsContext = {\n typename?: string;\n selectionSet?: SelectionSetNode;\n fragmentMap?: FragmentMap;\n // May be set by the KeyFieldsFunction to report fields that were involved\n // in computing the ID. Never passed in by the caller.\n keyObject?: Record;\n};\n\nexport type KeyFieldsFunction = (\n object: Readonly,\n context: KeyFieldsContext,\n) => KeySpecifier | false | ReturnType;\n\ntype KeyFieldsResult = Exclude, KeySpecifier>;\n\n// TODO Should TypePolicy be a generic type, with a TObject or TEntity\n// type parameter?\nexport type TypePolicy = {\n // Allows defining the primary key fields for this type, either using an\n // array of field names or a function that returns an arbitrary string.\n keyFields?: KeySpecifier | KeyFieldsFunction | false;\n\n // Allows defining a merge function (or merge:true/false shorthand) to\n // be used for merging objects of this type wherever they appear, unless\n // the parent field also defines a merge function/boolean (that is,\n // parent field merge functions take precedence over type policy merge\n // functions). In many cases, defining merge:true for a given type\n // policy can save you from specifying merge:true for all the field\n // policies where that type might be encountered.\n merge?: FieldMergeFunction | boolean;\n\n // In the rare event that your schema happens to use a different\n // __typename for the root Query, Mutation, and/or Schema types, you can\n // express your deviant preferences by enabling one of these options.\n queryType?: true,\n mutationType?: true,\n subscriptionType?: true,\n\n fields?: {\n [fieldName: string]:\n | FieldPolicy\n | FieldReadFunction;\n }\n};\n\nexport type KeyArgsFunction = (\n args: Record | null,\n context: {\n typename: string;\n fieldName: string;\n field: FieldNode | null;\n variables?: Record;\n },\n) => KeySpecifier | false | ReturnType;\n\ntype KeyArgsResult = Exclude, KeySpecifier>;\n\nexport type FieldPolicy<\n // The internal representation used to store the field's data in the\n // cache. Must be JSON-serializable if you plan to serialize the result\n // of cache.extract() using JSON.\n TExisting = any,\n // The type of the incoming parameter passed to the merge function,\n // typically matching the GraphQL response format, but with Reference\n // objects substituted for any identifiable child objects. Often the\n // same as TExisting, but not necessarily.\n TIncoming = TExisting,\n // The type that the read function actually returns, using TExisting\n // data and options.args as input. Usually the same as TIncoming.\n TReadResult = TIncoming,\n> = {\n keyArgs?: KeySpecifier | KeyArgsFunction | false;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction | boolean;\n};\n\nexport type StorageType = Record;\n\nfunction argsFromFieldSpecifier(spec: FieldSpecifier) {\n return spec.args !== void 0 ? spec.args :\n spec.field ? argumentsObjectFromField(spec.field, spec.variables) : null;\n}\n\nexport interface FieldFunctionOptions<\n TArgs = Record,\n TVars = Record,\n> {\n args: TArgs | null;\n\n // The name of the field, equal to options.field.name.value when\n // options.field is available. Useful if you reuse the same function for\n // multiple fields, and you need to know which field you're currently\n // processing. Always a string, even when options.field is null.\n fieldName: string;\n\n // The full field key used internally, including serialized key arguments.\n storeFieldName: string;\n\n // The FieldNode object used to read this field. Useful if you need to\n // know about other attributes of the field, such as its directives. This\n // option will be null when a string was passed to options.readField.\n field: FieldNode | null;\n\n variables?: TVars;\n\n // Utilities for dealing with { __ref } objects.\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n\n // A handy place to put field-specific data that you want to survive\n // across multiple read function calls. Useful for field-level caching,\n // if your read function does any expensive work.\n storage: StorageType;\n\n cache: InMemoryCache;\n\n // Helper function for reading other fields within the current object.\n // If a foreign object or reference is provided, the field will be read\n // from that object instead of the current object, so this function can\n // be used (together with isReference) to examine the cache outside the\n // current object. If a FieldNode is passed instead of a string, and\n // that FieldNode has arguments, the same options.variables will be used\n // to compute the argument values. Note that this function will invoke\n // custom read functions for other fields, if defined. Always returns\n // immutable data (enforced with Object.freeze in development).\n readField: ReadFieldFunction;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n canRead: CanReadFunction;\n\n // Instead of just merging objects with { ...existing, ...incoming }, this\n // helper function can be used to merge objects in a way that respects any\n // custom merge functions defined for their fields.\n mergeObjects: MergeObjectsFunction;\n}\n\ntype MergeObjectsFunction = (\n existing: T,\n incoming: T,\n) => T;\n\nexport type FieldReadFunction = (\n // When reading a field, one often needs to know about any existing\n // value stored for that field. If the field is read before any value\n // has been written to the cache, this existing parameter will be\n // undefined, which makes it easy to use a default parameter expression\n // to supply the initial value. This parameter is positional (rather\n // than one of the named options) because that makes it possible for the\n // developer to annotate it with a type, without also having to provide\n // a whole new type for the options object.\n existing: SafeReadonly | undefined,\n options: FieldFunctionOptions,\n) => TReadResult | undefined;\n\nexport type FieldMergeFunction = (\n existing: SafeReadonly | undefined,\n // The incoming parameter needs to be positional as well, for the same\n // reasons discussed in FieldReadFunction above.\n incoming: SafeReadonly,\n options: FieldFunctionOptions,\n) => SafeReadonly;\n\nexport const defaultDataIdFromObject = (\n { __typename, id, _id }: Readonly,\n context?: KeyFieldsContext,\n) => {\n if (typeof __typename === \"string\") {\n if (context) {\n context.keyObject =\n id !== void 0 ? { id } :\n _id !== void 0 ? { _id } :\n void 0;\n }\n // If there is no object.id, fall back to object._id.\n if (id === void 0) id = _id;\n if (id !== void 0) {\n return `${__typename}:${(\n typeof id === \"number\" ||\n typeof id === \"string\"\n ) ? id : JSON.stringify(id)}`;\n }\n }\n};\n\nconst nullKeyFieldsFn: KeyFieldsFunction = () => void 0;\nconst simpleKeyArgsFn: KeyArgsFunction = (_args, context) => context.fieldName;\n\n// These merge functions can be selected by specifying merge:true or\n// merge:false in a field policy.\nconst mergeTrueFn: FieldMergeFunction =\n (existing, incoming, { mergeObjects }) => mergeObjects(existing, incoming);\nconst mergeFalseFn: FieldMergeFunction = (_, incoming) => incoming;\n\nexport type PossibleTypesMap = {\n [supertype: string]: string[];\n};\n\nexport class Policies {\n private typePolicies: {\n [__typename: string]: {\n keyFn?: KeyFieldsFunction;\n merge?: FieldMergeFunction;\n fields: {\n [fieldName: string]: {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction;\n };\n };\n };\n } = Object.create(null);\n\n private toBeAdded: {\n [__typename: string]: TypePolicy[];\n } = Object.create(null);\n\n // Map from subtype names to sets of supertype names. Note that this\n // representation inverts the structure of possibleTypes (whose keys are\n // supertypes and whose values are arrays of subtypes) because it tends\n // to be much more efficient to search upwards than downwards.\n private supertypeMap = new Map>();\n\n // Any fuzzy subtypes specified by possibleTypes will be converted to\n // RegExp objects and recorded here. Every key of this map can also be\n // found in supertypeMap. In many cases this Map will be empty, which\n // means no fuzzy subtype checking will happen in fragmentMatches.\n private fuzzySubtypes = new Map();\n\n public readonly cache: InMemoryCache;\n\n public readonly rootIdsByTypename: Record = Object.create(null);\n public readonly rootTypenamesById: Record = Object.create(null);\n\n public readonly usingPossibleTypes = false;\n\n constructor(private config: {\n cache: InMemoryCache;\n dataIdFromObject?: KeyFieldsFunction;\n possibleTypes?: PossibleTypesMap;\n typePolicies?: TypePolicies;\n }) {\n this.config = {\n dataIdFromObject: defaultDataIdFromObject,\n ...config,\n };\n\n this.cache = this.config.cache;\n\n this.setRootTypename(\"Query\");\n this.setRootTypename(\"Mutation\");\n this.setRootTypename(\"Subscription\");\n\n if (config.possibleTypes) {\n this.addPossibleTypes(config.possibleTypes);\n }\n\n if (config.typePolicies) {\n this.addTypePolicies(config.typePolicies);\n }\n }\n\n public identify(\n object: StoreObject,\n selectionSet?: SelectionSetNode,\n fragmentMap?: FragmentMap,\n ): [string?, StoreObject?] {\n // TODO Use an AliasMap here?\n const typename = selectionSet && fragmentMap\n ? getTypenameFromResult(object, selectionSet, fragmentMap)\n : object.__typename;\n\n // It should be possible to write root Query fields with\n // writeFragment, using { __typename: \"Query\", ... } as the data, but\n // it does not make sense to allow the same identification behavior\n // for the Mutation and Subscription types, since application code\n // should never be writing directly to (or reading directly from)\n // those root objects.\n if (typename === this.rootTypenamesById.ROOT_QUERY) {\n return [\"ROOT_QUERY\"];\n }\n\n const context: KeyFieldsContext = {\n typename,\n selectionSet,\n fragmentMap,\n };\n\n let id: KeyFieldsResult;\n\n const policy = typename && this.getTypePolicy(typename);\n let keyFn = policy && policy.keyFn || this.config.dataIdFromObject;\n while (keyFn) {\n const specifierOrId = keyFn(object, context);\n if (Array.isArray(specifierOrId)) {\n keyFn = keyFieldsFnFromSpecifier(specifierOrId);\n } else {\n id = specifierOrId;\n break;\n }\n }\n\n id = id ? String(id) : void 0;\n return context.keyObject ? [id, context.keyObject] : [id];\n }\n\n public addTypePolicies(typePolicies: TypePolicies) {\n Object.keys(typePolicies).forEach(typename => {\n const {\n queryType,\n mutationType,\n subscriptionType,\n ...incoming\n } = typePolicies[typename];\n\n // Though {query,mutation,subscription}Type configurations are rare,\n // it's important to call setRootTypename as early as possible,\n // since these configurations should apply consistently for the\n // entire lifetime of the cache. Also, since only one __typename can\n // qualify as one of these root types, these three properties cannot\n // be inherited, unlike the rest of the incoming properties. That\n // restriction is convenient, because the purpose of this.toBeAdded\n // is to delay the processing of type/field policies until the first\n // time they're used, allowing policies to be added in any order as\n // long as all relevant policies (including policies for supertypes)\n // have been added by the time a given policy is used for the first\n // time. In other words, since inheritance doesn't matter for these\n // properties, there's also no need to delay their processing using\n // the this.toBeAdded queue.\n if (queryType) this.setRootTypename(\"Query\", typename);\n if (mutationType) this.setRootTypename(\"Mutation\", typename);\n if (subscriptionType) this.setRootTypename(\"Subscription\", typename);\n\n if (hasOwn.call(this.toBeAdded, typename)) {\n this.toBeAdded[typename].push(incoming);\n } else {\n this.toBeAdded[typename] = [incoming];\n }\n });\n }\n\n private updateTypePolicy(typename: string, incoming: TypePolicy) {\n const existing = this.getTypePolicy(typename);\n const { keyFields, fields } = incoming;\n\n function setMerge(\n existing: { merge?: FieldMergeFunction | boolean; },\n merge?: FieldMergeFunction | boolean,\n ) {\n existing.merge =\n typeof merge === \"function\" ? merge :\n // Pass merge:true as a shorthand for a merge implementation\n // that returns options.mergeObjects(existing, incoming).\n merge === true ? mergeTrueFn :\n // Pass merge:false to make incoming always replace existing\n // without any warnings about data clobbering.\n merge === false ? mergeFalseFn :\n existing.merge;\n }\n\n // Type policies can define merge functions, as an alternative to\n // using field policies to merge child objects.\n setMerge(existing, incoming.merge);\n\n existing.keyFn =\n // Pass false to disable normalization for this typename.\n keyFields === false ? nullKeyFieldsFn :\n // Pass an array of strings to use those fields to compute a\n // composite ID for objects of this typename.\n Array.isArray(keyFields) ? keyFieldsFnFromSpecifier(keyFields) :\n // Pass a function to take full control over identification.\n typeof keyFields === \"function\" ? keyFields :\n // Leave existing.keyFn unchanged if above cases fail.\n existing.keyFn;\n\n if (fields) {\n Object.keys(fields).forEach(fieldName => {\n const existing = this.getFieldPolicy(typename, fieldName, true)!;\n const incoming = fields[fieldName];\n\n if (typeof incoming === \"function\") {\n existing.read = incoming;\n } else {\n const { keyArgs, read, merge } = incoming;\n\n existing.keyFn =\n // Pass false to disable argument-based differentiation of\n // field identities.\n keyArgs === false ? simpleKeyArgsFn :\n // Pass an array of strings to use named arguments to\n // compute a composite identity for the field.\n Array.isArray(keyArgs) ? keyArgsFnFromSpecifier(keyArgs) :\n // Pass a function to take full control over field identity.\n typeof keyArgs === \"function\" ? keyArgs :\n // Leave existing.keyFn unchanged if above cases fail.\n existing.keyFn;\n\n if (typeof read === \"function\") {\n existing.read = read;\n }\n\n setMerge(existing, merge);\n }\n\n if (existing.read && existing.merge) {\n // If we have both a read and a merge function, assume\n // keyArgs:false, because read and merge together can take\n // responsibility for interpreting arguments in and out. This\n // default assumption can always be overridden by specifying\n // keyArgs explicitly in the FieldPolicy.\n existing.keyFn = existing.keyFn || simpleKeyArgsFn;\n }\n });\n }\n }\n\n private setRootTypename(\n which: \"Query\" | \"Mutation\" | \"Subscription\",\n typename: string = which,\n ) {\n const rootId = \"ROOT_\" + which.toUpperCase();\n const old = this.rootTypenamesById[rootId];\n if (typename !== old) {\n invariant(!old || old === which, `Cannot change root ${which} __typename more than once`);\n // First, delete any old __typename associated with this rootId from\n // rootIdsByTypename.\n if (old) delete this.rootIdsByTypename[old];\n // Now make this the only __typename that maps to this rootId.\n this.rootIdsByTypename[typename] = rootId;\n // Finally, update the __typename associated with this rootId.\n this.rootTypenamesById[rootId] = typename;\n }\n }\n\n public addPossibleTypes(possibleTypes: PossibleTypesMap) {\n (this.usingPossibleTypes as boolean) = true;\n Object.keys(possibleTypes).forEach(supertype => {\n // Make sure all types have an entry in this.supertypeMap, even if\n // their supertype set is empty, so we can return false immediately\n // from policies.fragmentMatches for unknown supertypes.\n this.getSupertypeSet(supertype, true);\n\n possibleTypes[supertype].forEach(subtype => {\n this.getSupertypeSet(subtype, true)!.add(supertype);\n const match = subtype.match(TypeOrFieldNameRegExp);\n if (!match || match[0] !== subtype) {\n // TODO Don't interpret just any invalid typename as a RegExp.\n this.fuzzySubtypes.set(subtype, new RegExp(subtype));\n }\n });\n });\n }\n\n private getTypePolicy(typename: string): Policies[\"typePolicies\"][string] {\n if (!hasOwn.call(this.typePolicies, typename)) {\n const policy: Policies[\"typePolicies\"][string] =\n this.typePolicies[typename] = Object.create(null);\n policy.fields = Object.create(null);\n\n // When the TypePolicy for typename is first accessed, instead of\n // starting with an empty policy object, inherit any properties or\n // fields from the type policies of the supertypes of typename.\n //\n // Any properties or fields defined explicitly within the TypePolicy\n // for typename will take precedence, and if there are multiple\n // supertypes, the properties of policies whose types were added\n // later via addPossibleTypes will take precedence over those of\n // earlier supertypes. TODO Perhaps we should warn about these\n // conflicts in development, and recommend defining the property\n // explicitly in the subtype policy?\n //\n // Field policy inheritance is atomic/shallow: you can't inherit a\n // field policy and then override just its read function, since read\n // and merge functions often need to cooperate, so changing only one\n // of them would be a recipe for inconsistency.\n //\n // Once the TypePolicy for typename has been accessed, its\n // properties can still be updated directly using addTypePolicies,\n // but future changes to supertype policies will not be reflected in\n // this policy, because this code runs at most once per typename.\n const supertypes = this.supertypeMap.get(typename);\n if (supertypes && supertypes.size) {\n supertypes.forEach(supertype => {\n const { fields, ...rest } = this.getTypePolicy(supertype);\n Object.assign(policy, rest);\n Object.assign(policy.fields, fields);\n });\n }\n }\n\n const inbox = this.toBeAdded[typename];\n if (inbox && inbox.length) {\n this.updateTypePolicy(typename, compact(...inbox.splice(0)));\n }\n\n return this.typePolicies[typename];\n }\n\n private getFieldPolicy(\n typename: string | undefined,\n fieldName: string,\n createIfMissing: boolean,\n ): {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction;\n } | undefined {\n if (typename) {\n const fieldPolicies = this.getTypePolicy(typename).fields;\n return fieldPolicies[fieldName] || (\n createIfMissing && (fieldPolicies[fieldName] = Object.create(null)));\n }\n }\n\n private getSupertypeSet(\n subtype: string,\n createIfMissing: boolean,\n ): Set | undefined {\n let supertypeSet = this.supertypeMap.get(subtype);\n if (!supertypeSet && createIfMissing) {\n this.supertypeMap.set(subtype, supertypeSet = new Set());\n }\n return supertypeSet;\n }\n\n public fragmentMatches(\n fragment: InlineFragmentNode | FragmentDefinitionNode,\n typename: string | undefined,\n result?: Record,\n variables?: Record,\n ): boolean {\n if (!fragment.typeCondition) return true;\n\n // If the fragment has a type condition but the object we're matching\n // against does not have a __typename, the fragment cannot match.\n if (!typename) return false;\n\n const supertype = fragment.typeCondition.name.value;\n // Common case: fragment type condition and __typename are the same.\n if (typename === supertype) return true;\n\n if (this.usingPossibleTypes &&\n this.supertypeMap.has(supertype)) {\n const typenameSupertypeSet = this.getSupertypeSet(typename, true)!;\n const workQueue = [typenameSupertypeSet];\n const maybeEnqueue = (subtype: string) => {\n const supertypeSet = this.getSupertypeSet(subtype, false);\n if (supertypeSet &&\n supertypeSet.size &&\n workQueue.indexOf(supertypeSet) < 0) {\n workQueue.push(supertypeSet);\n }\n };\n\n // We need to check fuzzy subtypes only if we encountered fuzzy\n // subtype strings in addPossibleTypes, and only while writing to\n // the cache, since that's when selectionSetMatchesResult gives a\n // strong signal of fragment matching. The StoreReader class calls\n // policies.fragmentMatches without passing a result object, so\n // needToCheckFuzzySubtypes is always false while reading.\n let needToCheckFuzzySubtypes = !!(result && this.fuzzySubtypes.size);\n let checkingFuzzySubtypes = false;\n\n // It's important to keep evaluating workQueue.length each time through\n // the loop, because the queue can grow while we're iterating over it.\n for (let i = 0; i < workQueue.length; ++i) {\n const supertypeSet = workQueue[i];\n\n if (supertypeSet.has(supertype)) {\n if (!typenameSupertypeSet.has(supertype)) {\n if (checkingFuzzySubtypes) {\n invariant.warn(`Inferring subtype ${typename} of supertype ${supertype}`);\n }\n // Record positive results for faster future lookup.\n // Unfortunately, we cannot safely cache negative results,\n // because new possibleTypes data could always be added to the\n // Policies class.\n typenameSupertypeSet.add(supertype);\n }\n return true;\n }\n\n supertypeSet.forEach(maybeEnqueue);\n\n if (needToCheckFuzzySubtypes &&\n // Start checking fuzzy subtypes only after exhausting all\n // non-fuzzy subtypes (after the final iteration of the loop).\n i === workQueue.length - 1 &&\n // We could wait to compare fragment.selectionSet to result\n // after we verify the supertype, but this check is often less\n // expensive than that search, and we will have to do the\n // comparison anyway whenever we find a potential match.\n selectionSetMatchesResult(fragment.selectionSet, result!, variables)) {\n // We don't always need to check fuzzy subtypes (if no result\n // was provided, or !this.fuzzySubtypes.size), but, when we do,\n // we only want to check them once.\n needToCheckFuzzySubtypes = false;\n checkingFuzzySubtypes = true;\n\n // If we find any fuzzy subtypes that match typename, extend the\n // workQueue to search through the supertypes of those fuzzy\n // subtypes. Otherwise the for-loop will terminate and we'll\n // return false below.\n this.fuzzySubtypes.forEach((regExp, fuzzyString) => {\n const match = typename.match(regExp);\n if (match && match[0] === typename) {\n maybeEnqueue(fuzzyString);\n }\n });\n }\n }\n }\n\n return false;\n }\n\n public hasKeyArgs(typename: string | undefined, fieldName: string) {\n const policy = this.getFieldPolicy(typename, fieldName, false);\n return !!(policy && policy.keyFn);\n }\n\n public getStoreFieldName(fieldSpec: FieldSpecifier): string {\n const { typename, fieldName } = fieldSpec;\n const policy = this.getFieldPolicy(typename, fieldName, false);\n let storeFieldName: KeyArgsResult;\n\n let keyFn = policy && policy.keyFn;\n if (keyFn && typename) {\n const context: Parameters[1] = {\n typename,\n fieldName,\n field: fieldSpec.field || null,\n variables: fieldSpec.variables,\n };\n const args = argsFromFieldSpecifier(fieldSpec);\n while (keyFn) {\n const specifierOrString = keyFn(args, context);\n if (Array.isArray(specifierOrString)) {\n keyFn = keyArgsFnFromSpecifier(specifierOrString);\n } else {\n // If the custom keyFn returns a falsy value, fall back to\n // fieldName instead.\n storeFieldName = specifierOrString || fieldName;\n break;\n }\n }\n }\n\n if (storeFieldName === void 0) {\n storeFieldName = fieldSpec.field\n ? storeKeyNameFromField(fieldSpec.field, fieldSpec.variables)\n : getStoreKeyName(fieldName, argsFromFieldSpecifier(fieldSpec));\n }\n\n // Returning false from a keyArgs function is like configuring\n // keyArgs: false, but more dynamic.\n if (storeFieldName === false) {\n return fieldName;\n }\n\n // Make sure custom field names start with the actual field.name.value\n // of the field, so we can always figure out which properties of a\n // StoreObject correspond to which original field names.\n return fieldName === fieldNameFromStoreName(storeFieldName)\n ? storeFieldName\n : fieldName + \":\" + storeFieldName;\n }\n\n public readField(\n options: ReadFieldOptions,\n context: ReadMergeModifyContext,\n ): SafeReadonly | undefined {\n const objectOrReference = options.from;\n if (!objectOrReference) return;\n\n const nameOrField = options.field || options.fieldName;\n if (!nameOrField) return;\n\n if (options.typename === void 0) {\n const typename = context.store.getFieldValue(objectOrReference, \"__typename\");\n if (typename) options.typename = typename;\n }\n\n const storeFieldName = this.getStoreFieldName(options);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const existing = context.store.getFieldValue(objectOrReference, storeFieldName);\n const policy = this.getFieldPolicy(options.typename, fieldName, false);\n const read = policy && policy.read;\n\n if (read) {\n const readOptions = makeFieldFunctionOptions(\n this,\n objectOrReference,\n options,\n context,\n context.store.getStorage(\n isReference(objectOrReference)\n ? objectOrReference.__ref\n : objectOrReference,\n storeFieldName,\n ),\n );\n\n // Call read(existing, readOptions) with cacheSlot holding this.cache.\n return cacheSlot.withValue(\n this.cache,\n read,\n [existing, readOptions],\n ) as SafeReadonly;\n }\n\n return existing;\n }\n\n public getMergeFunction(\n parentTypename: string | undefined,\n fieldName: string,\n childTypename: string | undefined,\n ): FieldMergeFunction | undefined {\n let policy:\n | Policies[\"typePolicies\"][string]\n | Policies[\"typePolicies\"][string][\"fields\"][string]\n | undefined =\n this.getFieldPolicy(parentTypename, fieldName, false);\n let merge = policy && policy.merge;\n if (!merge && childTypename) {\n policy = this.getTypePolicy(childTypename);\n merge = policy && policy.merge;\n }\n return merge;\n }\n\n public runMergeFunction(\n existing: StoreValue,\n incoming: StoreValue,\n { field, typename, merge }: MergeInfo,\n context: ReadMergeModifyContext,\n storage?: StorageType,\n ) {\n if (merge === mergeTrueFn) {\n // Instead of going to the trouble of creating a full\n // FieldFunctionOptions object and calling mergeTrueFn, we can\n // simply call mergeObjects, as mergeTrueFn would.\n return makeMergeObjectsFunction(\n context.store.getFieldValue\n )(existing as StoreObject,\n incoming as StoreObject);\n }\n\n if (merge === mergeFalseFn) {\n // Likewise for mergeFalseFn, whose implementation is even simpler.\n return incoming;\n }\n\n return merge(existing, incoming, makeFieldFunctionOptions(\n this,\n // Unlike options.readField for read functions, we do not fall\n // back to the current object if no foreignObjOrRef is provided,\n // because it's not clear what the current object should be for\n // merge functions: the (possibly undefined) existing object, or\n // the incoming object? If you think your merge function needs\n // to read sibling fields in order to produce a new value for\n // the current field, you might want to rethink your strategy,\n // because that's a recipe for making merge behavior sensitive\n // to the order in which fields are written into the cache.\n // However, readField(name, ref) is useful for merge functions\n // that need to deduplicate child objects and references.\n void 0,\n { typename,\n fieldName: field.name.value,\n field,\n variables: context.variables },\n context,\n storage || Object.create(null),\n ));\n }\n}\n\nfunction makeFieldFunctionOptions(\n policies: Policies,\n objectOrReference: StoreObject | Reference | undefined,\n fieldSpec: FieldSpecifier,\n context: ReadMergeModifyContext,\n storage: StorageType,\n): FieldFunctionOptions {\n const storeFieldName = policies.getStoreFieldName(fieldSpec);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const variables = fieldSpec.variables || context.variables;\n const { getFieldValue, toReference, canRead } = context.store;\n\n return {\n args: argsFromFieldSpecifier(fieldSpec),\n field: fieldSpec.field || null,\n fieldName,\n storeFieldName,\n variables,\n isReference,\n toReference,\n storage,\n cache: policies.cache,\n canRead,\n\n readField(\n fieldNameOrOptions: string | ReadFieldOptions,\n from?: StoreObject | Reference,\n ) {\n const options: ReadFieldOptions =\n typeof fieldNameOrOptions === \"string\" ? {\n fieldName: fieldNameOrOptions,\n from,\n } : { ...fieldNameOrOptions };\n\n if (void 0 === options.from) {\n options.from = objectOrReference;\n }\n\n if (void 0 === options.variables) {\n options.variables = variables;\n }\n\n return policies.readField(options, context);\n },\n\n mergeObjects: makeMergeObjectsFunction(getFieldValue),\n };\n}\n\nfunction makeMergeObjectsFunction(\n getFieldValue: FieldValueGetter,\n): MergeObjectsFunction {\n return function mergeObjects(existing, incoming) {\n if (Array.isArray(existing) || Array.isArray(incoming)) {\n throw new InvariantError(\"Cannot automatically merge arrays\");\n }\n\n // These dynamic checks are necessary because the parameters of a\n // custom merge function can easily have the any type, so the type\n // system cannot always enforce the StoreObject | Reference parameter\n // types of options.mergeObjects.\n if (existing && typeof existing === \"object\" &&\n incoming && typeof incoming === \"object\") {\n const eType = getFieldValue(existing, \"__typename\");\n const iType = getFieldValue(incoming, \"__typename\");\n const typesDiffer = eType && iType && eType !== iType;\n\n if (typesDiffer ||\n !storeValueIsStoreObject(existing) ||\n !storeValueIsStoreObject(incoming)) {\n return incoming;\n }\n\n return { ...existing, ...incoming };\n }\n\n return incoming;\n };\n}\n\nfunction keyArgsFnFromSpecifier(\n specifier: KeySpecifier,\n): KeyArgsFunction {\n return (args, context) => {\n return args ? `${context.fieldName}:${\n JSON.stringify(computeKeyObject(args, specifier, false))\n }` : context.fieldName;\n };\n}\n\nfunction keyFieldsFnFromSpecifier(\n specifier: KeySpecifier,\n): KeyFieldsFunction {\n const trie = new KeyTrie<{\n aliasMap?: AliasMap;\n }>(canUseWeakMap);\n\n return (object, context) => {\n let aliasMap: AliasMap | undefined;\n if (context.selectionSet && context.fragmentMap) {\n const info = trie.lookupArray([\n context.selectionSet,\n context.fragmentMap,\n ]);\n aliasMap = info.aliasMap || (\n info.aliasMap = makeAliasMap(context.selectionSet, context.fragmentMap)\n );\n }\n\n const keyObject = context.keyObject =\n computeKeyObject(object, specifier, true, aliasMap);\n\n return `${context.typename}:${JSON.stringify(keyObject)}`;\n };\n}\n\ntype AliasMap = {\n // Map from store key to corresponding response key. Undefined when there are\n // no aliased fields in this selection set.\n aliases?: Record;\n // Map from store key to AliasMap correponding to a child selection set.\n // Undefined when there are no child selection sets.\n subsets?: Record;\n};\n\nfunction makeAliasMap(\n selectionSet: SelectionSetNode,\n fragmentMap: FragmentMap,\n): AliasMap {\n let map: AliasMap = Object.create(null);\n // TODO Cache this work, perhaps by storing selectionSet._aliasMap?\n const workQueue = new Set([selectionSet]);\n workQueue.forEach(selectionSet => {\n selectionSet.selections.forEach(selection => {\n if (isField(selection)) {\n if (selection.alias) {\n const responseKey = selection.alias.value;\n const storeKey = selection.name.value;\n if (storeKey !== responseKey) {\n const aliases = map.aliases || (map.aliases = Object.create(null));\n aliases[storeKey] = responseKey;\n }\n }\n if (selection.selectionSet) {\n const subsets = map.subsets || (map.subsets = Object.create(null));\n subsets[selection.name.value] =\n makeAliasMap(selection.selectionSet, fragmentMap);\n }\n } else {\n const fragment = getFragmentFromSelection(selection, fragmentMap);\n if (fragment) {\n workQueue.add(fragment.selectionSet);\n }\n }\n });\n });\n return map;\n}\n\nfunction computeKeyObject(\n response: Record,\n specifier: KeySpecifier,\n strict: boolean,\n aliasMap?: AliasMap,\n): Record {\n // The order of adding properties to keyObj affects its JSON serialization,\n // so we are careful to build keyObj in the order of keys given in\n // specifier.\n const keyObj = Object.create(null);\n let prevKey: string | undefined;\n specifier.forEach(s => {\n if (Array.isArray(s)) {\n if (typeof prevKey === \"string\") {\n const subsets = aliasMap && aliasMap.subsets;\n const subset = subsets && subsets[prevKey];\n keyObj[prevKey] = computeKeyObject(response[prevKey], s, strict, subset);\n }\n } else {\n const aliases = aliasMap && aliasMap.aliases;\n const responseName = aliases && aliases[s] || s;\n if (hasOwn.call(response, responseName)) {\n keyObj[prevKey = s] = response[responseName];\n } else {\n invariant(!strict, `Missing field '${responseName}' while computing key fields`);\n prevKey = void 0;\n }\n }\n });\n return keyObj;\n}\n","import { makeUniqueId } from \"./makeUniqueId\";\n\nexport function stringifyForDisplay(value: any): string {\n const undefId = makeUniqueId(\"stringifyForDisplay\");\n return JSON.stringify(value, (key, value) => {\n return value === void 0 ? undefId : value;\n }).split(JSON.stringify(undefId)).join(\"\");\n}\n","import { SelectionSetNode, FieldNode, DocumentNode } from 'graphql';\nimport { invariant, InvariantError } from 'ts-invariant';\nimport { equal } from '@wry/equality';\n\nimport {\n createFragmentMap,\n FragmentMap,\n getFragmentFromSelection,\n getDefaultValues,\n getFragmentDefinitions,\n getOperationDefinition,\n getTypenameFromResult,\n makeReference,\n isField,\n resultKeyNameFromField,\n StoreValue,\n StoreObject,\n Reference,\n isReference,\n shouldInclude,\n hasDirectives,\n cloneDeep,\n} from '../../utilities';\n\nimport { NormalizedCache, ReadMergeModifyContext, MergeTree } from './types';\nimport { makeProcessedFieldsMerger, fieldNameFromStoreName, storeValueIsStoreObject } from './helpers';\nimport { StoreReader } from './readFromStore';\nimport { InMemoryCache } from './inMemoryCache';\nimport { EntityStore } from './entityStore';\n\nexport interface WriteContext extends ReadMergeModifyContext {\n readonly written: {\n [dataId: string]: SelectionSetNode[];\n };\n readonly fragmentMap?: FragmentMap;\n // General-purpose deep-merge function for use during writes.\n merge(existing: T, incoming: T): T;\n};\n\ninterface ProcessSelectionSetOptions {\n dataId?: string,\n result: Record;\n selectionSet: SelectionSetNode;\n context: WriteContext;\n mergeTree: MergeTree;\n}\n\nexport interface WriteToStoreOptions {\n query: DocumentNode;\n result: Object;\n dataId?: string;\n store: NormalizedCache;\n variables?: Object;\n}\n\nexport class StoreWriter {\n constructor(\n public readonly cache: InMemoryCache,\n private reader?: StoreReader,\n ) {}\n\n /**\n * Writes the result of a query to the store.\n *\n * @param result The result object returned for the query document.\n *\n * @param query The query document whose result we are writing to the store.\n *\n * @param store The {@link NormalizedCache} used by Apollo for the `data` portion of the store.\n *\n * @param variables A map from the name of a variable to its value. These variables can be\n * referenced by the query document.\n *\n * @return A `Reference` to the written object.\n */\n public writeToStore({\n query,\n result,\n dataId,\n store,\n variables,\n }: WriteToStoreOptions): Reference | undefined {\n const operationDefinition = getOperationDefinition(query)!;\n const merger = makeProcessedFieldsMerger();\n\n variables = {\n ...getDefaultValues(operationDefinition),\n ...variables!,\n };\n\n const ref = this.processSelectionSet({\n result: result || Object.create(null),\n dataId,\n selectionSet: operationDefinition.selectionSet,\n mergeTree: { map: new Map },\n context: {\n store,\n written: Object.create(null),\n merge(existing: T, incoming: T) {\n return merger.merge(existing, incoming) as T;\n },\n variables,\n varString: JSON.stringify(variables),\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n },\n });\n\n if (!isReference(ref)) {\n throw new InvariantError(`Could not identify object ${JSON.stringify(result)}`);\n }\n\n // Any IDs written explicitly to the cache will be retained as\n // reachable root IDs for garbage collection purposes. Although this\n // logic includes root IDs like ROOT_QUERY and ROOT_MUTATION, their\n // retainment counts are effectively ignored because cache.gc() always\n // includes them in its root ID set.\n store.retain(ref.__ref);\n\n return ref;\n }\n\n private processSelectionSet({\n dataId,\n result,\n selectionSet,\n context,\n // This object allows processSelectionSet to report useful information\n // to its callers without explicitly returning that information.\n mergeTree,\n }: ProcessSelectionSetOptions): StoreObject | Reference {\n const { policies } = this.cache;\n\n // Identify the result object, even if dataId was already provided,\n // since we always need keyObject below.\n const [id, keyObject] = policies.identify(\n result, selectionSet, context.fragmentMap);\n\n // If dataId was not provided, fall back to the id just generated by\n // policies.identify.\n dataId = dataId || id;\n\n if (\"string\" === typeof dataId) {\n // Avoid processing the same entity object using the same selection\n // set more than once. We use an array instead of a Set since most\n // entity IDs will be written using only one selection set, so the\n // size of this array is likely to be very small, meaning indexOf is\n // likely to be faster than Set.prototype.has.\n const sets = context.written[dataId] || (context.written[dataId] = []);\n const ref = makeReference(dataId);\n if (sets.indexOf(selectionSet) >= 0) return ref;\n sets.push(selectionSet);\n\n // If we're about to write a result object into the store, but we\n // happen to know that the exact same (===) result object would be\n // returned if we were to reread the result with the same inputs,\n // then we can skip the rest of the processSelectionSet work for\n // this object, and immediately return a Reference to it.\n if (this.reader && this.reader.isFresh(\n result,\n ref,\n selectionSet,\n context,\n )) {\n return ref;\n }\n }\n\n // This variable will be repeatedly updated using context.merge to\n // accumulate all fields that need to be written into the store.\n let incomingFields: StoreObject = Object.create(null);\n\n // Write any key fields that were used during identification, even if\n // they were not mentioned in the original query.\n if (keyObject) {\n incomingFields = context.merge(incomingFields, keyObject);\n }\n\n // If typename was not passed in, infer it. Note that typename is\n // always passed in for tricky-to-infer cases such as \"Query\" for\n // ROOT_QUERY.\n const typename: string | undefined =\n (dataId && policies.rootTypenamesById[dataId]) ||\n getTypenameFromResult(result, selectionSet, context.fragmentMap) ||\n (dataId && context.store.get(dataId, \"__typename\") as string);\n\n if (\"string\" === typeof typename) {\n incomingFields.__typename = typename;\n }\n\n const workSet = new Set(selectionSet.selections);\n\n workSet.forEach(selection => {\n if (!shouldInclude(selection, context.variables)) return;\n\n if (isField(selection)) {\n const resultFieldKey = resultKeyNameFromField(selection);\n const value = result[resultFieldKey];\n\n if (typeof value !== 'undefined') {\n const storeFieldName = policies.getStoreFieldName({\n typename,\n fieldName: selection.name.value,\n field: selection,\n variables: context.variables,\n });\n\n const childTree = getChildMergeTree(mergeTree, storeFieldName);\n\n let incomingValue =\n this.processFieldValue(value, selection, context, childTree);\n\n const childTypename = selection.selectionSet\n && context.store.getFieldValue(incomingValue as StoreObject, \"__typename\")\n || void 0;\n\n const merge = policies.getMergeFunction(\n typename,\n selection.name.value,\n childTypename,\n );\n\n if (merge) {\n childTree.info = {\n // TODO Check compatibility against any existing\n // childTree.field?\n field: selection,\n typename,\n merge,\n };\n } else {\n maybeRecycleChildMergeTree(mergeTree, storeFieldName);\n }\n\n incomingFields = context.merge(incomingFields, {\n [storeFieldName]: incomingValue,\n });\n\n } else if (\n policies.usingPossibleTypes &&\n !hasDirectives([\"defer\", \"client\"], selection)\n ) {\n throw new InvariantError(\n `Missing field '${resultFieldKey}' in ${JSON.stringify(\n result,\n null,\n 2,\n ).substring(0, 100)}`,\n );\n }\n } else {\n // This is not a field, so it must be a fragment, either inline or named\n const fragment = getFragmentFromSelection(\n selection,\n context.fragmentMap,\n );\n\n if (fragment &&\n // By passing result and context.variables, we enable\n // policies.fragmentMatches to bend the rules when typename is\n // not a known subtype of the fragment type condition, but the\n // result object contains all the keys requested by the\n // fragment, which strongly suggests the fragment probably\n // matched. This fuzzy matching behavior must be enabled by\n // including a regular expression string (such as \".*\" or\n // \"Prefix.*\" or \".*Suffix\") in the possibleTypes array for\n // specific supertypes; otherwise, all matching remains exact.\n // Fuzzy matches are remembered by the Policies object and\n // later used when reading from the cache. Since there is no\n // incoming result object to check when reading, reading does\n // not involve the same fuzzy inference, so the StoreReader\n // class calls policies.fragmentMatches without passing result\n // or context.variables. The flexibility of fuzzy matching\n // allows existing clients to accommodate previously unknown\n // __typename strings produced by server/schema changes, which\n // would otherwise be breaking changes.\n policies.fragmentMatches(fragment, typename, result, context.variables)) {\n fragment.selectionSet.selections.forEach(workSet.add, workSet);\n }\n }\n });\n\n if (\"string\" === typeof dataId) {\n const entityRef = makeReference(dataId);\n\n if (mergeTree.map.size) {\n incomingFields = this.applyMerges(mergeTree, entityRef, incomingFields, context);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n const hasSelectionSet = (storeFieldName: string) =>\n fieldsWithSelectionSets.has(fieldNameFromStoreName(storeFieldName));\n const fieldsWithSelectionSets = new Set();\n workSet.forEach(selection => {\n if (isField(selection) && selection.selectionSet) {\n fieldsWithSelectionSets.add(selection.name.value);\n }\n });\n\n const hasMergeFunction = (storeFieldName: string) => {\n const childTree = mergeTree.map.get(storeFieldName);\n return Boolean(childTree && childTree.info && childTree.info.merge);\n };\n\n Object.keys(incomingFields).forEach(storeFieldName => {\n // If a merge function was defined for this field, trust that it\n // did the right thing about (not) clobbering data. If the field\n // has no selection set, it's a scalar field, so it doesn't need\n // a merge function (even if it's an object, like JSON data).\n if (hasSelectionSet(storeFieldName) &&\n !hasMergeFunction(storeFieldName)) {\n warnAboutDataLoss(\n entityRef,\n incomingFields,\n storeFieldName,\n context.store,\n );\n }\n });\n }\n\n context.store.merge(dataId, incomingFields);\n\n return entityRef;\n }\n\n return incomingFields;\n }\n\n private processFieldValue(\n value: any,\n field: FieldNode,\n context: WriteContext,\n mergeTree: MergeTree,\n ): StoreValue {\n if (!field.selectionSet || value === null) {\n // In development, we need to clone scalar values so that they can be\n // safely frozen with maybeDeepFreeze in readFromStore.ts. In production,\n // it's cheaper to store the scalar values directly in the cache.\n return process.env.NODE_ENV === 'production' ? value : cloneDeep(value);\n }\n\n if (Array.isArray(value)) {\n return value.map((item, i) => {\n const value = this.processFieldValue(\n item, field, context, getChildMergeTree(mergeTree, i));\n maybeRecycleChildMergeTree(mergeTree, i);\n return value;\n });\n }\n\n return this.processSelectionSet({\n result: value,\n selectionSet: field.selectionSet,\n context,\n mergeTree,\n });\n }\n\n private applyMerges(\n mergeTree: MergeTree,\n existing: StoreValue,\n incoming: T,\n context: ReadMergeModifyContext,\n getStorageArgs?: Parameters,\n ): T {\n if (mergeTree.map.size && !isReference(incoming)) {\n const e: StoreObject | Reference | undefined = (\n // Items in the same position in different arrays are not\n // necessarily related to each other, so when incoming is an array\n // we process its elements as if there was no existing data.\n !Array.isArray(incoming) &&\n // Likewise, existing must be either a Reference or a StoreObject\n // in order for its fields to be safe to merge with the fields of\n // the incoming object.\n (isReference(existing) || storeValueIsStoreObject(existing))\n ) ? existing : void 0;\n\n // This narrowing is implied by mergeTree.map.size > 0 and\n // !isReference(incoming), though TypeScript understandably cannot\n // hope to infer this type.\n const i = incoming as StoreObject | StoreValue[];\n\n // The options.storage objects provided to read and merge functions\n // are derived from the identity of the parent object plus a\n // sequence of storeFieldName strings/numbers identifying the nested\n // field name path of each field value to be merged.\n if (e && !getStorageArgs) {\n getStorageArgs = [isReference(e) ? e.__ref : e];\n }\n\n // It's possible that applying merge functions to this subtree will\n // not change the incoming data, so this variable tracks the fields\n // that did change, so we can create a new incoming object when (and\n // only when) at least one incoming field has changed. We use a Map\n // to preserve the type of numeric keys.\n let changedFields: Map | undefined;\n\n const getValue = (\n from: typeof e | typeof i,\n name: string | number,\n ): StoreValue => {\n return Array.isArray(from)\n ? (typeof name === \"number\" ? from[name] : void 0)\n : context.store.getFieldValue(from, String(name))\n };\n\n mergeTree.map.forEach((childTree, storeFieldName) => {\n if (getStorageArgs) {\n getStorageArgs.push(storeFieldName);\n }\n const eVal = getValue(e, storeFieldName);\n const iVal = getValue(i, storeFieldName);\n const aVal = this.applyMerges(\n childTree,\n eVal,\n iVal,\n context,\n getStorageArgs,\n );\n if (aVal !== iVal) {\n changedFields = changedFields || new Map;\n changedFields.set(storeFieldName, aVal);\n }\n if (getStorageArgs) {\n invariant(getStorageArgs.pop() === storeFieldName);\n }\n });\n\n if (changedFields) {\n // Shallow clone i so we can add changed fields to it.\n incoming = (Array.isArray(i) ? i.slice(0) : { ...i }) as T;\n changedFields.forEach((value, name) => {\n (incoming as any)[name] = value;\n });\n }\n }\n\n if (mergeTree.info) {\n return this.cache.policies.runMergeFunction(\n existing,\n incoming,\n mergeTree.info,\n context,\n getStorageArgs && context.store.getStorage(...getStorageArgs),\n );\n }\n\n return incoming;\n }\n}\n\nconst emptyMergeTreePool: MergeTree[] = [];\n\nfunction getChildMergeTree(\n { map }: MergeTree,\n name: string | number,\n): MergeTree {\n if (!map.has(name)) {\n map.set(name, emptyMergeTreePool.pop() || { map: new Map });\n }\n return map.get(name)!;\n}\n\nfunction maybeRecycleChildMergeTree(\n { map }: MergeTree,\n name: string | number,\n) {\n const childTree = map.get(name);\n if (childTree &&\n !childTree.info &&\n !childTree.map.size) {\n emptyMergeTreePool.push(childTree);\n map.delete(name);\n }\n}\n\nconst warnings = new Set();\n\n// Note that this function is unused in production, and thus should be\n// pruned by any well-configured minifier.\nfunction warnAboutDataLoss(\n existingRef: Reference,\n incomingObj: StoreObject,\n storeFieldName: string,\n store: NormalizedCache,\n) {\n const getChild = (objOrRef: StoreObject | Reference): StoreObject | false => {\n const child = store.getFieldValue(objOrRef, storeFieldName);\n return typeof child === \"object\" && child;\n };\n\n const existing = getChild(existingRef);\n if (!existing) return;\n\n const incoming = getChild(incomingObj);\n if (!incoming) return;\n\n // It's always safe to replace a reference, since it refers to data\n // safely stored elsewhere.\n if (isReference(existing)) return;\n\n // If the values are structurally equivalent, we do not need to worry\n // about incoming replacing existing.\n if (equal(existing, incoming)) return;\n\n // If we're replacing every key of the existing object, then the\n // existing data would be overwritten even if the objects were\n // normalized, so warning would not be helpful here.\n if (Object.keys(existing).every(\n key => store.getFieldValue(incoming, key) !== void 0)) {\n return;\n }\n\n const parentType =\n store.getFieldValue(existingRef, \"__typename\") ||\n store.getFieldValue(incomingObj, \"__typename\");\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const typeDotName = `${parentType}.${fieldName}`;\n // Avoid warning more than once for the same type and field name.\n if (warnings.has(typeDotName)) return;\n warnings.add(typeDotName);\n\n const childTypenames: string[] = [];\n // Arrays do not have __typename fields, and always need a custom merge\n // function, even if their elements are normalized entities.\n if (!Array.isArray(existing) &&\n !Array.isArray(incoming)) {\n [existing, incoming].forEach(child => {\n const typename = store.getFieldValue(child, \"__typename\");\n if (typeof typename === \"string\" &&\n !childTypenames.includes(typename)) {\n childTypenames.push(typename);\n }\n });\n }\n\n invariant.warn(\n`Cache data may be lost when replacing the ${fieldName} field of a ${parentType} object.\n\nTo address this problem (which is not a bug in Apollo Client), ${\n childTypenames.length\n ? \"either ensure all objects of type \" +\n childTypenames.join(\" and \") + \" have an ID or a custom merge function, or \"\n : \"\"\n}define a custom merge function for the ${\n typeDotName\n} field, so InMemoryCache can safely merge these objects:\n\n existing: ${JSON.stringify(existing).slice(0, 1000)}\n incoming: ${JSON.stringify(incoming).slice(0, 1000)}\n\nFor more information about these options, please refer to the documentation:\n\n * Ensuring entity objects have IDs: https://go.apollo.dev/c/generating-unique-identifiers\n * Defining custom merge functions: https://go.apollo.dev/c/merging-non-normalized-objects\n`);\n}\n","// Make builtins like Map and Set safe to use with non-extensible objects.\nimport './fixPolyfills';\n\nimport { DocumentNode } from 'graphql';\nimport { dep, wrap } from 'optimism';\n\nimport { ApolloCache } from '../core/cache';\nimport { Cache } from '../core/types/Cache';\nimport { MissingFieldError } from '../core/types/common';\nimport {\n addTypenameToDocument,\n StoreObject,\n Reference,\n isReference,\n} from '../../utilities';\nimport {\n ApolloReducerConfig,\n NormalizedCacheObject,\n} from './types';\nimport { StoreReader } from './readFromStore';\nimport { StoreWriter } from './writeToStore';\nimport { EntityStore, supportsResultCaching } from './entityStore';\nimport { makeVar, forgetCache, recallCache } from './reactiveVars';\nimport {\n defaultDataIdFromObject,\n PossibleTypesMap,\n Policies,\n TypePolicies,\n} from './policies';\nimport { hasOwn } from './helpers';\n\nexport interface InMemoryCacheConfig extends ApolloReducerConfig {\n resultCaching?: boolean;\n possibleTypes?: PossibleTypesMap;\n typePolicies?: TypePolicies;\n}\n\nconst defaultConfig: InMemoryCacheConfig = {\n dataIdFromObject: defaultDataIdFromObject,\n addTypename: true,\n resultCaching: true,\n typePolicies: {},\n};\n\nexport class InMemoryCache extends ApolloCache {\n private data: EntityStore;\n private optimisticData: EntityStore;\n\n protected config: InMemoryCacheConfig;\n private watches = new Set();\n private addTypename: boolean;\n\n private typenameDocumentCache = new Map();\n private storeReader: StoreReader;\n private storeWriter: StoreWriter;\n\n // Dynamically imported code can augment existing typePolicies or\n // possibleTypes by calling cache.policies.addTypePolicies or\n // cache.policies.addPossibletypes.\n public readonly policies: Policies;\n\n public readonly makeVar = makeVar;\n\n constructor(config: InMemoryCacheConfig = {}) {\n super();\n this.config = { ...defaultConfig, ...config };\n this.addTypename = !!this.config.addTypename;\n\n this.policies = new Policies({\n cache: this,\n dataIdFromObject: this.config.dataIdFromObject,\n possibleTypes: this.config.possibleTypes,\n typePolicies: this.config.typePolicies,\n });\n\n // Passing { resultCaching: false } in the InMemoryCache constructor options\n // will completely disable dependency tracking, which will improve memory\n // usage but worsen the performance of repeated reads.\n this.data = new EntityStore.Root({\n policies: this.policies,\n resultCaching: this.config.resultCaching,\n });\n\n // When no optimistic writes are currently active, cache.optimisticData ===\n // cache.data, so there are no additional layers on top of the actual data.\n // When an optimistic update happens, this.optimisticData will become a\n // linked list of OptimisticCacheLayer objects that terminates with the\n // original this.data cache object.\n this.optimisticData = this.data;\n\n this.storeWriter = new StoreWriter(\n this,\n this.storeReader = new StoreReader({\n cache: this,\n addTypename: this.addTypename,\n }),\n );\n }\n\n public restore(data: NormalizedCacheObject): this {\n if (data) this.data.replace(data);\n return this;\n }\n\n public extract(optimistic: boolean = false): NormalizedCacheObject {\n return (optimistic ? this.optimisticData : this.data).extract();\n }\n\n public read(options: Cache.ReadOptions): T | null {\n const {\n // Since read returns data or null, without any additional metadata\n // about whether/where there might have been missing fields, the\n // default behavior cannot be returnPartialData = true (like it is\n // for the diff method), since defaulting to true would violate the\n // integrity of the T in the return type. However, partial data may\n // be useful in some cases, so returnPartialData:true may be\n // specified explicitly.\n returnPartialData = false,\n } = options;\n try {\n return this.storeReader.diffQueryAgainstStore({\n store: options.optimistic ? this.optimisticData : this.data,\n query: options.query,\n variables: options.variables,\n rootId: options.rootId,\n config: this.config,\n returnPartialData,\n }).result || null;\n } catch (e) {\n if (e instanceof MissingFieldError) {\n // Swallow MissingFieldError and return null, so callers do not\n // need to worry about catching \"normal\" exceptions resulting from\n // incomplete cache data. Unexpected errors will be re-thrown. If\n // you need more information about which fields were missing, use\n // cache.diff instead, and examine diffResult.missing.\n return null;\n }\n throw e;\n }\n }\n\n public write(options: Cache.WriteOptions): Reference | undefined {\n try {\n ++this.txCount;\n return this.storeWriter.writeToStore({\n store: this.data,\n query: options.query,\n result: options.result,\n dataId: options.dataId,\n variables: options.variables,\n });\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public modify(options: Cache.ModifyOptions): boolean {\n if (hasOwn.call(options, \"id\") && !options.id) {\n // To my knowledge, TypeScript does not currently provide a way to\n // enforce that an optional property?:type must *not* be undefined\n // when present. That ability would be useful here, because we want\n // options.id to default to ROOT_QUERY only when no options.id was\n // provided. If the caller attempts to pass options.id with a\n // falsy/undefined value (perhaps because cache.identify failed), we\n // should not assume the goal was to modify the ROOT_QUERY object.\n // We could throw, but it seems natural to return false to indicate\n // that nothing was modified.\n return false;\n }\n const store = options.optimistic // Defaults to false.\n ? this.optimisticData\n : this.data;\n try {\n ++this.txCount;\n return store.modify(options.id || \"ROOT_QUERY\", options.fields);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public diff(options: Cache.DiffOptions): Cache.DiffResult {\n return this.storeReader.diffQueryAgainstStore({\n store: options.optimistic ? this.optimisticData : this.data,\n rootId: options.id || \"ROOT_QUERY\",\n query: options.query,\n variables: options.variables,\n returnPartialData: options.returnPartialData,\n config: this.config,\n });\n }\n\n public watch(watch: Cache.WatchOptions): () => void {\n if (!this.watches.size) {\n // In case we previously called forgetCache(this) because\n // this.watches became empty (see below), reattach this cache to any\n // reactive variables on which it previously depended. It might seem\n // paradoxical that we're able to recall something we supposedly\n // forgot, but the point of calling forgetCache(this) is to silence\n // useless broadcasts while this.watches is empty, and to allow the\n // cache to be garbage collected. If, however, we manage to call\n // recallCache(this) here, this cache object must not have been\n // garbage collected yet, and should resume receiving updates from\n // reactive variables, now that it has a watcher to notify.\n recallCache(this);\n }\n this.watches.add(watch);\n if (watch.immediate) {\n this.maybeBroadcastWatch(watch);\n }\n return () => {\n // Once we remove the last watch from this.watches, cache.broadcastWatches\n // no longer does anything, so we preemptively tell the reactive variable\n // system to exclude this cache from future broadcasts.\n if (this.watches.delete(watch) && !this.watches.size) {\n forgetCache(this);\n }\n this.watchDep.dirty(watch);\n // Remove this watch from the LRU cache managed by the\n // maybeBroadcastWatch OptimisticWrapperFunction, to prevent memory\n // leaks involving the closure of watch.callback.\n this.maybeBroadcastWatch.forget(watch);\n };\n }\n\n // Request garbage collection of unreachable normalized entities.\n public gc() {\n return this.optimisticData.gc();\n }\n\n // Call this method to ensure the given root ID remains in the cache after\n // garbage collection, along with its transitive child entities. Note that\n // the cache automatically retains all directly written entities. By default,\n // the retainment persists after optimistic updates are removed. Pass true\n // for the optimistic argument if you would prefer for the retainment to be\n // discarded when the top-most optimistic layer is removed. Returns the\n // resulting (non-negative) retainment count.\n public retain(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).retain(rootId);\n }\n\n // Call this method to undo the effect of the retain method, above. Once the\n // retainment count falls to zero, the given ID will no longer be preserved\n // during garbage collection, though it may still be preserved by other safe\n // entities that refer to it. Returns the resulting (non-negative) retainment\n // count, in case that's useful.\n public release(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).release(rootId);\n }\n\n // Returns the canonical ID for a given StoreObject, obeying typePolicies\n // and keyFields (and dataIdFromObject, if you still use that). At minimum,\n // the object must contain a __typename and any primary key fields required\n // to identify entities of that type. If you pass a query result object, be\n // sure that none of the primary key fields have been renamed by aliasing.\n // If you pass a Reference object, its __ref ID string will be returned.\n public identify(object: StoreObject | Reference): string | undefined {\n return isReference(object) ? object.__ref :\n this.policies.identify(object)[0];\n }\n\n public evict(options: Cache.EvictOptions): boolean {\n if (!options.id) {\n if (hasOwn.call(options, \"id\")) {\n // See comment in modify method about why we return false when\n // options.id exists but is falsy/undefined.\n return false;\n }\n options = { ...options, id: \"ROOT_QUERY\" };\n }\n try {\n // It's unlikely that the eviction will end up invoking any other\n // cache update operations while it's running, but {in,de}crementing\n // this.txCount still seems like a good idea, for uniformity with\n // the other update methods.\n ++this.txCount;\n return this.optimisticData.evict(options);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public reset(): Promise {\n this.data.clear();\n this.optimisticData = this.data;\n this.broadcastWatches();\n return Promise.resolve();\n }\n\n public removeOptimistic(idToRemove: string) {\n const newOptimisticData = this.optimisticData.removeLayer(idToRemove);\n if (newOptimisticData !== this.optimisticData) {\n this.optimisticData = newOptimisticData;\n this.broadcastWatches();\n }\n }\n\n private txCount = 0;\n\n public performTransaction(\n transaction: (cache: InMemoryCache) => any,\n optimisticId?: string | null,\n ) {\n const perform = (layer?: EntityStore) => {\n const { data, optimisticData } = this;\n ++this.txCount;\n if (layer) {\n this.data = this.optimisticData = layer;\n }\n try {\n transaction(this);\n } finally {\n --this.txCount;\n this.data = data;\n this.optimisticData = optimisticData;\n }\n };\n\n let fromOptimisticTransaction = false;\n\n if (typeof optimisticId === 'string') {\n // Note that there can be multiple layers with the same optimisticId.\n // When removeOptimistic(id) is called for that id, all matching layers\n // will be removed, and the remaining layers will be reapplied.\n this.optimisticData = this.optimisticData.addLayer(optimisticId, perform);\n fromOptimisticTransaction = true;\n } else if (optimisticId === null) {\n // Ensure both this.data and this.optimisticData refer to the root\n // (non-optimistic) layer of the cache during the transaction. Note\n // that this.data could be a Layer if we are currently executing an\n // optimistic transaction function, but otherwise will always be an\n // EntityStore.Root instance.\n perform(this.data);\n } else {\n // Otherwise, leave this.data and this.optimisticData unchanged and\n // run the transaction with broadcast batching.\n perform();\n }\n\n // This broadcast does nothing if this.txCount > 0.\n this.broadcastWatches(fromOptimisticTransaction);\n }\n\n public transformDocument(document: DocumentNode): DocumentNode {\n if (this.addTypename) {\n let result = this.typenameDocumentCache.get(document);\n if (!result) {\n result = addTypenameToDocument(document);\n this.typenameDocumentCache.set(document, result);\n // If someone calls transformDocument and then mistakenly passes the\n // result back into an API that also calls transformDocument, make sure\n // we don't keep creating new query documents.\n this.typenameDocumentCache.set(result, result);\n }\n return result;\n }\n return document;\n }\n\n protected broadcastWatches(fromOptimisticTransaction?: boolean) {\n if (!this.txCount) {\n this.watches.forEach(c => this.maybeBroadcastWatch(c, fromOptimisticTransaction));\n }\n }\n\n private maybeBroadcastWatch = wrap((\n c: Cache.WatchOptions,\n fromOptimisticTransaction?: boolean,\n ) => {\n return this.broadcastWatch.call(this, c, !!fromOptimisticTransaction);\n }, {\n makeCacheKey: (c: Cache.WatchOptions) => {\n // Return a cache key (thus enabling result caching) only if we're\n // currently using a data store that can track cache dependencies.\n const store = c.optimistic ? this.optimisticData : this.data;\n if (supportsResultCaching(store)) {\n const { optimistic, rootId, variables } = c;\n return store.makeCacheKey(\n c.query,\n // Different watches can have the same query, optimistic\n // status, rootId, and variables, but if their callbacks are\n // different, the (identical) result needs to be delivered to\n // each distinct callback. The easiest way to achieve that\n // separation is to include c.callback in the cache key for\n // maybeBroadcastWatch calls. See issue #5733.\n c.callback,\n JSON.stringify({ optimistic, rootId, variables }),\n );\n }\n }\n });\n\n private watchDep = dep();\n\n // This method is wrapped by maybeBroadcastWatch, which is called by\n // broadcastWatches, so that we compute and broadcast results only when\n // the data that would be broadcast might have changed. It would be\n // simpler to check for changes after recomputing a result but before\n // broadcasting it, but this wrapping approach allows us to skip both\n // the recomputation and the broadcast, in most cases.\n private broadcastWatch(\n c: Cache.WatchOptions,\n fromOptimisticTransaction: boolean,\n ) {\n // First, invalidate any other maybeBroadcastWatch wrapper functions\n // currently depending on this Cache.WatchOptions object (including\n // the one currently calling broadcastWatch), so they will be included\n // in the next broadcast, even if the result they receive is the same\n // as the previous result they received. This is important because we\n // are about to deliver a different result to c.callback, so any\n // previous results should have a chance to be redelivered.\n this.watchDep.dirty(c);\n\n // Next, re-depend on this.watchDep for just this invocation of\n // maybeBroadcastWatch (this is a no-op if broadcastWatch was not\n // called by maybeBroadcastWatch). This allows only the most recent\n // maybeBroadcastWatch invocation for this watcher to remain cached,\n // enabling re-broadcast of previous results even if they have not\n // changed since they were previously delivered.\n this.watchDep(c);\n\n const diff = this.diff({\n query: c.query,\n variables: c.variables,\n optimistic: c.optimistic,\n });\n\n if (c.optimistic && fromOptimisticTransaction) {\n diff.fromOptimisticTransaction = true;\n }\n\n c.callback(diff);\n }\n}\n","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Return true if `value` is object-like. A value is object-like if it's not\n * `null` and has a `typeof` result of \"object\".\n */\nexport default function isObjectLike(value) {\n return _typeof(value) == 'object' && value !== null;\n}\n","/**\n * Represents a location in a Source.\n */\n\n/**\n * Takes a Source and a UTF-8 character offset, and returns the corresponding\n * line and column as a SourceLocation.\n */\nexport function getLocation(source, position) {\n var lineRegexp = /\\r\\n|[\\n\\r]/g;\n var line = 1;\n var column = position + 1;\n var match;\n\n while ((match = lineRegexp.exec(source.body)) && match.index < position) {\n line += 1;\n column = position + 1 - (match.index + match[0].length);\n }\n\n return {\n line: line,\n column: column\n };\n}\n","import { getLocation } from \"./location.mjs\";\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\n\nexport function printLocation(location) {\n return printSourceLocation(location.source, getLocation(location.source, location.start));\n}\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\n\nexport function printSourceLocation(source, sourceLocation) {\n var firstLineColumnOffset = source.locationOffset.column - 1;\n var body = whitespace(firstLineColumnOffset) + source.body;\n var lineIndex = sourceLocation.line - 1;\n var lineOffset = source.locationOffset.line - 1;\n var lineNum = sourceLocation.line + lineOffset;\n var columnOffset = sourceLocation.line === 1 ? firstLineColumnOffset : 0;\n var columnNum = sourceLocation.column + columnOffset;\n var locationStr = \"\".concat(source.name, \":\").concat(lineNum, \":\").concat(columnNum, \"\\n\");\n var lines = body.split(/\\r\\n|[\\n\\r]/g);\n var locationLine = lines[lineIndex]; // Special case for minified documents\n\n if (locationLine.length > 120) {\n var subLineIndex = Math.floor(columnNum / 80);\n var subLineColumnNum = columnNum % 80;\n var subLines = [];\n\n for (var i = 0; i < locationLine.length; i += 80) {\n subLines.push(locationLine.slice(i, i + 80));\n }\n\n return locationStr + printPrefixedLines([[\"\".concat(lineNum), subLines[0]]].concat(subLines.slice(1, subLineIndex + 1).map(function (subLine) {\n return ['', subLine];\n }), [[' ', whitespace(subLineColumnNum - 1) + '^'], ['', subLines[subLineIndex + 1]]]));\n }\n\n return locationStr + printPrefixedLines([// Lines specified like this: [\"prefix\", \"string\"],\n [\"\".concat(lineNum - 1), lines[lineIndex - 1]], [\"\".concat(lineNum), locationLine], ['', whitespace(columnNum - 1) + '^'], [\"\".concat(lineNum + 1), lines[lineIndex + 1]]]);\n}\n\nfunction printPrefixedLines(lines) {\n var existingLines = lines.filter(function (_ref) {\n var _ = _ref[0],\n line = _ref[1];\n return line !== undefined;\n });\n var padLen = Math.max.apply(Math, existingLines.map(function (_ref2) {\n var prefix = _ref2[0];\n return prefix.length;\n }));\n return existingLines.map(function (_ref3) {\n var prefix = _ref3[0],\n line = _ref3[1];\n return leftPad(padLen, prefix) + (line ? ' | ' + line : ' |');\n }).join('\\n');\n}\n\nfunction whitespace(len) {\n return Array(len + 1).join(' ');\n}\n\nfunction leftPad(len, str) {\n return whitespace(len - str.length) + str;\n}\n","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\n\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\n// FIXME:\n// flowlint uninitialized-instance-property:off\nimport isObjectLike from \"../jsutils/isObjectLike.mjs\";\nimport { SYMBOL_TO_STRING_TAG } from \"../polyfills/symbols.mjs\";\nimport { getLocation } from \"../language/location.mjs\";\nimport { printLocation, printSourceLocation } from \"../language/printLocation.mjs\";\n/**\n * A GraphQLError describes an Error found during the parse, validate, or\n * execute phases of performing a GraphQL operation. In addition to a message\n * and stack trace, it also includes information about the locations in a\n * GraphQL document and/or execution result that correspond to the Error.\n */\n\nexport var GraphQLError = /*#__PURE__*/function (_Error) {\n _inherits(GraphQLError, _Error);\n\n var _super = _createSuper(GraphQLError);\n\n /**\n * A message describing the Error for debugging purposes.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n *\n * Note: should be treated as readonly, despite invariant usage.\n */\n\n /**\n * An array of { line, column } locations within the source GraphQL document\n * which correspond to this error.\n *\n * Errors during validation often contain multiple locations, for example to\n * point out two things with the same name. Errors during execution include a\n * single location, the field which produced the error.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array describing the JSON-path into the execution response which\n * corresponds to this error. Only included for errors during execution.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array of GraphQL AST Nodes corresponding to this error.\n */\n\n /**\n * The source GraphQL document for the first location of this error.\n *\n * Note that if this Error represents more than one node, the source may not\n * represent nodes after the first node.\n */\n\n /**\n * An array of character offsets within the source GraphQL document\n * which correspond to this error.\n */\n\n /**\n * The original error thrown from a field resolver during execution.\n */\n\n /**\n * Extension fields to add to the formatted error.\n */\n function GraphQLError(message, nodes, source, positions, path, originalError, extensions) {\n var _locations2, _source2, _positions2, _extensions2;\n\n var _this;\n\n _classCallCheck(this, GraphQLError);\n\n _this = _super.call(this, message); // Compute list of blame nodes.\n\n var _nodes = Array.isArray(nodes) ? nodes.length !== 0 ? nodes : undefined : nodes ? [nodes] : undefined; // Compute locations in the source for the given nodes/positions.\n\n\n var _source = source;\n\n if (!_source && _nodes) {\n var _nodes$0$loc;\n\n _source = (_nodes$0$loc = _nodes[0].loc) === null || _nodes$0$loc === void 0 ? void 0 : _nodes$0$loc.source;\n }\n\n var _positions = positions;\n\n if (!_positions && _nodes) {\n _positions = _nodes.reduce(function (list, node) {\n if (node.loc) {\n list.push(node.loc.start);\n }\n\n return list;\n }, []);\n }\n\n if (_positions && _positions.length === 0) {\n _positions = undefined;\n }\n\n var _locations;\n\n if (positions && source) {\n _locations = positions.map(function (pos) {\n return getLocation(source, pos);\n });\n } else if (_nodes) {\n _locations = _nodes.reduce(function (list, node) {\n if (node.loc) {\n list.push(getLocation(node.loc.source, node.loc.start));\n }\n\n return list;\n }, []);\n }\n\n var _extensions = extensions;\n\n if (_extensions == null && originalError != null) {\n var originalExtensions = originalError.extensions;\n\n if (isObjectLike(originalExtensions)) {\n _extensions = originalExtensions;\n }\n }\n\n Object.defineProperties(_assertThisInitialized(_this), {\n name: {\n value: 'GraphQLError'\n },\n message: {\n value: message,\n // By being enumerable, JSON.stringify will include `message` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: true,\n writable: true\n },\n locations: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: (_locations2 = _locations) !== null && _locations2 !== void 0 ? _locations2 : undefined,\n // By being enumerable, JSON.stringify will include `locations` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: _locations != null\n },\n path: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: path !== null && path !== void 0 ? path : undefined,\n // By being enumerable, JSON.stringify will include `path` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: path != null\n },\n nodes: {\n value: _nodes !== null && _nodes !== void 0 ? _nodes : undefined\n },\n source: {\n value: (_source2 = _source) !== null && _source2 !== void 0 ? _source2 : undefined\n },\n positions: {\n value: (_positions2 = _positions) !== null && _positions2 !== void 0 ? _positions2 : undefined\n },\n originalError: {\n value: originalError\n },\n extensions: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: (_extensions2 = _extensions) !== null && _extensions2 !== void 0 ? _extensions2 : undefined,\n // By being enumerable, JSON.stringify will include `path` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: _extensions != null\n }\n }); // Include (non-enumerable) stack trace.\n\n if (originalError !== null && originalError !== void 0 && originalError.stack) {\n Object.defineProperty(_assertThisInitialized(_this), 'stack', {\n value: originalError.stack,\n writable: true,\n configurable: true\n });\n return _possibleConstructorReturn(_this);\n } // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(_assertThisInitialized(_this), GraphQLError);\n } else {\n Object.defineProperty(_assertThisInitialized(_this), 'stack', {\n value: Error().stack,\n writable: true,\n configurable: true\n });\n }\n\n return _this;\n }\n\n _createClass(GraphQLError, [{\n key: \"toString\",\n value: function toString() {\n return printError(this);\n } // FIXME: workaround to not break chai comparisons, should be remove in v16\n // $FlowFixMe[unsupported-syntax] Flow doesn't support computed properties yet\n\n }, {\n key: SYMBOL_TO_STRING_TAG,\n get: function get() {\n return 'Object';\n }\n }]);\n\n return GraphQLError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n/**\n * Prints a GraphQLError to a string, representing useful location information\n * about the error's position in the source.\n */\n\nexport function printError(error) {\n var output = error.message;\n\n if (error.nodes) {\n for (var _i2 = 0, _error$nodes2 = error.nodes; _i2 < _error$nodes2.length; _i2++) {\n var node = _error$nodes2[_i2];\n\n if (node.loc) {\n output += '\\n\\n' + printLocation(node.loc);\n }\n }\n } else if (error.source && error.locations) {\n for (var _i4 = 0, _error$locations2 = error.locations; _i4 < _error$locations2.length; _i4++) {\n var location = _error$locations2[_i4];\n output += '\\n\\n' + printSourceLocation(error.source, location);\n }\n }\n\n return output;\n}\n","import { GraphQLError } from \"./GraphQLError.mjs\";\n/**\n * Produces a GraphQLError representing a syntax error, containing useful\n * descriptive information about the syntax error's position in the source.\n */\n\nexport function syntaxError(source, position, description) {\n return new GraphQLError(\"Syntax Error: \".concat(description), undefined, source, [position]);\n}\n","/**\n * An exported enum describing the different kinds of tokens that the\n * lexer emits.\n */\nexport var TokenKind = Object.freeze({\n SOF: '',\n EOF: '',\n BANG: '!',\n DOLLAR: '$',\n AMP: '&',\n PAREN_L: '(',\n PAREN_R: ')',\n SPREAD: '...',\n COLON: ':',\n EQUALS: '=',\n AT: '@',\n BRACKET_L: '[',\n BRACKET_R: ']',\n BRACE_L: '{',\n PIPE: '|',\n BRACE_R: '}',\n NAME: 'Name',\n INT: 'Int',\n FLOAT: 'Float',\n STRING: 'String',\n BLOCK_STRING: 'BlockString',\n COMMENT: 'Comment'\n});\n/**\n * The enum type representing the token kinds values.\n */\n","/**\n * The set of allowed directive location values.\n */\nexport var DirectiveLocation = Object.freeze({\n // Request Definitions\n QUERY: 'QUERY',\n MUTATION: 'MUTATION',\n SUBSCRIPTION: 'SUBSCRIPTION',\n FIELD: 'FIELD',\n FRAGMENT_DEFINITION: 'FRAGMENT_DEFINITION',\n FRAGMENT_SPREAD: 'FRAGMENT_SPREAD',\n INLINE_FRAGMENT: 'INLINE_FRAGMENT',\n VARIABLE_DEFINITION: 'VARIABLE_DEFINITION',\n // Type System Definitions\n SCHEMA: 'SCHEMA',\n SCALAR: 'SCALAR',\n OBJECT: 'OBJECT',\n FIELD_DEFINITION: 'FIELD_DEFINITION',\n ARGUMENT_DEFINITION: 'ARGUMENT_DEFINITION',\n INTERFACE: 'INTERFACE',\n UNION: 'UNION',\n ENUM: 'ENUM',\n ENUM_VALUE: 'ENUM_VALUE',\n INPUT_OBJECT: 'INPUT_OBJECT',\n INPUT_FIELD_DEFINITION: 'INPUT_FIELD_DEFINITION'\n});\n/**\n * The enum type representing the directive location values.\n */\n","import { syntaxError } from \"../error/syntaxError.mjs\";\nimport { Token } from \"./ast.mjs\";\nimport { TokenKind } from \"./tokenKind.mjs\";\nimport { dedentBlockStringValue } from \"./blockString.mjs\";\n/**\n * Given a Source object, creates a Lexer for that source.\n * A Lexer is a stateful stream generator in that every time\n * it is advanced, it returns the next token in the Source. Assuming the\n * source lexes, the final Token emitted by the lexer will be of kind\n * EOF, after which the lexer will repeatedly return the same EOF token\n * whenever called.\n */\n\nexport var Lexer = /*#__PURE__*/function () {\n /**\n * The previously focused non-ignored token.\n */\n\n /**\n * The currently focused non-ignored token.\n */\n\n /**\n * The (1-indexed) line containing the current token.\n */\n\n /**\n * The character offset at which the current line begins.\n */\n function Lexer(source) {\n var startOfFileToken = new Token(TokenKind.SOF, 0, 0, 0, 0, null);\n this.source = source;\n this.lastToken = startOfFileToken;\n this.token = startOfFileToken;\n this.line = 1;\n this.lineStart = 0;\n }\n /**\n * Advances the token stream to the next non-ignored token.\n */\n\n\n var _proto = Lexer.prototype;\n\n _proto.advance = function advance() {\n this.lastToken = this.token;\n var token = this.token = this.lookahead();\n return token;\n }\n /**\n * Looks ahead and returns the next non-ignored token, but does not change\n * the state of Lexer.\n */\n ;\n\n _proto.lookahead = function lookahead() {\n var token = this.token;\n\n if (token.kind !== TokenKind.EOF) {\n do {\n var _token$next;\n\n // Note: next is only mutable during parsing, so we cast to allow this.\n token = (_token$next = token.next) !== null && _token$next !== void 0 ? _token$next : token.next = readToken(this, token);\n } while (token.kind === TokenKind.COMMENT);\n }\n\n return token;\n };\n\n return Lexer;\n}();\n/**\n * @internal\n */\n\nexport function isPunctuatorTokenKind(kind) {\n return kind === TokenKind.BANG || kind === TokenKind.DOLLAR || kind === TokenKind.AMP || kind === TokenKind.PAREN_L || kind === TokenKind.PAREN_R || kind === TokenKind.SPREAD || kind === TokenKind.COLON || kind === TokenKind.EQUALS || kind === TokenKind.AT || kind === TokenKind.BRACKET_L || kind === TokenKind.BRACKET_R || kind === TokenKind.BRACE_L || kind === TokenKind.PIPE || kind === TokenKind.BRACE_R;\n}\n\nfunction printCharCode(code) {\n return (// NaN/undefined represents access beyond the end of the file.\n isNaN(code) ? TokenKind.EOF : // Trust JSON for ASCII.\n code < 0x007f ? JSON.stringify(String.fromCharCode(code)) : // Otherwise print the escaped form.\n \"\\\"\\\\u\".concat(('00' + code.toString(16).toUpperCase()).slice(-4), \"\\\"\")\n );\n}\n/**\n * Gets the next token from the source starting at the given position.\n *\n * This skips over whitespace until it finds the next lexable token, then lexes\n * punctuators immediately or calls the appropriate helper function for more\n * complicated tokens.\n */\n\n\nfunction readToken(lexer, prev) {\n var source = lexer.source;\n var body = source.body;\n var bodyLength = body.length;\n var pos = prev.end;\n\n while (pos < bodyLength) {\n var code = body.charCodeAt(pos);\n var _line = lexer.line;\n\n var _col = 1 + pos - lexer.lineStart; // SourceCharacter\n\n\n switch (code) {\n case 0xfeff: // \n\n case 9: // \\t\n\n case 32: // \n\n case 44:\n // ,\n ++pos;\n continue;\n\n case 10:\n // \\n\n ++pos;\n ++lexer.line;\n lexer.lineStart = pos;\n continue;\n\n case 13:\n // \\r\n if (body.charCodeAt(pos + 1) === 10) {\n pos += 2;\n } else {\n ++pos;\n }\n\n ++lexer.line;\n lexer.lineStart = pos;\n continue;\n\n case 33:\n // !\n return new Token(TokenKind.BANG, pos, pos + 1, _line, _col, prev);\n\n case 35:\n // #\n return readComment(source, pos, _line, _col, prev);\n\n case 36:\n // $\n return new Token(TokenKind.DOLLAR, pos, pos + 1, _line, _col, prev);\n\n case 38:\n // &\n return new Token(TokenKind.AMP, pos, pos + 1, _line, _col, prev);\n\n case 40:\n // (\n return new Token(TokenKind.PAREN_L, pos, pos + 1, _line, _col, prev);\n\n case 41:\n // )\n return new Token(TokenKind.PAREN_R, pos, pos + 1, _line, _col, prev);\n\n case 46:\n // .\n if (body.charCodeAt(pos + 1) === 46 && body.charCodeAt(pos + 2) === 46) {\n return new Token(TokenKind.SPREAD, pos, pos + 3, _line, _col, prev);\n }\n\n break;\n\n case 58:\n // :\n return new Token(TokenKind.COLON, pos, pos + 1, _line, _col, prev);\n\n case 61:\n // =\n return new Token(TokenKind.EQUALS, pos, pos + 1, _line, _col, prev);\n\n case 64:\n // @\n return new Token(TokenKind.AT, pos, pos + 1, _line, _col, prev);\n\n case 91:\n // [\n return new Token(TokenKind.BRACKET_L, pos, pos + 1, _line, _col, prev);\n\n case 93:\n // ]\n return new Token(TokenKind.BRACKET_R, pos, pos + 1, _line, _col, prev);\n\n case 123:\n // {\n return new Token(TokenKind.BRACE_L, pos, pos + 1, _line, _col, prev);\n\n case 124:\n // |\n return new Token(TokenKind.PIPE, pos, pos + 1, _line, _col, prev);\n\n case 125:\n // }\n return new Token(TokenKind.BRACE_R, pos, pos + 1, _line, _col, prev);\n\n case 34:\n // \"\n if (body.charCodeAt(pos + 1) === 34 && body.charCodeAt(pos + 2) === 34) {\n return readBlockString(source, pos, _line, _col, prev, lexer);\n }\n\n return readString(source, pos, _line, _col, prev);\n\n case 45: // -\n\n case 48: // 0\n\n case 49: // 1\n\n case 50: // 2\n\n case 51: // 3\n\n case 52: // 4\n\n case 53: // 5\n\n case 54: // 6\n\n case 55: // 7\n\n case 56: // 8\n\n case 57:\n // 9\n return readNumber(source, pos, code, _line, _col, prev);\n\n case 65: // A\n\n case 66: // B\n\n case 67: // C\n\n case 68: // D\n\n case 69: // E\n\n case 70: // F\n\n case 71: // G\n\n case 72: // H\n\n case 73: // I\n\n case 74: // J\n\n case 75: // K\n\n case 76: // L\n\n case 77: // M\n\n case 78: // N\n\n case 79: // O\n\n case 80: // P\n\n case 81: // Q\n\n case 82: // R\n\n case 83: // S\n\n case 84: // T\n\n case 85: // U\n\n case 86: // V\n\n case 87: // W\n\n case 88: // X\n\n case 89: // Y\n\n case 90: // Z\n\n case 95: // _\n\n case 97: // a\n\n case 98: // b\n\n case 99: // c\n\n case 100: // d\n\n case 101: // e\n\n case 102: // f\n\n case 103: // g\n\n case 104: // h\n\n case 105: // i\n\n case 106: // j\n\n case 107: // k\n\n case 108: // l\n\n case 109: // m\n\n case 110: // n\n\n case 111: // o\n\n case 112: // p\n\n case 113: // q\n\n case 114: // r\n\n case 115: // s\n\n case 116: // t\n\n case 117: // u\n\n case 118: // v\n\n case 119: // w\n\n case 120: // x\n\n case 121: // y\n\n case 122:\n // z\n return readName(source, pos, _line, _col, prev);\n }\n\n throw syntaxError(source, pos, unexpectedCharacterMessage(code));\n }\n\n var line = lexer.line;\n var col = 1 + pos - lexer.lineStart;\n return new Token(TokenKind.EOF, bodyLength, bodyLength, line, col, prev);\n}\n/**\n * Report a message that an unexpected character was encountered.\n */\n\n\nfunction unexpectedCharacterMessage(code) {\n if (code < 0x0020 && code !== 0x0009 && code !== 0x000a && code !== 0x000d) {\n return \"Cannot contain the invalid character \".concat(printCharCode(code), \".\");\n }\n\n if (code === 39) {\n // '\n return 'Unexpected single quote character (\\'), did you mean to use a double quote (\")?';\n }\n\n return \"Cannot parse the unexpected character \".concat(printCharCode(code), \".\");\n}\n/**\n * Reads a comment token from the source file.\n *\n * #[\\u0009\\u0020-\\uFFFF]*\n */\n\n\nfunction readComment(source, start, line, col, prev) {\n var body = source.body;\n var code;\n var position = start;\n\n do {\n code = body.charCodeAt(++position);\n } while (!isNaN(code) && ( // SourceCharacter but not LineTerminator\n code > 0x001f || code === 0x0009));\n\n return new Token(TokenKind.COMMENT, start, position, line, col, prev, body.slice(start + 1, position));\n}\n/**\n * Reads a number token from the source file, either a float\n * or an int depending on whether a decimal point appears.\n *\n * Int: -?(0|[1-9][0-9]*)\n * Float: -?(0|[1-9][0-9]*)(\\.[0-9]+)?((E|e)(+|-)?[0-9]+)?\n */\n\n\nfunction readNumber(source, start, firstCode, line, col, prev) {\n var body = source.body;\n var code = firstCode;\n var position = start;\n var isFloat = false;\n\n if (code === 45) {\n // -\n code = body.charCodeAt(++position);\n }\n\n if (code === 48) {\n // 0\n code = body.charCodeAt(++position);\n\n if (code >= 48 && code <= 57) {\n throw syntaxError(source, position, \"Invalid number, unexpected digit after 0: \".concat(printCharCode(code), \".\"));\n }\n } else {\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n }\n\n if (code === 46) {\n // .\n isFloat = true;\n code = body.charCodeAt(++position);\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n }\n\n if (code === 69 || code === 101) {\n // E e\n isFloat = true;\n code = body.charCodeAt(++position);\n\n if (code === 43 || code === 45) {\n // + -\n code = body.charCodeAt(++position);\n }\n\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n } // Numbers cannot be followed by . or NameStart\n\n\n if (code === 46 || isNameStart(code)) {\n throw syntaxError(source, position, \"Invalid number, expected digit but got: \".concat(printCharCode(code), \".\"));\n }\n\n return new Token(isFloat ? TokenKind.FLOAT : TokenKind.INT, start, position, line, col, prev, body.slice(start, position));\n}\n/**\n * Returns the new position in the source after reading digits.\n */\n\n\nfunction readDigits(source, start, firstCode) {\n var body = source.body;\n var position = start;\n var code = firstCode;\n\n if (code >= 48 && code <= 57) {\n // 0 - 9\n do {\n code = body.charCodeAt(++position);\n } while (code >= 48 && code <= 57); // 0 - 9\n\n\n return position;\n }\n\n throw syntaxError(source, position, \"Invalid number, expected digit but got: \".concat(printCharCode(code), \".\"));\n}\n/**\n * Reads a string token from the source file.\n *\n * \"([^\"\\\\\\u000A\\u000D]|(\\\\(u[0-9a-fA-F]{4}|[\"\\\\/bfnrt])))*\"\n */\n\n\nfunction readString(source, start, line, col, prev) {\n var body = source.body;\n var position = start + 1;\n var chunkStart = position;\n var code = 0;\n var value = '';\n\n while (position < body.length && !isNaN(code = body.charCodeAt(position)) && // not LineTerminator\n code !== 0x000a && code !== 0x000d) {\n // Closing Quote (\")\n if (code === 34) {\n value += body.slice(chunkStart, position);\n return new Token(TokenKind.STRING, start, position + 1, line, col, prev, value);\n } // SourceCharacter\n\n\n if (code < 0x0020 && code !== 0x0009) {\n throw syntaxError(source, position, \"Invalid character within String: \".concat(printCharCode(code), \".\"));\n }\n\n ++position;\n\n if (code === 92) {\n // \\\n value += body.slice(chunkStart, position - 1);\n code = body.charCodeAt(position);\n\n switch (code) {\n case 34:\n value += '\"';\n break;\n\n case 47:\n value += '/';\n break;\n\n case 92:\n value += '\\\\';\n break;\n\n case 98:\n value += '\\b';\n break;\n\n case 102:\n value += '\\f';\n break;\n\n case 110:\n value += '\\n';\n break;\n\n case 114:\n value += '\\r';\n break;\n\n case 116:\n value += '\\t';\n break;\n\n case 117:\n {\n // uXXXX\n var charCode = uniCharCode(body.charCodeAt(position + 1), body.charCodeAt(position + 2), body.charCodeAt(position + 3), body.charCodeAt(position + 4));\n\n if (charCode < 0) {\n var invalidSequence = body.slice(position + 1, position + 5);\n throw syntaxError(source, position, \"Invalid character escape sequence: \\\\u\".concat(invalidSequence, \".\"));\n }\n\n value += String.fromCharCode(charCode);\n position += 4;\n break;\n }\n\n default:\n throw syntaxError(source, position, \"Invalid character escape sequence: \\\\\".concat(String.fromCharCode(code), \".\"));\n }\n\n ++position;\n chunkStart = position;\n }\n }\n\n throw syntaxError(source, position, 'Unterminated string.');\n}\n/**\n * Reads a block string token from the source file.\n *\n * \"\"\"(\"?\"?(\\\\\"\"\"|\\\\(?!=\"\"\")|[^\"\\\\]))*\"\"\"\n */\n\n\nfunction readBlockString(source, start, line, col, prev, lexer) {\n var body = source.body;\n var position = start + 3;\n var chunkStart = position;\n var code = 0;\n var rawValue = '';\n\n while (position < body.length && !isNaN(code = body.charCodeAt(position))) {\n // Closing Triple-Quote (\"\"\")\n if (code === 34 && body.charCodeAt(position + 1) === 34 && body.charCodeAt(position + 2) === 34) {\n rawValue += body.slice(chunkStart, position);\n return new Token(TokenKind.BLOCK_STRING, start, position + 3, line, col, prev, dedentBlockStringValue(rawValue));\n } // SourceCharacter\n\n\n if (code < 0x0020 && code !== 0x0009 && code !== 0x000a && code !== 0x000d) {\n throw syntaxError(source, position, \"Invalid character within String: \".concat(printCharCode(code), \".\"));\n }\n\n if (code === 10) {\n // new line\n ++position;\n ++lexer.line;\n lexer.lineStart = position;\n } else if (code === 13) {\n // carriage return\n if (body.charCodeAt(position + 1) === 10) {\n position += 2;\n } else {\n ++position;\n }\n\n ++lexer.line;\n lexer.lineStart = position;\n } else if ( // Escape Triple-Quote (\\\"\"\")\n code === 92 && body.charCodeAt(position + 1) === 34 && body.charCodeAt(position + 2) === 34 && body.charCodeAt(position + 3) === 34) {\n rawValue += body.slice(chunkStart, position) + '\"\"\"';\n position += 4;\n chunkStart = position;\n } else {\n ++position;\n }\n }\n\n throw syntaxError(source, position, 'Unterminated string.');\n}\n/**\n * Converts four hexadecimal chars to the integer that the\n * string represents. For example, uniCharCode('0','0','0','f')\n * will return 15, and uniCharCode('0','0','f','f') returns 255.\n *\n * Returns a negative number on error, if a char was invalid.\n *\n * This is implemented by noting that char2hex() returns -1 on error,\n * which means the result of ORing the char2hex() will also be negative.\n */\n\n\nfunction uniCharCode(a, b, c, d) {\n return char2hex(a) << 12 | char2hex(b) << 8 | char2hex(c) << 4 | char2hex(d);\n}\n/**\n * Converts a hex character to its integer value.\n * '0' becomes 0, '9' becomes 9\n * 'A' becomes 10, 'F' becomes 15\n * 'a' becomes 10, 'f' becomes 15\n *\n * Returns -1 on error.\n */\n\n\nfunction char2hex(a) {\n return a >= 48 && a <= 57 ? a - 48 // 0-9\n : a >= 65 && a <= 70 ? a - 55 // A-F\n : a >= 97 && a <= 102 ? a - 87 // a-f\n : -1;\n}\n/**\n * Reads an alphanumeric + underscore name from the source.\n *\n * [_A-Za-z][_0-9A-Za-z]*\n */\n\n\nfunction readName(source, start, line, col, prev) {\n var body = source.body;\n var bodyLength = body.length;\n var position = start + 1;\n var code = 0;\n\n while (position !== bodyLength && !isNaN(code = body.charCodeAt(position)) && (code === 95 || // _\n code >= 48 && code <= 57 || // 0-9\n code >= 65 && code <= 90 || // A-Z\n code >= 97 && code <= 122) // a-z\n ) {\n ++position;\n }\n\n return new Token(TokenKind.NAME, start, position, line, col, prev, body.slice(start, position));\n} // _ A-Z a-z\n\n\nfunction isNameStart(code) {\n return code === 95 || code >= 65 && code <= 90 || code >= 97 && code <= 122;\n}\n","import { syntaxError } from \"../error/syntaxError.mjs\";\nimport { Kind } from \"./kinds.mjs\";\nimport { Location } from \"./ast.mjs\";\nimport { TokenKind } from \"./tokenKind.mjs\";\nimport { Source, isSource } from \"./source.mjs\";\nimport { DirectiveLocation } from \"./directiveLocation.mjs\";\nimport { Lexer, isPunctuatorTokenKind } from \"./lexer.mjs\";\n/**\n * Configuration options to control parser behavior\n */\n\n/**\n * Given a GraphQL source, parses it into a Document.\n * Throws GraphQLError if a syntax error is encountered.\n */\nexport function parse(source, options) {\n var parser = new Parser(source, options);\n return parser.parseDocument();\n}\n/**\n * Given a string containing a GraphQL value (ex. `[42]`), parse the AST for\n * that value.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Values directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: valueFromAST().\n */\n\nexport function parseValue(source, options) {\n var parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n var value = parser.parseValueLiteral(false);\n parser.expectToken(TokenKind.EOF);\n return value;\n}\n/**\n * Given a string containing a GraphQL Type (ex. `[Int!]`), parse the AST for\n * that type.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Types directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: typeFromAST().\n */\n\nexport function parseType(source, options) {\n var parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n var type = parser.parseTypeReference();\n parser.expectToken(TokenKind.EOF);\n return type;\n}\n/**\n * This class is exported only to assist people in implementing their own parsers\n * without duplicating too much code and should be used only as last resort for cases\n * such as experimental syntax or if certain features could not be contributed upstream.\n *\n * It is still part of the internal API and is versioned, so any changes to it are never\n * considered breaking changes. If you still need to support multiple versions of the\n * library, please use the `versionInfo` variable for version detection.\n *\n * @internal\n */\n\nexport var Parser = /*#__PURE__*/function () {\n function Parser(source, options) {\n var sourceObj = isSource(source) ? source : new Source(source);\n this._lexer = new Lexer(sourceObj);\n this._options = options;\n }\n /**\n * Converts a name lex token into a name parse node.\n */\n\n\n var _proto = Parser.prototype;\n\n _proto.parseName = function parseName() {\n var token = this.expectToken(TokenKind.NAME);\n return {\n kind: Kind.NAME,\n value: token.value,\n loc: this.loc(token)\n };\n } // Implements the parsing rules in the Document section.\n\n /**\n * Document : Definition+\n */\n ;\n\n _proto.parseDocument = function parseDocument() {\n var start = this._lexer.token;\n return {\n kind: Kind.DOCUMENT,\n definitions: this.many(TokenKind.SOF, this.parseDefinition, TokenKind.EOF),\n loc: this.loc(start)\n };\n }\n /**\n * Definition :\n * - ExecutableDefinition\n * - TypeSystemDefinition\n * - TypeSystemExtension\n *\n * ExecutableDefinition :\n * - OperationDefinition\n * - FragmentDefinition\n */\n ;\n\n _proto.parseDefinition = function parseDefinition() {\n if (this.peek(TokenKind.NAME)) {\n switch (this._lexer.token.value) {\n case 'query':\n case 'mutation':\n case 'subscription':\n return this.parseOperationDefinition();\n\n case 'fragment':\n return this.parseFragmentDefinition();\n\n case 'schema':\n case 'scalar':\n case 'type':\n case 'interface':\n case 'union':\n case 'enum':\n case 'input':\n case 'directive':\n return this.parseTypeSystemDefinition();\n\n case 'extend':\n return this.parseTypeSystemExtension();\n }\n } else if (this.peek(TokenKind.BRACE_L)) {\n return this.parseOperationDefinition();\n } else if (this.peekDescription()) {\n return this.parseTypeSystemDefinition();\n }\n\n throw this.unexpected();\n } // Implements the parsing rules in the Operations section.\n\n /**\n * OperationDefinition :\n * - SelectionSet\n * - OperationType Name? VariableDefinitions? Directives? SelectionSet\n */\n ;\n\n _proto.parseOperationDefinition = function parseOperationDefinition() {\n var start = this._lexer.token;\n\n if (this.peek(TokenKind.BRACE_L)) {\n return {\n kind: Kind.OPERATION_DEFINITION,\n operation: 'query',\n name: undefined,\n variableDefinitions: [],\n directives: [],\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n\n var operation = this.parseOperationType();\n var name;\n\n if (this.peek(TokenKind.NAME)) {\n name = this.parseName();\n }\n\n return {\n kind: Kind.OPERATION_DEFINITION,\n operation: operation,\n name: name,\n variableDefinitions: this.parseVariableDefinitions(),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * OperationType : one of query mutation subscription\n */\n ;\n\n _proto.parseOperationType = function parseOperationType() {\n var operationToken = this.expectToken(TokenKind.NAME);\n\n switch (operationToken.value) {\n case 'query':\n return 'query';\n\n case 'mutation':\n return 'mutation';\n\n case 'subscription':\n return 'subscription';\n }\n\n throw this.unexpected(operationToken);\n }\n /**\n * VariableDefinitions : ( VariableDefinition+ )\n */\n ;\n\n _proto.parseVariableDefinitions = function parseVariableDefinitions() {\n return this.optionalMany(TokenKind.PAREN_L, this.parseVariableDefinition, TokenKind.PAREN_R);\n }\n /**\n * VariableDefinition : Variable : Type DefaultValue? Directives[Const]?\n */\n ;\n\n _proto.parseVariableDefinition = function parseVariableDefinition() {\n var start = this._lexer.token;\n return {\n kind: Kind.VARIABLE_DEFINITION,\n variable: this.parseVariable(),\n type: (this.expectToken(TokenKind.COLON), this.parseTypeReference()),\n defaultValue: this.expectOptionalToken(TokenKind.EQUALS) ? this.parseValueLiteral(true) : undefined,\n directives: this.parseDirectives(true),\n loc: this.loc(start)\n };\n }\n /**\n * Variable : $ Name\n */\n ;\n\n _proto.parseVariable = function parseVariable() {\n var start = this._lexer.token;\n this.expectToken(TokenKind.DOLLAR);\n return {\n kind: Kind.VARIABLE,\n name: this.parseName(),\n loc: this.loc(start)\n };\n }\n /**\n * SelectionSet : { Selection+ }\n */\n ;\n\n _proto.parseSelectionSet = function parseSelectionSet() {\n var start = this._lexer.token;\n return {\n kind: Kind.SELECTION_SET,\n selections: this.many(TokenKind.BRACE_L, this.parseSelection, TokenKind.BRACE_R),\n loc: this.loc(start)\n };\n }\n /**\n * Selection :\n * - Field\n * - FragmentSpread\n * - InlineFragment\n */\n ;\n\n _proto.parseSelection = function parseSelection() {\n return this.peek(TokenKind.SPREAD) ? this.parseFragment() : this.parseField();\n }\n /**\n * Field : Alias? Name Arguments? Directives? SelectionSet?\n *\n * Alias : Name :\n */\n ;\n\n _proto.parseField = function parseField() {\n var start = this._lexer.token;\n var nameOrAlias = this.parseName();\n var alias;\n var name;\n\n if (this.expectOptionalToken(TokenKind.COLON)) {\n alias = nameOrAlias;\n name = this.parseName();\n } else {\n name = nameOrAlias;\n }\n\n return {\n kind: Kind.FIELD,\n alias: alias,\n name: name,\n arguments: this.parseArguments(false),\n directives: this.parseDirectives(false),\n selectionSet: this.peek(TokenKind.BRACE_L) ? this.parseSelectionSet() : undefined,\n loc: this.loc(start)\n };\n }\n /**\n * Arguments[Const] : ( Argument[?Const]+ )\n */\n ;\n\n _proto.parseArguments = function parseArguments(isConst) {\n var item = isConst ? this.parseConstArgument : this.parseArgument;\n return this.optionalMany(TokenKind.PAREN_L, item, TokenKind.PAREN_R);\n }\n /**\n * Argument[Const] : Name : Value[?Const]\n */\n ;\n\n _proto.parseArgument = function parseArgument() {\n var start = this._lexer.token;\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return {\n kind: Kind.ARGUMENT,\n name: name,\n value: this.parseValueLiteral(false),\n loc: this.loc(start)\n };\n };\n\n _proto.parseConstArgument = function parseConstArgument() {\n var start = this._lexer.token;\n return {\n kind: Kind.ARGUMENT,\n name: this.parseName(),\n value: (this.expectToken(TokenKind.COLON), this.parseValueLiteral(true)),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Fragments section.\n\n /**\n * Corresponds to both FragmentSpread and InlineFragment in the spec.\n *\n * FragmentSpread : ... FragmentName Directives?\n *\n * InlineFragment : ... TypeCondition? Directives? SelectionSet\n */\n ;\n\n _proto.parseFragment = function parseFragment() {\n var start = this._lexer.token;\n this.expectToken(TokenKind.SPREAD);\n var hasTypeCondition = this.expectOptionalKeyword('on');\n\n if (!hasTypeCondition && this.peek(TokenKind.NAME)) {\n return {\n kind: Kind.FRAGMENT_SPREAD,\n name: this.parseFragmentName(),\n directives: this.parseDirectives(false),\n loc: this.loc(start)\n };\n }\n\n return {\n kind: Kind.INLINE_FRAGMENT,\n typeCondition: hasTypeCondition ? this.parseNamedType() : undefined,\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * FragmentDefinition :\n * - fragment FragmentName on TypeCondition Directives? SelectionSet\n *\n * TypeCondition : NamedType\n */\n ;\n\n _proto.parseFragmentDefinition = function parseFragmentDefinition() {\n var _this$_options;\n\n var start = this._lexer.token;\n this.expectKeyword('fragment'); // Experimental support for defining variables within fragments changes\n // the grammar of FragmentDefinition:\n // - fragment FragmentName VariableDefinitions? on TypeCondition Directives? SelectionSet\n\n if (((_this$_options = this._options) === null || _this$_options === void 0 ? void 0 : _this$_options.experimentalFragmentVariables) === true) {\n return {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n variableDefinitions: this.parseVariableDefinitions(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n\n return {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * FragmentName : Name but not `on`\n */\n ;\n\n _proto.parseFragmentName = function parseFragmentName() {\n if (this._lexer.token.value === 'on') {\n throw this.unexpected();\n }\n\n return this.parseName();\n } // Implements the parsing rules in the Values section.\n\n /**\n * Value[Const] :\n * - [~Const] Variable\n * - IntValue\n * - FloatValue\n * - StringValue\n * - BooleanValue\n * - NullValue\n * - EnumValue\n * - ListValue[?Const]\n * - ObjectValue[?Const]\n *\n * BooleanValue : one of `true` `false`\n *\n * NullValue : `null`\n *\n * EnumValue : Name but not `true`, `false` or `null`\n */\n ;\n\n _proto.parseValueLiteral = function parseValueLiteral(isConst) {\n var token = this._lexer.token;\n\n switch (token.kind) {\n case TokenKind.BRACKET_L:\n return this.parseList(isConst);\n\n case TokenKind.BRACE_L:\n return this.parseObject(isConst);\n\n case TokenKind.INT:\n this._lexer.advance();\n\n return {\n kind: Kind.INT,\n value: token.value,\n loc: this.loc(token)\n };\n\n case TokenKind.FLOAT:\n this._lexer.advance();\n\n return {\n kind: Kind.FLOAT,\n value: token.value,\n loc: this.loc(token)\n };\n\n case TokenKind.STRING:\n case TokenKind.BLOCK_STRING:\n return this.parseStringLiteral();\n\n case TokenKind.NAME:\n this._lexer.advance();\n\n switch (token.value) {\n case 'true':\n return {\n kind: Kind.BOOLEAN,\n value: true,\n loc: this.loc(token)\n };\n\n case 'false':\n return {\n kind: Kind.BOOLEAN,\n value: false,\n loc: this.loc(token)\n };\n\n case 'null':\n return {\n kind: Kind.NULL,\n loc: this.loc(token)\n };\n\n default:\n return {\n kind: Kind.ENUM,\n value: token.value,\n loc: this.loc(token)\n };\n }\n\n case TokenKind.DOLLAR:\n if (!isConst) {\n return this.parseVariable();\n }\n\n break;\n }\n\n throw this.unexpected();\n };\n\n _proto.parseStringLiteral = function parseStringLiteral() {\n var token = this._lexer.token;\n\n this._lexer.advance();\n\n return {\n kind: Kind.STRING,\n value: token.value,\n block: token.kind === TokenKind.BLOCK_STRING,\n loc: this.loc(token)\n };\n }\n /**\n * ListValue[Const] :\n * - [ ]\n * - [ Value[?Const]+ ]\n */\n ;\n\n _proto.parseList = function parseList(isConst) {\n var _this = this;\n\n var start = this._lexer.token;\n\n var item = function item() {\n return _this.parseValueLiteral(isConst);\n };\n\n return {\n kind: Kind.LIST,\n values: this.any(TokenKind.BRACKET_L, item, TokenKind.BRACKET_R),\n loc: this.loc(start)\n };\n }\n /**\n * ObjectValue[Const] :\n * - { }\n * - { ObjectField[?Const]+ }\n */\n ;\n\n _proto.parseObject = function parseObject(isConst) {\n var _this2 = this;\n\n var start = this._lexer.token;\n\n var item = function item() {\n return _this2.parseObjectField(isConst);\n };\n\n return {\n kind: Kind.OBJECT,\n fields: this.any(TokenKind.BRACE_L, item, TokenKind.BRACE_R),\n loc: this.loc(start)\n };\n }\n /**\n * ObjectField[Const] : Name : Value[?Const]\n */\n ;\n\n _proto.parseObjectField = function parseObjectField(isConst) {\n var start = this._lexer.token;\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return {\n kind: Kind.OBJECT_FIELD,\n name: name,\n value: this.parseValueLiteral(isConst),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Directives section.\n\n /**\n * Directives[Const] : Directive[?Const]+\n */\n ;\n\n _proto.parseDirectives = function parseDirectives(isConst) {\n var directives = [];\n\n while (this.peek(TokenKind.AT)) {\n directives.push(this.parseDirective(isConst));\n }\n\n return directives;\n }\n /**\n * Directive[Const] : @ Name Arguments[?Const]?\n */\n ;\n\n _proto.parseDirective = function parseDirective(isConst) {\n var start = this._lexer.token;\n this.expectToken(TokenKind.AT);\n return {\n kind: Kind.DIRECTIVE,\n name: this.parseName(),\n arguments: this.parseArguments(isConst),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Types section.\n\n /**\n * Type :\n * - NamedType\n * - ListType\n * - NonNullType\n */\n ;\n\n _proto.parseTypeReference = function parseTypeReference() {\n var start = this._lexer.token;\n var type;\n\n if (this.expectOptionalToken(TokenKind.BRACKET_L)) {\n type = this.parseTypeReference();\n this.expectToken(TokenKind.BRACKET_R);\n type = {\n kind: Kind.LIST_TYPE,\n type: type,\n loc: this.loc(start)\n };\n } else {\n type = this.parseNamedType();\n }\n\n if (this.expectOptionalToken(TokenKind.BANG)) {\n return {\n kind: Kind.NON_NULL_TYPE,\n type: type,\n loc: this.loc(start)\n };\n }\n\n return type;\n }\n /**\n * NamedType : Name\n */\n ;\n\n _proto.parseNamedType = function parseNamedType() {\n var start = this._lexer.token;\n return {\n kind: Kind.NAMED_TYPE,\n name: this.parseName(),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Type Definition section.\n\n /**\n * TypeSystemDefinition :\n * - SchemaDefinition\n * - TypeDefinition\n * - DirectiveDefinition\n *\n * TypeDefinition :\n * - ScalarTypeDefinition\n * - ObjectTypeDefinition\n * - InterfaceTypeDefinition\n * - UnionTypeDefinition\n * - EnumTypeDefinition\n * - InputObjectTypeDefinition\n */\n ;\n\n _proto.parseTypeSystemDefinition = function parseTypeSystemDefinition() {\n // Many definitions begin with a description and require a lookahead.\n var keywordToken = this.peekDescription() ? this._lexer.lookahead() : this._lexer.token;\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaDefinition();\n\n case 'scalar':\n return this.parseScalarTypeDefinition();\n\n case 'type':\n return this.parseObjectTypeDefinition();\n\n case 'interface':\n return this.parseInterfaceTypeDefinition();\n\n case 'union':\n return this.parseUnionTypeDefinition();\n\n case 'enum':\n return this.parseEnumTypeDefinition();\n\n case 'input':\n return this.parseInputObjectTypeDefinition();\n\n case 'directive':\n return this.parseDirectiveDefinition();\n }\n }\n\n throw this.unexpected(keywordToken);\n };\n\n _proto.peekDescription = function peekDescription() {\n return this.peek(TokenKind.STRING) || this.peek(TokenKind.BLOCK_STRING);\n }\n /**\n * Description : StringValue\n */\n ;\n\n _proto.parseDescription = function parseDescription() {\n if (this.peekDescription()) {\n return this.parseStringLiteral();\n }\n }\n /**\n * SchemaDefinition : Description? schema Directives[Const]? { OperationTypeDefinition+ }\n */\n ;\n\n _proto.parseSchemaDefinition = function parseSchemaDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('schema');\n var directives = this.parseDirectives(true);\n var operationTypes = this.many(TokenKind.BRACE_L, this.parseOperationTypeDefinition, TokenKind.BRACE_R);\n return {\n kind: Kind.SCHEMA_DEFINITION,\n description: description,\n directives: directives,\n operationTypes: operationTypes,\n loc: this.loc(start)\n };\n }\n /**\n * OperationTypeDefinition : OperationType : NamedType\n */\n ;\n\n _proto.parseOperationTypeDefinition = function parseOperationTypeDefinition() {\n var start = this._lexer.token;\n var operation = this.parseOperationType();\n this.expectToken(TokenKind.COLON);\n var type = this.parseNamedType();\n return {\n kind: Kind.OPERATION_TYPE_DEFINITION,\n operation: operation,\n type: type,\n loc: this.loc(start)\n };\n }\n /**\n * ScalarTypeDefinition : Description? scalar Name Directives[Const]?\n */\n ;\n\n _proto.parseScalarTypeDefinition = function parseScalarTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('scalar');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.SCALAR_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ObjectTypeDefinition :\n * Description?\n * type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition?\n */\n ;\n\n _proto.parseObjectTypeDefinition = function parseObjectTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('type');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n return {\n kind: Kind.OBJECT_TYPE_DEFINITION,\n description: description,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * ImplementsInterfaces :\n * - implements `&`? NamedType\n * - ImplementsInterfaces & NamedType\n */\n ;\n\n _proto.parseImplementsInterfaces = function parseImplementsInterfaces() {\n var _this$_options2;\n\n if (!this.expectOptionalKeyword('implements')) {\n return [];\n }\n\n if (((_this$_options2 = this._options) === null || _this$_options2 === void 0 ? void 0 : _this$_options2.allowLegacySDLImplementsInterfaces) === true) {\n var types = []; // Optional leading ampersand\n\n this.expectOptionalToken(TokenKind.AMP);\n\n do {\n types.push(this.parseNamedType());\n } while (this.expectOptionalToken(TokenKind.AMP) || this.peek(TokenKind.NAME));\n\n return types;\n }\n\n return this.delimitedMany(TokenKind.AMP, this.parseNamedType);\n }\n /**\n * FieldsDefinition : { FieldDefinition+ }\n */\n ;\n\n _proto.parseFieldsDefinition = function parseFieldsDefinition() {\n var _this$_options3;\n\n // Legacy support for the SDL?\n if (((_this$_options3 = this._options) === null || _this$_options3 === void 0 ? void 0 : _this$_options3.allowLegacySDLEmptyFields) === true && this.peek(TokenKind.BRACE_L) && this._lexer.lookahead().kind === TokenKind.BRACE_R) {\n this._lexer.advance();\n\n this._lexer.advance();\n\n return [];\n }\n\n return this.optionalMany(TokenKind.BRACE_L, this.parseFieldDefinition, TokenKind.BRACE_R);\n }\n /**\n * FieldDefinition :\n * - Description? Name ArgumentsDefinition? : Type Directives[Const]?\n */\n ;\n\n _proto.parseFieldDefinition = function parseFieldDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n var args = this.parseArgumentDefs();\n this.expectToken(TokenKind.COLON);\n var type = this.parseTypeReference();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.FIELD_DEFINITION,\n description: description,\n name: name,\n arguments: args,\n type: type,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ArgumentsDefinition : ( InputValueDefinition+ )\n */\n ;\n\n _proto.parseArgumentDefs = function parseArgumentDefs() {\n return this.optionalMany(TokenKind.PAREN_L, this.parseInputValueDef, TokenKind.PAREN_R);\n }\n /**\n * InputValueDefinition :\n * - Description? Name : Type DefaultValue? Directives[Const]?\n */\n ;\n\n _proto.parseInputValueDef = function parseInputValueDef() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n var type = this.parseTypeReference();\n var defaultValue;\n\n if (this.expectOptionalToken(TokenKind.EQUALS)) {\n defaultValue = this.parseValueLiteral(true);\n }\n\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.INPUT_VALUE_DEFINITION,\n description: description,\n name: name,\n type: type,\n defaultValue: defaultValue,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * InterfaceTypeDefinition :\n * - Description? interface Name Directives[Const]? FieldsDefinition?\n */\n ;\n\n _proto.parseInterfaceTypeDefinition = function parseInterfaceTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('interface');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n return {\n kind: Kind.INTERFACE_TYPE_DEFINITION,\n description: description,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * UnionTypeDefinition :\n * - Description? union Name Directives[Const]? UnionMemberTypes?\n */\n ;\n\n _proto.parseUnionTypeDefinition = function parseUnionTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('union');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var types = this.parseUnionMemberTypes();\n return {\n kind: Kind.UNION_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n types: types,\n loc: this.loc(start)\n };\n }\n /**\n * UnionMemberTypes :\n * - = `|`? NamedType\n * - UnionMemberTypes | NamedType\n */\n ;\n\n _proto.parseUnionMemberTypes = function parseUnionMemberTypes() {\n return this.expectOptionalToken(TokenKind.EQUALS) ? this.delimitedMany(TokenKind.PIPE, this.parseNamedType) : [];\n }\n /**\n * EnumTypeDefinition :\n * - Description? enum Name Directives[Const]? EnumValuesDefinition?\n */\n ;\n\n _proto.parseEnumTypeDefinition = function parseEnumTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('enum');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var values = this.parseEnumValuesDefinition();\n return {\n kind: Kind.ENUM_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n values: values,\n loc: this.loc(start)\n };\n }\n /**\n * EnumValuesDefinition : { EnumValueDefinition+ }\n */\n ;\n\n _proto.parseEnumValuesDefinition = function parseEnumValuesDefinition() {\n return this.optionalMany(TokenKind.BRACE_L, this.parseEnumValueDefinition, TokenKind.BRACE_R);\n }\n /**\n * EnumValueDefinition : Description? EnumValue Directives[Const]?\n *\n * EnumValue : Name\n */\n ;\n\n _proto.parseEnumValueDefinition = function parseEnumValueDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.ENUM_VALUE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * InputObjectTypeDefinition :\n * - Description? input Name Directives[Const]? InputFieldsDefinition?\n */\n ;\n\n _proto.parseInputObjectTypeDefinition = function parseInputObjectTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('input');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var fields = this.parseInputFieldsDefinition();\n return {\n kind: Kind.INPUT_OBJECT_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * InputFieldsDefinition : { InputValueDefinition+ }\n */\n ;\n\n _proto.parseInputFieldsDefinition = function parseInputFieldsDefinition() {\n return this.optionalMany(TokenKind.BRACE_L, this.parseInputValueDef, TokenKind.BRACE_R);\n }\n /**\n * TypeSystemExtension :\n * - SchemaExtension\n * - TypeExtension\n *\n * TypeExtension :\n * - ScalarTypeExtension\n * - ObjectTypeExtension\n * - InterfaceTypeExtension\n * - UnionTypeExtension\n * - EnumTypeExtension\n * - InputObjectTypeDefinition\n */\n ;\n\n _proto.parseTypeSystemExtension = function parseTypeSystemExtension() {\n var keywordToken = this._lexer.lookahead();\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaExtension();\n\n case 'scalar':\n return this.parseScalarTypeExtension();\n\n case 'type':\n return this.parseObjectTypeExtension();\n\n case 'interface':\n return this.parseInterfaceTypeExtension();\n\n case 'union':\n return this.parseUnionTypeExtension();\n\n case 'enum':\n return this.parseEnumTypeExtension();\n\n case 'input':\n return this.parseInputObjectTypeExtension();\n }\n }\n\n throw this.unexpected(keywordToken);\n }\n /**\n * SchemaExtension :\n * - extend schema Directives[Const]? { OperationTypeDefinition+ }\n * - extend schema Directives[Const]\n */\n ;\n\n _proto.parseSchemaExtension = function parseSchemaExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('schema');\n var directives = this.parseDirectives(true);\n var operationTypes = this.optionalMany(TokenKind.BRACE_L, this.parseOperationTypeDefinition, TokenKind.BRACE_R);\n\n if (directives.length === 0 && operationTypes.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.SCHEMA_EXTENSION,\n directives: directives,\n operationTypes: operationTypes,\n loc: this.loc(start)\n };\n }\n /**\n * ScalarTypeExtension :\n * - extend scalar Name Directives[Const]\n */\n ;\n\n _proto.parseScalarTypeExtension = function parseScalarTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('scalar');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n\n if (directives.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.SCALAR_TYPE_EXTENSION,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ObjectTypeExtension :\n * - extend type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend type Name ImplementsInterfaces? Directives[Const]\n * - extend type Name ImplementsInterfaces\n */\n ;\n\n _proto.parseObjectTypeExtension = function parseObjectTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('type');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n\n if (interfaces.length === 0 && directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.OBJECT_TYPE_EXTENSION,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * InterfaceTypeExtension :\n * - extend interface Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend interface Name ImplementsInterfaces? Directives[Const]\n * - extend interface Name ImplementsInterfaces\n */\n ;\n\n _proto.parseInterfaceTypeExtension = function parseInterfaceTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('interface');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n\n if (interfaces.length === 0 && directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.INTERFACE_TYPE_EXTENSION,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * UnionTypeExtension :\n * - extend union Name Directives[Const]? UnionMemberTypes\n * - extend union Name Directives[Const]\n */\n ;\n\n _proto.parseUnionTypeExtension = function parseUnionTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('union');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var types = this.parseUnionMemberTypes();\n\n if (directives.length === 0 && types.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.UNION_TYPE_EXTENSION,\n name: name,\n directives: directives,\n types: types,\n loc: this.loc(start)\n };\n }\n /**\n * EnumTypeExtension :\n * - extend enum Name Directives[Const]? EnumValuesDefinition\n * - extend enum Name Directives[Const]\n */\n ;\n\n _proto.parseEnumTypeExtension = function parseEnumTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('enum');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var values = this.parseEnumValuesDefinition();\n\n if (directives.length === 0 && values.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.ENUM_TYPE_EXTENSION,\n name: name,\n directives: directives,\n values: values,\n loc: this.loc(start)\n };\n }\n /**\n * InputObjectTypeExtension :\n * - extend input Name Directives[Const]? InputFieldsDefinition\n * - extend input Name Directives[Const]\n */\n ;\n\n _proto.parseInputObjectTypeExtension = function parseInputObjectTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('input');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var fields = this.parseInputFieldsDefinition();\n\n if (directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.INPUT_OBJECT_TYPE_EXTENSION,\n name: name,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * DirectiveDefinition :\n * - Description? directive @ Name ArgumentsDefinition? `repeatable`? on DirectiveLocations\n */\n ;\n\n _proto.parseDirectiveDefinition = function parseDirectiveDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('directive');\n this.expectToken(TokenKind.AT);\n var name = this.parseName();\n var args = this.parseArgumentDefs();\n var repeatable = this.expectOptionalKeyword('repeatable');\n this.expectKeyword('on');\n var locations = this.parseDirectiveLocations();\n return {\n kind: Kind.DIRECTIVE_DEFINITION,\n description: description,\n name: name,\n arguments: args,\n repeatable: repeatable,\n locations: locations,\n loc: this.loc(start)\n };\n }\n /**\n * DirectiveLocations :\n * - `|`? DirectiveLocation\n * - DirectiveLocations | DirectiveLocation\n */\n ;\n\n _proto.parseDirectiveLocations = function parseDirectiveLocations() {\n return this.delimitedMany(TokenKind.PIPE, this.parseDirectiveLocation);\n }\n /*\n * DirectiveLocation :\n * - ExecutableDirectiveLocation\n * - TypeSystemDirectiveLocation\n *\n * ExecutableDirectiveLocation : one of\n * `QUERY`\n * `MUTATION`\n * `SUBSCRIPTION`\n * `FIELD`\n * `FRAGMENT_DEFINITION`\n * `FRAGMENT_SPREAD`\n * `INLINE_FRAGMENT`\n *\n * TypeSystemDirectiveLocation : one of\n * `SCHEMA`\n * `SCALAR`\n * `OBJECT`\n * `FIELD_DEFINITION`\n * `ARGUMENT_DEFINITION`\n * `INTERFACE`\n * `UNION`\n * `ENUM`\n * `ENUM_VALUE`\n * `INPUT_OBJECT`\n * `INPUT_FIELD_DEFINITION`\n */\n ;\n\n _proto.parseDirectiveLocation = function parseDirectiveLocation() {\n var start = this._lexer.token;\n var name = this.parseName();\n\n if (DirectiveLocation[name.value] !== undefined) {\n return name;\n }\n\n throw this.unexpected(start);\n } // Core parsing utility functions\n\n /**\n * Returns a location object, used to identify the place in the source that created a given parsed object.\n */\n ;\n\n _proto.loc = function loc(startToken) {\n var _this$_options4;\n\n if (((_this$_options4 = this._options) === null || _this$_options4 === void 0 ? void 0 : _this$_options4.noLocation) !== true) {\n return new Location(startToken, this._lexer.lastToken, this._lexer.source);\n }\n }\n /**\n * Determines if the next token is of a given kind\n */\n ;\n\n _proto.peek = function peek(kind) {\n return this._lexer.token.kind === kind;\n }\n /**\n * If the next token is of the given kind, return that token after advancing the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n ;\n\n _proto.expectToken = function expectToken(kind) {\n var token = this._lexer.token;\n\n if (token.kind === kind) {\n this._lexer.advance();\n\n return token;\n }\n\n throw syntaxError(this._lexer.source, token.start, \"Expected \".concat(getTokenKindDesc(kind), \", found \").concat(getTokenDesc(token), \".\"));\n }\n /**\n * If the next token is of the given kind, return that token after advancing the lexer.\n * Otherwise, do not change the parser state and return undefined.\n */\n ;\n\n _proto.expectOptionalToken = function expectOptionalToken(kind) {\n var token = this._lexer.token;\n\n if (token.kind === kind) {\n this._lexer.advance();\n\n return token;\n }\n\n return undefined;\n }\n /**\n * If the next token is a given keyword, advance the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n ;\n\n _proto.expectKeyword = function expectKeyword(value) {\n var token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this._lexer.advance();\n } else {\n throw syntaxError(this._lexer.source, token.start, \"Expected \\\"\".concat(value, \"\\\", found \").concat(getTokenDesc(token), \".\"));\n }\n }\n /**\n * If the next token is a given keyword, return \"true\" after advancing the lexer.\n * Otherwise, do not change the parser state and return \"false\".\n */\n ;\n\n _proto.expectOptionalKeyword = function expectOptionalKeyword(value) {\n var token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this._lexer.advance();\n\n return true;\n }\n\n return false;\n }\n /**\n * Helper function for creating an error when an unexpected lexed token is encountered.\n */\n ;\n\n _proto.unexpected = function unexpected(atToken) {\n var token = atToken !== null && atToken !== void 0 ? atToken : this._lexer.token;\n return syntaxError(this._lexer.source, token.start, \"Unexpected \".concat(getTokenDesc(token), \".\"));\n }\n /**\n * Returns a possibly empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.any = function any(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n var nodes = [];\n\n while (!this.expectOptionalToken(closeKind)) {\n nodes.push(parseFn.call(this));\n }\n\n return nodes;\n }\n /**\n * Returns a list of parse nodes, determined by the parseFn.\n * It can be empty only if open token is missing otherwise it will always return non-empty list\n * that begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.optionalMany = function optionalMany(openKind, parseFn, closeKind) {\n if (this.expectOptionalToken(openKind)) {\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n\n return [];\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.many = function many(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list may begin with a lex token of delimiterKind followed by items separated by lex tokens of tokenKind.\n * Advances the parser to the next lex token after last item in the list.\n */\n ;\n\n _proto.delimitedMany = function delimitedMany(delimiterKind, parseFn) {\n this.expectOptionalToken(delimiterKind);\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (this.expectOptionalToken(delimiterKind));\n\n return nodes;\n };\n\n return Parser;\n}();\n/**\n * A helper function to describe a token as a string for debugging.\n */\n\nfunction getTokenDesc(token) {\n var value = token.value;\n return getTokenKindDesc(token.kind) + (value != null ? \" \\\"\".concat(value, \"\\\"\") : '');\n}\n/**\n * A helper function to describe a token kind as a string for debugging.\n */\n\n\nfunction getTokenKindDesc(kind) {\n return isPunctuatorTokenKind(kind) ? \"\\\"\".concat(kind, \"\\\"\") : kind;\n}\n","import { InvariantError, invariant } from '../../utilities/globals';\n\nimport { Observable, Observer } from '../../utilities';\nimport {\n NextLink,\n Operation,\n RequestHandler,\n FetchResult,\n GraphQLRequest\n} from './types';\nimport {\n validateOperation,\n createOperation,\n transformOperation,\n} from '../utils';\n\nfunction passthrough(op: Operation, forward: NextLink) {\n return (forward ? forward(op) : Observable.of()) as Observable;\n}\n\nfunction toLink(handler: RequestHandler | ApolloLink) {\n return typeof handler === 'function' ? new ApolloLink(handler) : handler;\n}\n\nfunction isTerminating(link: ApolloLink): boolean {\n return link.request.length <= 1;\n}\n\nclass LinkError extends Error {\n public link?: ApolloLink;\n constructor(message?: string, link?: ApolloLink) {\n super(message);\n this.link = link;\n }\n}\n\nexport class ApolloLink {\n public static empty(): ApolloLink {\n return new ApolloLink(() => Observable.of());\n }\n\n public static from(links: (ApolloLink | RequestHandler)[]): ApolloLink {\n if (links.length === 0) return ApolloLink.empty();\n return links.map(toLink).reduce((x, y) => x.concat(y)) as ApolloLink;\n }\n\n public static split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler,\n ): ApolloLink {\n const leftLink = toLink(left);\n const rightLink = toLink(right || new ApolloLink(passthrough));\n\n if (isTerminating(leftLink) && isTerminating(rightLink)) {\n return new ApolloLink(operation => {\n return test(operation)\n ? leftLink.request(operation) || Observable.of()\n : rightLink.request(operation) || Observable.of();\n });\n } else {\n return new ApolloLink((operation, forward) => {\n return test(operation)\n ? leftLink.request(operation, forward) || Observable.of()\n : rightLink.request(operation, forward) || Observable.of();\n });\n }\n }\n\n public static execute(\n link: ApolloLink,\n operation: GraphQLRequest,\n ): Observable {\n return (\n link.request(\n createOperation(\n operation.context,\n transformOperation(validateOperation(operation)),\n ),\n ) || Observable.of()\n );\n }\n\n public static concat(\n first: ApolloLink | RequestHandler,\n second: ApolloLink | RequestHandler,\n ) {\n const firstLink = toLink(first);\n if (isTerminating(firstLink)) {\n invariant.warn(\n new LinkError(\n `You are calling concat on a terminating link, which will have no effect`,\n firstLink,\n ),\n );\n return firstLink;\n }\n const nextLink = toLink(second);\n\n if (isTerminating(nextLink)) {\n return new ApolloLink(\n operation =>\n firstLink.request(\n operation,\n op => nextLink.request(op) || Observable.of(),\n ) || Observable.of(),\n );\n } else {\n return new ApolloLink((operation, forward) => {\n return (\n firstLink.request(operation, op => {\n return nextLink.request(op, forward) || Observable.of();\n }) || Observable.of()\n );\n });\n }\n }\n\n constructor(request?: RequestHandler) {\n if (request) this.request = request;\n }\n\n public split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler,\n ): ApolloLink {\n return this.concat(\n ApolloLink.split(test, left, right || new ApolloLink(passthrough))\n );\n }\n\n public concat(next: ApolloLink | RequestHandler): ApolloLink {\n return ApolloLink.concat(this, next);\n }\n\n public request(\n operation: Operation,\n forward?: NextLink,\n ): Observable | null {\n throw new InvariantError('request is not implemented');\n }\n\n protected onError(\n error: any,\n observer?: Observer,\n ): false | void {\n if (observer && observer.error) {\n observer.error(error);\n // Returning false indicates that observer.error does not need to be\n // called again, since it was already called (on the previous line).\n // Calling observer.error again would not cause any real problems,\n // since only the first call matters, but custom onError functions\n // might have other reasons for wanting to prevent the default\n // behavior by returning false.\n return false;\n }\n // Throw errors will be passed to observer.error.\n throw error;\n }\n\n public setOnError(fn: ApolloLink[\"onError\"]): this {\n this.onError = fn;\n return this;\n }\n}\n","export { empty } from './empty';\nexport { from } from './from';\nexport { split } from './split';\nexport { concat } from './concat';\nexport { execute } from './execute';\nexport { ApolloLink } from './ApolloLink';\n\nexport * from './types';\n","import \"../../utilities/globals\";\n\nimport { Trie } from \"@wry/trie\";\nimport {\n canUseWeakMap,\n canUseWeakSet,\n isNonNullObject as isObjectOrArray,\n} from \"../../utilities\";\nimport { isArray } from \"./helpers\";\n\nfunction shallowCopy(value: T): T {\n if (isObjectOrArray(value)) {\n return isArray(value)\n ? value.slice(0) as any as T\n : { __proto__: Object.getPrototypeOf(value), ...value };\n }\n return value;\n}\n\n// When programmers talk about the \"canonical form\" of an object, they\n// usually have the following meaning in mind, which I've copied from\n// https://en.wiktionary.org/wiki/canonical_form:\n//\n// 1. A standard or normal presentation of a mathematical entity [or\n// object]. A canonical form is an element of a set of representatives\n// of equivalence classes of forms such that there is a function or\n// procedure which projects every element of each equivalence class\n// onto that one element, the canonical form of that equivalence\n// class. The canonical form is expected to be simpler than the rest of\n// the forms in some way.\n//\n// That's a long-winded way of saying any two objects that have the same\n// canonical form may be considered equivalent, even if they are !==,\n// which usually means the objects are structurally equivalent (deeply\n// equal), but don't necessarily use the same memory.\n//\n// Like a literary or musical canon, this ObjectCanon class represents a\n// collection of unique canonical items (JavaScript objects), with the\n// important property that canon.admit(a) === canon.admit(b) if a and b\n// are deeply equal to each other. In terms of the definition above, the\n// canon.admit method is the \"function or procedure which projects every\"\n// object \"onto that one element, the canonical form.\"\n//\n// In the worst case, the canonicalization process may involve looking at\n// every property in the provided object tree, so it takes the same order\n// of time as deep equality checking. Fortunately, already-canonicalized\n// objects are returned immediately from canon.admit, so the presence of\n// canonical subtrees tends to speed up canonicalization.\n//\n// Since consumers of canonical objects can check for deep equality in\n// constant time, canonicalizing cache results can massively improve the\n// performance of application code that skips re-rendering unchanged\n// results, such as \"pure\" UI components in a framework like React.\n//\n// Of course, since canonical objects may be shared widely between\n// unrelated consumers, it's important to think of them as immutable, even\n// though they are not actually frozen with Object.freeze in production,\n// due to the extra performance overhead that comes with frozen objects.\n//\n// Custom scalar objects whose internal class name is neither Array nor\n// Object can be included safely in the admitted tree, but they will not\n// be replaced with a canonical version (to put it another way, they are\n// assumed to be canonical already).\n//\n// If we ignore custom objects, no detection of cycles or repeated object\n// references is currently required by the StoreReader class, since\n// GraphQL result objects are JSON-serializable trees (and thus contain\n// neither cycles nor repeated subtrees), so we can avoid the complexity\n// of keeping track of objects we've already seen during the recursion of\n// the admit method.\n//\n// In the future, we may consider adding additional cases to the switch\n// statement to handle other common object types, such as \"[object Date]\"\n// objects, as needed.\nexport class ObjectCanon {\n // Set of all canonical objects this ObjectCanon has admitted, allowing\n // canon.admit to return previously-canonicalized objects immediately.\n private known = new (canUseWeakSet ? WeakSet : Set)();\n\n // Efficient storage/lookup structure for canonical objects.\n private pool = new Trie<{\n array?: any[];\n object?: Record;\n keys?: SortedKeysInfo;\n }>(canUseWeakMap);\n\n public isKnown(value: any): boolean {\n return isObjectOrArray(value) && this.known.has(value);\n }\n\n // Make the ObjectCanon assume this value has already been\n // canonicalized.\n private passes = new WeakMap();\n public pass(value: T): T;\n public pass(value: any) {\n if (isObjectOrArray(value)) {\n const copy = shallowCopy(value);\n this.passes.set(copy, value);\n return copy;\n }\n return value;\n }\n\n // Returns the canonical version of value.\n public admit(value: T): T;\n public admit(value: any) {\n if (isObjectOrArray(value)) {\n const original = this.passes.get(value);\n if (original) return original;\n\n const proto = Object.getPrototypeOf(value);\n switch (proto) {\n case Array.prototype: {\n if (this.known.has(value)) return value;\n const array: any[] = (value as any[]).map(this.admit, this);\n // Arrays are looked up in the Trie using their recursively\n // canonicalized elements, and the known version of the array is\n // preserved as node.array.\n const node = this.pool.lookupArray(array);\n if (!node.array) {\n this.known.add(node.array = array);\n // Since canonical arrays may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(array);\n }\n }\n return node.array;\n }\n\n case null:\n case Object.prototype: {\n if (this.known.has(value)) return value;\n const proto = Object.getPrototypeOf(value);\n const array = [proto];\n const keys = this.sortedKeys(value);\n array.push(keys.json);\n const firstValueIndex = array.length;\n keys.sorted.forEach(key => {\n array.push(this.admit((value as any)[key]));\n });\n // Objects are looked up in the Trie by their prototype (which\n // is *not* recursively canonicalized), followed by a JSON\n // representation of their (sorted) keys, followed by the\n // sequence of recursively canonicalized values corresponding to\n // those keys. To keep the final results unambiguous with other\n // sequences (such as arrays that just happen to contain [proto,\n // keys.json, value1, value2, ...]), the known version of the\n // object is stored as node.object.\n const node = this.pool.lookupArray(array);\n if (!node.object) {\n const obj = node.object = Object.create(proto);\n this.known.add(obj);\n keys.sorted.forEach((key, i) => {\n obj[key] = array[firstValueIndex + i];\n });\n // Since canonical objects may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(obj);\n }\n }\n return node.object;\n }\n }\n }\n return value;\n }\n\n // It's worthwhile to cache the sorting of arrays of strings, since the\n // same initial unsorted arrays tend to be encountered many times.\n // Fortunately, we can reuse the Trie machinery to look up the sorted\n // arrays in linear time (which is faster than sorting large arrays).\n private sortedKeys(obj: object) {\n const keys = Object.keys(obj);\n const node = this.pool.lookupArray(keys);\n if (!node.keys) {\n keys.sort();\n const json = JSON.stringify(keys);\n if (!(node.keys = this.keysByJSON.get(json))) {\n this.keysByJSON.set(json, node.keys = { sorted: keys, json });\n }\n }\n return node.keys;\n }\n // Arrays that contain the same elements in a different order can share\n // the same SortedKeysInfo object, to save memory.\n private keysByJSON = new Map();\n\n // This has to come last because it depends on keysByJSON.\n public readonly empty = this.admit({});\n}\n\ntype SortedKeysInfo = {\n sorted: string[];\n json: string;\n};\n\n// Since the keys of canonical objects are always created in lexicographically\n// sorted order, we can use the ObjectCanon to implement a fast and stable\n// version of JSON.stringify, which automatically sorts object keys.\nexport const canonicalStringify = Object.assign(function (value: any): string {\n if (isObjectOrArray(value)) {\n if (stringifyCanon === void 0) {\n resetCanonicalStringify();\n }\n const canonical = stringifyCanon.admit(value);\n let json = stringifyCache.get(canonical);\n if (json === void 0) {\n stringifyCache.set(\n canonical,\n json = JSON.stringify(canonical),\n );\n }\n return json;\n }\n return JSON.stringify(value);\n}, {\n reset: resetCanonicalStringify,\n});\n\n// Can be reset by calling canonicalStringify.reset().\nlet stringifyCanon: ObjectCanon;\nlet stringifyCache: WeakMap;\n\nfunction resetCanonicalStringify() {\n stringifyCanon = new ObjectCanon;\n stringifyCache = new (canUseWeakMap ? WeakMap : Map)();\n}\n","import { GraphQLError } from 'graphql';\n\nimport { isNonEmptyArray } from '../utilities';\nimport { ServerParseError } from '../link/http';\nimport { ServerError } from '../link/utils';\n\nexport function isApolloError(err: Error): err is ApolloError {\n return err.hasOwnProperty('graphQLErrors');\n}\n\n// Sets the error message on this error according to the\n// the GraphQL and network errors that are present.\n// If the error message has already been set through the\n// constructor or otherwise, this function is a nop.\nconst generateErrorMessage = (err: ApolloError) => {\n let message = '';\n // If we have GraphQL errors present, add that to the error message.\n if (isNonEmptyArray(err.graphQLErrors)) {\n err.graphQLErrors.forEach((graphQLError: GraphQLError) => {\n const errorMessage = graphQLError\n ? graphQLError.message\n : 'Error message not found.';\n message += `${errorMessage}\\n`;\n });\n }\n\n if (err.networkError) {\n message += `${err.networkError.message}\\n`;\n }\n\n // strip newline from the end of the message\n message = message.replace(/\\n$/, '');\n return message;\n};\n\nexport class ApolloError extends Error {\n public message: string;\n public graphQLErrors: ReadonlyArray;\n public networkError: Error | ServerParseError | ServerError | null;\n\n // An object that can be used to provide some additional information\n // about an error, e.g. specifying the type of error this is. Used\n // internally within Apollo Client.\n public extraInfo: any;\n\n // Constructs an instance of ApolloError given a GraphQLError\n // or a network error. Note that one of these has to be a valid\n // value or the constructed error will be meaningless.\n constructor({\n graphQLErrors,\n networkError,\n errorMessage,\n extraInfo,\n }: {\n graphQLErrors?: ReadonlyArray;\n networkError?: Error | ServerParseError | ServerError | null;\n errorMessage?: string;\n extraInfo?: any;\n }) {\n super(errorMessage);\n this.graphQLErrors = graphQLErrors || [];\n this.networkError = networkError || null;\n this.message = errorMessage || generateErrorMessage(this);\n this.extraInfo = extraInfo;\n\n // We're not using `Object.setPrototypeOf` here as it isn't fully\n // supported on Android (see issue #3236).\n (this as any).__proto__ = ApolloError.prototype;\n }\n}\n","export function maybe(thunk: () => T): T | undefined {\n try { return thunk() } catch {}\n}\n","export { Transaction, ApolloCache } from './core/cache';\nexport { Cache } from './core/types/Cache';\nexport { DataProxy } from './core/types/DataProxy';\nexport { MissingFieldError } from './core/types/common';\n\nexport {\n Reference,\n isReference,\n makeReference,\n} from '../utilities';\n\nexport {\n InMemoryCache,\n InMemoryCacheConfig,\n} from './inmemory/inMemoryCache';\n\nexport {\n ReactiveVar,\n makeVar,\n cacheSlot,\n} from './inmemory/reactiveVars';\n\nexport {\n defaultDataIdFromObject,\n TypePolicies,\n TypePolicy,\n FieldPolicy,\n FieldReadFunction,\n FieldMergeFunction,\n FieldFunctionOptions,\n PossibleTypesMap,\n} from './inmemory/policies';\n\nexport * from './inmemory/types';\n","import { dep, OptimisticDependencyFunction } from \"optimism\";\nimport { Slot } from \"@wry/context\";\nimport { InMemoryCache } from \"./inMemoryCache\";\nimport { ApolloCache } from '../../core';\n\nexport interface ReactiveVar {\n (newValue?: T): T;\n onNextChange(listener: ReactiveListener): () => void;\n attachCache(cache: ApolloCache): this;\n forgetCache(cache: ApolloCache): boolean;\n}\n\nexport type ReactiveListener = (value: T) => any;\n\n// Contextual Slot that acquires its value when custom read functions are\n// called in Policies#readField.\nexport const cacheSlot = new Slot>();\n\nconst cacheInfoMap = new WeakMap, {\n vars: Set>;\n dep: OptimisticDependencyFunction>;\n}>();\n\nfunction getCacheInfo(cache: ApolloCache) {\n let info = cacheInfoMap.get(cache)!;\n if (!info) {\n cacheInfoMap.set(cache, info = {\n vars: new Set,\n dep: dep(),\n });\n }\n return info;\n}\n\nexport function forgetCache(cache: ApolloCache) {\n getCacheInfo(cache).vars.forEach(rv => rv.forgetCache(cache));\n}\n\n// Calling forgetCache(cache) serves to silence broadcasts and allows the\n// cache to be garbage collected. However, the varsByCache WeakMap\n// preserves the set of reactive variables that were previously associated\n// with this cache, which makes it possible to \"recall\" the cache at a\n// later time, by reattaching it to those variables. If the cache has been\n// garbage collected in the meantime, because it is no longer reachable,\n// you won't be able to call recallCache(cache), and the cache will\n// automatically disappear from the varsByCache WeakMap.\nexport function recallCache(cache: ApolloCache) {\n getCacheInfo(cache).vars.forEach(rv => rv.attachCache(cache));\n}\n\nexport function makeVar(value: T): ReactiveVar {\n const caches = new Set>();\n const listeners = new Set>();\n\n const rv: ReactiveVar = function (newValue) {\n if (arguments.length > 0) {\n if (value !== newValue) {\n value = newValue!;\n caches.forEach(cache => {\n // Invalidate any fields with custom read functions that\n // consumed this variable, so query results involving those\n // fields will be recomputed the next time we read them.\n getCacheInfo(cache).dep.dirty(rv);\n // Broadcast changes to any caches that have previously read\n // from this variable.\n broadcast(cache);\n });\n // Finally, notify any listeners added via rv.onNextChange.\n const oldListeners = Array.from(listeners);\n listeners.clear();\n oldListeners.forEach(listener => listener(value));\n }\n } else {\n // When reading from the variable, obtain the current cache from\n // context via cacheSlot. This isn't entirely foolproof, but it's\n // the same system that powers varDep.\n const cache = cacheSlot.getValue();\n if (cache) {\n attach(cache);\n getCacheInfo(cache).dep(rv);\n }\n }\n\n return value;\n };\n\n rv.onNextChange = listener => {\n listeners.add(listener);\n return () => {\n listeners.delete(listener);\n };\n };\n\n const attach = rv.attachCache = cache => {\n caches.add(cache);\n getCacheInfo(cache).vars.add(rv);\n return rv;\n };\n\n rv.forgetCache = cache => caches.delete(cache);\n\n return rv;\n}\n\ntype Broadcastable = ApolloCache & {\n // This method is protected in InMemoryCache, which we are ignoring, but\n // we still want some semblance of type safety when we call it.\n broadcastWatches?: InMemoryCache[\"broadcastWatches\"];\n};\n\nfunction broadcast(cache: Broadcastable) {\n if (cache.broadcastWatches) {\n cache.broadcastWatches();\n }\n}\n","const genericMessage = \"Invariant Violation\";\nconst {\n setPrototypeOf = function (obj: any, proto: any) {\n obj.__proto__ = proto;\n return obj;\n },\n} = Object as any;\n\nexport class InvariantError extends Error {\n framesToPop = 1;\n name = genericMessage;\n constructor(message: string | number = genericMessage) {\n super(\n typeof message === \"number\"\n ? `${genericMessage}: ${message} (see https://github.com/apollographql/invariant-packages)`\n : message\n );\n setPrototypeOf(this, InvariantError.prototype);\n }\n}\n\nexport function invariant(\n condition: any,\n message?: string | number,\n): asserts condition {\n if (!condition) {\n throw new InvariantError(message);\n }\n}\n\nconst verbosityLevels = [\"log\", \"warn\", \"error\", \"silent\"] as const;\ntype VerbosityLevel = (typeof verbosityLevels)[number];\ntype ConsoleMethodName = Exclude;\nlet verbosityLevel = verbosityLevels.indexOf(\"log\");\n\nfunction wrapConsoleMethod(method: M) {\n return function () {\n if (verbosityLevels.indexOf(method) >= verbosityLevel) {\n return console[method].apply(console, arguments as any);\n }\n } as (typeof console)[M];\n}\n\nexport namespace invariant {\n export const log = wrapConsoleMethod(\"log\");\n export const warn = wrapConsoleMethod(\"warn\");\n export const error = wrapConsoleMethod(\"error\");\n}\n\nexport function setVerbosity(level: VerbosityLevel): VerbosityLevel {\n const old = verbosityLevels[verbosityLevel];\n verbosityLevel = Math.max(0, verbosityLevels.indexOf(level));\n return old;\n}\n\n// Code that uses ts-invariant with rollup-plugin-invariant may want to\n// import this process stub to avoid errors evaluating process.env.NODE_ENV.\n// However, because most ESM-to-CJS compilers will rewrite the process import\n// as tsInvariant.process, which prevents proper replacement by minifiers, we\n// also export processStub, so you can import { invariant, processStub } from\n// \"ts-invariant\" and assign processStub to a local variable named process.\nexport const processStub: {\n env: Record;\n [key: string]: any;\n} = (\n typeof process === \"object\" &&\n typeof process.env === \"object\"\n) ? process : { env: {} };\n\nexport { processStub as process };\n\nexport default invariant;\n","import global from \"./global\";\nimport { maybe } from \"./maybe\";\n\n// To keep string-based find/replace minifiers from messing with __DEV__ inside\n// string literals or properties like global.__DEV__, we construct the \"__DEV__\"\n// string in a roundabout way that won't be altered by find/replace strategies.\nconst __ = \"__\";\nconst GLOBAL_KEY = [__, __].join(\"DEV\");\n\nfunction getDEV() {\n try {\n return Boolean(__DEV__);\n } catch {\n Object.defineProperty(global, GLOBAL_KEY, {\n // In a buildless browser environment, maybe(() => process.env.NODE_ENV)\n // evaluates as undefined, so __DEV__ becomes true by default, but can be\n // initialized to false instead by a script/module that runs earlier.\n value: maybe(() => process.env.NODE_ENV) !== \"production\",\n enumerable: false,\n configurable: true,\n writable: true,\n });\n // Using computed property access rather than global.__DEV__ here prevents\n // string-based find/replace strategies from munging this to global.false:\n return (global as any)[GLOBAL_KEY];\n }\n}\n\nexport default getDEV();\n","// The ordering of these imports is important, because it ensures the temporary\n// process.env.NODE_ENV polyfill is defined globally (if necessary) before we\n// import { Source } from 'graphql'. The instanceOf function that we really care\n// about (the one that uses process.env.NODE_ENV) is not exported from the\n// top-level graphql package, but graphql/language/source uses instanceOf, and\n// has relatively few dependencies, so importing it here should not increase\n// bundle sizes as much as other options.\nimport { remove } from 'ts-invariant/process';\nimport { Source } from 'graphql';\n\nexport function removeTemporaryGlobals() {\n // Using Source here here just to make sure it won't be tree-shaken away.\n return typeof Source === \"function\" ? remove() : remove();\n}\n","import { invariant, InvariantError } from \"ts-invariant\";\n\n// Just in case the graphql package switches from process.env.NODE_ENV to\n// __DEV__, make sure __DEV__ is polyfilled before importing graphql.\nimport DEV from \"./DEV\";\nexport { DEV }\nexport function checkDEV() {\n invariant(\"boolean\" === typeof DEV, DEV);\n}\n\n// Import graphql/jsutils/instanceOf safely, working around its unchecked usage\n// of process.env.NODE_ENV and https://github.com/graphql/graphql-js/pull/2894.\nimport { removeTemporaryGlobals } from \"./fix-graphql\";\n\n// Synchronously undo the global process.env.NODE_ENV polyfill that we created\n// temporarily while importing the offending graphql/jsutils/instanceOf module.\nremoveTemporaryGlobals();\n\nexport { maybe } from \"./maybe\";\nexport { default as global } from \"./global\";\nexport { invariant, InvariantError }\n\n// Ensure __DEV__ was properly initialized, and prevent tree-shaking bundlers\n// from mistakenly pruning the ./DEV module (see issue #8674).\ncheckDEV();\n","import { invariant } from '../../utilities/globals';\n\nimport {\n DocumentNode,\n DefinitionNode,\n VariableDefinitionNode,\n OperationDefinitionNode\n} from 'graphql';\n\nexport enum DocumentType {\n Query,\n Mutation,\n Subscription\n}\n\nexport interface IDocumentDefinition {\n type: DocumentType;\n name: string;\n variables: ReadonlyArray;\n}\n\nconst cache = new Map();\n\nexport function operationName(type: DocumentType) {\n let name;\n switch (type) {\n case DocumentType.Query:\n name = 'Query';\n break;\n case DocumentType.Mutation:\n name = 'Mutation';\n break;\n case DocumentType.Subscription:\n name = 'Subscription';\n break;\n }\n return name;\n}\n\n// This parser is mostly used to safety check incoming documents.\nexport function parser(document: DocumentNode): IDocumentDefinition {\n const cached = cache.get(document);\n if (cached) return cached;\n\n let variables, type, name;\n\n invariant(\n !!document && !!document.kind,\n `Argument of ${document} passed to parser was not a valid GraphQL ` +\n `DocumentNode. You may need to use 'graphql-tag' or another method ` +\n `to convert your operation into a document`\n );\n\n const fragments = document.definitions.filter(\n (x: DefinitionNode) => x.kind === 'FragmentDefinition'\n );\n\n const queries = document.definitions.filter(\n (x: DefinitionNode) =>\n x.kind === 'OperationDefinition' && x.operation === 'query'\n );\n\n const mutations = document.definitions.filter(\n (x: DefinitionNode) =>\n x.kind === 'OperationDefinition' && x.operation === 'mutation'\n );\n\n const subscriptions = document.definitions.filter(\n (x: DefinitionNode) =>\n x.kind === 'OperationDefinition' && x.operation === 'subscription'\n );\n\n invariant(\n !fragments.length ||\n (queries.length || mutations.length || subscriptions.length),\n `Passing only a fragment to 'graphql' is not yet supported. ` +\n `You must include a query, subscription or mutation as well`\n );\n\n invariant(\n queries.length + mutations.length + subscriptions.length <= 1,\n `react-apollo only supports a query, subscription, or a mutation per HOC. ` +\n `${document} had ${queries.length} queries, ${subscriptions.length} ` +\n `subscriptions and ${mutations.length} mutations. ` +\n `You can use 'compose' to join multiple operation types to a component`\n );\n\n type = queries.length ? DocumentType.Query : DocumentType.Mutation;\n if (!queries.length && !mutations.length) type = DocumentType.Subscription;\n\n const definitions = queries.length\n ? queries\n : mutations.length\n ? mutations\n : subscriptions;\n\n invariant(\n definitions.length === 1,\n `react-apollo only supports one definition per HOC. ${document} had ` +\n `${definitions.length} definitions. ` +\n `You can use 'compose' to join multiple operation types to a component`\n );\n\n const definition = definitions[0] as OperationDefinitionNode;\n variables = definition.variableDefinitions || [];\n\n if (definition.name && definition.name.kind === 'Name') {\n name = definition.name.value;\n } else {\n name = 'data'; // fallback to using data if no name\n }\n\n const payload = { name, type, variables };\n cache.set(document, payload);\n return payload;\n}\n\nexport function verifyDocumentType(document: DocumentNode, type: DocumentType) {\n const operation = parser(document);\n const requiredOperationName = operationName(type);\n const usedOperationName = operationName(operation.type);\n invariant(\n operation.type === type,\n `Running a ${requiredOperationName} requires a graphql ` +\n `${requiredOperationName}, but a ${usedOperationName} was used instead.`\n );\n}\n\n","import { invariant } from '../../utilities/globals';\nimport { useContext } from 'react';\nimport { ApolloClient } from '../../core';\nimport { getApolloContext } from '../context';\n\nexport function useApolloClient(\n override?: ApolloClient,\n): ApolloClient {\n const context = useContext(getApolloContext());\n const client = override || context.client;\n invariant(\n !!client,\n 'Could not find \"client\" in the context or passed in as an option. ' +\n 'Wrap the root component in an , or pass an ApolloClient ' +\n 'instance in via options.',\n );\n\n return client;\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { Operation } from '../core';\nimport { throwServerError } from '../utils';\n\nconst { hasOwnProperty } = Object.prototype;\n\nexport type ServerParseError = Error & {\n response: Response;\n statusCode: number;\n bodyText: string;\n};\n\nexport function parseAndCheckHttpResponse(\n operations: Operation | Operation[],\n) {\n return (response: Response) => response\n .text()\n .then(bodyText => {\n try {\n return JSON.parse(bodyText);\n } catch (err) {\n const parseError = err as ServerParseError;\n parseError.name = 'ServerParseError';\n parseError.response = response;\n parseError.statusCode = response.status;\n parseError.bodyText = bodyText;\n throw parseError;\n }\n })\n .then((result: any) => {\n if (response.status >= 300) {\n // Network error\n throwServerError(\n response,\n result,\n `Response not successful: Received status code ${response.status}`,\n );\n }\n\n if (\n !Array.isArray(result) &&\n !hasOwnProperty.call(result, 'data') &&\n !hasOwnProperty.call(result, 'errors')\n ) {\n // Data error\n throwServerError(\n response,\n result,\n `Server response was missing for query '${\n Array.isArray(operations)\n ? operations.map(op => op.operationName)\n : operations.operationName\n }'.`,\n );\n }\n return result;\n });\n}\n","import { InvariantError } from '../../utilities/globals';\n\nexport type ClientParseError = InvariantError & {\n parseError: Error;\n};\n\nexport const serializeFetchParameter = (p: any, label: string) => {\n let serialized;\n try {\n serialized = JSON.stringify(p);\n } catch (e) {\n const parseError = new InvariantError(\n `Network request failed. ${label} is not serializable: ${e.message}`,\n ) as ClientParseError;\n parseError.parseError = e;\n throw parseError;\n }\n return serialized;\n};\n","import { ASTNode, print } from 'graphql';\n\nimport { Operation } from '../core';\n\nexport interface Printer {\n (node: ASTNode, originalPrint: typeof print): string\n};\n\nexport interface UriFunction {\n (operation: Operation): string;\n}\n\nexport interface Body {\n query?: string;\n operationName?: string;\n variables?: Record;\n extensions?: Record;\n}\n\nexport interface HttpOptions {\n /**\n * The URI to use when fetching operations.\n *\n * Defaults to '/graphql'.\n */\n uri?: string | UriFunction;\n\n /**\n * Passes the extensions field to your graphql server.\n *\n * Defaults to false.\n */\n includeExtensions?: boolean;\n\n /**\n * A `fetch`-compatible API to use when making requests.\n */\n fetch?: WindowOrWorkerGlobalScope['fetch'];\n\n /**\n * An object representing values to be sent as headers on the request.\n */\n headers?: any;\n\n /**\n * The credentials policy you want to use for the fetch call.\n */\n credentials?: string;\n\n /**\n * Any overrides of the fetch options argument to pass to the fetch call.\n */\n fetchOptions?: any;\n\n /**\n * If set to true, use the HTTP GET method for query operations. Mutations\n * will still use the method specified in fetchOptions.method (which defaults\n * to POST).\n */\n useGETForQueries?: boolean;\n\n /**\n * If set to true, the default behavior of stripping unused variables\n * from the request will be disabled.\n *\n * Unused variables are likely to trigger server-side validation errors,\n * per https://spec.graphql.org/draft/#sec-All-Variables-Used, but this\n * includeUnusedVariables option can be useful if your server deviates\n * from the GraphQL specification by not strictly enforcing that rule.\n */\n includeUnusedVariables?: boolean;\n /**\n * A function to substitute for the default query print function. Can be\n * used to apply changes to the results of the print function.\n */\n print?: Printer;\n}\n\nexport interface HttpQueryOptions {\n includeQuery?: boolean;\n includeExtensions?: boolean;\n}\n\nexport interface HttpConfig {\n http?: HttpQueryOptions;\n options?: any;\n headers?: any;\n credentials?: any;\n}\n\nconst defaultHttpOptions: HttpQueryOptions = {\n includeQuery: true,\n includeExtensions: false,\n};\n\nconst defaultHeaders = {\n // headers are case insensitive (https://stackoverflow.com/a/5259004)\n accept: '*/*',\n 'content-type': 'application/json',\n};\n\nconst defaultOptions = {\n method: 'POST',\n};\n\nexport const fallbackHttpConfig = {\n http: defaultHttpOptions,\n headers: defaultHeaders,\n options: defaultOptions,\n};\n\nexport const defaultPrinter: Printer = (ast, printer) => printer(ast);\n\nexport function selectHttpOptionsAndBody(\n operation: Operation,\n fallbackConfig: HttpConfig,\n ...configs: Array\n) {\n configs.unshift(fallbackConfig);\n return selectHttpOptionsAndBodyInternal(\n operation,\n defaultPrinter,\n ...configs,\n );\n}\n\nexport function selectHttpOptionsAndBodyInternal(\n operation: Operation,\n printer: Printer,\n ...configs: HttpConfig[]\n) {\n let options = {} as HttpConfig & Record;\n let http = {} as HttpQueryOptions;\n\n configs.forEach(config => {\n options = {\n ...options,\n ...config.options,\n headers: {\n ...options.headers,\n ...headersToLowerCase(config.headers),\n },\n };\n\n if (config.credentials) {\n options.credentials = config.credentials;\n }\n\n http = {\n ...http,\n ...config.http,\n };\n });\n\n //The body depends on the http options\n const { operationName, extensions, variables, query } = operation;\n const body: Body = { operationName, variables };\n\n if (http.includeExtensions) (body as any).extensions = extensions;\n\n // not sending the query (i.e persisted queries)\n if (http.includeQuery) (body as any).query = printer(query, print);\n\n return {\n options,\n body,\n };\n};\n\nfunction headersToLowerCase(\n headers: Record | undefined\n): typeof headers {\n if (headers) {\n const normalized = Object.create(null);\n Object.keys(Object(headers)).forEach(name => {\n normalized[name.toLowerCase()] = headers[name];\n });\n return normalized;\n }\n return headers;\n}\n","import { InvariantError } from '../../utilities/globals';\n\nexport const checkFetcher = (fetcher: WindowOrWorkerGlobalScope['fetch'] | undefined) => {\n if (!fetcher && typeof fetch === 'undefined') {\n throw new InvariantError(`\n\"fetch\" has not been found globally and no fetcher has been \\\nconfigured. To fix this, install a fetch package (like \\\nhttps://www.npmjs.com/package/cross-fetch), instantiate the \\\nfetcher, and pass it into your HttpLink constructor. For example:\n\nimport fetch from 'cross-fetch';\nimport { ApolloClient, HttpLink } from '@apollo/client';\nconst client = new ApolloClient({\n link: new HttpLink({ uri: '/graphql', fetch })\n});\n `);\n }\n};\n","export const createSignalIfSupported = () => {\n if (typeof AbortController === 'undefined')\n return { controller: false, signal: false };\n\n const controller = new AbortController();\n const signal = controller.signal;\n return { controller, signal };\n};\n","import { Operation } from '../core';\n\nexport const selectURI = (\n operation: Operation,\n fallbackURI?: string | ((operation: Operation) => string),\n) => {\n const context = operation.getContext();\n const contextURI = context.uri;\n\n if (contextURI) {\n return contextURI;\n } else if (typeof fallbackURI === 'function') {\n return fallbackURI(operation);\n } else {\n return (fallbackURI as string) || '/graphql';\n }\n};\n","import { serializeFetchParameter } from './serializeFetchParameter';\nimport { Body } from './selectHttpOptionsAndBody';\n\n// For GET operations, returns the given URI rewritten with parameters, or a\n// parse error.\nexport function rewriteURIForGET(chosenURI: string, body: Body) {\n // Implement the standard HTTP GET serialization, plus 'extensions'. Note\n // the extra level of JSON serialization!\n const queryParams: string[] = [];\n const addQueryParam = (key: string, value: string) => {\n queryParams.push(`${key}=${encodeURIComponent(value)}`);\n };\n\n if ('query' in body) {\n addQueryParam('query', body.query!);\n }\n if (body.operationName) {\n addQueryParam('operationName', body.operationName);\n }\n if (body.variables) {\n let serializedVariables;\n try {\n serializedVariables = serializeFetchParameter(\n body.variables,\n 'Variables map',\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam('variables', serializedVariables);\n }\n if (body.extensions) {\n let serializedExtensions;\n try {\n serializedExtensions = serializeFetchParameter(\n body.extensions,\n 'Extensions map',\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam('extensions', serializedExtensions);\n }\n\n // Reconstruct the URI with added query params.\n // XXX This assumes that the URI is well-formed and that it doesn't\n // already contain any of these query params. We could instead use the\n // URL API and take a polyfill (whatwg-url@6) for older browsers that\n // don't support URLSearchParams. Note that some browsers (and\n // versions of whatwg-url) support URL but not URLSearchParams!\n let fragment = '',\n preFragment = chosenURI;\n const fragmentStart = chosenURI.indexOf('#');\n if (fragmentStart !== -1) {\n fragment = chosenURI.substr(fragmentStart);\n preFragment = chosenURI.substr(0, fragmentStart);\n }\n const queryParamsPrefix = preFragment.indexOf('?') === -1 ? '?' : '&';\n const newURI =\n preFragment + queryParamsPrefix + queryParams.join('&') + fragment;\n return { newURI };\n}\n","import '../../utilities/globals';\n\nimport { visit, DefinitionNode, VariableDefinitionNode } from 'graphql';\n\nimport { ApolloLink } from '../core';\nimport { Observable } from '../../utilities';\nimport { serializeFetchParameter } from './serializeFetchParameter';\nimport { selectURI } from './selectURI';\nimport { parseAndCheckHttpResponse } from './parseAndCheckHttpResponse';\nimport { checkFetcher } from './checkFetcher';\nimport {\n selectHttpOptionsAndBodyInternal,\n defaultPrinter,\n fallbackHttpConfig,\n HttpOptions\n} from './selectHttpOptionsAndBody';\nimport { createSignalIfSupported } from './createSignalIfSupported';\nimport { rewriteURIForGET } from './rewriteURIForGET';\nimport { fromError } from '../utils';\nimport { maybe } from '../../utilities';\n\nconst backupFetch = maybe(() => fetch);\n\nexport const createHttpLink = (linkOptions: HttpOptions = {}) => {\n let {\n uri = '/graphql',\n // use default global fetch if nothing passed in\n fetch: preferredFetch,\n print = defaultPrinter,\n includeExtensions,\n useGETForQueries,\n includeUnusedVariables = false,\n ...requestOptions\n } = linkOptions;\n\n if (__DEV__) {\n // Make sure at least one of preferredFetch, window.fetch, or backupFetch is\n // defined, so requests won't fail at runtime.\n checkFetcher(preferredFetch || backupFetch);\n }\n\n const linkConfig = {\n http: { includeExtensions },\n options: requestOptions.fetchOptions,\n credentials: requestOptions.credentials,\n headers: requestOptions.headers,\n };\n\n return new ApolloLink(operation => {\n let chosenURI = selectURI(operation, uri);\n\n const context = operation.getContext();\n\n // `apollographql-client-*` headers are automatically set if a\n // `clientAwareness` object is found in the context. These headers are\n // set first, followed by the rest of the headers pulled from\n // `context.headers`. If desired, `apollographql-client-*` headers set by\n // the `clientAwareness` object can be overridden by\n // `apollographql-client-*` headers set in `context.headers`.\n const clientAwarenessHeaders: {\n 'apollographql-client-name'?: string;\n 'apollographql-client-version'?: string;\n } = {};\n\n if (context.clientAwareness) {\n const { name, version } = context.clientAwareness;\n if (name) {\n clientAwarenessHeaders['apollographql-client-name'] = name;\n }\n if (version) {\n clientAwarenessHeaders['apollographql-client-version'] = version;\n }\n }\n\n const contextHeaders = { ...clientAwarenessHeaders, ...context.headers };\n\n const contextConfig = {\n http: context.http,\n options: context.fetchOptions,\n credentials: context.credentials,\n headers: contextHeaders,\n };\n\n //uses fallback, link, and then context to build options\n const { options, body } = selectHttpOptionsAndBodyInternal(\n operation,\n print,\n fallbackHttpConfig,\n linkConfig,\n contextConfig,\n );\n\n if (body.variables && !includeUnusedVariables) {\n const unusedNames = new Set(Object.keys(body.variables));\n visit(operation.query, {\n Variable(node, _key, parent) {\n // A variable type definition at the top level of a query is not\n // enough to silence server-side errors about the variable being\n // unused, so variable definitions do not count as usage.\n // https://spec.graphql.org/draft/#sec-All-Variables-Used\n if (parent && (parent as VariableDefinitionNode).kind !== 'VariableDefinition') {\n unusedNames.delete(node.name.value);\n }\n },\n });\n if (unusedNames.size) {\n // Make a shallow copy of body.variables (with keys in the same\n // order) and then delete unused variables from the copy.\n body.variables = { ...body.variables };\n unusedNames.forEach(name => {\n delete body.variables![name];\n });\n }\n }\n\n let controller: any;\n if (!(options as any).signal) {\n const { controller: _controller, signal } = createSignalIfSupported();\n controller = _controller;\n if (controller) (options as any).signal = signal;\n }\n\n // If requested, set method to GET if there are no mutations.\n const definitionIsMutation = (d: DefinitionNode) => {\n return d.kind === 'OperationDefinition' && d.operation === 'mutation';\n };\n if (\n useGETForQueries &&\n !operation.query.definitions.some(definitionIsMutation)\n ) {\n options.method = 'GET';\n }\n\n if (options.method === 'GET') {\n const { newURI, parseError } = rewriteURIForGET(chosenURI, body);\n if (parseError) {\n return fromError(parseError);\n }\n chosenURI = newURI;\n } else {\n try {\n (options as any).body = serializeFetchParameter(body, 'Payload');\n } catch (parseError) {\n return fromError(parseError);\n }\n }\n\n return new Observable(observer => {\n // Prefer linkOptions.fetch (preferredFetch) if provided, and otherwise\n // fall back to the *current* global window.fetch function (see issue\n // #7832), or (if all else fails) the backupFetch function we saved when\n // this module was first evaluated. This last option protects against the\n // removal of window.fetch, which is unlikely but not impossible.\n const currentFetch = preferredFetch || maybe(() => fetch) || backupFetch;\n\n currentFetch!(chosenURI, options)\n .then(response => {\n operation.setContext({ response });\n return response;\n })\n .then(parseAndCheckHttpResponse(operation))\n .then(result => {\n // we have data and can send it to back up the link chain\n observer.next(result);\n observer.complete();\n return result;\n })\n .catch(err => {\n // fetch was cancelled so it's already been cleaned up in the unsubscribe\n if (err.name === 'AbortError') return;\n // if it is a network error, BUT there is graphql result info\n // fire the next observer before calling error\n // this gives apollo-client (and react-apollo) the `graphqlErrors` and `networErrors`\n // to pass to UI\n // this should only happen if we *also* have data as part of the response key per\n // the spec\n if (err.result && err.result.errors && err.result.data) {\n // if we don't call next, the UI can only show networkError because AC didn't\n // get any graphqlErrors\n // this is graphql execution result info (i.e errors and possibly data)\n // this is because there is no formal spec how errors should translate to\n // http status codes. So an auth error (401) could have both data\n // from a public field, errors from a private field, and a status of 401\n // {\n // user { // this will have errors\n // firstName\n // }\n // products { // this is public so will have data\n // cost\n // }\n // }\n //\n // the result of above *could* look like this:\n // {\n // data: { products: [{ cost: \"$10\" }] },\n // errors: [{\n // message: 'your session has timed out',\n // path: []\n // }]\n // }\n // status code of above would be a 401\n // in the UI you want to show data where you can, errors as data where you can\n // and use correct http status codes\n observer.next(err.result);\n }\n observer.error(err);\n });\n\n return () => {\n // XXX support canceling this request\n // https://developers.google.com/web/updates/2017/09/abortable-fetch\n if (controller) controller.abort();\n };\n });\n });\n};\n","import { ApolloLink, RequestHandler } from '../core';\nimport { HttpOptions } from './selectHttpOptionsAndBody';\nimport { createHttpLink } from './createHttpLink';\n\nexport class HttpLink extends ApolloLink {\n public requester: RequestHandler;\n constructor(public options: HttpOptions = {}) {\n super(createHttpLink(options).request);\n }\n}\n","import { maybe } from \"./maybe\";\n\ndeclare global {\n // Despite our attempts to reuse the React Native __DEV__ constant instead of\n // inventing something new and Apollo-specific, declaring a useful type for\n // __DEV__ unfortunately conflicts (TS2451) with the global declaration in\n // @types/react-native/index.d.ts.\n //\n // To hide that harmless conflict, we @ts-ignore this line, which should\n // continue to provide a type for __DEV__ elsewhere in the Apollo Client\n // codebase, even when @types/react-native is not in use.\n //\n // However, because TypeScript drops @ts-ignore comments when generating .d.ts\n // files (https://github.com/microsoft/TypeScript/issues/38628), we also\n // sanitize the dist/utilities/globals/global.d.ts file to avoid declaring\n // __DEV__ globally altogether when @apollo/client is installed in the\n // node_modules directory of an application.\n //\n // @ts-ignore\n const __DEV__: boolean | undefined;\n}\n\nexport default (\n maybe(() => globalThis) ||\n maybe(() => window) ||\n maybe(() => self) ||\n maybe(() => global) ||\n // We don't expect the Function constructor ever to be invoked at runtime, as\n // long as at least one of globalThis, window, self, or global is defined, so\n // we are under no obligation to make it easy for static analysis tools to\n // detect syntactic usage of the Function constructor. If you think you can\n // improve your static analysis to detect this obfuscation, think again. This\n // is an arms race you cannot win, at least not in JavaScript.\n maybe(function() { return maybe.constructor(\"return this\")() })\n) as typeof globalThis & {\n __DEV__: typeof __DEV__;\n};\n","// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\nvar nodejsCustomInspectSymbol = typeof Symbol === 'function' && typeof Symbol.for === 'function' ? Symbol.for('nodejs.util.inspect.custom') : undefined;\nexport default nodejsCustomInspectSymbol;\n","import { SelectionSetNode } from 'graphql';\n\nimport { NormalizedCache } from './types';\nimport {\n Reference,\n isReference,\n StoreValue,\n StoreObject,\n isField,\n DeepMerger,\n resultKeyNameFromField,\n shouldInclude,\n} from '../../utilities';\n\nexport const hasOwn = Object.prototype.hasOwnProperty;\n\nexport function getTypenameFromStoreObject(\n store: NormalizedCache,\n objectOrReference: StoreObject | Reference,\n): string | undefined {\n return isReference(objectOrReference)\n ? store.get(objectOrReference.__ref, \"__typename\") as string\n : objectOrReference && objectOrReference.__typename;\n}\n\nexport const TypeOrFieldNameRegExp = /^[_a-z][_0-9a-z]*/i;\n\nexport function fieldNameFromStoreName(storeFieldName: string): string {\n const match = storeFieldName.match(TypeOrFieldNameRegExp);\n return match ? match[0] : storeFieldName;\n}\n\nexport function selectionSetMatchesResult(\n selectionSet: SelectionSetNode,\n result: Record,\n variables?: Record,\n): boolean {\n if (result && typeof result === \"object\") {\n return Array.isArray(result)\n ? result.every(item => selectionSetMatchesResult(selectionSet, item, variables))\n : selectionSet.selections.every(field => {\n if (isField(field) && shouldInclude(field, variables)) {\n const key = resultKeyNameFromField(field);\n return hasOwn.call(result, key) &&\n (!field.selectionSet ||\n selectionSetMatchesResult(field.selectionSet, result[key], variables));\n }\n // If the selection has been skipped with @skip(true) or\n // @include(false), it should not count against the matching. If\n // the selection is not a field, it must be a fragment (inline or\n // named). We will determine if selectionSetMatchesResult for that\n // fragment when we get to it, so for now we return true.\n return true;\n });\n }\n return false;\n}\n\nexport function storeValueIsStoreObject(\n value: StoreValue,\n): value is StoreObject {\n return value !== null &&\n typeof value === \"object\" &&\n !isReference(value) &&\n !Array.isArray(value);\n}\n\nexport function makeProcessedFieldsMerger() {\n return new DeepMerger;\n}\n","import { WatchQueryOptions } from './watchQueryOptions';\nimport { NetworkStatus } from './networkStatus';\nimport { ApolloQueryResult } from './types';\nimport { Observer, Concast, compact } from '../utilities';\nimport { invariant } from 'ts-invariant';\n\n// Given that QueryManager#fetchQueryObservable returns only a single\n// query's worth of results, other code must be responsible for repeatedly\n// calling fetchQueryObservable, while ensuring that the ObservableQuery\n// consuming those results remains subscribed to the concatenation of all\n// the observables returned by fetchQueryObservable. That responsibility\n// falls to this Reobserver class. As a bonus, the Reobserver class is\n// perfectly poised to handle polling logic, since polling is essentially\n// repeated reobservation. In principle, this code could have remained in\n// the ObservableQuery class, but I felt it would be easier to explain and\n// understand reobservation if it was confined to a separate class.\nexport class Reobserver {\n constructor(\n private observer: Observer>,\n private options: WatchQueryOptions,\n // Almost certainly just a wrapper function around\n // QueryManager#fetchQueryObservable, but this small dose of\n // indirection means the Reobserver doesn't have to know/assume\n // anything about the QueryManager class.\n private fetch: (\n options: WatchQueryOptions,\n newNetworkStatus?: NetworkStatus,\n ) => Concast>,\n // If we're polling, there may be times when we should avoid fetching,\n // such as when the query is already in flight, or polling has been\n // completely disabled for server-side rendering. Passing false for\n // this parameter disables polling completely, and passing a boolean\n // function allows determining fetch safety dynamically.\n private shouldFetch: false | (() => boolean),\n ) {}\n\n private concast?: Concast>;\n\n public reobserve(\n newOptions?: Partial>,\n newNetworkStatus?: NetworkStatus,\n ): Promise> {\n if (newOptions) {\n this.updateOptions(newOptions);\n } else {\n // When we call this.updateOptions(newOptions) in the branch above,\n // it takes care of calling this.updatePolling(). In this branch, we\n // still need to update polling, even if there were no newOptions.\n this.updatePolling();\n }\n\n const concast = this.fetch(this.options, newNetworkStatus);\n\n if (this.concast) {\n // We use the {add,remove}Observer methods directly to avoid\n // wrapping observer with an unnecessary SubscriptionObserver\n // object, in part so that we can remove it here without triggering\n // any unsubscriptions, because we just want to ignore the old\n // observable, not prematurely shut it down, since other consumers\n // may be awaiting this.concast.promise.\n this.concast.removeObserver(this.observer, true);\n }\n\n concast.addObserver(this.observer);\n\n return (this.concast = concast).promise;\n }\n\n public updateOptions(newOptions: Partial>) {\n Object.assign(this.options, compact(newOptions));\n this.updatePolling();\n return this;\n }\n\n public stop() {\n if (this.concast) {\n this.concast.removeObserver(this.observer);\n delete this.concast;\n }\n\n if (this.pollingInfo) {\n clearTimeout(this.pollingInfo.timeout);\n this.options.pollInterval = 0;\n this.updatePolling();\n }\n }\n\n private pollingInfo?: {\n interval: number;\n timeout: ReturnType;\n };\n\n // Turns polling on or off based on this.options.pollInterval.\n private updatePolling() {\n const {\n pollingInfo,\n options: {\n pollInterval,\n },\n } = this;\n\n if (!pollInterval) {\n if (pollingInfo) {\n clearTimeout(pollingInfo.timeout);\n delete this.pollingInfo;\n }\n return;\n }\n\n if (pollingInfo &&\n pollingInfo.interval === pollInterval) {\n return;\n }\n\n invariant(\n pollInterval,\n 'Attempted to start a polling query without a polling interval.',\n );\n\n // Go no further if polling is disabled.\n if (this.shouldFetch === false) {\n return;\n }\n\n const info = pollingInfo || (\n this.pollingInfo = {} as Reobserver[\"pollingInfo\"]\n )!;\n\n info.interval = pollInterval;\n\n const maybeFetch = () => {\n if (this.pollingInfo) {\n if (this.shouldFetch && this.shouldFetch()) {\n this.reobserve({\n fetchPolicy: \"network-only\",\n nextFetchPolicy: this.options.fetchPolicy || \"cache-first\",\n }, NetworkStatus.poll).then(poll, poll);\n } else {\n poll();\n }\n };\n };\n\n const poll = () => {\n const info = this.pollingInfo;\n if (info) {\n clearTimeout(info.timeout);\n info.timeout = setTimeout(maybeFetch, info.interval);\n }\n };\n\n poll();\n }\n}\n","import { invariant } from '../utilities/globals';\n\nimport { equal } from '@wry/equality';\n\nimport { NetworkStatus, isNetworkRequestInFlight } from './networkStatus';\nimport {\n Concast,\n compact,\n cloneDeep,\n getOperationDefinition,\n Observable,\n Observer,\n ObservableSubscription,\n iterateObserversSafely,\n isNonEmptyArray,\n fixObservableSubclass,\n getQueryDefinition,\n} from '../utilities';\nimport { ApolloError } from '../errors';\nimport { QueryManager } from './QueryManager';\nimport { ApolloQueryResult, OperationVariables } from './types';\nimport {\n WatchQueryOptions,\n FetchMoreQueryOptions,\n SubscribeToMoreOptions,\n WatchQueryFetchPolicy,\n} from './watchQueryOptions';\nimport { QueryInfo } from './QueryInfo';\nimport { MissingFieldError } from '../cache';\nimport { MissingTree } from '../cache/core/types/common';\n\nconst {\n assign,\n hasOwnProperty,\n} = Object;\n\nexport interface FetchMoreOptions<\n TData = any,\n TVariables = OperationVariables\n> {\n updateQuery?: (\n previousQueryResult: TData,\n options: {\n fetchMoreResult?: TData;\n variables?: TVariables;\n },\n ) => TData;\n}\n\nexport interface UpdateQueryOptions {\n variables?: TVariables;\n}\n\nlet warnedAboutUpdateQuery = false;\n\ninterface Last {\n result: ApolloQueryResult;\n variables?: TVariables;\n error?: ApolloError;\n}\n\nexport class ObservableQuery<\n TData = any,\n TVariables = OperationVariables\n> extends Observable> {\n public readonly options: WatchQueryOptions;\n public readonly queryId: string;\n public readonly queryName?: string;\n\n // Computed shorthand for this.options.variables, preserved for\n // backwards compatibility.\n public get variables(): TVariables | undefined {\n return this.options.variables;\n }\n\n // Original value of this.options.fetchPolicy (defaulting to \"cache-first\"),\n // from whenever the ObservableQuery was first created.\n private initialFetchPolicy: WatchQueryFetchPolicy;\n\n private isTornDown: boolean;\n private queryManager: QueryManager;\n private observers = new Set>>();\n private subscriptions = new Set();\n\n private last?: Last;\n\n private queryInfo: QueryInfo;\n\n // When this.concast is defined, this.observer is the Observer currently\n // subscribed to that Concast.\n private concast?: Concast>;\n private observer?: Observer>;\n\n private pollingInfo?: {\n interval: number;\n timeout: ReturnType;\n };\n\n constructor({\n queryManager,\n queryInfo,\n options,\n }: {\n queryManager: QueryManager;\n queryInfo: QueryInfo;\n options: WatchQueryOptions;\n }) {\n super((observer: Observer>) => {\n // Zen Observable has its own error function, so in order to log correctly\n // we need to provide a custom error callback.\n try {\n var subObserver = (observer as any)._subscription._observer;\n if (subObserver && !subObserver.error) {\n subObserver.error = defaultSubscriptionObserverErrorCallback;\n }\n } catch {}\n\n const first = !this.observers.size;\n this.observers.add(observer);\n\n // Deliver most recent error or result.\n const last = this.last;\n if (last && last.error) {\n observer.error && observer.error(last.error);\n } else if (last && last.result) {\n observer.next && observer.next(last.result);\n }\n\n // Initiate observation of this query if it hasn't been reported to\n // the QueryManager yet.\n if (first) {\n // Blindly catching here prevents unhandled promise rejections,\n // and is safe because the ObservableQuery handles this error with\n // this.observer.error, so we're not just swallowing the error by\n // ignoring it here.\n this.reobserve().catch(() => {});\n }\n\n return () => {\n if (this.observers.delete(observer) && !this.observers.size) {\n this.tearDownQuery();\n }\n };\n });\n\n // active state\n this.isTornDown = false;\n\n // query information\n this.options = options;\n this.queryId = queryInfo.queryId || queryManager.generateQueryId();\n\n const opDef = getOperationDefinition(options.query);\n this.queryName = opDef && opDef.name && opDef.name.value;\n\n this.initialFetchPolicy = options.fetchPolicy || \"cache-first\";\n\n // related classes\n this.queryManager = queryManager;\n this.queryInfo = queryInfo;\n }\n\n public result(): Promise> {\n return new Promise((resolve, reject) => {\n // TODO: this code doesn’t actually make sense insofar as the observer\n // will never exist in this.observers due how zen-observable wraps observables.\n // https://github.com/zenparsing/zen-observable/blob/master/src/Observable.js#L169\n const observer: Observer> = {\n next: (result: ApolloQueryResult) => {\n resolve(result);\n\n // Stop the query within the QueryManager if we can before\n // this function returns.\n //\n // We do this in order to prevent observers piling up within\n // the QueryManager. Notice that we only fully unsubscribe\n // from the subscription in a setTimeout(..., 0) call. This call can\n // actually be handled by the browser at a much later time. If queries\n // are fired in the meantime, observers that should have been removed\n // from the QueryManager will continue to fire, causing an unnecessary\n // performance hit.\n this.observers.delete(observer);\n if (!this.observers.size) {\n this.queryManager.removeQuery(this.queryId);\n }\n\n setTimeout(() => {\n subscription.unsubscribe();\n }, 0);\n },\n error: reject,\n };\n const subscription = this.subscribe(observer);\n });\n }\n\n public getCurrentResult(saveAsLastResult = true): ApolloQueryResult {\n // Use the last result as long as the variables match this.variables.\n const lastResult = this.getLastResult(true);\n\n const networkStatus =\n this.queryInfo.networkStatus ||\n (lastResult && lastResult.networkStatus) ||\n NetworkStatus.ready;\n\n const result = {\n ...lastResult,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n } as ApolloQueryResult;\n\n const { fetchPolicy = \"cache-first\" } = this.options;\n if (\n // These fetch policies should never deliver data from the cache, unless\n // redelivering a previously delivered result.\n fetchPolicy === 'network-only' ||\n fetchPolicy === 'no-cache' ||\n fetchPolicy === 'standby' ||\n // If this.options.query has @client(always: true) fields, we cannot\n // trust diff.result, since it was read from the cache without running\n // local resolvers (and it's too late to run resolvers now, since we must\n // return a result synchronously).\n this.queryManager.transform(this.options.query).hasForcedResolvers\n ) {\n // Fall through.\n } else {\n const diff = this.queryInfo.getDiff();\n\n if (diff.complete || this.options.returnPartialData) {\n result.data = diff.result;\n }\n\n if (equal(result.data, {})) {\n result.data = void 0 as any;\n }\n\n if (diff.complete) {\n // Similar to setting result.partial to false, but taking advantage of the\n // falsiness of missing fields.\n delete result.partial;\n\n // If the diff is complete, and we're using a FetchPolicy that\n // terminates after a complete cache read, we can assume the next result\n // we receive will have NetworkStatus.ready and !loading.\n if (\n diff.complete &&\n result.networkStatus === NetworkStatus.loading &&\n (fetchPolicy === 'cache-first' ||\n fetchPolicy === 'cache-only')\n ) {\n result.networkStatus = NetworkStatus.ready;\n result.loading = false;\n }\n } else {\n result.partial = true;\n }\n\n if (\n __DEV__ &&\n !diff.complete &&\n !this.options.partialRefetch &&\n !result.loading &&\n !result.data &&\n !result.error\n ) {\n logMissingFieldErrors(diff.missing);\n }\n }\n\n if (saveAsLastResult) {\n this.updateLastResult(result);\n }\n\n return result;\n }\n\n // Compares newResult to the snapshot we took of this.lastResult when it was\n // first received.\n public isDifferentFromLastResult(newResult: ApolloQueryResult) {\n return !this.last || !equal(this.last.result, newResult);\n }\n\n private getLast>(\n key: K,\n variablesMustMatch?: boolean,\n ) {\n const last = this.last;\n if (\n last &&\n last[key] &&\n (!variablesMustMatch || equal(last.variables, this.variables))\n ) {\n return last[key];\n }\n }\n\n public getLastResult(variablesMustMatch?: boolean): ApolloQueryResult | undefined {\n return this.getLast(\"result\", variablesMustMatch);\n }\n\n public getLastError(variablesMustMatch?: boolean): ApolloError | undefined {\n return this.getLast(\"error\", variablesMustMatch);\n }\n\n public resetLastResults(): void {\n delete this.last;\n this.isTornDown = false;\n }\n\n public resetQueryStoreErrors() {\n this.queryManager.resetErrors(this.queryId);\n }\n\n /**\n * Update the variables of this observable query, and fetch the new results.\n * This method should be preferred over `setVariables` in most use cases.\n *\n * @param variables: The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public refetch(variables?: Partial): Promise> {\n const reobserveOptions: Partial> = {\n // Always disable polling for refetches.\n pollInterval: 0,\n };\n\n // Unless the provided fetchPolicy always consults the network\n // (no-cache, network-only, or cache-and-network), override it with\n // network-only to force the refetch for this fetchQuery call.\n const { fetchPolicy } = this.options;\n if (fetchPolicy === 'cache-and-network') {\n reobserveOptions.fetchPolicy = fetchPolicy;\n } else if (fetchPolicy === 'no-cache') {\n reobserveOptions.fetchPolicy = 'no-cache';\n } else {\n reobserveOptions.fetchPolicy = 'network-only';\n }\n\n if (__DEV__ && variables && hasOwnProperty.call(variables, \"variables\")) {\n const queryDef = getQueryDefinition(this.options.query);\n const vars = queryDef.variableDefinitions;\n if (!vars || !vars.some(v => v.variable.name.value === \"variables\")) {\n invariant.warn(`Called refetch(${\n JSON.stringify(variables)\n }) for query ${\n queryDef.name?.value || JSON.stringify(queryDef)\n }, which does not declare a $variables variable.\nDid you mean to call refetch(variables) instead of refetch({ variables })?`);\n }\n }\n\n if (variables && !equal(this.options.variables, variables)) {\n // Update the existing options with new variables\n reobserveOptions.variables = this.options.variables = {\n ...this.options.variables,\n ...variables,\n } as TVariables;\n }\n\n this.queryInfo.resetLastWrite();\n return this.reobserve(reobserveOptions, NetworkStatus.refetch);\n }\n\n public fetchMore(\n fetchMoreOptions: FetchMoreQueryOptions &\n FetchMoreOptions,\n ): Promise> {\n const combinedOptions = {\n ...(fetchMoreOptions.query ? fetchMoreOptions : {\n ...this.options,\n ...fetchMoreOptions,\n variables: {\n ...this.options.variables,\n ...fetchMoreOptions.variables,\n },\n }),\n // The fetchMore request goes immediately to the network and does\n // not automatically write its result to the cache (hence no-cache\n // instead of network-only), because we allow the caller of\n // fetchMore to provide an updateQuery callback that determines how\n // the data gets written to the cache.\n fetchPolicy: \"no-cache\",\n } as WatchQueryOptions;\n\n const qid = this.queryManager.generateQueryId();\n\n // Simulate a loading result for the original query with\n // result.networkStatus === NetworkStatus.fetchMore.\n if (combinedOptions.notifyOnNetworkStatusChange) {\n this.queryInfo.networkStatus = NetworkStatus.fetchMore;\n this.observe();\n }\n\n return this.queryManager.fetchQuery(\n qid,\n combinedOptions,\n NetworkStatus.fetchMore,\n ).then(fetchMoreResult => {\n const data = fetchMoreResult.data as TData;\n const { updateQuery } = fetchMoreOptions;\n\n if (updateQuery) {\n if (__DEV__ &&\n !warnedAboutUpdateQuery) {\n invariant.warn(\n`The updateQuery callback for fetchMore is deprecated, and will be removed\nin the next major version of Apollo Client.\n\nPlease convert updateQuery functions to field policies with appropriate\nread and merge functions, or use/adapt a helper function (such as\nconcatPagination, offsetLimitPagination, or relayStylePagination) from\n@apollo/client/utilities.\n\nThe field policy system handles pagination more effectively than a\nhand-written updateQuery function, and you only need to define the policy\nonce, rather than every time you call fetchMore.`);\n warnedAboutUpdateQuery = true;\n }\n this.updateQuery(previous => updateQuery(previous, {\n fetchMoreResult: data,\n variables: combinedOptions.variables as TVariables,\n }));\n } else {\n // If we're using a field policy instead of updateQuery, the only\n // thing we need to do is write the new data to the cache using\n // combinedOptions.variables (instead of this.variables, which is\n // what this.updateQuery uses, because it works by abusing the\n // original field value, keyed by the original variables).\n this.queryManager.cache.writeQuery({\n query: combinedOptions.query,\n variables: combinedOptions.variables,\n data,\n });\n }\n\n return fetchMoreResult as ApolloQueryResult;\n\n }).finally(() => {\n this.queryManager.stopQuery(qid);\n this.reobserve();\n });\n }\n\n // XXX the subscription variables are separate from the query variables.\n // if you want to update subscription variables, right now you have to do that separately,\n // and you can only do it by stopping the subscription and then subscribing again with new variables.\n public subscribeToMore<\n TSubscriptionData = TData,\n TSubscriptionVariables = TVariables\n >(\n options: SubscribeToMoreOptions<\n TData,\n TSubscriptionVariables,\n TSubscriptionData\n >,\n ) {\n const subscription = this.queryManager\n .startGraphQLSubscription({\n query: options.document,\n variables: options.variables,\n context: options.context,\n })\n .subscribe({\n next: (subscriptionData: { data: TSubscriptionData }) => {\n const { updateQuery } = options;\n if (updateQuery) {\n this.updateQuery(\n (previous, { variables }) =>\n updateQuery(previous, {\n subscriptionData,\n variables,\n }),\n );\n }\n },\n error: (err: any) => {\n if (options.onError) {\n options.onError(err);\n return;\n }\n invariant.error('Unhandled GraphQL subscription error', err);\n },\n });\n\n this.subscriptions.add(subscription);\n\n return () => {\n if (this.subscriptions.delete(subscription)) {\n subscription.unsubscribe();\n }\n };\n }\n\n public setOptions(\n newOptions: Partial>,\n ): Promise> {\n return this.reobserve(newOptions);\n }\n\n /**\n * This is for *internal* use only. Most users should instead use `refetch`\n * in order to be properly notified of results even when they come from cache.\n *\n * Update the variables of this observable query, and fetch the new results\n * if they've changed. If you want to force new results, use `refetch`.\n *\n * Note: the `next` callback will *not* fire if the variables have not changed\n * or if the result is coming from cache.\n *\n * Note: the promise will return the old results immediately if the variables\n * have not changed.\n *\n * Note: the promise will return null immediately if the query is not active\n * (there are no subscribers).\n *\n * @private\n *\n * @param variables: The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public setVariables(\n variables: TVariables,\n ): Promise | void> {\n if (equal(this.variables, variables)) {\n // If we have no observers, then we don't actually want to make a network\n // request. As soon as someone observes the query, the request will kick\n // off. For now, we just store any changes. (See #1077)\n return this.observers.size\n ? this.result()\n : Promise.resolve();\n }\n\n this.options.variables = variables;\n\n // See comment above\n if (!this.observers.size) {\n return Promise.resolve();\n }\n\n return this.reobserve({\n // Reset options.fetchPolicy to its original value.\n fetchPolicy: this.initialFetchPolicy,\n variables,\n }, NetworkStatus.setVariables);\n }\n\n public updateQuery(\n mapFn: (\n previousQueryResult: TData,\n options: Pick, \"variables\">,\n ) => TData,\n ): void {\n const { queryManager } = this;\n const { result } = queryManager.cache.diff({\n query: this.options.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n const newResult = mapFn(result!, {\n variables: (this as any).variables,\n });\n\n if (newResult) {\n queryManager.cache.writeQuery({\n query: this.options.query,\n data: newResult,\n variables: this.variables,\n });\n\n queryManager.broadcastQueries();\n }\n }\n\n public startPolling(pollInterval: number) {\n this.options.pollInterval = pollInterval;\n this.updatePolling();\n }\n\n public stopPolling() {\n this.options.pollInterval = 0;\n this.updatePolling();\n }\n\n private fetch(\n options: WatchQueryOptions,\n newNetworkStatus?: NetworkStatus,\n ): Concast> {\n this.queryManager.setObservableQuery(this);\n return this.queryManager.fetchQueryObservable(\n this.queryId,\n options,\n newNetworkStatus,\n );\n }\n\n // Turns polling on or off based on this.options.pollInterval.\n private updatePolling() {\n // Avoid polling in SSR mode\n if (this.queryManager.ssrMode) {\n return;\n }\n\n const {\n pollingInfo,\n options: {\n pollInterval,\n },\n } = this;\n\n if (!pollInterval) {\n if (pollingInfo) {\n clearTimeout(pollingInfo.timeout);\n delete this.pollingInfo;\n }\n return;\n }\n\n if (pollingInfo &&\n pollingInfo.interval === pollInterval) {\n return;\n }\n\n invariant(\n pollInterval,\n 'Attempted to start a polling query without a polling interval.',\n );\n\n const info = pollingInfo || (this.pollingInfo = {} as any);\n info.interval = pollInterval;\n\n const maybeFetch = () => {\n if (this.pollingInfo) {\n if (!isNetworkRequestInFlight(this.queryInfo.networkStatus)) {\n this.reobserve({\n fetchPolicy: \"network-only\",\n }, NetworkStatus.poll).then(poll, poll);\n } else {\n poll();\n }\n };\n };\n\n const poll = () => {\n const info = this.pollingInfo;\n if (info) {\n clearTimeout(info.timeout);\n info.timeout = setTimeout(maybeFetch, info.interval);\n }\n };\n\n poll();\n }\n\n private updateLastResult(\n newResult: ApolloQueryResult,\n variables = this.variables,\n ) {\n this.last = {\n ...this.last,\n result: this.queryManager.assumeImmutableResults\n ? newResult\n : cloneDeep(newResult),\n variables,\n };\n if (!isNonEmptyArray(newResult.errors)) {\n delete this.last.error;\n }\n return this.last;\n }\n\n public reobserve(\n newOptions?: Partial>,\n newNetworkStatus?: NetworkStatus,\n ): Promise> {\n this.isTornDown = false;\n\n const useDisposableConcast =\n // Refetching uses a disposable Concast to allow refetches using different\n // options/variables, without permanently altering the options of the\n // original ObservableQuery.\n newNetworkStatus === NetworkStatus.refetch ||\n // The fetchMore method does not actually call the reobserve method, but,\n // if it did, it would definitely use a disposable Concast.\n newNetworkStatus === NetworkStatus.fetchMore ||\n // Polling uses a disposable Concast so the polling options (which force\n // fetchPolicy to be \"network-only\") won't override the original options.\n newNetworkStatus === NetworkStatus.poll;\n\n // Save the old variables, since Object.assign may modify them below.\n const oldVariables = this.options.variables;\n\n const options = useDisposableConcast\n // Disposable Concast fetches receive a shallow copy of this.options\n // (merged with newOptions), leaving this.options unmodified.\n ? compact(this.options, newOptions)\n : assign(this.options, compact(newOptions));\n\n if (!useDisposableConcast) {\n // We can skip calling updatePolling if we're not changing this.options.\n this.updatePolling();\n\n // Reset options.fetchPolicy to its original value when variables change,\n // unless a new fetchPolicy was provided by newOptions.\n if (\n newOptions &&\n newOptions.variables &&\n !newOptions.fetchPolicy &&\n !equal(newOptions.variables, oldVariables)\n ) {\n options.fetchPolicy = this.initialFetchPolicy;\n if (newNetworkStatus === void 0) {\n newNetworkStatus = NetworkStatus.setVariables;\n }\n }\n }\n\n const variables = options.variables && { ...options.variables };\n const concast = this.fetch(options, newNetworkStatus);\n const observer: Observer> = {\n next: result => {\n this.reportResult(result, variables);\n },\n error: error => {\n this.reportError(error, variables);\n },\n };\n\n if (!useDisposableConcast) {\n // We use the {add,remove}Observer methods directly to avoid wrapping\n // observer with an unnecessary SubscriptionObserver object, in part so\n // that we can remove it here without triggering any unsubscriptions,\n // because we just want to ignore the old observable, not prematurely shut\n // it down, since other consumers may be awaiting this.concast.promise.\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer, true);\n }\n\n this.concast = concast;\n this.observer = observer;\n }\n\n concast.addObserver(observer);\n\n return concast.promise;\n }\n\n // Pass the current result to this.observer.next without applying any\n // fetch policies.\n private observe() {\n // Passing false is important so that this.getCurrentResult doesn't\n // save the fetchMore result as this.lastResult, causing it to be\n // ignored due to the this.isDifferentFromLastResult check in\n // this.observer.next.\n this.reportResult(\n this.getCurrentResult(false),\n this.variables,\n );\n }\n\n private reportResult(\n result: ApolloQueryResult,\n variables: TVariables | undefined,\n ) {\n const lastError = this.getLastError();\n if (lastError || this.isDifferentFromLastResult(result)) {\n if (lastError || !result.partial || this.options.returnPartialData) {\n this.updateLastResult(result, variables);\n }\n\n iterateObserversSafely(this.observers, 'next', result);\n }\n }\n\n private reportError(\n error: ApolloError,\n variables: TVariables | undefined,\n ) {\n // Since we don't get the current result on errors, only the error, we\n // must mirror the updates that occur in QueryStore.markQueryError here\n const errorResult = {\n ...this.getLastResult(),\n error,\n errors: error.graphQLErrors,\n networkStatus: NetworkStatus.error,\n loading: false,\n } as ApolloQueryResult;\n\n this.updateLastResult(errorResult, variables);\n\n iterateObserversSafely(this.observers, 'error', this.last!.error = error);\n }\n\n public hasObservers() {\n return this.observers.size > 0;\n }\n\n private tearDownQuery() {\n if (this.isTornDown) return;\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n delete this.concast;\n delete this.observer;\n }\n\n this.stopPolling();\n // stop all active GraphQL subscriptions\n this.subscriptions.forEach(sub => sub.unsubscribe());\n this.subscriptions.clear();\n this.queryManager.stopQuery(this.queryId);\n this.observers.clear();\n this.isTornDown = true;\n }\n}\n\n// Necessary because the ObservableQuery constructor has a different\n// signature than the Observable constructor.\nfixObservableSubclass(ObservableQuery);\n\nfunction defaultSubscriptionObserverErrorCallback(error: ApolloError) {\n invariant.error('Unhandled error', error.message, error.stack);\n}\n\nexport function logMissingFieldErrors(\n missing: MissingFieldError[] | MissingTree | undefined,\n) {\n if (__DEV__ && missing) {\n invariant.debug(`Missing cache result fields: ${\n JSON.stringify(missing)\n }`, missing);\n }\n}\n\n// Adopt options.nextFetchPolicy (if defined) as a replacement for\n// options.fetchPolicy. Since this method also removes options.nextFetchPolicy\n// from options, the adoption tends to be idempotent, unless nextFetchPolicy\n// is a function that keeps setting options.nextFetchPolicy (uncommon).\nexport function applyNextFetchPolicy(\n options: Pick<\n WatchQueryOptions,\n | \"fetchPolicy\"\n | \"nextFetchPolicy\"\n >,\n) {\n const {\n fetchPolicy = \"cache-first\",\n nextFetchPolicy,\n } = options;\n\n if (nextFetchPolicy) {\n // When someone chooses \"cache-and-network\" or \"network-only\" as their\n // initial FetchPolicy, they often do not want future cache updates to\n // trigger unconditional network requests, which is what repeatedly\n // applying the \"cache-and-network\" or \"network-only\" policies would seem\n // to imply. Instead, when the cache reports an update after the initial\n // network request, it may be desirable for subsequent network requests to\n // be triggered only if the cache result is incomplete. To that end, the\n // options.nextFetchPolicy option provides an easy way to update\n // options.fetchPolicy after the initial network request, without having to\n // call observableQuery.setOptions.\n options.fetchPolicy = typeof nextFetchPolicy === \"function\"\n ? nextFetchPolicy.call(options, fetchPolicy)\n : nextFetchPolicy;\n }\n}\n","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/* eslint-disable flowtype/no-weak-types */\nimport nodejsCustomInspectSymbol from \"./nodejsCustomInspectSymbol.mjs\";\nvar MAX_ARRAY_LENGTH = 10;\nvar MAX_RECURSIVE_DEPTH = 2;\n/**\n * Used to print values in error messages.\n */\n\nexport default function inspect(value) {\n return formatValue(value, []);\n}\n\nfunction formatValue(value, seenValues) {\n switch (_typeof(value)) {\n case 'string':\n return JSON.stringify(value);\n\n case 'function':\n return value.name ? \"[function \".concat(value.name, \"]\") : '[function]';\n\n case 'object':\n if (value === null) {\n return 'null';\n }\n\n return formatObjectValue(value, seenValues);\n\n default:\n return String(value);\n }\n}\n\nfunction formatObjectValue(value, previouslySeenValues) {\n if (previouslySeenValues.indexOf(value) !== -1) {\n return '[Circular]';\n }\n\n var seenValues = [].concat(previouslySeenValues, [value]);\n var customInspectFn = getCustomFn(value);\n\n if (customInspectFn !== undefined) {\n var customValue = customInspectFn.call(value); // check for infinite recursion\n\n if (customValue !== value) {\n return typeof customValue === 'string' ? customValue : formatValue(customValue, seenValues);\n }\n } else if (Array.isArray(value)) {\n return formatArray(value, seenValues);\n }\n\n return formatObject(value, seenValues);\n}\n\nfunction formatObject(object, seenValues) {\n var keys = Object.keys(object);\n\n if (keys.length === 0) {\n return '{}';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[' + getObjectTag(object) + ']';\n }\n\n var properties = keys.map(function (key) {\n var value = formatValue(object[key], seenValues);\n return key + ': ' + value;\n });\n return '{ ' + properties.join(', ') + ' }';\n}\n\nfunction formatArray(array, seenValues) {\n if (array.length === 0) {\n return '[]';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[Array]';\n }\n\n var len = Math.min(MAX_ARRAY_LENGTH, array.length);\n var remaining = array.length - len;\n var items = [];\n\n for (var i = 0; i < len; ++i) {\n items.push(formatValue(array[i], seenValues));\n }\n\n if (remaining === 1) {\n items.push('... 1 more item');\n } else if (remaining > 1) {\n items.push(\"... \".concat(remaining, \" more items\"));\n }\n\n return '[' + items.join(', ') + ']';\n}\n\nfunction getCustomFn(object) {\n var customInspectFn = object[String(nodejsCustomInspectSymbol)];\n\n if (typeof customInspectFn === 'function') {\n return customInspectFn;\n }\n\n if (typeof object.inspect === 'function') {\n return object.inspect;\n }\n}\n\nfunction getObjectTag(object) {\n var tag = Object.prototype.toString.call(object).replace(/^\\[object /, '').replace(/]$/, '');\n\n if (tag === 'Object' && typeof object.constructor === 'function') {\n var name = object.constructor.name;\n\n if (typeof name === 'string' && name !== '') {\n return name;\n }\n }\n\n return tag;\n}\n","// In ES2015 (or a polyfilled) environment, this will be Symbol.iterator\n// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\nexport var SYMBOL_ITERATOR = typeof Symbol === 'function' && Symbol.iterator != null ? Symbol.iterator : '@@iterator'; // In ES2017 (or a polyfilled) environment, this will be Symbol.asyncIterator\n// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\nexport var SYMBOL_ASYNC_ITERATOR = typeof Symbol === 'function' && Symbol.asyncIterator != null ? Symbol.asyncIterator : '@@asyncIterator'; // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\nexport var SYMBOL_TO_STRING_TAG = typeof Symbol === 'function' && Symbol.toStringTag != null ? Symbol.toStringTag : '@@toStringTag';\n","/**\n * Produces the value of a block string from its parsed raw value, similar to\n * CoffeeScript's block string, Python's docstring trim or Ruby's strip_heredoc.\n *\n * This implements the GraphQL spec's BlockStringValue() static algorithm.\n *\n * @internal\n */\nexport function dedentBlockStringValue(rawString) {\n // Expand a block string's raw value into independent lines.\n var lines = rawString.split(/\\r\\n|[\\n\\r]/g); // Remove common indentation from all lines but first.\n\n var commonIndent = getBlockStringIndentation(rawString);\n\n if (commonIndent !== 0) {\n for (var i = 1; i < lines.length; i++) {\n lines[i] = lines[i].slice(commonIndent);\n }\n } // Remove leading and trailing blank lines.\n\n\n var startLine = 0;\n\n while (startLine < lines.length && isBlank(lines[startLine])) {\n ++startLine;\n }\n\n var endLine = lines.length;\n\n while (endLine > startLine && isBlank(lines[endLine - 1])) {\n --endLine;\n } // Return a string of the lines joined with U+000A.\n\n\n return lines.slice(startLine, endLine).join('\\n');\n}\n\nfunction isBlank(str) {\n for (var i = 0; i < str.length; ++i) {\n if (str[i] !== ' ' && str[i] !== '\\t') {\n return false;\n }\n }\n\n return true;\n}\n/**\n * @internal\n */\n\n\nexport function getBlockStringIndentation(value) {\n var _commonIndent;\n\n var isFirstLine = true;\n var isEmptyLine = true;\n var indent = 0;\n var commonIndent = null;\n\n for (var i = 0; i < value.length; ++i) {\n switch (value.charCodeAt(i)) {\n case 13:\n // \\r\n if (value.charCodeAt(i + 1) === 10) {\n ++i; // skip \\r\\n as one symbol\n }\n\n // falls through\n\n case 10:\n // \\n\n isFirstLine = false;\n isEmptyLine = true;\n indent = 0;\n break;\n\n case 9: // \\t\n\n case 32:\n // \n ++indent;\n break;\n\n default:\n if (isEmptyLine && !isFirstLine && (commonIndent === null || indent < commonIndent)) {\n commonIndent = indent;\n }\n\n isEmptyLine = false;\n }\n }\n\n return (_commonIndent = commonIndent) !== null && _commonIndent !== void 0 ? _commonIndent : 0;\n}\n/**\n * Print a block string in the indented block form by adding a leading and\n * trailing blank line. However, if a block string starts with whitespace and is\n * a single-line, adding a leading blank line would strip that whitespace.\n *\n * @internal\n */\n\nexport function printBlockString(value) {\n var indentation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var preferMultipleLines = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n var isSingleLine = value.indexOf('\\n') === -1;\n var hasLeadingSpace = value[0] === ' ' || value[0] === '\\t';\n var hasTrailingQuote = value[value.length - 1] === '\"';\n var hasTrailingSlash = value[value.length - 1] === '\\\\';\n var printAsMultipleLines = !isSingleLine || hasTrailingQuote || hasTrailingSlash || preferMultipleLines;\n var result = ''; // Format a multi-line block quote to account for leading space.\n\n if (printAsMultipleLines && !(isSingleLine && hasLeadingSpace)) {\n result += '\\n' + indentation;\n }\n\n result += indentation ? value.replace(/\\n/g, '\\n' + indentation) : value;\n\n if (printAsMultipleLines) {\n result += '\\n';\n }\n\n return '\"\"\"' + result.replace(/\"\"\"/g, '\\\\\"\"\"') + '\"\"\"';\n}\n","import * as React from 'react';\nimport { ApolloClient } from '../../core';\nimport { canUseSymbol } from '../../utilities';\nimport type { RenderPromises } from '../ssr';\n\nexport interface ApolloContextValue {\n client?: ApolloClient;\n renderPromises?: RenderPromises;\n}\n\n// To make sure Apollo Client doesn't create more than one React context\n// (which can lead to problems like having an Apollo Client instance added\n// in one context, then attempting to retrieve it from another different\n// context), a single Apollo context is created and tracked in global state.\nconst contextKey = canUseSymbol\n ? Symbol.for('__APOLLO_CONTEXT__')\n : '__APOLLO_CONTEXT__';\n\nexport function getApolloContext(): React.Context {\n let context = (React.createContext as any)[contextKey] as React.Context;\n if (!context) {\n Object.defineProperty(React.createContext, contextKey, {\n value: context = React.createContext({}),\n enumerable: false,\n writable: false,\n configurable: true,\n });\n context.displayName = 'ApolloContext';\n }\n return context;\n}\n\nexport { getApolloContext as resetApolloContext }\n","/**\n * The set of allowed kind values for AST nodes.\n */\nexport var Kind = Object.freeze({\n // Name\n NAME: 'Name',\n // Document\n DOCUMENT: 'Document',\n OPERATION_DEFINITION: 'OperationDefinition',\n VARIABLE_DEFINITION: 'VariableDefinition',\n SELECTION_SET: 'SelectionSet',\n FIELD: 'Field',\n ARGUMENT: 'Argument',\n // Fragments\n FRAGMENT_SPREAD: 'FragmentSpread',\n INLINE_FRAGMENT: 'InlineFragment',\n FRAGMENT_DEFINITION: 'FragmentDefinition',\n // Values\n VARIABLE: 'Variable',\n INT: 'IntValue',\n FLOAT: 'FloatValue',\n STRING: 'StringValue',\n BOOLEAN: 'BooleanValue',\n NULL: 'NullValue',\n ENUM: 'EnumValue',\n LIST: 'ListValue',\n OBJECT: 'ObjectValue',\n OBJECT_FIELD: 'ObjectField',\n // Directives\n DIRECTIVE: 'Directive',\n // Types\n NAMED_TYPE: 'NamedType',\n LIST_TYPE: 'ListType',\n NON_NULL_TYPE: 'NonNullType',\n // Type System Definitions\n SCHEMA_DEFINITION: 'SchemaDefinition',\n OPERATION_TYPE_DEFINITION: 'OperationTypeDefinition',\n // Type Definitions\n SCALAR_TYPE_DEFINITION: 'ScalarTypeDefinition',\n OBJECT_TYPE_DEFINITION: 'ObjectTypeDefinition',\n FIELD_DEFINITION: 'FieldDefinition',\n INPUT_VALUE_DEFINITION: 'InputValueDefinition',\n INTERFACE_TYPE_DEFINITION: 'InterfaceTypeDefinition',\n UNION_TYPE_DEFINITION: 'UnionTypeDefinition',\n ENUM_TYPE_DEFINITION: 'EnumTypeDefinition',\n ENUM_VALUE_DEFINITION: 'EnumValueDefinition',\n INPUT_OBJECT_TYPE_DEFINITION: 'InputObjectTypeDefinition',\n // Directive Definitions\n DIRECTIVE_DEFINITION: 'DirectiveDefinition',\n // Type System Extensions\n SCHEMA_EXTENSION: 'SchemaExtension',\n // Type Extensions\n SCALAR_TYPE_EXTENSION: 'ScalarTypeExtension',\n OBJECT_TYPE_EXTENSION: 'ObjectTypeExtension',\n INTERFACE_TYPE_EXTENSION: 'InterfaceTypeExtension',\n UNION_TYPE_EXTENSION: 'UnionTypeExtension',\n ENUM_TYPE_EXTENSION: 'EnumTypeExtension',\n INPUT_OBJECT_TYPE_EXTENSION: 'InputObjectTypeExtension'\n});\n/**\n * The enum type representing the possible kind values of AST nodes.\n */\n","import { invariant } from '../utilities/globals';\n\nimport {\n DocumentNode,\n OperationDefinitionNode,\n SelectionSetNode,\n SelectionNode,\n InlineFragmentNode,\n FragmentDefinitionNode,\n FieldNode,\n ASTNode,\n visit,\n BREAK,\n} from 'graphql';\n\nimport { ApolloCache } from '../cache';\nimport {\n FragmentMap,\n StoreObject,\n argumentsObjectFromField,\n buildQueryFromSelectionSet,\n createFragmentMap,\n getFragmentDefinitions,\n getMainDefinition,\n hasDirectives,\n isField,\n isInlineFragment,\n mergeDeep,\n mergeDeepArray,\n removeClientSetsFromDocument,\n resultKeyNameFromField,\n shouldInclude,\n} from '../utilities';\nimport { ApolloClient } from './ApolloClient';\nimport { Resolvers, OperationVariables } from './types';\nimport { FetchResult } from '../link/core';\nimport { cacheSlot } from '../cache';\n\nexport type Resolver = (\n rootValue?: any,\n args?: any,\n context?: any,\n info?: {\n field: FieldNode;\n fragmentMap: FragmentMap;\n },\n) => any;\n\nexport type VariableMap = { [name: string]: any };\n\nexport type FragmentMatcher = (\n rootValue: any,\n typeCondition: string,\n context: any,\n) => boolean;\n\nexport type ExecContext = {\n fragmentMap: FragmentMap;\n context: any;\n variables: VariableMap;\n fragmentMatcher: FragmentMatcher;\n defaultOperationType: string;\n exportedVariables: Record;\n onlyRunForcedResolvers: boolean;\n};\n\nexport type LocalStateOptions = {\n cache: ApolloCache;\n client?: ApolloClient;\n resolvers?: Resolvers | Resolvers[];\n fragmentMatcher?: FragmentMatcher;\n};\n\nexport class LocalState {\n private cache: ApolloCache;\n private client: ApolloClient;\n private resolvers?: Resolvers;\n private fragmentMatcher: FragmentMatcher;\n\n constructor({\n cache,\n client,\n resolvers,\n fragmentMatcher,\n }: LocalStateOptions) {\n this.cache = cache;\n\n if (client) {\n this.client = client;\n }\n\n if (resolvers) {\n this.addResolvers(resolvers);\n }\n\n if (fragmentMatcher) {\n this.setFragmentMatcher(fragmentMatcher);\n }\n }\n\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = this.resolvers || {};\n if (Array.isArray(resolvers)) {\n resolvers.forEach(resolverGroup => {\n this.resolvers = mergeDeep(this.resolvers, resolverGroup);\n });\n } else {\n this.resolvers = mergeDeep(this.resolvers, resolvers);\n }\n }\n\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = {};\n this.addResolvers(resolvers);\n }\n\n public getResolvers() {\n return this.resolvers || {};\n }\n\n // Run local client resolvers against the incoming query and remote data.\n // Locally resolved field values are merged with the incoming remote data,\n // and returned. Note that locally resolved fields will overwrite\n // remote data using the same field name.\n public async runResolvers({\n document,\n remoteResult,\n context,\n variables,\n onlyRunForcedResolvers = false,\n }: {\n document: DocumentNode | null;\n remoteResult: FetchResult;\n context?: Record;\n variables?: Record;\n onlyRunForcedResolvers?: boolean;\n }): Promise> {\n if (document) {\n return this.resolveDocument(\n document,\n remoteResult.data,\n context,\n variables,\n this.fragmentMatcher,\n onlyRunForcedResolvers,\n ).then(localResult => ({\n ...remoteResult,\n data: localResult.result,\n }));\n }\n\n return remoteResult;\n }\n\n public setFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.fragmentMatcher = fragmentMatcher;\n }\n\n public getFragmentMatcher(): FragmentMatcher {\n return this.fragmentMatcher;\n }\n\n // Client queries contain everything in the incoming document (if a @client\n // directive is found).\n public clientQuery(document: DocumentNode) {\n if (hasDirectives(['client'], document)) {\n if (this.resolvers) {\n return document;\n }\n }\n return null;\n }\n\n // Server queries are stripped of all @client based selection sets.\n public serverQuery(document: DocumentNode) {\n return removeClientSetsFromDocument(document);\n }\n\n public prepareContext(context?: Record) {\n const { cache } = this;\n return {\n ...context,\n cache,\n // Getting an entry's cache key is useful for local state resolvers.\n getCacheKey(obj: StoreObject) {\n return cache.identify(obj);\n },\n };\n }\n\n // To support `@client @export(as: \"someVar\")` syntax, we'll first resolve\n // @client @export fields locally, then pass the resolved values back to be\n // used alongside the original operation variables.\n public async addExportedVariables(\n document: DocumentNode,\n variables: OperationVariables = {},\n context = {},\n ) {\n if (document) {\n return this.resolveDocument(\n document,\n this.buildRootValueFromCache(document, variables) || {},\n this.prepareContext(context),\n variables,\n ).then(data => ({\n ...variables,\n ...data.exportedVariables,\n }));\n }\n\n return {\n ...variables,\n };\n }\n\n public shouldForceResolvers(document: ASTNode) {\n let forceResolvers = false;\n visit(document, {\n Directive: {\n enter(node) {\n if (node.name.value === 'client' && node.arguments) {\n forceResolvers = node.arguments.some(\n arg =>\n arg.name.value === 'always' &&\n arg.value.kind === 'BooleanValue' &&\n arg.value.value === true,\n );\n if (forceResolvers) {\n return BREAK;\n }\n }\n },\n },\n });\n return forceResolvers;\n }\n\n // Query the cache and return matching data.\n private buildRootValueFromCache(\n document: DocumentNode,\n variables?: Record,\n ) {\n return this.cache.diff({\n query: buildQueryFromSelectionSet(document),\n variables,\n returnPartialData: true,\n optimistic: false,\n }).result;\n }\n\n private async resolveDocument(\n document: DocumentNode,\n rootValue: TData,\n context: any = {},\n variables: VariableMap = {},\n fragmentMatcher: FragmentMatcher = () => true,\n onlyRunForcedResolvers: boolean = false,\n ) {\n const mainDefinition = getMainDefinition(document);\n const fragments = getFragmentDefinitions(document);\n const fragmentMap = createFragmentMap(fragments);\n\n const definitionOperation = (mainDefinition as OperationDefinitionNode)\n .operation;\n\n const defaultOperationType = definitionOperation\n ? definitionOperation.charAt(0).toUpperCase() +\n definitionOperation.slice(1)\n : 'Query';\n\n const { cache, client } = this;\n const execContext: ExecContext = {\n fragmentMap,\n context: {\n ...context,\n cache,\n client,\n },\n variables,\n fragmentMatcher,\n defaultOperationType,\n exportedVariables: {},\n onlyRunForcedResolvers,\n };\n\n return this.resolveSelectionSet(\n mainDefinition.selectionSet,\n rootValue,\n execContext,\n ).then(result => ({\n result,\n exportedVariables: execContext.exportedVariables,\n }));\n }\n\n private async resolveSelectionSet(\n selectionSet: SelectionSetNode,\n rootValue: TData,\n execContext: ExecContext,\n ) {\n const { fragmentMap, context, variables } = execContext;\n const resultsToMerge: TData[] = [rootValue];\n\n const execute = async (selection: SelectionNode): Promise => {\n if (!shouldInclude(selection, variables)) {\n // Skip this entirely.\n return;\n }\n\n if (isField(selection)) {\n return this.resolveField(selection, rootValue, execContext).then(\n fieldResult => {\n if (typeof fieldResult !== 'undefined') {\n resultsToMerge.push({\n [resultKeyNameFromField(selection)]: fieldResult,\n } as TData);\n }\n },\n );\n }\n\n let fragment: InlineFragmentNode | FragmentDefinitionNode;\n\n if (isInlineFragment(selection)) {\n fragment = selection;\n } else {\n // This is a named fragment.\n fragment = fragmentMap[selection.name.value];\n invariant(fragment, `No fragment named ${selection.name.value}`);\n }\n\n if (fragment && fragment.typeCondition) {\n const typeCondition = fragment.typeCondition.name.value;\n if (execContext.fragmentMatcher(rootValue, typeCondition, context)) {\n return this.resolveSelectionSet(\n fragment.selectionSet,\n rootValue,\n execContext,\n ).then(fragmentResult => {\n resultsToMerge.push(fragmentResult);\n });\n }\n }\n };\n\n return Promise.all(selectionSet.selections.map(execute)).then(function() {\n return mergeDeepArray(resultsToMerge);\n });\n }\n\n private async resolveField(\n field: FieldNode,\n rootValue: any,\n execContext: ExecContext,\n ): Promise {\n const { variables } = execContext;\n const fieldName = field.name.value;\n const aliasedFieldName = resultKeyNameFromField(field);\n const aliasUsed = fieldName !== aliasedFieldName;\n const defaultResult = rootValue[aliasedFieldName] || rootValue[fieldName];\n let resultPromise = Promise.resolve(defaultResult);\n\n // Usually all local resolvers are run when passing through here, but\n // if we've specifically identified that we only want to run forced\n // resolvers (that is, resolvers for fields marked with\n // `@client(always: true)`), then we'll skip running non-forced resolvers.\n if (\n !execContext.onlyRunForcedResolvers ||\n this.shouldForceResolvers(field)\n ) {\n const resolverType =\n rootValue.__typename || execContext.defaultOperationType;\n const resolverMap = this.resolvers && this.resolvers[resolverType];\n if (resolverMap) {\n const resolve = resolverMap[aliasUsed ? fieldName : aliasedFieldName];\n if (resolve) {\n resultPromise = Promise.resolve(\n // In case the resolve function accesses reactive variables,\n // set cacheSlot to the current cache instance.\n cacheSlot.withValue(this.cache, resolve, [\n rootValue,\n argumentsObjectFromField(field, variables),\n execContext.context,\n { field, fragmentMap: execContext.fragmentMap },\n ])\n );\n }\n }\n }\n\n return resultPromise.then((result = defaultResult) => {\n // If an @export directive is associated with the current field, store\n // the `as` export variable name and current result for later use.\n if (field.directives) {\n field.directives.forEach(directive => {\n if (directive.name.value === 'export' && directive.arguments) {\n directive.arguments.forEach(arg => {\n if (arg.name.value === 'as' && arg.value.kind === 'StringValue') {\n execContext.exportedVariables[arg.value.value] = result;\n }\n });\n }\n });\n }\n\n // Handle all scalar types here.\n if (!field.selectionSet) {\n return result;\n }\n\n // From here down, the field has a selection set, which means it's trying\n // to query a GraphQLObjectType.\n if (result == null) {\n // Basically any field in a GraphQL response can be null, or missing\n return result;\n }\n\n if (Array.isArray(result)) {\n return this.resolveSubSelectedArray(field, result, execContext);\n }\n\n // Returned value is an object, and the query has a sub-selection. Recurse.\n if (field.selectionSet) {\n return this.resolveSelectionSet(\n field.selectionSet,\n result,\n execContext,\n );\n }\n });\n }\n\n private resolveSubSelectedArray(\n field: FieldNode,\n result: any[],\n execContext: ExecContext,\n ): any {\n return Promise.all(\n result.map(item => {\n if (item === null) {\n return null;\n }\n\n // This is a nested array, recurse.\n if (Array.isArray(item)) {\n return this.resolveSubSelectedArray(field, item, execContext);\n }\n\n // This is an object, run the selection set on it.\n if (field.selectionSet) {\n return this.resolveSelectionSet(field.selectionSet, item, execContext);\n }\n }),\n );\n }\n}\n","import { DocumentNode, GraphQLError } from 'graphql';\nimport { equal } from \"@wry/equality\";\n\nimport { Cache, ApolloCache } from '../cache';\nimport { WatchQueryOptions, ErrorPolicy } from './watchQueryOptions';\nimport { ObservableQuery } from './ObservableQuery';\nimport { QueryListener } from './types';\nimport { FetchResult } from '../link/core';\nimport {\n ObservableSubscription,\n isNonEmptyArray,\n graphQLResultHasError,\n canUseWeakMap,\n} from '../utilities';\nimport {\n NetworkStatus,\n isNetworkRequestInFlight,\n} from './networkStatus';\nimport { ApolloError } from '../errors';\nimport { QueryManager } from './QueryManager';\n\nexport type QueryStoreValue = Pick;\n\nexport const enum CacheWriteBehavior {\n FORBID,\n OVERWRITE,\n MERGE,\n};\n\nconst destructiveMethodCounts = new (\n canUseWeakMap ? WeakMap : Map\n), number>();\n\nfunction wrapDestructiveCacheMethod(\n cache: ApolloCache,\n methodName: keyof ApolloCache,\n) {\n const original = cache[methodName];\n if (typeof original === \"function\") {\n cache[methodName] = function () {\n destructiveMethodCounts.set(\n cache,\n // The %1e15 allows the count to wrap around to 0 safely every\n // quadrillion evictions, so there's no risk of overflow. To be\n // clear, this is more of a pedantic principle than something\n // that matters in any conceivable practical scenario.\n (destructiveMethodCounts.get(cache)! + 1) % 1e15,\n );\n return original.apply(this, arguments);\n };\n }\n}\n\nfunction cancelNotifyTimeout(info: QueryInfo) {\n if (info[\"notifyTimeout\"]) {\n clearTimeout(info[\"notifyTimeout\"]);\n info[\"notifyTimeout\"] = void 0;\n }\n}\n\n// A QueryInfo object represents a single query managed by the\n// QueryManager, which tracks all QueryInfo objects by queryId in its\n// this.queries Map. QueryInfo objects store the latest results and errors\n// for the given query, and are responsible for reporting those results to\n// the corresponding ObservableQuery, via the QueryInfo.notify method.\n// Results are reported asynchronously whenever setDiff marks the\n// QueryInfo object as dirty, though a call to the QueryManager's\n// broadcastQueries method may trigger the notification before it happens\n// automatically. This class used to be a simple interface type without\n// any field privacy or meaningful methods, which is why it still has so\n// many public fields. The effort to lock down and simplify the QueryInfo\n// interface is ongoing, and further improvements are welcome.\nexport class QueryInfo {\n listeners = new Set();\n document: DocumentNode | null = null;\n lastRequestId = 1;\n subscriptions = new Set();\n variables?: Record;\n networkStatus?: NetworkStatus;\n networkError?: Error | null;\n graphQLErrors?: ReadonlyArray;\n stopped = false;\n\n private cache: ApolloCache;\n\n constructor(\n queryManager: QueryManager,\n public readonly queryId = queryManager.generateQueryId(),\n ) {\n const cache = this.cache = queryManager.cache;\n\n // Track how often cache.evict is called, since we want eviction to\n // override the feud-stopping logic in the markResult method, by\n // causing shouldWrite to return true. Wrapping the cache.evict method\n // is a bit of a hack, but it saves us from having to make eviction\n // counting an official part of the ApolloCache API.\n if (!destructiveMethodCounts.has(cache)) {\n destructiveMethodCounts.set(cache, 0);\n wrapDestructiveCacheMethod(cache, \"evict\");\n wrapDestructiveCacheMethod(cache, \"modify\");\n wrapDestructiveCacheMethod(cache, \"reset\");\n }\n }\n\n public init(query: {\n document: DocumentNode;\n variables: Record | undefined,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus?: NetworkStatus,\n observableQuery?: ObservableQuery;\n lastRequestId?: number;\n }): this {\n let networkStatus = query.networkStatus || NetworkStatus.loading;\n if (this.variables &&\n this.networkStatus !== NetworkStatus.loading &&\n !equal(this.variables, query.variables)) {\n networkStatus = NetworkStatus.setVariables;\n }\n\n if (!equal(query.variables, this.variables)) {\n this.lastDiff = void 0;\n }\n\n Object.assign(this, {\n document: query.document,\n variables: query.variables,\n networkError: null,\n graphQLErrors: this.graphQLErrors || [],\n networkStatus,\n });\n\n if (query.observableQuery) {\n this.setObservableQuery(query.observableQuery);\n }\n\n if (query.lastRequestId) {\n this.lastRequestId = query.lastRequestId;\n }\n\n return this;\n }\n\n private dirty: boolean = false;\n\n private notifyTimeout?: ReturnType;\n\n reset() {\n cancelNotifyTimeout(this);\n this.lastDiff = void 0;\n this.dirty = false;\n }\n\n getDiff(variables = this.variables): Cache.DiffResult {\n const options = this.getDiffOptions(variables);\n\n if (this.lastDiff && equal(options, this.lastDiff.options)) {\n return this.lastDiff.diff;\n }\n\n this.updateWatch(this.variables = variables);\n\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return { complete: false };\n }\n\n const diff = this.cache.diff(options);\n this.updateLastDiff(diff, options);\n return diff;\n }\n\n private lastDiff?: {\n diff: Cache.DiffResult,\n options: Cache.DiffOptions,\n };\n\n private updateLastDiff(\n diff: Cache.DiffResult | null,\n options?: Cache.DiffOptions,\n ) {\n this.lastDiff = diff ? {\n diff,\n options: options || this.getDiffOptions(),\n } : void 0;\n }\n\n private getDiffOptions(variables = this.variables): Cache.DiffOptions {\n return {\n query: this.document!,\n variables,\n returnPartialData: true,\n optimistic: true,\n canonizeResults: this.observableQuery?.options.canonizeResults,\n };\n }\n\n setDiff(diff: Cache.DiffResult | null) {\n const oldDiff = this.lastDiff && this.lastDiff.diff;\n this.updateLastDiff(diff);\n if (!this.dirty &&\n !equal(oldDiff && oldDiff.result,\n diff && diff.result)) {\n this.dirty = true;\n if (!this.notifyTimeout) {\n this.notifyTimeout = setTimeout(() => this.notify(), 0);\n }\n }\n }\n\n public readonly observableQuery: ObservableQuery | null = null;\n private oqListener?: QueryListener;\n\n setObservableQuery(oq: ObservableQuery | null) {\n if (oq === this.observableQuery) return;\n\n if (this.oqListener) {\n this.listeners.delete(this.oqListener);\n }\n\n (this as any).observableQuery = oq;\n\n if (oq) {\n oq[\"queryInfo\"] = this;\n this.listeners.add(this.oqListener = () => {\n // If this.diff came from an optimistic transaction, deliver the\n // current cache data to the ObservableQuery, but don't perform a\n // full reobservation, since oq.reobserve might make a network\n // request, and we don't want to trigger network requests for\n // optimistic updates.\n if (this.getDiff().fromOptimisticTransaction) {\n oq[\"observe\"]();\n } else {\n oq.reobserve();\n }\n });\n } else {\n delete this.oqListener;\n }\n }\n\n notify() {\n cancelNotifyTimeout(this);\n\n if (this.shouldNotify()) {\n this.listeners.forEach(listener => listener(this));\n }\n\n this.dirty = false;\n }\n\n private shouldNotify() {\n if (!this.dirty || !this.listeners.size) {\n return false;\n }\n\n if (isNetworkRequestInFlight(this.networkStatus) &&\n this.observableQuery) {\n const { fetchPolicy } = this.observableQuery.options;\n if (fetchPolicy !== \"cache-only\" &&\n fetchPolicy !== \"cache-and-network\") {\n return false;\n }\n }\n\n return true;\n }\n\n public stop() {\n if (!this.stopped) {\n this.stopped = true;\n\n // Cancel the pending notify timeout\n this.reset();\n\n this.cancel();\n // Revert back to the no-op version of cancel inherited from\n // QueryInfo.prototype.\n this.cancel = QueryInfo.prototype.cancel;\n\n this.subscriptions.forEach(sub => sub.unsubscribe());\n\n const oq = this.observableQuery;\n if (oq) oq.stopPolling();\n }\n }\n\n // This method is a no-op by default, until/unless overridden by the\n // updateWatch method.\n private cancel() {}\n\n private lastWatch?: Cache.WatchOptions;\n\n private updateWatch(variables = this.variables) {\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return;\n }\n\n const watchOptions: Cache.WatchOptions = {\n // Although this.getDiffOptions returns Cache.DiffOptions instead of\n // Cache.WatchOptions, all the overlapping options should be the same, so\n // we can reuse getDiffOptions here, for consistency.\n ...this.getDiffOptions(variables),\n watcher: this,\n callback: diff => this.setDiff(diff),\n };\n\n if (!this.lastWatch ||\n !equal(watchOptions, this.lastWatch)) {\n this.cancel();\n this.cancel = this.cache.watch(this.lastWatch = watchOptions);\n }\n }\n\n private lastWrite?: {\n result: FetchResult;\n variables: WatchQueryOptions[\"variables\"];\n dmCount: number | undefined;\n };\n\n public resetLastWrite() {\n this.lastWrite = void 0;\n }\n\n private shouldWrite(\n result: FetchResult,\n variables: WatchQueryOptions[\"variables\"],\n ) {\n const { lastWrite } = this;\n return !(\n lastWrite &&\n // If cache.evict has been called since the last time we wrote this\n // data into the cache, there's a chance writing this result into\n // the cache will repair what was evicted.\n lastWrite.dmCount === destructiveMethodCounts.get(this.cache) &&\n equal(variables, lastWrite.variables) &&\n equal(result.data, lastWrite.result.data)\n );\n }\n\n public markResult(\n result: FetchResult,\n options: Pick,\n cacheWriteBehavior: CacheWriteBehavior,\n ) {\n this.graphQLErrors = isNonEmptyArray(result.errors) ? result.errors : [];\n\n // Cancel the pending notify timeout (if it exists) to prevent extraneous network\n // requests. To allow future notify timeouts, diff and dirty are reset as well.\n this.reset();\n\n if (options.fetchPolicy === 'no-cache') {\n this.updateLastDiff(\n { result: result.data, complete: true },\n this.getDiffOptions(options.variables),\n );\n\n } else if (cacheWriteBehavior !== CacheWriteBehavior.FORBID) {\n if (shouldWriteResult(result, options.errorPolicy)) {\n // Using a transaction here so we have a chance to read the result\n // back from the cache before the watch callback fires as a result\n // of writeQuery, so we can store the new diff quietly and ignore\n // it when we receive it redundantly from the watch callback.\n this.cache.performTransaction(cache => {\n if (this.shouldWrite(result, options.variables)) {\n cache.writeQuery({\n query: this.document!,\n data: result.data as T,\n variables: options.variables,\n overwrite: cacheWriteBehavior === CacheWriteBehavior.OVERWRITE,\n });\n\n this.lastWrite = {\n result,\n variables: options.variables,\n dmCount: destructiveMethodCounts.get(this.cache),\n };\n } else {\n // If result is the same as the last result we received from\n // the network (and the variables match too), avoid writing\n // result into the cache again. The wisdom of skipping this\n // cache write is far from obvious, since any cache write\n // could be the one that puts the cache back into a desired\n // state, fixing corruption or missing data. However, if we\n // always write every network result into the cache, we enable\n // feuds between queries competing to update the same data in\n // incompatible ways, which can lead to an endless cycle of\n // cache broadcasts and useless network requests. As with any\n // feud, eventually one side must step back from the brink,\n // letting the other side(s) have the last word(s). There may\n // be other points where we could break this cycle, such as\n // silencing the broadcast for cache.writeQuery (not a good\n // idea, since it just delays the feud a bit) or somehow\n // avoiding the network request that just happened (also bad,\n // because the server could return useful new data). All\n // options considered, skipping this cache write seems to be\n // the least damaging place to break the cycle, because it\n // reflects the intuition that we recently wrote this exact\n // result into the cache, so the cache *should* already/still\n // contain this data. If some other query has clobbered that\n // data in the meantime, that's too bad, but there will be no\n // winners if every query blindly reverts to its own version\n // of the data. This approach also gives the network a chance\n // to return new data, which will be written into the cache as\n // usual, notifying only those queries that are directly\n // affected by the cache updates, as usual. In the future, an\n // even more sophisticated cache could perhaps prevent or\n // mitigate the clobbering somehow, but that would make this\n // particular cache write even less important, and thus\n // skipping it would be even safer than it is today.\n if (this.lastDiff &&\n this.lastDiff.diff.complete) {\n // Reuse data from the last good (complete) diff that we\n // received, when possible.\n result.data = this.lastDiff.diff.result;\n return;\n }\n // If the previous this.diff was incomplete, fall through to\n // re-reading the latest data with cache.diff, below.\n }\n\n const diffOptions = this.getDiffOptions(options.variables);\n const diff = cache.diff(diffOptions);\n\n // In case the QueryManager stops this QueryInfo before its\n // results are delivered, it's important to avoid restarting the\n // cache watch when markResult is called.\n if (!this.stopped) {\n // Any time we're about to update this.diff, we need to make\n // sure we've started watching the cache.\n this.updateWatch(options.variables);\n }\n\n // If we're allowed to write to the cache, and we can read a\n // complete result from the cache, update result.data to be the\n // result from the cache, rather than the raw network result.\n // Set without setDiff to avoid triggering a notify call, since\n // we have other ways of notifying for this result.\n this.updateLastDiff(diff, diffOptions);\n if (diff.complete) {\n result.data = diff.result;\n }\n });\n } else {\n this.lastWrite = void 0;\n }\n }\n }\n\n public markReady() {\n this.networkError = null;\n return this.networkStatus = NetworkStatus.ready;\n }\n\n public markError(error: ApolloError) {\n this.networkStatus = NetworkStatus.error;\n this.lastWrite = void 0;\n\n this.reset();\n\n if (error.graphQLErrors) {\n this.graphQLErrors = error.graphQLErrors;\n }\n\n if (error.networkError) {\n this.networkError = error.networkError;\n }\n\n return error;\n }\n}\n\nexport function shouldWriteResult(\n result: FetchResult,\n errorPolicy: ErrorPolicy = \"none\",\n) {\n const ignoreErrors =\n errorPolicy === \"ignore\" ||\n errorPolicy === \"all\";\n let writeWithErrors = !graphQLResultHasError(result);\n if (!writeWithErrors && ignoreErrors && result.data) {\n writeWithErrors = true;\n }\n return writeWithErrors;\n}\n","import { invariant, InvariantError } from '../utilities/globals';\n\nimport { DocumentNode } from 'graphql';\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype OperationTypeNode = any;\nimport { equal } from '@wry/equality';\n\nimport { ApolloLink, execute, FetchResult } from '../link/core';\nimport { Cache, ApolloCache, canonicalStringify } from '../cache';\n\nimport {\n getDefaultValues,\n getOperationDefinition,\n getOperationName,\n hasClientExports,\n graphQLResultHasError,\n removeConnectionDirectiveFromDocument,\n canUseWeakMap,\n ObservableSubscription,\n Observable,\n asyncMap,\n isNonEmptyArray,\n Concast,\n ConcastSourcesIterable,\n makeUniqueId,\n isDocumentNode,\n isNonNullObject,\n} from '../utilities';\nimport { ApolloError, isApolloError } from '../errors';\nimport {\n QueryOptions,\n WatchQueryOptions,\n SubscriptionOptions,\n MutationOptions,\n WatchQueryFetchPolicy,\n ErrorPolicy,\n MutationFetchPolicy,\n} from './watchQueryOptions';\nimport { ObservableQuery, applyNextFetchPolicy, logMissingFieldErrors } from './ObservableQuery';\nimport { NetworkStatus, isNetworkRequestInFlight } from './networkStatus';\nimport {\n ApolloQueryResult,\n OperationVariables,\n MutationUpdaterFunction,\n OnQueryUpdated,\n InternalRefetchQueriesInclude,\n InternalRefetchQueriesOptions,\n InternalRefetchQueriesResult,\n InternalRefetchQueriesMap,\n} from './types';\nimport { LocalState } from './LocalState';\n\nimport {\n QueryInfo,\n QueryStoreValue,\n shouldWriteResult,\n CacheWriteBehavior,\n} from './QueryInfo';\n\nconst { hasOwnProperty } = Object.prototype;\n\ninterface MutationStoreValue {\n mutation: DocumentNode;\n variables: Record;\n loading: boolean;\n error: Error | null;\n}\n\ntype UpdateQueries = MutationOptions[\"updateQueries\"];\n\ninterface TransformCacheEntry {\n document: DocumentNode;\n hasClientExports: boolean;\n hasForcedResolvers: boolean;\n clientQuery: DocumentNode | null;\n serverQuery: DocumentNode | null;\n defaultVars: OperationVariables;\n asQuery: DocumentNode;\n}\n\nexport class QueryManager {\n public cache: ApolloCache;\n public link: ApolloLink;\n public readonly assumeImmutableResults: boolean;\n public readonly ssrMode: boolean;\n\n private queryDeduplication: boolean;\n private clientAwareness: Record = {};\n private localState: LocalState;\n\n private onBroadcast?: () => void;\n public mutationStore?: {\n [mutationId: string]: MutationStoreValue;\n };\n\n // All the queries that the QueryManager is currently managing (not\n // including mutations and subscriptions).\n private queries = new Map();\n\n // Maps from queryId strings to Promise rejection functions for\n // currently active queries and fetches.\n private fetchCancelFns = new Map any>();\n\n constructor({\n cache,\n link,\n queryDeduplication = false,\n onBroadcast,\n ssrMode = false,\n clientAwareness = {},\n localState,\n assumeImmutableResults,\n }: {\n cache: ApolloCache;\n link: ApolloLink;\n queryDeduplication?: boolean;\n onBroadcast?: () => void;\n ssrMode?: boolean;\n clientAwareness?: Record;\n localState?: LocalState;\n assumeImmutableResults?: boolean;\n }) {\n this.cache = cache;\n this.link = link;\n this.queryDeduplication = queryDeduplication;\n this.clientAwareness = clientAwareness;\n this.localState = localState || new LocalState({ cache });\n this.ssrMode = ssrMode;\n this.assumeImmutableResults = !!assumeImmutableResults;\n if ((this.onBroadcast = onBroadcast)) {\n this.mutationStore = Object.create(null);\n }\n }\n\n /**\n * Call this method to terminate any active query processes, making it safe\n * to dispose of this QueryManager instance.\n */\n public stop() {\n this.queries.forEach((_info, queryId) => {\n this.stopQueryNoBroadcast(queryId);\n });\n\n this.cancelPendingFetches(\n new InvariantError('QueryManager stopped while query was in flight'),\n );\n }\n\n private cancelPendingFetches(error: Error) {\n this.fetchCancelFns.forEach(cancel => cancel(error));\n this.fetchCancelFns.clear();\n }\n\n public async mutate<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache\n >({\n mutation,\n variables,\n optimisticResponse,\n updateQueries,\n refetchQueries = [],\n awaitRefetchQueries = false,\n update: updateWithProxyFn,\n onQueryUpdated,\n errorPolicy = 'none',\n fetchPolicy = 'network-only',\n keepRootFields,\n context,\n }: MutationOptions): Promise> {\n invariant(\n mutation,\n 'mutation option is required. You must specify your GraphQL document in the mutation option.',\n );\n\n invariant(\n fetchPolicy === 'network-only' ||\n fetchPolicy === 'no-cache',\n \"Mutations support only 'network-only' or 'no-cache' fetchPolicy strings. The default `network-only` behavior automatically writes mutation results to the cache. Passing `no-cache` skips the cache write.\"\n );\n\n const mutationId = this.generateMutationId();\n mutation = this.transform(mutation).document;\n\n variables = this.getVariables(mutation, variables) as TVariables;\n\n if (this.transform(mutation).hasClientExports) {\n variables = await this.localState.addExportedVariables(mutation, variables, context) as TVariables;\n }\n\n const mutationStoreValue =\n this.mutationStore &&\n (this.mutationStore[mutationId] = {\n mutation,\n variables,\n loading: true,\n error: null,\n } as MutationStoreValue);\n\n if (optimisticResponse) {\n this.markMutationOptimistic<\n TData,\n TVariables,\n TContext,\n TCache\n >(optimisticResponse, {\n mutationId,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n updateQueries,\n update: updateWithProxyFn,\n keepRootFields,\n });\n }\n\n this.broadcastQueries();\n\n const self = this;\n\n return new Promise((resolve, reject) => {\n return asyncMap(\n self.getObservableFromLink(\n mutation,\n {\n ...context,\n optimisticResponse,\n },\n variables,\n false,\n ),\n\n (result: FetchResult) => {\n if (graphQLResultHasError(result) && errorPolicy === 'none') {\n throw new ApolloError({\n graphQLErrors: result.errors,\n });\n }\n\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = null;\n }\n\n const storeResult: typeof result = { ...result };\n\n if (typeof refetchQueries === \"function\") {\n refetchQueries = refetchQueries(storeResult);\n }\n\n if (errorPolicy === 'ignore' &&\n graphQLResultHasError(storeResult)) {\n delete storeResult.errors;\n }\n\n return self.markMutationResult<\n TData,\n TVariables,\n TContext,\n TCache\n >({\n mutationId,\n result: storeResult,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n update: updateWithProxyFn,\n updateQueries,\n awaitRefetchQueries,\n refetchQueries,\n removeOptimistic: optimisticResponse ? mutationId : void 0,\n onQueryUpdated,\n keepRootFields,\n });\n },\n\n ).subscribe({\n next(storeResult) {\n self.broadcastQueries();\n\n // At the moment, a mutation can have only one result, so we can\n // immediately resolve upon receiving the first result. In the future,\n // mutations containing @defer or @stream directives might receive\n // multiple FetchResult payloads from the ApolloLink chain, so we will\n // probably need to collect those results in this next method and call\n // resolve only later, in an observer.complete function.\n resolve(storeResult);\n },\n\n error(err: Error) {\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = err;\n }\n\n if (optimisticResponse) {\n self.cache.removeOptimistic(mutationId);\n }\n\n self.broadcastQueries();\n\n reject(\n err instanceof ApolloError ? err : new ApolloError({\n networkError: err,\n }),\n );\n },\n });\n });\n }\n\n public markMutationResult<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache\n >(\n mutation: {\n mutationId: string;\n result: FetchResult;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries;\n update?: MutationUpdaterFunction;\n awaitRefetchQueries?: boolean;\n refetchQueries?: InternalRefetchQueriesInclude;\n removeOptimistic?: string;\n onQueryUpdated?: OnQueryUpdated;\n keepRootFields?: boolean;\n },\n cache = this.cache,\n ): Promise> {\n let { result } = mutation;\n const cacheWrites: Cache.WriteOptions[] = [];\n const skipCache = mutation.fetchPolicy === \"no-cache\";\n\n if (!skipCache && shouldWriteResult(result, mutation.errorPolicy)) {\n cacheWrites.push({\n result: result.data,\n dataId: 'ROOT_MUTATION',\n query: mutation.document,\n variables: mutation.variables,\n });\n\n const { updateQueries } = mutation;\n if (updateQueries) {\n this.queries.forEach(({ observableQuery }, queryId) => {\n const queryName = observableQuery && observableQuery.queryName;\n if (!queryName || !hasOwnProperty.call(updateQueries, queryName)) {\n return;\n }\n const updater = updateQueries[queryName];\n const { document, variables } = this.queries.get(queryId)!;\n\n // Read the current query result from the store.\n const { result: currentQueryResult, complete } = cache.diff({\n query: document!,\n variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n if (complete && currentQueryResult) {\n // Run our reducer using the current query result and the mutation result.\n const nextQueryResult = updater(currentQueryResult, {\n mutationResult: result,\n queryName: document && getOperationName(document) || void 0,\n queryVariables: variables!,\n });\n\n // Write the modified result back into the store if we got a new result.\n if (nextQueryResult) {\n cacheWrites.push({\n result: nextQueryResult,\n dataId: 'ROOT_QUERY',\n query: document!,\n variables,\n });\n }\n }\n });\n }\n }\n\n if (\n cacheWrites.length > 0 ||\n mutation.refetchQueries ||\n mutation.update ||\n mutation.onQueryUpdated ||\n mutation.removeOptimistic\n ) {\n const results: any[] = [];\n\n this.refetchQueries({\n updateCache: (cache: TCache) => {\n if (!skipCache) {\n cacheWrites.forEach(write => cache.write(write));\n }\n\n // If the mutation has some writes associated with it then we need to\n // apply those writes to the store by running this reducer again with\n // a write action.\n const { update } = mutation;\n if (update) {\n if (!skipCache) {\n // Re-read the ROOT_MUTATION data we just wrote into the cache\n // (the first cache.write call in the cacheWrites.forEach loop\n // above), so field read functions have a chance to run for\n // fields within mutation result objects.\n const diff = cache.diff({\n id: \"ROOT_MUTATION\",\n // The cache complains if passed a mutation where it expects a\n // query, so we transform mutations and subscriptions to queries\n // (only once, thanks to this.transformCache).\n query: this.transform(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true,\n });\n\n if (diff.complete) {\n result = { ...result, data: diff.result };\n }\n }\n\n update(cache, result, {\n context: mutation.context,\n variables: mutation.variables,\n });\n }\n\n // TODO Do this with cache.evict({ id: 'ROOT_MUTATION' }) but make it\n // shallow to allow rolling back optimistic evictions.\n if (!skipCache && !mutation.keepRootFields) {\n cache.modify({\n id: 'ROOT_MUTATION',\n fields(value, { fieldName, DELETE }) {\n return fieldName === \"__typename\" ? value : DELETE;\n },\n });\n }\n },\n\n include: mutation.refetchQueries,\n\n // Write the final mutation.result to the root layer of the cache.\n optimistic: false,\n\n // Remove the corresponding optimistic layer at the same time as we\n // write the final non-optimistic result.\n removeOptimistic: mutation.removeOptimistic,\n\n // Let the caller of client.mutate optionally determine the refetching\n // behavior for watched queries after the mutation.update function runs.\n // If no onQueryUpdated function was provided for this mutation, pass\n // null instead of undefined to disable the default refetching behavior.\n onQueryUpdated: mutation.onQueryUpdated || null,\n\n }).forEach(result => results.push(result));\n\n if (mutation.awaitRefetchQueries || mutation.onQueryUpdated) {\n // Returning a promise here makes the mutation await that promise, so we\n // include results in that promise's work if awaitRefetchQueries or an\n // onQueryUpdated function was specified.\n return Promise.all(results).then(() => result);\n }\n }\n\n return Promise.resolve(result);\n }\n\n public markMutationOptimistic>(\n optimisticResponse: any,\n mutation: {\n mutationId: string;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries,\n update?: MutationUpdaterFunction;\n keepRootFields?: boolean,\n },\n ) {\n const data = typeof optimisticResponse === \"function\"\n ? optimisticResponse(mutation.variables)\n : optimisticResponse;\n\n return this.cache.recordOptimisticTransaction(cache => {\n try {\n this.markMutationResult({\n ...mutation,\n result: { data },\n }, cache);\n } catch (error) {\n invariant.error(error);\n }\n }, mutation.mutationId);\n }\n\n public fetchQuery(\n queryId: string,\n options: WatchQueryOptions,\n networkStatus?: NetworkStatus,\n ): Promise> {\n return this.fetchQueryObservable(\n queryId,\n options,\n networkStatus,\n ).promise;\n }\n\n public getQueryStore() {\n const store: Record = Object.create(null);\n this.queries.forEach((info, queryId) => {\n store[queryId] = {\n variables: info.variables,\n networkStatus: info.networkStatus,\n networkError: info.networkError,\n graphQLErrors: info.graphQLErrors,\n };\n });\n return store;\n }\n\n public resetErrors(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) {\n queryInfo.networkError = undefined;\n queryInfo.graphQLErrors = [];\n }\n }\n\n private transformCache = new (\n canUseWeakMap ? WeakMap : Map\n )();\n\n public transform(document: DocumentNode) {\n const { transformCache } = this;\n\n if (!transformCache.has(document)) {\n const transformed = this.cache.transformDocument(document);\n const forLink = removeConnectionDirectiveFromDocument(\n this.cache.transformForLink(transformed));\n\n const clientQuery = this.localState.clientQuery(transformed);\n const serverQuery = forLink && this.localState.serverQuery(forLink);\n\n const cacheEntry: TransformCacheEntry = {\n document: transformed,\n // TODO These two calls (hasClientExports and shouldForceResolvers)\n // could probably be merged into a single traversal.\n hasClientExports: hasClientExports(transformed),\n hasForcedResolvers: this.localState.shouldForceResolvers(transformed),\n clientQuery,\n serverQuery,\n defaultVars: getDefaultValues(\n getOperationDefinition(transformed)\n ) as OperationVariables,\n // Transform any mutation or subscription operations to query operations\n // so we can read/write them from/to the cache.\n asQuery: {\n ...transformed,\n definitions: transformed.definitions.map(def => {\n if (def.kind === \"OperationDefinition\" &&\n def.operation !== \"query\") {\n return { ...def, operation: \"query\" as OperationTypeNode };\n }\n return def;\n }),\n }\n };\n\n const add = (doc: DocumentNode | null) => {\n if (doc && !transformCache.has(doc)) {\n transformCache.set(doc, cacheEntry);\n }\n }\n // Add cacheEntry to the transformCache using several different keys,\n // since any one of these documents could end up getting passed to the\n // transform method again in the future.\n add(document);\n add(transformed);\n add(clientQuery);\n add(serverQuery);\n }\n\n return transformCache.get(document)!;\n }\n\n private getVariables(\n document: DocumentNode,\n variables?: TVariables,\n ): OperationVariables {\n return {\n ...this.transform(document).defaultVars,\n ...variables,\n };\n }\n\n public watchQuery(\n options: WatchQueryOptions,\n ): ObservableQuery {\n // assign variable default values if supplied\n options = {\n ...options,\n variables: this.getVariables(\n options.query,\n options.variables,\n ) as TVariables,\n };\n\n if (typeof options.notifyOnNetworkStatusChange === 'undefined') {\n options.notifyOnNetworkStatusChange = false;\n }\n\n const queryInfo = new QueryInfo(this);\n const observable = new ObservableQuery({\n queryManager: this,\n queryInfo,\n options,\n });\n\n this.queries.set(observable.queryId, queryInfo);\n\n queryInfo.init({\n document: options.query,\n observableQuery: observable,\n variables: options.variables,\n });\n\n return observable;\n }\n\n public query(\n options: QueryOptions,\n queryId = this.generateQueryId(),\n ): Promise> {\n invariant(\n options.query,\n 'query option is required. You must specify your GraphQL document ' +\n 'in the query option.',\n );\n\n invariant(\n options.query.kind === 'Document',\n 'You must wrap the query string in a \"gql\" tag.',\n );\n\n invariant(\n !(options as any).returnPartialData,\n 'returnPartialData option only supported on watchQuery.',\n );\n\n invariant(\n !(options as any).pollInterval,\n 'pollInterval option only supported on watchQuery.',\n );\n\n return this.fetchQuery(\n queryId,\n options,\n ).finally(() => this.stopQuery(queryId));\n }\n\n private queryIdCounter = 1;\n public generateQueryId() {\n return String(this.queryIdCounter++);\n }\n\n private requestIdCounter = 1;\n public generateRequestId() {\n return this.requestIdCounter++;\n }\n\n private mutationIdCounter = 1;\n public generateMutationId() {\n return String(this.mutationIdCounter++);\n }\n\n public stopQueryInStore(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryInStoreNoBroadcast(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) queryInfo.stop();\n }\n\n public clearStore(options: Cache.ResetOptions = {\n discardWatches: true,\n }): Promise {\n // Before we have sent the reset action to the store, we can no longer\n // rely on the results returned by in-flight requests since these may\n // depend on values that previously existed in the data portion of the\n // store. So, we cancel the promises and observers that we have issued\n // so far and not yet resolved (in the case of queries).\n this.cancelPendingFetches(new InvariantError(\n 'Store reset while query was in flight (not completed in link chain)',\n ));\n\n this.queries.forEach(queryInfo => {\n if (queryInfo.observableQuery) {\n // Set loading to true so listeners don't trigger unless they want\n // results with partial data.\n queryInfo.networkStatus = NetworkStatus.loading;\n } else {\n queryInfo.stop();\n }\n });\n\n if (this.mutationStore) {\n this.mutationStore = Object.create(null);\n }\n\n // begin removing data from the store\n return this.cache.reset(options);\n }\n\n public getObservableQueries(\n include: InternalRefetchQueriesInclude = \"active\",\n ) {\n const queries = new Map>();\n const queryNamesAndDocs = new Map();\n const legacyQueryOptions = new Set();\n\n if (Array.isArray(include)) {\n include.forEach(desc => {\n if (typeof desc === \"string\") {\n queryNamesAndDocs.set(desc, false);\n } else if (isDocumentNode(desc)) {\n queryNamesAndDocs.set(this.transform(desc).document, false);\n } else if (isNonNullObject(desc) && desc.query) {\n legacyQueryOptions.add(desc);\n }\n });\n }\n\n this.queries.forEach(({ observableQuery: oq, document }, queryId) => {\n if (oq) {\n if (include === \"all\") {\n queries.set(queryId, oq);\n return;\n }\n\n const {\n queryName,\n options: { fetchPolicy },\n } = oq;\n\n if (\n fetchPolicy === \"standby\" ||\n (include === \"active\" && !oq.hasObservers())\n ) {\n return;\n }\n\n if (\n include === \"active\" ||\n (queryName && queryNamesAndDocs.has(queryName)) ||\n (document && queryNamesAndDocs.has(document))\n ) {\n queries.set(queryId, oq);\n if (queryName) queryNamesAndDocs.set(queryName, true);\n if (document) queryNamesAndDocs.set(document, true);\n }\n }\n });\n\n if (legacyQueryOptions.size) {\n legacyQueryOptions.forEach((options: QueryOptions) => {\n // We will be issuing a fresh network request for this query, so we\n // pre-allocate a new query ID here, using a special prefix to enable\n // cleaning up these temporary queries later, after fetching.\n const queryId = makeUniqueId(\"legacyOneTimeQuery\");\n const queryInfo = this.getQuery(queryId).init({\n document: options.query,\n variables: options.variables,\n });\n const oq = new ObservableQuery({\n queryManager: this,\n queryInfo,\n options: {\n ...options,\n fetchPolicy: \"network-only\",\n },\n });\n invariant(oq.queryId === queryId);\n queryInfo.setObservableQuery(oq);\n queries.set(queryId, oq);\n });\n }\n\n if (__DEV__ && queryNamesAndDocs.size) {\n queryNamesAndDocs.forEach((included, nameOrDoc) => {\n if (!included) {\n invariant.warn(`Unknown query ${\n typeof nameOrDoc === \"string\" ? \"named \" : \"\"\n }${\n JSON.stringify(nameOrDoc, null, 2)\n } requested in refetchQueries options.include array`);\n }\n });\n }\n\n return queries;\n }\n\n public reFetchObservableQueries(\n includeStandby: boolean = false,\n ): Promise[]> {\n const observableQueryPromises: Promise>[] = [];\n\n this.getObservableQueries(\n includeStandby ? \"all\" : \"active\"\n ).forEach((observableQuery, queryId) => {\n const { fetchPolicy } = observableQuery.options;\n observableQuery.resetLastResults();\n if (includeStandby ||\n (fetchPolicy !== \"standby\" &&\n fetchPolicy !== \"cache-only\")) {\n observableQueryPromises.push(observableQuery.refetch());\n }\n this.getQuery(queryId).setDiff(null);\n });\n\n this.broadcastQueries();\n\n return Promise.all(observableQueryPromises);\n }\n\n public setObservableQuery(observableQuery: ObservableQuery) {\n this.getQuery(observableQuery.queryId).setObservableQuery(observableQuery);\n }\n\n public startGraphQLSubscription({\n query,\n fetchPolicy,\n errorPolicy,\n variables,\n context = {},\n }: SubscriptionOptions): Observable> {\n query = this.transform(query).document;\n variables = this.getVariables(query, variables);\n\n const makeObservable = (variables: OperationVariables) =>\n this.getObservableFromLink(\n query,\n context,\n variables,\n ).map(result => {\n if (fetchPolicy !== 'no-cache') {\n // the subscription interface should handle not sending us results we no longer subscribe to.\n // XXX I don't think we ever send in an object with errors, but we might in the future...\n if (shouldWriteResult(result, errorPolicy)) {\n this.cache.write({\n query,\n result: result.data,\n dataId: 'ROOT_SUBSCRIPTION',\n variables: variables,\n });\n }\n\n this.broadcastQueries();\n }\n\n if (graphQLResultHasError(result)) {\n throw new ApolloError({\n graphQLErrors: result.errors,\n });\n }\n\n return result;\n });\n\n if (this.transform(query).hasClientExports) {\n const observablePromise = this.localState.addExportedVariables(\n query,\n variables,\n context,\n ).then(makeObservable);\n\n return new Observable>(observer => {\n let sub: ObservableSubscription | null = null;\n observablePromise.then(\n observable => sub = observable.subscribe(observer),\n observer.error,\n );\n return () => sub && sub.unsubscribe();\n });\n }\n\n return makeObservable(variables);\n }\n\n public stopQuery(queryId: string) {\n this.stopQueryNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryNoBroadcast(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.removeQuery(queryId);\n }\n\n public removeQuery(queryId: string) {\n // teardown all links\n // Both `QueryManager.fetchRequest` and `QueryManager.query` create separate promises\n // that each add their reject functions to fetchCancelFns.\n // A query created with `QueryManager.query()` could trigger a `QueryManager.fetchRequest`.\n // The same queryId could have two rejection fns for two promises\n this.fetchCancelFns.delete(queryId);\n this.getQuery(queryId).stop();\n this.queries.delete(queryId);\n }\n\n public broadcastQueries() {\n if (this.onBroadcast) this.onBroadcast();\n this.queries.forEach(info => info.notify());\n }\n\n public getLocalState(): LocalState {\n return this.localState;\n }\n\n private inFlightLinkObservables = new Map<\n DocumentNode,\n Map>\n >();\n\n private getObservableFromLink(\n query: DocumentNode,\n context: any,\n variables?: OperationVariables,\n deduplication: boolean =\n // Prefer context.queryDeduplication if specified.\n context?.queryDeduplication ??\n this.queryDeduplication,\n ): Observable> {\n let observable: Observable>;\n\n const { serverQuery } = this.transform(query);\n if (serverQuery) {\n const { inFlightLinkObservables, link } = this;\n\n const operation = {\n query: serverQuery,\n variables,\n operationName: getOperationName(serverQuery) || void 0,\n context: this.prepareContext({\n ...context,\n forceFetch: !deduplication\n }),\n };\n\n context = operation.context;\n\n if (deduplication) {\n const byVariables = inFlightLinkObservables.get(serverQuery) || new Map();\n inFlightLinkObservables.set(serverQuery, byVariables);\n\n const varJson = canonicalStringify(variables);\n observable = byVariables.get(varJson);\n\n if (!observable) {\n const concast = new Concast([\n execute(link, operation) as Observable>\n ]);\n\n byVariables.set(varJson, observable = concast);\n\n concast.cleanup(() => {\n if (byVariables.delete(varJson) &&\n byVariables.size < 1) {\n inFlightLinkObservables.delete(serverQuery);\n }\n });\n }\n\n } else {\n observable = new Concast([\n execute(link, operation) as Observable>\n ]);\n }\n } else {\n observable = new Concast([\n Observable.of({ data: {} } as FetchResult)\n ]);\n context = this.prepareContext(context);\n }\n\n const { clientQuery } = this.transform(query);\n if (clientQuery) {\n observable = asyncMap(observable, result => {\n return this.localState.runResolvers({\n document: clientQuery,\n remoteResult: result,\n context,\n variables,\n });\n });\n }\n\n return observable;\n }\n\n private getResultsFromLink(\n queryInfo: QueryInfo,\n cacheWriteBehavior: CacheWriteBehavior,\n options: Pick,\n | \"variables\"\n | \"context\"\n | \"fetchPolicy\"\n | \"errorPolicy\">,\n ): Observable> {\n const requestId = queryInfo.lastRequestId = this.generateRequestId();\n\n return asyncMap(\n this.getObservableFromLink(\n queryInfo.document!,\n options.context,\n options.variables,\n ),\n\n result => {\n const hasErrors = isNonEmptyArray(result.errors);\n\n // If we interrupted this request by calling getResultsFromLink again\n // with the same QueryInfo object, we ignore the old results.\n if (requestId >= queryInfo.lastRequestId) {\n if (hasErrors && options.errorPolicy === \"none\") {\n // Throwing here effectively calls observer.error.\n throw queryInfo.markError(new ApolloError({\n graphQLErrors: result.errors,\n }));\n }\n queryInfo.markResult(result, options, cacheWriteBehavior);\n queryInfo.markReady();\n }\n\n const aqr: ApolloQueryResult = {\n data: result.data,\n loading: false,\n networkStatus: queryInfo.networkStatus || NetworkStatus.ready,\n };\n\n if (hasErrors && options.errorPolicy !== \"ignore\") {\n aqr.errors = result.errors;\n }\n\n return aqr;\n },\n\n networkError => {\n const error = isApolloError(networkError)\n ? networkError\n : new ApolloError({ networkError });\n\n // Avoid storing errors from older interrupted queries.\n if (requestId >= queryInfo.lastRequestId) {\n queryInfo.markError(error);\n }\n\n throw error;\n },\n );\n }\n\n public fetchQueryObservable(\n queryId: string,\n options: WatchQueryOptions,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus = NetworkStatus.loading,\n ): Concast> {\n const query = this.transform(options.query).document;\n const variables = this.getVariables(query, options.variables) as TVars;\n const queryInfo = this.getQuery(queryId);\n\n let {\n fetchPolicy = \"cache-first\" as WatchQueryFetchPolicy,\n errorPolicy = \"none\" as ErrorPolicy,\n returnPartialData = false,\n notifyOnNetworkStatusChange = false,\n context = {},\n } = options;\n\n const normalized = Object.assign({}, options, {\n query,\n variables,\n fetchPolicy,\n errorPolicy,\n returnPartialData,\n notifyOnNetworkStatusChange,\n context,\n });\n\n const fromVariables = (variables: TVars) => {\n // Since normalized is always a fresh copy of options, it's safe to\n // modify its properties here, rather than creating yet another new\n // WatchQueryOptions object.\n normalized.variables = variables;\n return this.fetchQueryByPolicy(\n queryInfo,\n normalized,\n networkStatus,\n );\n };\n\n // This cancel function needs to be set before the concast is created,\n // in case concast creation synchronously cancels the request.\n this.fetchCancelFns.set(queryId, reason => {\n // This delay ensures the concast variable has been initialized.\n setTimeout(() => concast.cancel(reason));\n });\n\n // A Concast can be created either from an Iterable>\n // or from a PromiseLike>>, where T in this\n // case is ApolloQueryResult.\n const concast = new Concast(\n // If the query has @export(as: ...) directives, then we need to\n // process those directives asynchronously. When there are no\n // @export directives (the common case), we deliberately avoid\n // wrapping the result of this.fetchQueryByPolicy in a Promise,\n // since the timing of result delivery is (unfortunately) important\n // for backwards compatibility. TODO This code could be simpler if\n // we deprecated and removed LocalState.\n this.transform(normalized.query).hasClientExports\n ? this.localState.addExportedVariables(\n normalized.query,\n normalized.variables,\n normalized.context,\n ).then(fromVariables)\n : fromVariables(normalized.variables!)\n );\n\n concast.cleanup(() => {\n this.fetchCancelFns.delete(queryId);\n applyNextFetchPolicy(options);\n });\n\n return concast;\n }\n\n public refetchQueries({\n updateCache,\n include,\n optimistic = false,\n removeOptimistic = optimistic ? makeUniqueId(\"refetchQueries\") : void 0,\n onQueryUpdated,\n }: InternalRefetchQueriesOptions, TResult>\n ): InternalRefetchQueriesMap {\n const includedQueriesById = new Map;\n lastDiff?: Cache.DiffResult;\n diff?: Cache.DiffResult;\n }>();\n\n if (include) {\n this.getObservableQueries(include).forEach((oq, queryId) => {\n includedQueriesById.set(queryId, {\n oq,\n lastDiff: this.getQuery(queryId).getDiff(),\n });\n });\n }\n\n const results: InternalRefetchQueriesMap = new Map;\n\n if (updateCache) {\n this.cache.batch({\n update: updateCache,\n\n // Since you can perform any combination of cache reads and/or writes in\n // the cache.batch update function, its optimistic option can be either\n // a boolean or a string, representing three distinct modes of\n // operation:\n //\n // * false: read/write only the root layer\n // * true: read/write the topmost layer\n // * string: read/write a fresh optimistic layer with that ID string\n //\n // When typeof optimistic === \"string\", a new optimistic layer will be\n // temporarily created within cache.batch with that string as its ID. If\n // we then pass that same string as the removeOptimistic option, we can\n // make cache.batch immediately remove the optimistic layer after\n // running the updateCache function, triggering only one broadcast.\n //\n // However, the refetchQueries method accepts only true or false for its\n // optimistic option (not string). We interpret true to mean a temporary\n // optimistic layer should be created, to allow efficiently rolling back\n // the effect of the updateCache function, which involves passing a\n // string instead of true as the optimistic option to cache.batch, when\n // refetchQueries receives optimistic: true.\n //\n // In other words, we are deliberately not supporting the use case of\n // writing to an *existing* optimistic layer (using the refetchQueries\n // updateCache function), since that would potentially interfere with\n // other optimistic updates in progress. Instead, you can read/write\n // only the root layer by passing optimistic: false to refetchQueries,\n // or you can read/write a brand new optimistic layer that will be\n // automatically removed by passing optimistic: true.\n optimistic: optimistic && removeOptimistic || false,\n\n // The removeOptimistic option can also be provided by itself, even if\n // optimistic === false, to remove some previously-added optimistic\n // layer safely and efficiently, like we do in markMutationResult.\n //\n // If an explicit removeOptimistic string is provided with optimistic:\n // true, the removeOptimistic string will determine the ID of the\n // temporary optimistic layer, in case that ever matters.\n removeOptimistic,\n\n onWatchUpdated(watch, diff, lastDiff) {\n const oq =\n watch.watcher instanceof QueryInfo &&\n watch.watcher.observableQuery;\n\n if (oq) {\n if (onQueryUpdated) {\n // Since we're about to handle this query now, remove it from\n // includedQueriesById, in case it was added earlier because of\n // options.include.\n includedQueriesById.delete(oq.queryId);\n\n let result: TResult | boolean | Promise> =\n onQueryUpdated(oq, diff, lastDiff);\n\n if (result === true) {\n // The onQueryUpdated function requested the default refetching\n // behavior by returning true.\n result = oq.refetch();\n }\n\n // Record the result in the results Map, as long as onQueryUpdated\n // did not return false to skip/ignore this result.\n if (result !== false) {\n results.set(oq, result as InternalRefetchQueriesResult);\n }\n\n // Allow the default cache broadcast to happen, except when\n // onQueryUpdated returns false.\n return result;\n }\n\n if (onQueryUpdated !== null) {\n // If we don't have an onQueryUpdated function, and onQueryUpdated\n // was not disabled by passing null, make sure this query is\n // \"included\" like any other options.include-specified query.\n includedQueriesById.set(oq.queryId, { oq, lastDiff, diff });\n }\n }\n },\n });\n }\n\n if (includedQueriesById.size) {\n includedQueriesById.forEach(({ oq, lastDiff, diff }, queryId) => {\n let result: TResult | boolean | Promise> | undefined;\n\n // If onQueryUpdated is provided, we want to use it for all included\n // queries, even the QueryOptions ones.\n if (onQueryUpdated) {\n if (!diff) {\n const info = oq[\"queryInfo\"];\n info.reset(); // Force info.getDiff() to read from cache.\n diff = info.getDiff();\n }\n result = onQueryUpdated(oq, diff, lastDiff);\n }\n\n // Otherwise, we fall back to refetching.\n if (!onQueryUpdated || result === true) {\n result = oq.refetch();\n }\n\n if (result !== false) {\n results.set(oq, result as InternalRefetchQueriesResult);\n }\n\n if (queryId.indexOf(\"legacyOneTimeQuery\") >= 0) {\n this.stopQueryNoBroadcast(queryId);\n }\n });\n }\n\n if (removeOptimistic) {\n // In case no updateCache callback was provided (so cache.batch was not\n // called above, and thus did not already remove the optimistic layer),\n // remove it here. Since this is a no-op when the layer has already been\n // removed, we do it even if we called cache.batch above, since it's\n // possible this.cache is an instance of some ApolloCache subclass other\n // than InMemoryCache, and does not fully support the removeOptimistic\n // option for cache.batch.\n this.cache.removeOptimistic(removeOptimistic);\n }\n\n return results;\n }\n\n private fetchQueryByPolicy(\n queryInfo: QueryInfo,\n { query,\n variables,\n fetchPolicy,\n refetchWritePolicy,\n errorPolicy,\n returnPartialData,\n context,\n notifyOnNetworkStatusChange,\n }: WatchQueryOptions,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus: NetworkStatus,\n ): ConcastSourcesIterable> {\n const oldNetworkStatus = queryInfo.networkStatus;\n\n queryInfo.init({\n document: query,\n variables,\n networkStatus,\n });\n\n const readCache = () => queryInfo.getDiff(variables);\n\n const resultsFromCache = (\n diff: Cache.DiffResult,\n networkStatus = queryInfo.networkStatus || NetworkStatus.loading,\n ) => {\n const data = diff.result;\n\n if (__DEV__ &&\n !returnPartialData &&\n !equal(data, {})) {\n logMissingFieldErrors(diff.missing);\n }\n\n const fromData = (data: TData | undefined) => Observable.of({\n data,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n ...(diff.complete ? null : { partial: true }),\n } as ApolloQueryResult);\n\n if (data && this.transform(query).hasForcedResolvers) {\n return this.localState.runResolvers({\n document: query,\n remoteResult: { data },\n context,\n variables,\n onlyRunForcedResolvers: true,\n }).then(resolved => fromData(resolved.data || void 0));\n }\n\n return fromData(data);\n };\n\n const cacheWriteBehavior =\n fetchPolicy === \"no-cache\" ? CacheWriteBehavior.FORBID :\n ( // Watched queries must opt into overwriting existing data on refetch,\n // by passing refetchWritePolicy: \"overwrite\" in their WatchQueryOptions.\n networkStatus === NetworkStatus.refetch &&\n refetchWritePolicy !== \"merge\"\n ) ? CacheWriteBehavior.OVERWRITE\n : CacheWriteBehavior.MERGE;\n\n const resultsFromLink = () =>\n this.getResultsFromLink(queryInfo, cacheWriteBehavior, {\n variables,\n context,\n fetchPolicy,\n errorPolicy,\n });\n\n const shouldNotify =\n notifyOnNetworkStatusChange &&\n typeof oldNetworkStatus === \"number\" &&\n oldNetworkStatus !== networkStatus &&\n isNetworkRequestInFlight(networkStatus);\n\n switch (fetchPolicy) {\n default: case \"cache-first\": {\n const diff = readCache();\n\n if (diff.complete) {\n return [\n resultsFromCache(diff, queryInfo.markReady()),\n ];\n }\n\n if (returnPartialData || shouldNotify) {\n return [\n resultsFromCache(diff),\n resultsFromLink(),\n ];\n }\n\n return [\n resultsFromLink(),\n ];\n }\n\n case \"cache-and-network\": {\n const diff = readCache();\n\n if (diff.complete || returnPartialData || shouldNotify) {\n return [\n resultsFromCache(diff),\n resultsFromLink(),\n ];\n }\n\n return [\n resultsFromLink(),\n ];\n }\n\n case \"cache-only\":\n return [\n resultsFromCache(readCache(), queryInfo.markReady()),\n ];\n\n case \"network-only\":\n if (shouldNotify) {\n return [\n resultsFromCache(readCache()),\n resultsFromLink(),\n ];\n }\n\n return [resultsFromLink()];\n\n case \"no-cache\":\n if (shouldNotify) {\n return [\n // Note that queryInfo.getDiff() for no-cache queries does not call\n // cache.diff, but instead returns a { complete: false } stub result\n // when there is no queryInfo.diff already defined.\n resultsFromCache(queryInfo.getDiff()),\n resultsFromLink(),\n ];\n }\n\n return [resultsFromLink()];\n\n case \"standby\":\n return [];\n }\n }\n\n private getQuery(queryId: string): QueryInfo {\n if (queryId && !this.queries.has(queryId)) {\n this.queries.set(queryId, new QueryInfo(this, queryId));\n }\n return this.queries.get(queryId)!;\n }\n\n private prepareContext(context = {}) {\n const newContext = this.localState.prepareContext(context);\n return {\n ...newContext,\n clientAwareness: this.clientAwareness,\n };\n }\n}\n","import { invariant, InvariantError } from '../utilities/globals';\n\nimport { ExecutionResult, DocumentNode } from 'graphql';\n\nimport { ApolloLink, FetchResult, GraphQLRequest, execute } from '../link/core';\nimport { ApolloCache, DataProxy } from '../cache';\nimport { Observable, compact } from '../utilities';\nimport { version } from '../version';\nimport { HttpLink, UriFunction } from '../link/http';\n\nimport { QueryManager } from './QueryManager';\nimport { ObservableQuery } from './ObservableQuery';\n\nimport {\n ApolloQueryResult,\n DefaultContext,\n OperationVariables,\n Resolvers,\n RefetchQueriesOptions,\n RefetchQueriesResult,\n InternalRefetchQueriesResult,\n RefetchQueriesInclude,\n} from './types';\n\nimport {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n SubscriptionOptions,\n WatchQueryFetchPolicy,\n} from './watchQueryOptions';\n\nimport {\n LocalState,\n FragmentMatcher,\n} from './LocalState';\n\nexport interface DefaultOptions {\n watchQuery?: Partial>;\n query?: Partial>;\n mutate?: Partial>;\n}\n\nlet hasSuggestedDevtools = false;\n\nexport type ApolloClientOptions = {\n uri?: string | UriFunction;\n credentials?: string;\n headers?: Record;\n link?: ApolloLink;\n cache: ApolloCache;\n ssrForceFetchDelay?: number;\n ssrMode?: boolean;\n connectToDevTools?: boolean;\n queryDeduplication?: boolean;\n defaultOptions?: DefaultOptions;\n assumeImmutableResults?: boolean;\n resolvers?: Resolvers | Resolvers[];\n typeDefs?: string | string[] | DocumentNode | DocumentNode[];\n fragmentMatcher?: FragmentMatcher;\n name?: string;\n version?: string;\n};\n\ntype OptionsUnion =\n | WatchQueryOptions\n | QueryOptions\n | MutationOptions;\n\nexport function mergeOptions<\n TOptions extends OptionsUnion\n>(\n defaults: Partial,\n options: TOptions,\n): TOptions {\n return compact(defaults, options, options.variables && {\n variables: {\n ...defaults.variables,\n ...options.variables,\n },\n });\n}\n\n/**\n * This is the primary Apollo Client class. It is used to send GraphQL documents (i.e. queries\n * and mutations) to a GraphQL spec-compliant server over a {@link NetworkInterface} instance,\n * receive results from the server and cache the results in a store. It also delivers updates\n * to GraphQL queries through {@link Observable} instances.\n */\nexport class ApolloClient implements DataProxy {\n public link: ApolloLink;\n public cache: ApolloCache;\n public disableNetworkFetches: boolean;\n public version: string;\n public queryDeduplication: boolean;\n public defaultOptions: DefaultOptions = {};\n public readonly typeDefs: ApolloClientOptions['typeDefs'];\n\n private queryManager: QueryManager;\n private devToolsHookCb: Function;\n private resetStoreCallbacks: Array<() => Promise> = [];\n private clearStoreCallbacks: Array<() => Promise> = [];\n private localState: LocalState;\n\n /**\n * Constructs an instance of {@link ApolloClient}.\n *\n * @param uri The GraphQL endpoint that Apollo Client will connect to. If\n * `link` is configured, this option is ignored.\n * @param link The {@link ApolloLink} over which GraphQL documents will be resolved into a response.\n *\n * @param cache The initial cache to use in the data store.\n *\n * @param ssrMode Determines whether this is being run in Server Side Rendering (SSR) mode.\n *\n * @param ssrForceFetchDelay Determines the time interval before we force fetch queries for a\n * server side render.\n *\n * @param queryDeduplication If set to false, a query will still be sent to the server even if a query\n * with identical parameters (query, variables, operationName) is already in flight.\n *\n * @param defaultOptions Used to set application wide defaults for the\n * options supplied to `watchQuery`, `query`, or\n * `mutate`.\n *\n * @param assumeImmutableResults When this option is true, the client will assume results\n * read from the cache are never mutated by application code,\n * which enables substantial performance optimizations. Passing\n * `{ freezeResults: true }` to the `InMemoryCache` constructor\n * can help enforce this immutability.\n *\n * @param name A custom name that can be used to identify this client, when\n * using Apollo client awareness features. E.g. \"iOS\".\n *\n * @param version A custom version that can be used to identify this client,\n * when using Apollo client awareness features. This is the\n * version of your client, which you may want to increment on\n * new builds. This is NOT the version of Apollo Client that\n * you are using.\n */\n constructor(options: ApolloClientOptions) {\n const {\n uri,\n credentials,\n headers,\n cache,\n ssrMode = false,\n ssrForceFetchDelay = 0,\n connectToDevTools =\n // Expose the client instance as window.__APOLLO_CLIENT__ and call\n // onBroadcast in queryManager.broadcastQueries to enable browser\n // devtools, but disable them by default in production.\n typeof window === 'object' &&\n !(window as any).__APOLLO_CLIENT__ &&\n __DEV__,\n queryDeduplication = true,\n defaultOptions,\n assumeImmutableResults = false,\n resolvers,\n typeDefs,\n fragmentMatcher,\n name: clientAwarenessName,\n version: clientAwarenessVersion,\n } = options;\n\n let { link } = options;\n\n if (!link) {\n link = uri\n ? new HttpLink({ uri, credentials, headers })\n : ApolloLink.empty();\n }\n\n if (!cache) {\n throw new InvariantError(\n \"To initialize Apollo Client, you must specify a 'cache' property \" +\n \"in the options object. \\n\" +\n \"For more information, please visit: https://go.apollo.dev/c/docs\"\n );\n }\n\n this.link = link;\n this.cache = cache;\n this.disableNetworkFetches = ssrMode || ssrForceFetchDelay > 0;\n this.queryDeduplication = queryDeduplication;\n this.defaultOptions = defaultOptions || {};\n this.typeDefs = typeDefs;\n\n if (ssrForceFetchDelay) {\n setTimeout(\n () => (this.disableNetworkFetches = false),\n ssrForceFetchDelay,\n );\n }\n\n this.watchQuery = this.watchQuery.bind(this);\n this.query = this.query.bind(this);\n this.mutate = this.mutate.bind(this);\n this.resetStore = this.resetStore.bind(this);\n this.reFetchObservableQueries = this.reFetchObservableQueries.bind(this);\n\n if (connectToDevTools && typeof window === 'object') {\n (window as any).__APOLLO_CLIENT__ = this;\n }\n\n /**\n * Suggest installing the devtools for developers who don't have them\n */\n if (!hasSuggestedDevtools && __DEV__) {\n hasSuggestedDevtools = true;\n if (\n typeof window !== 'undefined' &&\n window.document &&\n window.top === window.self &&\n !(window as any).__APOLLO_DEVTOOLS_GLOBAL_HOOK__\n ) {\n const nav = window.navigator;\n const ua = nav && nav.userAgent;\n let url: string | undefined;\n if (typeof ua === \"string\") {\n if (ua.indexOf(\"Chrome/\") > -1) {\n url = \"https://chrome.google.com/webstore/detail/\" +\n \"apollo-client-developer-t/jdkknkkbebbapilgoeccciglkfbmbnfm\";\n } else if (ua.indexOf(\"Firefox/\") > -1) {\n url = \"https://addons.mozilla.org/en-US/firefox/addon/apollo-developer-tools/\";\n }\n }\n if (url) {\n invariant.log(\n \"Download the Apollo DevTools for a better development \" +\n \"experience: \" + url\n );\n }\n }\n }\n\n this.version = version;\n\n this.localState = new LocalState({\n cache,\n client: this,\n resolvers,\n fragmentMatcher,\n });\n\n this.queryManager = new QueryManager({\n cache: this.cache,\n link: this.link,\n queryDeduplication,\n ssrMode,\n clientAwareness: {\n name: clientAwarenessName!,\n version: clientAwarenessVersion!,\n },\n localState: this.localState,\n assumeImmutableResults,\n onBroadcast: connectToDevTools ? () => {\n if (this.devToolsHookCb) {\n this.devToolsHookCb({\n action: {},\n state: {\n queries: this.queryManager.getQueryStore(),\n mutations: this.queryManager.mutationStore || {},\n },\n dataWithOptimisticResults: this.cache.extract(true),\n });\n }\n } : void 0,\n });\n }\n\n /**\n * Call this method to terminate any active client processes, making it safe\n * to dispose of this `ApolloClient` instance.\n */\n public stop() {\n this.queryManager.stop();\n }\n\n /**\n * This watches the cache store of the query according to the options specified and\n * returns an {@link ObservableQuery}. We can subscribe to this {@link ObservableQuery} and\n * receive updated results through a GraphQL observer when the cache store changes.\n *

\n * Note that this method is not an implementation of GraphQL subscriptions. Rather,\n * it uses Apollo's store in order to reactively deliver updates to your query results.\n *

\n * For example, suppose you call watchQuery on a GraphQL query that fetches a person's\n * first and last name and this person has a particular object identifier, provided by\n * dataIdFromObject. Later, a different query fetches that same person's\n * first and last name and the first name has now changed. Then, any observers associated\n * with the results of the first query will be updated with a new result object.\n *

\n * Note that if the cache does not change, the subscriber will *not* be notified.\n *

\n * See [here](https://medium.com/apollo-stack/the-concepts-of-graphql-bc68bd819be3#.3mb0cbcmc) for\n * a description of store reactivity.\n */\n public watchQuery(\n options: WatchQueryOptions,\n ): ObservableQuery {\n if (this.defaultOptions.watchQuery) {\n options = mergeOptions(this.defaultOptions.watchQuery, options);\n }\n\n // XXX Overwriting options is probably not the best way to do this long term...\n if (\n this.disableNetworkFetches &&\n (options.fetchPolicy === 'network-only' ||\n options.fetchPolicy === 'cache-and-network')\n ) {\n options = { ...options, fetchPolicy: 'cache-first' };\n }\n\n return this.queryManager.watchQuery(options);\n }\n\n /**\n * This resolves a single query according to the options specified and\n * returns a {@link Promise} which is either resolved with the resulting data\n * or rejected with an error.\n *\n * @param options An object of type {@link QueryOptions} that allows us to\n * describe how this query should be treated e.g. whether it should hit the\n * server at all or just resolve from the cache, etc.\n */\n public query(\n options: QueryOptions,\n ): Promise> {\n if (this.defaultOptions.query) {\n options = mergeOptions(this.defaultOptions.query, options);\n }\n\n invariant(\n (options.fetchPolicy as WatchQueryFetchPolicy) !== 'cache-and-network',\n 'The cache-and-network fetchPolicy does not work with client.query, because ' +\n 'client.query can only return a single result. Please use client.watchQuery ' +\n 'to receive multiple results from the cache and the network, or consider ' +\n 'using a different fetchPolicy, such as cache-first or network-only.'\n );\n\n if (this.disableNetworkFetches && options.fetchPolicy === 'network-only') {\n options = { ...options, fetchPolicy: 'cache-first' };\n }\n\n return this.queryManager.query(options);\n }\n\n /**\n * This resolves a single mutation according to the options specified and returns a\n * {@link Promise} which is either resolved with the resulting data or rejected with an\n * error.\n *\n * It takes options as an object with the following keys and values:\n */\n public mutate<\n TData = any,\n TVariables = OperationVariables,\n TContext = DefaultContext,\n TCache extends ApolloCache = ApolloCache\n >(\n options: MutationOptions,\n ): Promise> {\n if (this.defaultOptions.mutate) {\n options = mergeOptions(this.defaultOptions.mutate, options);\n }\n return this.queryManager.mutate(options);\n }\n\n /**\n * This subscribes to a graphql subscription according to the options specified and returns an\n * {@link Observable} which either emits received data or an error.\n */\n public subscribe(\n options: SubscriptionOptions,\n ): Observable> {\n return this.queryManager.startGraphQLSubscription(options);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL query without making a network request. This method will start at\n * the root query. To start at a specific id returned by `dataIdFromObject`\n * use `readFragment`.\n *\n * @param optimistic Set to `true` to allow `readQuery` to return\n * optimistic results. Is `false` by default.\n */\n public readQuery(\n options: DataProxy.Query,\n optimistic: boolean = false,\n ): T | null {\n return this.cache.readQuery(options, optimistic);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL fragment without making a network request. This method will read a\n * GraphQL fragment from any arbitrary id that is currently cached, unlike\n * `readQuery` which will only read from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are reading. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n *\n * @param optimistic Set to `true` to allow `readFragment` to return\n * optimistic results. Is `false` by default.\n */\n public readFragment(\n options: DataProxy.Fragment,\n optimistic: boolean = false,\n ): T | null {\n return this.cache.readFragment(options, optimistic);\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL query directly to\n * the store. This method will start at the root query. To start at a\n * specific id returned by `dataIdFromObject` then use `writeFragment`.\n */\n public writeQuery(\n options: DataProxy.WriteQueryOptions,\n ): void {\n this.cache.writeQuery(options);\n this.queryManager.broadcastQueries();\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL fragment directly to\n * the store. This method will write to a GraphQL fragment from any arbitrary\n * id that is currently cached, unlike `writeQuery` which will only write\n * from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are writing. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n */\n public writeFragment(\n options: DataProxy.WriteFragmentOptions,\n ): void {\n this.cache.writeFragment(options);\n this.queryManager.broadcastQueries();\n }\n\n public __actionHookForDevTools(cb: () => any) {\n this.devToolsHookCb = cb;\n }\n\n public __requestRaw(payload: GraphQLRequest): Observable {\n return execute(this.link, payload);\n }\n\n /**\n * Resets your entire store by clearing out your cache and then re-executing\n * all of your active queries. This makes it so that you may guarantee that\n * there is no data left in your store from a time before you called this\n * method.\n *\n * `resetStore()` is useful when your user just logged out. You’ve removed the\n * user session, and you now want to make sure that any references to data you\n * might have fetched while the user session was active is gone.\n *\n * It is important to remember that `resetStore()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public resetStore(): Promise[] | null> {\n return Promise.resolve()\n .then(() => this.queryManager.clearStore({\n discardWatches: false,\n }))\n .then(() => Promise.all(this.resetStoreCallbacks.map(fn => fn())))\n .then(() => this.reFetchObservableQueries());\n }\n\n /**\n * Remove all data from the store. Unlike `resetStore`, `clearStore` will\n * not refetch any active queries.\n */\n public clearStore(): Promise {\n return Promise.resolve()\n .then(() => this.queryManager.clearStore({\n discardWatches: true,\n }))\n .then(() => Promise.all(this.clearStoreCallbacks.map(fn => fn())));\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * reset. `onResetStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onResetStore(cb: () => Promise): () => void {\n this.resetStoreCallbacks.push(cb);\n return () => {\n this.resetStoreCallbacks = this.resetStoreCallbacks.filter(c => c !== cb);\n };\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * cleared. `onClearStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onClearStore(cb: () => Promise): () => void {\n this.clearStoreCallbacks.push(cb);\n return () => {\n this.clearStoreCallbacks = this.clearStoreCallbacks.filter(c => c !== cb);\n };\n }\n\n /**\n * Refetches all of your active queries.\n *\n * `reFetchObservableQueries()` is useful if you want to bring the client back to proper state in case of a network outage\n *\n * It is important to remember that `reFetchObservableQueries()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n * Takes optional parameter `includeStandby` which will include queries in standby-mode when refetching.\n */\n public reFetchObservableQueries(\n includeStandby?: boolean,\n ): Promise[]> {\n return this.queryManager.reFetchObservableQueries(includeStandby);\n }\n\n /**\n * Refetches specified active queries. Similar to \"reFetchObservableQueries()\" but with a specific list of queries.\n *\n * `refetchQueries()` is useful for use cases to imperatively refresh a selection of queries.\n *\n * It is important to remember that `refetchQueries()` *will* refetch specified active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public refetchQueries<\n TCache extends ApolloCache = ApolloCache,\n TResult = Promise>,\n >(\n options: RefetchQueriesOptions,\n ): RefetchQueriesResult {\n const map = this.queryManager.refetchQueries(options);\n const queries: ObservableQuery[] = [];\n const results: InternalRefetchQueriesResult[] = [];\n\n map.forEach((result, obsQuery) => {\n queries.push(obsQuery);\n results.push(result);\n });\n\n const result = Promise.all(\n results as TResult[]\n ) as RefetchQueriesResult;\n\n // In case you need the raw results immediately, without awaiting\n // Promise.all(results):\n result.queries = queries;\n result.results = results;\n\n // If you decide to ignore the result Promise because you're using\n // result.queries and result.results instead, you shouldn't have to worry\n // about preventing uncaught rejections for the Promise.all result.\n result.catch(error => {\n invariant.debug(`In client.refetchQueries, Promise.all promise rejected with error ${error}`);\n });\n\n return result;\n }\n\n /**\n * Get all currently active `ObservableQuery` objects, in a `Map` keyed by\n * query ID strings. An \"active\" query is one that has observers and a\n * `fetchPolicy` other than \"standby\" or \"cache-only\". You can include all\n * `ObservableQuery` objects (including the inactive ones) by passing \"all\"\n * instead of \"active\", or you can include just a subset of active queries by\n * passing an array of query names or DocumentNode objects.\n */\n public getObservableQueries(\n include: RefetchQueriesInclude = \"active\",\n ): Map> {\n return this.queryManager.getObservableQueries(include);\n }\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public extract(optimistic?: boolean): TCacheShape {\n return this.cache.extract(optimistic);\n }\n\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public restore(serializedState: TCacheShape): ApolloCache {\n return this.cache.restore(serializedState);\n }\n\n /**\n * Add additional local resolvers.\n */\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.addResolvers(resolvers);\n }\n\n /**\n * Set (override existing) local resolvers.\n */\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.setResolvers(resolvers);\n }\n\n /**\n * Get all registered local resolvers.\n */\n public getResolvers() {\n return this.localState.getResolvers();\n }\n\n /**\n * Set a custom local state fragment matcher.\n */\n public setLocalStateFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.localState.setFragmentMatcher(fragmentMatcher);\n }\n\n /**\n * Define a new ApolloLink (or link chain) that Apollo Client will use.\n */\n public setLink(newLink: ApolloLink) {\n this.link = this.queryManager.link = newLink;\n }\n}\n","export const version = 'local';\n","function maybe(thunk) {\n try { return thunk() } catch (_) {}\n}\n\nvar safeGlobal = (\n maybe(function() { return globalThis }) ||\n maybe(function() { return window }) ||\n maybe(function() { return self }) ||\n maybe(function() { return global }) ||\n // We don't expect the Function constructor ever to be invoked at runtime, as\n // long as at least one of globalThis, window, self, or global is defined, so\n // we are under no obligation to make it easy for static analysis tools to\n // detect syntactic usage of the Function constructor. If you think you can\n // improve your static analysis to detect this obfuscation, think again. This\n // is an arms race you cannot win, at least not in JavaScript.\n maybe(function() { return maybe.constructor(\"return this\")() })\n);\n\nvar needToRemove = false;\n\nexport function install() {\n if (safeGlobal &&\n !maybe(function() { return process.env.NODE_ENV }) &&\n !maybe(function() { return process })) {\n Object.defineProperty(safeGlobal, \"process\", {\n value: {\n env: {\n // This default needs to be \"production\" instead of \"development\", to\n // avoid the problem https://github.com/graphql/graphql-js/pull/2894\n // will eventually solve, once merged and released.\n NODE_ENV: \"production\",\n },\n },\n // Let anyone else change global.process as they see fit, but hide it from\n // Object.keys(global) enumeration.\n configurable: true,\n enumerable: false,\n writable: true,\n });\n needToRemove = true;\n }\n}\n\n// Call install() at least once, when this module is imported.\ninstall();\n\nexport function remove() {\n if (needToRemove) {\n delete safeGlobal.process;\n needToRemove = false;\n }\n}\n","import inspect from \"../jsutils/inspect.mjs\";\nimport { isNode } from \"./ast.mjs\";\n/**\n * A visitor is provided to visit, it contains the collection of\n * relevant functions to be called during the visitor's traversal.\n */\n\nexport var QueryDocumentKeys = {\n Name: [],\n Document: ['definitions'],\n OperationDefinition: ['name', 'variableDefinitions', 'directives', 'selectionSet'],\n VariableDefinition: ['variable', 'type', 'defaultValue', 'directives'],\n Variable: ['name'],\n SelectionSet: ['selections'],\n Field: ['alias', 'name', 'arguments', 'directives', 'selectionSet'],\n Argument: ['name', 'value'],\n FragmentSpread: ['name', 'directives'],\n InlineFragment: ['typeCondition', 'directives', 'selectionSet'],\n FragmentDefinition: ['name', // Note: fragment variable definitions are experimental and may be changed\n // or removed in the future.\n 'variableDefinitions', 'typeCondition', 'directives', 'selectionSet'],\n IntValue: [],\n FloatValue: [],\n StringValue: [],\n BooleanValue: [],\n NullValue: [],\n EnumValue: [],\n ListValue: ['values'],\n ObjectValue: ['fields'],\n ObjectField: ['name', 'value'],\n Directive: ['name', 'arguments'],\n NamedType: ['name'],\n ListType: ['type'],\n NonNullType: ['type'],\n SchemaDefinition: ['description', 'directives', 'operationTypes'],\n OperationTypeDefinition: ['type'],\n ScalarTypeDefinition: ['description', 'name', 'directives'],\n ObjectTypeDefinition: ['description', 'name', 'interfaces', 'directives', 'fields'],\n FieldDefinition: ['description', 'name', 'arguments', 'type', 'directives'],\n InputValueDefinition: ['description', 'name', 'type', 'defaultValue', 'directives'],\n InterfaceTypeDefinition: ['description', 'name', 'interfaces', 'directives', 'fields'],\n UnionTypeDefinition: ['description', 'name', 'directives', 'types'],\n EnumTypeDefinition: ['description', 'name', 'directives', 'values'],\n EnumValueDefinition: ['description', 'name', 'directives'],\n InputObjectTypeDefinition: ['description', 'name', 'directives', 'fields'],\n DirectiveDefinition: ['description', 'name', 'arguments', 'locations'],\n SchemaExtension: ['directives', 'operationTypes'],\n ScalarTypeExtension: ['name', 'directives'],\n ObjectTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n InterfaceTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n UnionTypeExtension: ['name', 'directives', 'types'],\n EnumTypeExtension: ['name', 'directives', 'values'],\n InputObjectTypeExtension: ['name', 'directives', 'fields']\n};\nexport var BREAK = Object.freeze({});\n/**\n * visit() will walk through an AST using a depth-first traversal, calling\n * the visitor's enter function at each node in the traversal, and calling the\n * leave function after visiting that node and all of its child nodes.\n *\n * By returning different values from the enter and leave functions, the\n * behavior of the visitor can be altered, including skipping over a sub-tree of\n * the AST (by returning false), editing the AST by returning a value or null\n * to remove the value, or to stop the whole traversal by returning BREAK.\n *\n * When using visit() to edit an AST, the original AST will not be modified, and\n * a new version of the AST with the changes applied will be returned from the\n * visit function.\n *\n * const editedAST = visit(ast, {\n * enter(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: skip visiting this node\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * },\n * leave(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: no action\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * }\n * });\n *\n * Alternatively to providing enter() and leave() functions, a visitor can\n * instead provide functions named the same as the kinds of AST nodes, or\n * enter/leave visitors at a named key, leading to four permutations of the\n * visitor API:\n *\n * 1) Named visitors triggered when entering a node of a specific kind.\n *\n * visit(ast, {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * })\n *\n * 2) Named visitors that trigger upon entering and leaving a node of\n * a specific kind.\n *\n * visit(ast, {\n * Kind: {\n * enter(node) {\n * // enter the \"Kind\" node\n * }\n * leave(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n *\n * 3) Generic visitors that trigger upon entering and leaving any node.\n *\n * visit(ast, {\n * enter(node) {\n * // enter any node\n * },\n * leave(node) {\n * // leave any node\n * }\n * })\n *\n * 4) Parallel visitors for entering and leaving nodes of a specific kind.\n *\n * visit(ast, {\n * enter: {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * },\n * leave: {\n * Kind(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n */\n\nexport function visit(root, visitor) {\n var visitorKeys = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : QueryDocumentKeys;\n\n /* eslint-disable no-undef-init */\n var stack = undefined;\n var inArray = Array.isArray(root);\n var keys = [root];\n var index = -1;\n var edits = [];\n var node = undefined;\n var key = undefined;\n var parent = undefined;\n var path = [];\n var ancestors = [];\n var newRoot = root;\n /* eslint-enable no-undef-init */\n\n do {\n index++;\n var isLeaving = index === keys.length;\n var isEdited = isLeaving && edits.length !== 0;\n\n if (isLeaving) {\n key = ancestors.length === 0 ? undefined : path[path.length - 1];\n node = parent;\n parent = ancestors.pop();\n\n if (isEdited) {\n if (inArray) {\n node = node.slice();\n } else {\n var clone = {};\n\n for (var _i2 = 0, _Object$keys2 = Object.keys(node); _i2 < _Object$keys2.length; _i2++) {\n var k = _Object$keys2[_i2];\n clone[k] = node[k];\n }\n\n node = clone;\n }\n\n var editOffset = 0;\n\n for (var ii = 0; ii < edits.length; ii++) {\n var editKey = edits[ii][0];\n var editValue = edits[ii][1];\n\n if (inArray) {\n editKey -= editOffset;\n }\n\n if (inArray && editValue === null) {\n node.splice(editKey, 1);\n editOffset++;\n } else {\n node[editKey] = editValue;\n }\n }\n }\n\n index = stack.index;\n keys = stack.keys;\n edits = stack.edits;\n inArray = stack.inArray;\n stack = stack.prev;\n } else {\n key = parent ? inArray ? index : keys[index] : undefined;\n node = parent ? parent[key] : newRoot;\n\n if (node === null || node === undefined) {\n continue;\n }\n\n if (parent) {\n path.push(key);\n }\n }\n\n var result = void 0;\n\n if (!Array.isArray(node)) {\n if (!isNode(node)) {\n throw new Error(\"Invalid AST Node: \".concat(inspect(node), \".\"));\n }\n\n var visitFn = getVisitFn(visitor, node.kind, isLeaving);\n\n if (visitFn) {\n result = visitFn.call(visitor, node, key, parent, path, ancestors);\n\n if (result === BREAK) {\n break;\n }\n\n if (result === false) {\n if (!isLeaving) {\n path.pop();\n continue;\n }\n } else if (result !== undefined) {\n edits.push([key, result]);\n\n if (!isLeaving) {\n if (isNode(result)) {\n node = result;\n } else {\n path.pop();\n continue;\n }\n }\n }\n }\n }\n\n if (result === undefined && isEdited) {\n edits.push([key, node]);\n }\n\n if (isLeaving) {\n path.pop();\n } else {\n var _visitorKeys$node$kin;\n\n stack = {\n inArray: inArray,\n index: index,\n keys: keys,\n edits: edits,\n prev: stack\n };\n inArray = Array.isArray(node);\n keys = inArray ? node : (_visitorKeys$node$kin = visitorKeys[node.kind]) !== null && _visitorKeys$node$kin !== void 0 ? _visitorKeys$node$kin : [];\n index = -1;\n edits = [];\n\n if (parent) {\n ancestors.push(parent);\n }\n\n parent = node;\n }\n } while (stack !== undefined);\n\n if (edits.length !== 0) {\n newRoot = edits[edits.length - 1][1];\n }\n\n return newRoot;\n}\n/**\n * Creates a new visitor instance which delegates to many visitors to run in\n * parallel. Each visitor will be visited for each node before moving on.\n *\n * If a prior visitor edits a node, no following visitors will see that node.\n */\n\nexport function visitInParallel(visitors) {\n var skipping = new Array(visitors.length);\n return {\n enter: function enter(node) {\n for (var i = 0; i < visitors.length; i++) {\n if (skipping[i] == null) {\n var fn = getVisitFn(visitors[i], node.kind,\n /* isLeaving */\n false);\n\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\n\n if (result === false) {\n skipping[i] = node;\n } else if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined) {\n return result;\n }\n }\n }\n }\n },\n leave: function leave(node) {\n for (var i = 0; i < visitors.length; i++) {\n if (skipping[i] == null) {\n var fn = getVisitFn(visitors[i], node.kind,\n /* isLeaving */\n true);\n\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\n\n if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined && result !== false) {\n return result;\n }\n }\n } else if (skipping[i] === node) {\n skipping[i] = null;\n }\n }\n }\n };\n}\n/**\n * Given a visitor instance, if it is leaving or not, and a node kind, return\n * the function the visitor runtime should call.\n */\n\nexport function getVisitFn(visitor, kind, isLeaving) {\n var kindVisitor = visitor[kind];\n\n if (kindVisitor) {\n if (!isLeaving && typeof kindVisitor === 'function') {\n // { Kind() {} }\n return kindVisitor;\n }\n\n var kindSpecificVisitor = isLeaving ? kindVisitor.leave : kindVisitor.enter;\n\n if (typeof kindSpecificVisitor === 'function') {\n // { Kind: { enter() {}, leave() {} } }\n return kindSpecificVisitor;\n }\n } else {\n var specificVisitor = isLeaving ? visitor.leave : visitor.enter;\n\n if (specificVisitor) {\n if (typeof specificVisitor === 'function') {\n // { enter() {}, leave() {} }\n return specificVisitor;\n }\n\n var specificKindVisitor = specificVisitor[kind];\n\n if (typeof specificKindVisitor === 'function') {\n // { enter: { Kind() {} }, leave: { Kind() {} } }\n return specificKindVisitor;\n }\n }\n }\n}\n","export default function devAssert(condition, message) {\n var booleanCondition = Boolean(condition); // istanbul ignore else (See transformation done in './resources/inlineInvariant.js')\n\n if (!booleanCondition) {\n throw new Error(message);\n }\n}\n","/**\n * A replacement for instanceof which includes an error warning when multi-realm\n * constructors are detected.\n */\n// See: https://expressjs.com/en/advanced/best-practice-performance.html#set-node_env-to-production\n// See: https://webpack.js.org/guides/production/\nexport default process.env.NODE_ENV === 'production' ? // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n// eslint-disable-next-line no-shadow\nfunction instanceOf(value, constructor) {\n return value instanceof constructor;\n} : // eslint-disable-next-line no-shadow\nfunction instanceOf(value, constructor) {\n if (value instanceof constructor) {\n return true;\n }\n\n if (value) {\n var valueClass = value.constructor;\n var className = constructor.name;\n\n if (className && valueClass && valueClass.name === className) {\n throw new Error(\"Cannot use \".concat(className, \" \\\"\").concat(value, \"\\\" from another module or realm.\\n\\nEnsure that there is only one instance of \\\"graphql\\\" in the node_modules\\ndirectory. If different versions of \\\"graphql\\\" are the dependencies of other\\nrelied on modules, use \\\"resolutions\\\" to ensure only one version is installed.\\n\\nhttps://yarnpkg.com/en/docs/selective-version-resolutions\\n\\nDuplicate \\\"graphql\\\" modules cannot be used at the same time since different\\nversions may have different capabilities and behavior. The data from one\\nversion used in the function from another could produce confusing and\\nspurious results.\"));\n }\n }\n\n return false;\n};\n","function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nimport { SYMBOL_TO_STRING_TAG } from \"../polyfills/symbols.mjs\";\nimport inspect from \"../jsutils/inspect.mjs\";\nimport devAssert from \"../jsutils/devAssert.mjs\";\nimport instanceOf from \"../jsutils/instanceOf.mjs\";\n\n/**\n * A representation of source input to GraphQL. The `name` and `locationOffset` parameters are\n * optional, but they are useful for clients who store GraphQL documents in source files.\n * For example, if the GraphQL input starts at line 40 in a file named `Foo.graphql`, it might\n * be useful for `name` to be `\"Foo.graphql\"` and location to be `{ line: 40, column: 1 }`.\n * The `line` and `column` properties in `locationOffset` are 1-indexed.\n */\nexport var Source = /*#__PURE__*/function () {\n function Source(body) {\n var name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'GraphQL request';\n var locationOffset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n line: 1,\n column: 1\n };\n typeof body === 'string' || devAssert(0, \"Body must be a string. Received: \".concat(inspect(body), \".\"));\n this.body = body;\n this.name = name;\n this.locationOffset = locationOffset;\n this.locationOffset.line > 0 || devAssert(0, 'line in locationOffset is 1-indexed and must be positive.');\n this.locationOffset.column > 0 || devAssert(0, 'column in locationOffset is 1-indexed and must be positive.');\n } // $FlowFixMe[unsupported-syntax] Flow doesn't support computed properties yet\n\n\n _createClass(Source, [{\n key: SYMBOL_TO_STRING_TAG,\n get: function get() {\n return 'Source';\n }\n }]);\n\n return Source;\n}();\n/**\n * Test if the given value is a Source object.\n *\n * @internal\n */\n\n// eslint-disable-next-line no-redeclare\nexport function isSource(source) {\n return instanceOf(source, Source);\n}\n","import { ApolloLink } from './ApolloLink';\n\nexport const empty = ApolloLink.empty;\n","import { ApolloLink } from './ApolloLink';\n\nexport const concat = ApolloLink.concat;\n","import { ApolloLink } from './ApolloLink';\n\nexport const execute = ApolloLink.execute;\n","import { DataProxy } from './DataProxy';\nimport { Modifier, Modifiers } from './common';\n\nexport namespace Cache {\n export type WatchCallback = (diff: Cache.DiffResult) => void;\n\n export interface ReadOptions\n extends DataProxy.Query {\n rootId?: string;\n previousResult?: any;\n optimistic: boolean;\n returnPartialData?: boolean;\n }\n\n export interface WriteOptions\n extends DataProxy.Query {\n dataId?: string;\n result: TResult;\n broadcast?: boolean;\n }\n\n export interface DiffOptions extends ReadOptions {\n // The DiffOptions interface is currently just an alias for\n // ReadOptions, though DiffOptions used to be responsible for\n // declaring the returnPartialData option.\n }\n\n export interface WatchOptions extends ReadOptions {\n immediate?: boolean;\n callback: WatchCallback;\n }\n\n export interface EvictOptions {\n id?: string;\n fieldName?: string;\n args?: Record;\n broadcast?: boolean;\n }\n\n export interface ModifyOptions {\n id?: string;\n fields: Modifiers | Modifier;\n optimistic?: boolean;\n broadcast?: boolean;\n }\n\n export import DiffResult = DataProxy.DiffResult;\n export import ReadQueryOptions = DataProxy.ReadQueryOptions;\n export import ReadFragmentOptions = DataProxy.ReadFragmentOptions;\n export import WriteQueryOptions = DataProxy.WriteQueryOptions;\n export import WriteFragmentOptions = DataProxy.WriteFragmentOptions;\n export import Fragment = DataProxy.Fragment;\n}\n","/**\n * The current status of a query’s execution in our system.\n */\nexport enum NetworkStatus {\n /**\n * The query has never been run before and the query is now currently running. A query will still\n * have this network status even if a partial data result was returned from the cache, but a\n * query was dispatched anyway.\n */\n loading = 1,\n\n /**\n * If `setVariables` was called and a query was fired because of that then the network status\n * will be `setVariables` until the result of that query comes back.\n */\n setVariables = 2,\n\n /**\n * Indicates that `fetchMore` was called on this query and that the query created is currently in\n * flight.\n */\n fetchMore = 3,\n\n /**\n * Similar to the `setVariables` network status. It means that `refetch` was called on a query\n * and the refetch request is currently in flight.\n */\n refetch = 4,\n\n /**\n * Indicates that a polling query is currently in flight. So for example if you are polling a\n * query every 10 seconds then the network status will switch to `poll` every 10 seconds whenever\n * a poll request has been sent but not resolved.\n */\n poll = 6,\n\n /**\n * No request is in flight for this query, and no errors happened. Everything is OK.\n */\n ready = 7,\n\n /**\n * No request is in flight for this query, but one or more errors were detected.\n */\n error = 8,\n}\n\n/**\n * Returns true if there is currently a network request in flight according to a given network\n * status.\n */\nexport function isNetworkRequestInFlight(\n networkStatus?: NetworkStatus,\n): boolean {\n return networkStatus ? networkStatus < 7 : false;\n}\n","const prefixCounts = new Map();\n\n// These IDs won't be globally unique, but they will be unique within this\n// process, thanks to the counter, and unguessable thanks to the random suffix.\nexport function makeUniqueId(prefix: string) {\n const count = prefixCounts.get(prefix) || 1;\n prefixCounts.set(prefix, count + 1);\n return `${prefix}:${count}:${Math.random().toString(36).slice(2)}`;\n}\n","import { SubscriptionClient, ClientOptions } from 'subscriptions-transport-ws';\n\nimport { ApolloLink, Operation, FetchResult } from '../core';\nimport { Observable } from '../../utilities';\n\nexport namespace WebSocketLink {\n /**\n * Configuration to use when constructing the subscription client (subscriptions-transport-ws).\n */\n export interface Configuration {\n /**\n * The endpoint to connect to.\n */\n uri: string;\n\n /**\n * Options to pass when constructing the subscription client.\n */\n options?: ClientOptions;\n\n /**\n * A custom WebSocket implementation to use.\n */\n webSocketImpl?: any;\n }\n}\n\n// For backwards compatibility.\nexport import WebSocketParams = WebSocketLink.Configuration;\n\nexport class WebSocketLink extends ApolloLink {\n private subscriptionClient: SubscriptionClient;\n\n constructor(\n paramsOrClient: WebSocketLink.Configuration | SubscriptionClient,\n ) {\n super();\n\n if (paramsOrClient instanceof SubscriptionClient) {\n this.subscriptionClient = paramsOrClient;\n } else {\n this.subscriptionClient = new SubscriptionClient(\n paramsOrClient.uri,\n paramsOrClient.options,\n paramsOrClient.webSocketImpl,\n );\n }\n }\n\n public request(operation: Operation): Observable | null {\n return this.subscriptionClient.request(operation) as Observable<\n FetchResult\n >;\n }\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export default function symbolObservablePonyfill(root) {\n\tvar result;\n\tvar Symbol = root.Symbol;\n\n\tif (typeof Symbol === 'function') {\n\t\tif (Symbol.observable) {\n\t\t\tresult = Symbol.observable;\n\t\t} else {\n\n\t\t\t// This just needs to be something that won't trample other user's Symbol.for use\n\t\t\t// It also will guide people to the source of their issues, if this is problematic.\n\t\t\t// META: It's a resource locator!\n\t\t\tresult = Symbol.for('https://github.com/benlesh/symbol-observable');\n\t\t\ttry {\n\t\t\t\tSymbol.observable = result;\n\t\t\t} catch (err) {\n\t\t\t\t// Do nothing. In some environments, users have frozen `Symbol` for security reasons,\n\t\t\t\t// if it is frozen assigning to it will throw. In this case, we don't care, because\n\t\t\t\t// they will need to use the returned value from the ponyfill.\n\t\t\t}\n\t\t}\n\t} else {\n\t\tresult = '@@observable';\n\t}\n\n\treturn result;\n};\n","import { ExecutionResult } from 'graphql';\n\nimport { NetworkError, GraphQLErrors } from '../../errors';\nimport { Observable } from '../../utilities';\nimport { ApolloLink, Operation, FetchResult, NextLink } from '../core';\n\nexport interface ErrorResponse {\n graphQLErrors?: GraphQLErrors;\n networkError?: NetworkError;\n response?: ExecutionResult;\n operation: Operation;\n forward: NextLink;\n}\n\nexport namespace ErrorLink {\n /**\n * Callback to be triggered when an error occurs within the link stack.\n */\n export interface ErrorHandler {\n (error: ErrorResponse): Observable | void;\n }\n}\n\n// For backwards compatibility.\nexport import ErrorHandler = ErrorLink.ErrorHandler;\n\nexport function onError(errorHandler: ErrorHandler): ApolloLink {\n return new ApolloLink((operation, forward) => {\n return new Observable(observer => {\n let sub: any;\n let retriedSub: any;\n let retriedResult: any;\n\n try {\n sub = forward(operation).subscribe({\n next: result => {\n if (result.errors) {\n retriedResult = errorHandler({\n graphQLErrors: result.errors,\n response: result,\n operation,\n forward,\n });\n\n if (retriedResult) {\n retriedSub = retriedResult.subscribe({\n next: observer.next.bind(observer),\n error: observer.error.bind(observer),\n complete: observer.complete.bind(observer),\n });\n return;\n }\n }\n observer.next(result);\n },\n error: networkError => {\n retriedResult = errorHandler({\n operation,\n networkError,\n //Network errors can return GraphQL errors on for example a 403\n graphQLErrors:\n networkError &&\n networkError.result &&\n networkError.result.errors,\n forward,\n });\n if (retriedResult) {\n retriedSub = retriedResult.subscribe({\n next: observer.next.bind(observer),\n error: observer.error.bind(observer),\n complete: observer.complete.bind(observer),\n });\n return;\n }\n observer.error(networkError);\n },\n complete: () => {\n // disable the previous sub from calling complete on observable\n // if retry is in flight.\n if (!retriedResult) {\n observer.complete.bind(observer)();\n }\n },\n });\n } catch (e) {\n errorHandler({ networkError: e, operation, forward });\n observer.error(e);\n }\n\n return () => {\n if (sub) sub.unsubscribe();\n if (retriedSub) sub.unsubscribe();\n };\n });\n });\n}\n\nexport class ErrorLink extends ApolloLink {\n private link: ApolloLink;\n constructor(errorHandler: ErrorLink.ErrorHandler) {\n super();\n this.link = onError(errorHandler);\n }\n\n public request(\n operation: Operation,\n forward: NextLink,\n ): Observable | null {\n return this.link.request(operation, forward);\n }\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import invariant from \"./invariant.mjs\";\nimport nodejsCustomInspectSymbol from \"./nodejsCustomInspectSymbol.mjs\";\n/**\n * The `defineInspect()` function defines `inspect()` prototype method as alias of `toJSON`\n */\n\nexport default function defineInspect(classObject) {\n var fn = classObject.prototype.toJSON;\n typeof fn === 'function' || invariant(0);\n classObject.prototype.inspect = fn; // istanbul ignore else (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\n if (nodejsCustomInspectSymbol) {\n classObject.prototype[nodejsCustomInspectSymbol] = fn;\n }\n}\n","export default function invariant(condition, message) {\n var booleanCondition = Boolean(condition); // istanbul ignore else (See transformation done in './resources/inlineInvariant.js')\n\n if (!booleanCondition) {\n throw new Error(message != null ? message : 'Unexpected invariant triggered.');\n }\n}\n","import defineInspect from \"../jsutils/defineInspect.mjs\";\n\n/**\n * Contains a range of UTF-8 character offsets and token references that\n * identify the region of the source from which the AST derived.\n */\nexport var Location = /*#__PURE__*/function () {\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The Token at which this Node begins.\n */\n\n /**\n * The Token at which this Node ends.\n */\n\n /**\n * The Source document the AST represents.\n */\n function Location(startToken, endToken, source) {\n this.start = startToken.start;\n this.end = endToken.end;\n this.startToken = startToken;\n this.endToken = endToken;\n this.source = source;\n }\n\n var _proto = Location.prototype;\n\n _proto.toJSON = function toJSON() {\n return {\n start: this.start,\n end: this.end\n };\n };\n\n return Location;\n}(); // Print a simplified form when appearing in `inspect` and `util.inspect`.\n\ndefineInspect(Location);\n/**\n * Represents a range of characters represented by a lexical token\n * within a Source.\n */\n\nexport var Token = /*#__PURE__*/function () {\n /**\n * The kind of Token.\n */\n\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The 1-indexed line number on which this Token appears.\n */\n\n /**\n * The 1-indexed column number at which this Token begins.\n */\n\n /**\n * For non-punctuation tokens, represents the interpreted value of the token.\n */\n\n /**\n * Tokens exist as nodes in a double-linked-list amongst all tokens\n * including ignored tokens. is always the first node and \n * the last.\n */\n function Token(kind, start, end, line, column, prev, value) {\n this.kind = kind;\n this.start = start;\n this.end = end;\n this.line = line;\n this.column = column;\n this.value = value;\n this.prev = prev;\n this.next = null;\n }\n\n var _proto2 = Token.prototype;\n\n _proto2.toJSON = function toJSON() {\n return {\n kind: this.kind,\n value: this.value,\n line: this.line,\n column: this.column\n };\n };\n\n return Token;\n}(); // Print a simplified form when appearing in `inspect` and `util.inspect`.\n\ndefineInspect(Token);\n/**\n * @internal\n */\n\nexport function isNode(maybeNode) {\n return maybeNode != null && typeof maybeNode.kind === 'string';\n}\n/**\n * The list of all possible AST node types.\n */\n"],"sourceRoot":""}